pkg/macos: add CoreVide for DisplayLink

This commit is contained in:
Mitchell Hashimoto
2023-11-14 14:03:38 -08:00
parent 67dce5ce0e
commit 0230222c0d
5 changed files with 82 additions and 0 deletions

View File

@ -28,6 +28,7 @@ pub fn build(b: *std.Build) !void {
lib.linkFramework("CoreFoundation");
lib.linkFramework("CoreGraphics");
lib.linkFramework("CoreText");
lib.linkFramework("CoreVideo");
if (!target.isNative()) try apple_sdk.addPaths(b, lib);
b.installArtifact(lib);

View File

@ -2,6 +2,7 @@ pub const foundation = @import("foundation.zig");
pub const graphics = @import("graphics.zig");
pub const os = @import("os.zig");
pub const text = @import("text.zig");
pub const video = @import("video.zig");
test {
@import("std").testing.refAllDecls(@This());

6
pkg/macos/video.zig Normal file
View File

@ -0,0 +1,6 @@
pub const c = @import("video/c.zig");
pub usingnamespace @import("video/display_link.zig");
test {
@import("std").testing.refAllDecls(@This());
}

3
pkg/macos/video/c.zig Normal file
View File

@ -0,0 +1,3 @@
pub usingnamespace @cImport({
@cInclude("CoreVideo/CoreVideo.h");
});

View File

@ -0,0 +1,71 @@
const std = @import("std");
const assert = std.debug.assert;
const Allocator = std.mem.Allocator;
const c = @import("c.zig");
pub const DisplayLink = opaque {
pub const Error = error{
InvalidOperation,
};
pub fn createWithActiveCGDisplays() Allocator.Error!*DisplayLink {
var result: ?*DisplayLink = null;
if (c.CVDisplayLinkCreateWithActiveCGDisplays(
@ptrCast(&result),
) != c.kCVReturnSuccess)
return error.OutOfMemory;
return result orelse error.OutOfMemory;
}
pub fn release(self: *DisplayLink) void {
c.CVDisplayLinkRelease(@ptrCast(self));
}
pub fn start(self: *DisplayLink) Error!void {
if (c.CVDisplayLinkStart(@ptrCast(self)) != c.kCVReturnSuccess)
return error.InvalidOperation;
}
pub fn stop(self: *DisplayLink) Error!void {
if (c.CVDisplayLinkStop(@ptrCast(self)) != c.kCVReturnSuccess)
return error.InvalidOperation;
}
pub fn isRunning(self: *DisplayLink) bool {
return c.CVDisplayLinkIsRunning(@ptrCast(self)) != 0;
}
// Note: this purposely throws away a ton of arguments I didn't need.
// It would be trivial to refactor this into Zig types and properly
// pass this through.
pub fn setOutputCallback(
self: *DisplayLink,
comptime callbackFn: *const fn (*DisplayLink, ?*anyopaque) void,
userinfo: ?*anyopaque,
) Error!void {
if (c.CVDisplayLinkSetOutputCallback(
@ptrCast(self),
@ptrCast(&(struct {
fn callback(
displayLink: *DisplayLink,
inNow: *const c.CVTimeStamp,
inOutputTime: *const c.CVTimeStamp,
flagsIn: c.CVOptionFlags,
flagsOut: *c.CVOptionFlags,
inner_userinfo: ?*anyopaque,
) callconv(.C) c.CVReturn {
_ = inNow;
_ = inOutputTime;
_ = flagsIn;
_ = flagsOut;
callbackFn(displayLink, inner_userinfo);
return c.kCVReturnSuccess;
}
}).callback),
userinfo,
) != c.kCVReturnSuccess)
return error.InvalidOperation;
}
};