mirror of
https://github.com/ghostty-org/ghostty.git
synced 2025-06-04 14:38:45 +03:00

Closes #6702 This removes our mach-glfw dependency and replaces it with an in-tree pkg/glfw that includes both the source for compiling glfw as well as the Zig bindings. This matches the pattern from our other packages. This is based on the upstream mach-glfw work and therefore includes the original license and copyright information. The reasoning is stated in the issue but to summarize for the commit: - mach-glfw is no longer maintained, so we have to take ownership - mach-glfw depended on some large blobs of header files to enable cross-compilation but this isn't something we actually care about, so we can (and do) drop the blobs - mach-glfw blobs were hosted on mach hosts. given mach-glfw is unmaintained, we can't rely on this hosting - mach-glfw relied on a "glfw" package which was owned by another person to be Zig 0.14 compatible, but we no longer need to rely on this - mach-glfw builds were outdated based on latest Zig practices
168 lines
5.0 KiB
Zig
168 lines
5.0 KiB
Zig
//! Modifier key flags
|
|
//!
|
|
//! See glfw.setKeyCallback for how these are used.
|
|
|
|
const c = @import("c.zig").c;
|
|
|
|
// must be in sync with GLFW C constants in modifier group, search for "@defgroup mods Modifier key flags"
|
|
/// A bitmask of all key modifiers
|
|
pub const Mods = packed struct(u8) {
|
|
shift: bool = false,
|
|
control: bool = false,
|
|
alt: bool = false,
|
|
super: bool = false,
|
|
caps_lock: bool = false,
|
|
num_lock: bool = false,
|
|
_padding: u2 = 0,
|
|
|
|
inline fn verifyIntType(comptime IntType: type) void {
|
|
comptime {
|
|
switch (@import("shims.zig").typeInfo(IntType)) {
|
|
.int => {},
|
|
else => @compileError("Int was not of int type"),
|
|
}
|
|
}
|
|
}
|
|
|
|
pub inline fn toInt(self: Mods, comptime IntType: type) IntType {
|
|
verifyIntType(IntType);
|
|
return @as(IntType, @intCast(@as(u8, @bitCast(self))));
|
|
}
|
|
|
|
pub inline fn fromInt(flags: anytype) Mods {
|
|
verifyIntType(@TypeOf(flags));
|
|
return @as(Mods, @bitCast(@as(u8, @intCast(flags))));
|
|
}
|
|
};
|
|
|
|
/// Holds all GLFW mod values in their raw form.
|
|
pub const RawMods = struct {
|
|
/// If this bit is set one or more Shift keys were held down.
|
|
pub const shift = c.GLFW_MOD_SHIFT;
|
|
|
|
/// If this bit is set one or more Control keys were held down.
|
|
pub const control = c.GLFW_MOD_CONTROL;
|
|
|
|
/// If this bit is set one or more Alt keys were held down.
|
|
pub const alt = c.GLFW_MOD_ALT;
|
|
|
|
/// If this bit is set one or more Super keys were held down.
|
|
pub const super = c.GLFW_MOD_SUPER;
|
|
|
|
/// If this bit is set the Caps Lock key is enabled and the glfw.lock_key_mods input mode is set.
|
|
pub const caps_lock = c.GLFW_MOD_CAPS_LOCK;
|
|
|
|
/// If this bit is set the Num Lock key is enabled and the glfw.lock_key_mods input mode is set.
|
|
pub const num_lock = c.GLFW_MOD_NUM_LOCK;
|
|
};
|
|
|
|
test "shift int to bitmask" {
|
|
const std = @import("std");
|
|
|
|
const int_mod = RawMods.shift;
|
|
const mod = Mods.fromInt(int_mod);
|
|
|
|
try std.testing.expect(mod.shift == true);
|
|
try std.testing.expect(mod.control == false);
|
|
try std.testing.expect(mod.alt == false);
|
|
try std.testing.expect(mod.super == false);
|
|
try std.testing.expect(mod.caps_lock == false);
|
|
try std.testing.expect(mod.num_lock == false);
|
|
}
|
|
|
|
test "shift int and alt to bitmask" {
|
|
const std = @import("std");
|
|
|
|
const int_mod = RawMods.shift | RawMods.alt;
|
|
const mod = Mods.fromInt(int_mod);
|
|
|
|
try std.testing.expect(mod.shift == true);
|
|
try std.testing.expect(mod.control == false);
|
|
try std.testing.expect(mod.alt == true);
|
|
try std.testing.expect(mod.super == false);
|
|
try std.testing.expect(mod.caps_lock == false);
|
|
try std.testing.expect(mod.num_lock == false);
|
|
}
|
|
|
|
test "super int to bitmask" {
|
|
const std = @import("std");
|
|
|
|
const int_mod = RawMods.super;
|
|
const mod = Mods.fromInt(int_mod);
|
|
|
|
try std.testing.expect(mod.shift == false);
|
|
try std.testing.expect(mod.control == false);
|
|
try std.testing.expect(mod.alt == false);
|
|
try std.testing.expect(mod.super == true);
|
|
try std.testing.expect(mod.caps_lock == false);
|
|
try std.testing.expect(mod.num_lock == false);
|
|
}
|
|
|
|
test "num lock int to bitmask" {
|
|
const std = @import("std");
|
|
|
|
const int_mod = RawMods.num_lock;
|
|
const mod = Mods.fromInt(int_mod);
|
|
|
|
try std.testing.expect(mod.shift == false);
|
|
try std.testing.expect(mod.control == false);
|
|
try std.testing.expect(mod.alt == false);
|
|
try std.testing.expect(mod.super == false);
|
|
try std.testing.expect(mod.caps_lock == false);
|
|
try std.testing.expect(mod.num_lock == true);
|
|
}
|
|
|
|
test "all int to bitmask" {
|
|
const std = @import("std");
|
|
|
|
const int_mod = RawMods.shift | RawMods.control |
|
|
RawMods.alt | RawMods.super |
|
|
RawMods.caps_lock | RawMods.num_lock;
|
|
const mod = Mods.fromInt(int_mod);
|
|
|
|
try std.testing.expect(mod.shift == true);
|
|
try std.testing.expect(mod.control == true);
|
|
try std.testing.expect(mod.alt == true);
|
|
try std.testing.expect(mod.super == true);
|
|
try std.testing.expect(mod.caps_lock == true);
|
|
try std.testing.expect(mod.num_lock == true);
|
|
}
|
|
|
|
test "shift bitmask to int" {
|
|
const std = @import("std");
|
|
|
|
const mod = Mods{ .shift = true };
|
|
const int_mod = mod.toInt(c_int);
|
|
|
|
try std.testing.expectEqual(int_mod, RawMods.shift);
|
|
}
|
|
|
|
test "shift and alt bitmask to int" {
|
|
const std = @import("std");
|
|
|
|
const mod = Mods{ .shift = true, .alt = true };
|
|
const int_mod = mod.toInt(c_int);
|
|
|
|
try std.testing.expectEqual(int_mod, RawMods.shift | RawMods.alt);
|
|
}
|
|
|
|
test "all bitmask to int" {
|
|
const std = @import("std");
|
|
|
|
const mod = Mods{
|
|
.shift = true,
|
|
.control = true,
|
|
.alt = true,
|
|
.super = true,
|
|
.caps_lock = true,
|
|
.num_lock = true,
|
|
};
|
|
const int_mod = mod.toInt(c_int);
|
|
|
|
const expected = RawMods.shift | RawMods.control |
|
|
RawMods.alt | RawMods.super |
|
|
RawMods.caps_lock | RawMods.num_lock;
|
|
|
|
try std.testing.expectEqual(int_mod, expected);
|
|
}
|