Mitchell Hashimoto 93f2a99b64 macos: CFArray
2022-09-30 15:10:11 -07:00

53 lines
1.5 KiB
Zig

const std = @import("std");
const Allocator = std.mem.Allocator;
const cftype = @import("type.zig");
pub const Array = opaque {
pub fn create(comptime T: type, values: []*const T) Allocator.Error!*Array {
return CFArrayCreate(
null,
@ptrCast([*]*const anyopaque, values.ptr),
@intCast(usize, values.len),
null,
) orelse error.OutOfMemory;
}
pub fn release(self: *Array) void {
cftype.CFRelease(self);
}
pub fn getCount(self: *Array) usize {
return CFArrayGetCount(self);
}
pub fn getValueAtIndex(self: *Array, comptime T: type, idx: usize) *const T {
return @ptrCast(*const T, CFArrayGetValueAtIndex(self, idx));
}
pub extern "c" fn CFArrayCreate(
allocator: ?*anyopaque,
values: [*]*const anyopaque,
num_values: usize,
callbacks: ?*const anyopaque,
) ?*Array;
pub extern "c" fn CFArrayGetCount(*Array) usize;
pub extern "c" fn CFArrayGetValueAtIndex(*Array, usize) *const anyopaque;
extern "c" var kCFTypeArrayCallBacks: anyopaque;
};
test "array" {
const testing = std.testing;
const str = "hello";
var values = [_]*const u8{ &str[0], &str[1] };
const arr = try Array.create(u8, &values);
defer arr.release();
try testing.expectEqual(@as(usize, 2), arr.getCount());
{
const ch = arr.getValueAtIndex(u8, 0);
try testing.expectEqual(@as(u8, 'h'), ch.*);
}
}