Allow floating views to appear at the mouse
This commit is contained in:
@ -26,6 +26,7 @@ const util = @import("../util.zig");
|
||||
const Error = @import("../command.zig").Error;
|
||||
const Seat = @import("../Seat.zig");
|
||||
const View = @import("../View.zig");
|
||||
const Anchor = @import("../Config.zig").Anchor;
|
||||
const RuleGlobs = @import("../rule_list.zig").RuleGlobs;
|
||||
|
||||
const Action = enum {
|
||||
@ -36,6 +37,7 @@ const Action = enum {
|
||||
tags,
|
||||
output,
|
||||
position,
|
||||
@"relative-position",
|
||||
dimensions,
|
||||
fullscreen,
|
||||
@"no-fullscreen",
|
||||
@ -59,6 +61,7 @@ pub fn ruleAdd(_: *Seat, args: []const [:0]const u8, _: *?[]const u8) Error!void
|
||||
.float, .@"no-float", .ssd, .csd, .fullscreen, .@"no-fullscreen", .tearing, .@"no-tearing" => 1,
|
||||
.tags, .output => 2,
|
||||
.position, .dimensions => 3,
|
||||
.@"relative-position" => 4,
|
||||
};
|
||||
if (result.args.len > positional_arguments_count) return Error.TooManyArguments;
|
||||
if (result.args.len < positional_arguments_count) return Error.NotEnoughArguments;
|
||||
@ -112,14 +115,32 @@ pub fn ruleAdd(_: *Seat, args: []const [:0]const u8, _: *?[]const u8) Error!void
|
||||
});
|
||||
},
|
||||
.position => {
|
||||
const x = try fmt.parseInt(u31, result.args[1], 10);
|
||||
const y = try fmt.parseInt(u31, result.args[2], 10);
|
||||
const x = try fmt.parseInt(i31, result.args[1], 10);
|
||||
const y = try fmt.parseInt(i31, result.args[2], 10);
|
||||
if (x < 0 or y < 0) return Error.OutOfBounds;
|
||||
try server.config.rules.position.add(.{
|
||||
.app_id_glob = app_id_glob,
|
||||
.title_glob = title_glob,
|
||||
.value = .{
|
||||
.x = x,
|
||||
.y = y,
|
||||
.anchor = .absolute,
|
||||
.x = @intCast(x),
|
||||
.y = @intCast(y),
|
||||
},
|
||||
});
|
||||
},
|
||||
.@"relative-position" => {
|
||||
const anchor = std.meta.stringToEnum(Anchor, result.args[1]) orelse return Error.UnknownOption;
|
||||
// force the use of the normal position command for absolute positions
|
||||
if (anchor == .absolute) return Error.UnknownOption;
|
||||
const x_off = try fmt.parseInt(i31, result.args[2], 10);
|
||||
const y_off = try fmt.parseInt(i31, result.args[3], 10);
|
||||
try server.config.rules.position.add(.{
|
||||
.app_id_glob = app_id_glob,
|
||||
.title_glob = title_glob,
|
||||
.value = .{
|
||||
.anchor = anchor,
|
||||
.x = x_off,
|
||||
.y = y_off,
|
||||
},
|
||||
});
|
||||
},
|
||||
@ -179,7 +200,7 @@ pub fn ruleDel(_: *Seat, args: []const [:0]const u8, _: *?[]const u8) Error!void
|
||||
util.gpa.free(output_rule);
|
||||
}
|
||||
},
|
||||
.position => {
|
||||
.position, .@"relative-position" => {
|
||||
_ = server.config.rules.position.del(rule);
|
||||
},
|
||||
.dimensions => {
|
||||
@ -278,7 +299,7 @@ pub fn listRules(_: *Seat, args: []const [:0]const u8, out: *?[]const u8) Error!
|
||||
for (server.config.rules.position.rules.items) |rule| {
|
||||
try fmt.formatBuf(rule.title_glob, .{ .width = title_column_max, .alignment = .left }, writer);
|
||||
try fmt.formatBuf(rule.app_id_glob, .{ .width = app_id_column_max, .alignment = .left }, writer);
|
||||
try writer.print("{d},{d}\n", .{ rule.value.x, rule.value.y });
|
||||
try writer.print("{s},{d},{d}", .{ @tagName(rule.value.anchor), rule.value.x, rule.value.y });
|
||||
}
|
||||
},
|
||||
.dimensions => {
|
||||
|
||||
Reference in New Issue
Block a user