mirror of
https://github.com/ghostty-org/ghostty.git
synced 2025-07-15 16:26:08 +03:00
cli: boolean value support for packed structs
Allow standalone boolean values like "true" and "false" to turn on or off all of the struct's fields.
This commit is contained in:
@ -285,6 +285,17 @@ fn parsePackedStruct(comptime T: type, v: []const u8) !T {
|
||||
|
||||
var result: T = .{};
|
||||
|
||||
// Allow standalone boolean values like "true" and "false" to
|
||||
// turn on or off all of the struct's fields.
|
||||
bools: {
|
||||
const b = parseBool(v) catch break :bools;
|
||||
inline for (info.fields) |field| {
|
||||
assert(field.type == bool);
|
||||
@field(result, field.name) = b;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
// We split each value by ","
|
||||
var iter = std.mem.splitSequence(u8, v, ",");
|
||||
loop: while (iter.next()) |part_raw| {
|
||||
@ -586,6 +597,34 @@ test "parseIntoField: packed struct negation" {
|
||||
try testing.expect(!data.v.b);
|
||||
}
|
||||
|
||||
test "parseIntoField: packed struct true/false" {
|
||||
const testing = std.testing;
|
||||
var arena = ArenaAllocator.init(testing.allocator);
|
||||
defer arena.deinit();
|
||||
const alloc = arena.allocator();
|
||||
|
||||
const Field = packed struct {
|
||||
a: bool = false,
|
||||
b: bool = true,
|
||||
};
|
||||
var data: struct {
|
||||
v: Field,
|
||||
} = undefined;
|
||||
|
||||
try parseIntoField(@TypeOf(data), alloc, &data, "v", "true");
|
||||
try testing.expect(data.v.a);
|
||||
try testing.expect(data.v.b);
|
||||
|
||||
try parseIntoField(@TypeOf(data), alloc, &data, "v", "false");
|
||||
try testing.expect(!data.v.a);
|
||||
try testing.expect(!data.v.b);
|
||||
|
||||
try testing.expectError(
|
||||
error.InvalidValue,
|
||||
parseIntoField(@TypeOf(data), alloc, &data, "v", "true,a"),
|
||||
);
|
||||
}
|
||||
|
||||
test "parseIntoField: packed struct whitespace" {
|
||||
const testing = std.testing;
|
||||
var arena = ArenaAllocator.init(testing.allocator);
|
||||
|
Reference in New Issue
Block a user