mirror of
https://git.robbyzambito.me/zaprus
synced 2025-12-20 16:24:50 +00:00
This commit is contained in:
@@ -77,9 +77,9 @@ pub fn sendInitialConnection(payload: []const u8, initial_port: u16, allocator:
|
||||
}
|
||||
|
||||
pub fn connect(payload: []const u8, allocator: Allocator) !?SaprusConnection {
|
||||
var foo: gcat.nic.RawSocket = try .init("enp7s0");
|
||||
var foo: gcat.nic.RawSocket = try .init("enp7s0"); // /proc/net/dev
|
||||
defer foo.deinit();
|
||||
// _ = gcat.nic.RawSocket;
|
||||
|
||||
var initial_port: u16 = 0;
|
||||
if (rand) |r| {
|
||||
initial_port = r.intRangeAtMost(u16, 1024, 65000);
|
||||
|
||||
@@ -50,7 +50,7 @@ pub fn main() !void {
|
||||
}
|
||||
|
||||
if (res.args.relay) |r| {
|
||||
const dest = parseDest(res.args.dest) catch .{ 70, 70, 70, 70 };
|
||||
const dest = parseDest(res.args.dest);
|
||||
try SaprusClient.sendRelay(
|
||||
if (r.len > 0) r else "Hello darkness my old friend",
|
||||
dest,
|
||||
@@ -79,7 +79,7 @@ fn parseDest(in: ?[]const u8) [4]u8 {
|
||||
const addr = std.net.Ip4Address.parse(dest, 0) catch return "FAIL".*;
|
||||
return @bitCast(addr.sa.addr);
|
||||
}
|
||||
return "zap".*;
|
||||
return "zap\x00".*;
|
||||
}
|
||||
|
||||
const builtin = @import("builtin");
|
||||
|
||||
@@ -28,6 +28,59 @@ pub const Error = error{
|
||||
UnknownSaprusType,
|
||||
};
|
||||
|
||||
// ZERO COPY STUFF
|
||||
// &payload could be a void value that is treated as a pointer to a [*]u8
|
||||
pub const ZeroCopyMessage = packed struct {
|
||||
pub const Relay = packed struct {
|
||||
dest: @Vector(4, u8),
|
||||
/// @as([*]u8, @ptrCast(&payload))
|
||||
payload: void,
|
||||
};
|
||||
pub const Connection = packed struct {
|
||||
src_port: u16, // random number > 1024
|
||||
dest_port: u16, // random number > 1024
|
||||
seq_num: u32 = 0,
|
||||
msg_id: u32 = 0,
|
||||
reserved: u8 = 0,
|
||||
options: ConnectionOptions = .{},
|
||||
payload: void,
|
||||
};
|
||||
|
||||
const Self = @This();
|
||||
|
||||
type: PacketType,
|
||||
length: u16,
|
||||
bytes: void = {},
|
||||
|
||||
fn getRelay(self: *align(1) Self) *align(1) const Relay {
|
||||
return std.mem.bytesAsValue(Relay, &self.bytes);
|
||||
}
|
||||
fn getConnection(self: *align(1) Self) *align(1) const Connection {
|
||||
return std.mem.bytesAsValue(Connection, &self.bytes);
|
||||
}
|
||||
};
|
||||
|
||||
test "testing variable length zero copy struct" {
|
||||
const gpa = std.testing.allocator;
|
||||
const bytes = try gpa.alloc(u8, @sizeOf(ZeroCopyMessage) + 64);
|
||||
defer gpa.free(bytes);
|
||||
// const zcm = std.mem.bytesAsValue(ZeroCopyMessage, bytes).*;
|
||||
const zcm: *align(1) ZeroCopyMessage = @ptrCast(bytes.ptr);
|
||||
// @compileLog(@typeInfo(@TypeOf(ZeroCopyMessage{ .type = .relay, .length = 0 })));
|
||||
// @compileLog(@typeInfo(@TypeOf(zcm)));
|
||||
// _ = zcm;
|
||||
zcm.type = .relay;
|
||||
zcm.length = 3;
|
||||
std.debug.print("{any}\n", .{zcm});
|
||||
std.debug.print("{any}\n", .{zcm.getRelay()});
|
||||
std.debug.print("{any}\n", .{zcm.getConnection()});
|
||||
std.debug.print("{x}\n", .{std.mem.asBytes(zcm.getConnection())});
|
||||
std.debug.print("{x}\n", .{std.mem.asBytes(zcm.getRelay())});
|
||||
std.debug.print("{x}\n", .{bytes});
|
||||
|
||||
try std.testing.expect(true);
|
||||
}
|
||||
|
||||
/// All Saprus messages
|
||||
pub const Message = union(PacketType) {
|
||||
pub const Relay = struct {
|
||||
@@ -209,3 +262,7 @@ test "Round trip Connection toBytes and fromBytes" {
|
||||
|
||||
try std.testing.expectEqualDeep(msg, from_bytes);
|
||||
}
|
||||
|
||||
test {
|
||||
std.testing.refAllDeclsRecursive(@This());
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user