Skip to content

Commit

Permalink
feat: Windows port iteration
Browse files Browse the repository at this point in the history
  • Loading branch information
mochalins committed Sep 18, 2024
1 parent afcc18c commit 7102f76
Show file tree
Hide file tree
Showing 4 changed files with 90 additions and 33 deletions.
2 changes: 0 additions & 2 deletions src/backend/linux.zig
Original file line number Diff line number Diff line change
Expand Up @@ -170,8 +170,6 @@ pub const IteratorImpl = struct {
}
};

pub const StubImpl = void;

test {
const c = @cImport({
@cDefine("_XOPEN_SOURCE", "700");
Expand Down
2 changes: 0 additions & 2 deletions src/backend/macos.zig
Original file line number Diff line number Diff line change
Expand Up @@ -109,8 +109,6 @@ pub fn writer(port: PortImpl) Writer {
return port.writer();
}

pub const StubImpl = void;

pub fn iterate() !IteratorImpl {
var result: IteratorImpl = .{
.dir = try std.fs.cwd().openDir("/dev", .{ .iterate = true }),
Expand Down
118 changes: 90 additions & 28 deletions src/backend/windows.zig
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,73 @@ pub fn writer(port: PortImpl) Writer {
return .{ .context = port };
}

pub fn iterate() !IteratorImpl {
const HKEY_LOCAL_MACHINE = @as(windows.HKEY, @ptrFromInt(0x80000002));
const KEY_READ = 0x20019;

const w_str: [:0]const u16 = comptime b: {
const orig = "HARDWARE\\DEVICEMAP\\SERIALCOMM\\";
var result: [orig.len]u16 = undefined;
@memcpy(&result, orig);
break :b &result;
};

var result: IteratorImpl = .{ .key = undefined };
if (windows.advapi32.RegOpenKeyExW(
HKEY_LOCAL_MACHINE,
w_str.ptr,
0,
KEY_READ,
&result.key,
) != 0) {
return windows.unexpectedError(windows.GetLastError());
}

return result;
}

pub const IteratorImpl = struct {
key: windows.HKEY,
index: windows.DWORD = 0,
name_buffer: [16]u8 = undefined,
path_buffer: [16]u8 = undefined,

pub fn next(self: *@This()) !?serialport.Iterator.Stub {
defer self.index += 1;

var name_size: windows.DWORD = 256;
var data_size: windows.DWORD = 256;
var name: [255:0]u8 = undefined;

return switch (RegEnumValueA(
self.key,
self.index,
&name,
&name_size,
null,
null,
&self.name_buffer,
&data_size,
)) {
0 => serialport.Iterator.Stub{
.name = self.name_buffer[0 .. data_size - 1],
.path = try std.fmt.bufPrint(
&self.path_buffer,
"\\\\.\\{s}",
.{self.name_buffer[0 .. data_size - 1]},
),
},
259 => null,
else => windows.unexpectedError(windows.GetLastError()),
};
}

pub fn deinit(self: *@This()) void {
_ = windows.advapi32.RegCloseKey(self.key);
self.* = undefined;
}
};

const ReadContext = std.fs.File;
fn readFn(context: ReadContext, buffer: []u8) ReadError!usize {
var overlapped: windows.OVERLAPPED = .{
Expand Down Expand Up @@ -295,6 +362,19 @@ const DCB = extern struct {
};
};

const EventMask = packed struct(windows.DWORD) {
RXCHAR: bool = false,
RXFLAG: bool = false,
TXEMPTY: bool = false,
CTS: bool = false,
DSR: bool = false,
RLSD: bool = false,
BREAK: bool = false,
ERR: bool = false,
RING: bool = false,
_: u23 = 0,
};

extern "kernel32" fn SetCommState(
hFile: windows.HANDLE,
lpDCB: *DCB,
Expand Down Expand Up @@ -327,31 +407,13 @@ extern "kernel32" fn PurgeComm(
},
) callconv(windows.WINAPI) windows.BOOL;

const EventMask = packed struct(windows.DWORD) {
RXCHAR: bool = false,
RXFLAG: bool = false,
TXEMPTY: bool = false,
CTS: bool = false,
DSR: bool = false,
RLSD: bool = false,
BREAK: bool = false,
ERR: bool = false,
RING: bool = false,
_: u23 = 0,
};

pub const StubImpl = void;

pub fn iterate() !IteratorImpl {
@compileError("unimplemented");
}

pub const IteratorImpl = struct {
pub fn next(_: *@This()) !?serialport.Iterator.Stub {
@compileError("unimplemented");
}

pub fn deinit(_: *@This()) void {
@compileError("unimplemented");
}
};
extern "advapi32" fn RegEnumValueA(
hKey: windows.HKEY,
dwIndex: windows.DWORD,
lpValueName: windows.LPSTR,
lpcchValueName: *windows.DWORD,
lpReserved: ?*windows.DWORD,
lpType: ?*windows.DWORD,
lpData: [*]windows.BYTE,
lpcbData: *windows.DWORD,
) callconv(std.os.windows.WINAPI) std.os.windows.LSTATUS;
1 change: 0 additions & 1 deletion src/serialport.zig
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,6 @@ pub const Iterator = struct {
pub const Stub = struct {
name: []const u8,
path: []const u8,
_impl: backend.StubImpl,

pub fn open(self: @This()) !Port {
return serialport.open(self.path);
Expand Down

0 comments on commit 7102f76

Please sign in to comment.