summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/c_api.zig65
1 files changed, 49 insertions, 16 deletions
diff --git a/src/c_api.zig b/src/c_api.zig
index bb233e0..481dc78 100644
--- a/src/c_api.zig
+++ b/src/c_api.zig
@@ -1,5 +1,28 @@
-// client
+const c = @cImport({
+ @cInclude("zaprus.h");
+});
+
+fn zigToCMessage(msg: ?*zaprus.Message) ?*c.SaprusMessage {
+ if (msg) |m| {
+ return switch (m.*) {
+ .relay => |_| @constCast(&c.SaprusMessage{}),
+ .connection => |_| @constCast(&c.SaprusMessage{}),
+ else => |_| null,
+ };
+ } else return null;
+}
+fn cToZigMessage(msg: ?*c.SaprusMessage) ?*zaprus.Message {
+ _ = msg;
+ return @constCast(&zaprus.Message{
+ .relay = .{
+ .header = .{ .dest = @splat(0) },
+ .payload = &.{0},
+ },
+ });
+}
+
+// client
export fn zaprus_init() c_int {
SaprusClient.init() catch return 1;
return 0;
@@ -10,44 +33,54 @@ export fn zaprus_deinit() c_int {
return 0;
}
-export fn zaprus_send_relay(payload: [*]const u8, len: usize, dest: [4]u8) c_int {
- SaprusClient.sendRelay(payload[0..len], dest, allocator) catch return 1;
+export fn zaprus_send_relay(payload: [*]const u8, len: usize, dest: [*]u8) c_int {
+ SaprusClient.sendRelay(payload[0..len], dest[0..4].*, allocator) catch return 1;
return 0;
}
export fn zaprus_send_initial_connection(payload: [*]const u8, len: usize, initial_port: u16) c_int {
- SaprusClient.sendInitialConnection(payload[0..len], initial_port, allocator) catch return 1;
+ _ = SaprusClient.sendInitialConnection(payload[0..len], initial_port, allocator) catch return 1;
return 0;
}
-export fn zaprus_connect(payload: [*]const u8, len: usize) ?*SaprusMessage {
- return SaprusClient.connect(payload[0..len], allocator) catch null;
+export fn zaprus_connect(payload: [*]const u8, len: usize) ?*c.SaprusMessage {
+ if (SaprusClient.connect(payload[0..len], allocator)) |msg| {
+ return zigToCMessage(@constCast(&(msg.?)));
+ } else |_| {
+ return null;
+ }
}
// message
/// ptr should be freed by the caller.
-export fn zaprus_message_to_bytes(msg: SaprusMessage, ptr: *[*]u8, len: *usize) c_int {
- const bytes = msg.toBytes(allocator) catch return 1;
- ptr.* = bytes[0..].*;
- len.* = bytes.len;
- return 0;
+export fn zaprus_message_to_bytes(msg: c.SaprusMessage, ptr: *[*]u8, len: *usize) c_int {
+ if (cToZigMessage(@constCast(&msg))) |m| {
+ const bytes = m.toBytes(allocator) catch return 1;
+ ptr.* = bytes.ptr;
+ len.* = bytes.len;
+ return 0;
+ } else return 1;
}
/// Return value should be destroyed with zaprus_message_deinit.
-export fn zaprus_message_from_bytes(bytes: [*]const u8, len: usize) ?*SaprusMessage {
- return SaprusMessage.fromBytes(bytes[0..len], allocator) catch null;
+export fn zaprus_message_from_bytes(bytes: [*]const u8, len: usize) ?*c.SaprusMessage {
+ if (zaprus.Message.fromBytes(bytes[0..len], allocator)) |msg| {
+ return zigToCMessage(@constCast(&msg));
+ } else |_| return null;
}
-export fn zaprus_message_deinit(msg: *SaprusMessage) void {
- msg.deinit(allocator);
+export fn zaprus_message_deinit(msg: *c.SaprusMessage) void {
+ // noop
+ _ = msg;
+ // msg.*.deinit(allocator);
}
const std = @import("std");
const zaprus = @import("./root.zig");
const SaprusClient = zaprus.Client;
-const SaprusMessage = zaprus.Message;
+// const SaprusMessage = zaprus.Message;
const allocator = std.heap.c_allocator;