pub const FIOBJ = usize; pub extern fn is_invalid(o: FIOBJ) c_int; pub const fio_url_s = extern struct { scheme: fio_str_info_s, user: fio_str_info_s, password: fio_str_info_s, host: fio_str_info_s, port: fio_str_info_s, path: fio_str_info_s, query: fio_str_info_s, target: fio_str_info_s, }; pub extern fn fio_url_parse(url: [*c]const u8, length: usize) fio_url_s; pub const struct_fio_start_args = extern struct { threads: i16, workers: i16, }; pub const fio_start_args = struct_fio_start_args; pub extern fn fio_start(args: struct_fio_start_args) void; pub extern fn fio_stop() void; const struct_unnamed_37 = extern struct { vtbl: ?*anyopaque, flag: usize, out_headers: FIOBJ, }; pub const __time_t = c_long; pub const time_t = __time_t; pub const __syscall_slong_t = c_long; pub const struct_timespec = extern struct { tv_sec: __time_t, tv_nsec: __syscall_slong_t, }; pub const struct_http_settings_s = extern struct { on_request: ?*const fn ([*c]http_s) callconv(.C) void, on_upgrade: ?*const fn ([*c]http_s, [*c]u8, usize) callconv(.C) void, on_response: ?*const fn ([*c]http_s) callconv(.C) void, on_finish: ?*const fn ([*c]struct_http_settings_s) callconv(.C) void, udata: ?*anyopaque, public_folder: [*c]const u8, public_folder_length: usize, max_header_size: usize, max_body_size: usize, max_clients: isize, tls: ?*anyopaque, reserved1: isize, reserved2: isize, reserved3: isize, ws_max_msg_size: usize, timeout: u8, ws_timeout: u8, log: u8, is_client: u8, }; pub const http_settings_s = struct_http_settings_s; pub const http_s = extern struct { private_data: struct_unnamed_37, received_at: struct_timespec, method: FIOBJ, status_str: FIOBJ, version: FIOBJ, status: usize, path: FIOBJ, query: FIOBJ, headers: FIOBJ, cookies: FIOBJ, params: FIOBJ, body: FIOBJ, udata: ?*anyopaque, }; // zig-cache/i/e0c8a6e617497ade13de512cbe191f23/include/http.h:153:12: warning: struct demoted to opaque type - has bitfield // typedef struct { // /** The cookie's name (Symbol). */ // const char *name; // /** The cookie's value (leave blank to delete cookie). */ // const char *value; // /** The cookie's domain (optional). */ // const char *domain; // /** The cookie's path (optional). */ // const char *path; // /** The cookie name's size in bytes or a terminating NUL will be assumed.*/ // size_t name_len; // /** The cookie value's size in bytes or a terminating NUL will be assumed.*/ // size_t value_len; // /** The cookie domain's size in bytes or a terminating NUL will be assumed.*/ // size_t domain_len; // /** The cookie path's size in bytes or a terminating NULL will be assumed.*/ // size_t path_len; // /** Max Age (how long should the cookie persist), in seconds (0 == session).*/ // int max_age; // /** Limit cookie to secure connections.*/ // unsigned secure : 1; // /** Limit cookie to HTTP (intended to prevent javascript access/hijacking).*/ // unsigned http_only : 1; // } http_cookie_args_s; pub const http_cookie_args_s = extern struct { name: [*c]u8, value: [*c]u8, domain: [*c]u8, path: [*c]u8, name_len: isize, value_len: isize, domain_len: isize, path_len: isize, /// in seconds max_age: c_int, secure: c_uint, http_only: c_uint, }; pub const struct_fio_str_info_s = extern struct { capa: usize, len: usize, data: [*c]u8, }; pub const fio_str_info_s = struct_fio_str_info_s; pub extern fn http_send_body(h: [*c]http_s, data: ?*anyopaque, length: usize) c_int; pub fn fiobj_each1(arg_o: FIOBJ, arg_start_at: usize, arg_task: ?*const fn (FIOBJ, ?*anyopaque) callconv(.C) c_int, arg_arg: ?*anyopaque) callconv(.C) usize { var o = arg_o; var start_at = arg_start_at; var task = arg_task; var arg = arg_arg; if ((((o != 0) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) != @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6)))))) and (fiobj_type_vtable(o).*.each != null)) return fiobj_type_vtable(o).*.each.?(o, start_at, task, arg); return 0; } pub extern fn fiobj_hash_new() FIOBJ; pub extern fn fiobj_hash_set(hash: FIOBJ, key: FIOBJ, obj: FIOBJ) c_int; pub extern fn fiobj_hash_get(hash: FIOBJ, key: FIOBJ) FIOBJ; pub extern fn fiobj_hash_pop(hash: FIOBJ, key: [*c]FIOBJ) FIOBJ; pub extern fn fiobj_hash_count(hash: FIOBJ) usize; pub extern fn fiobj_hash_key_in_loop() FIOBJ; pub extern fn fiobj_hash_haskey(hash: FIOBJ, key: FIOBJ) c_int; pub extern fn fiobj_ary_new() FIOBJ; pub extern fn fiobj_ary_new2(capa: usize) FIOBJ; pub extern fn fiobj_ary_count(ary: FIOBJ) usize; pub extern fn fiobj_ary_capa(ary: FIOBJ) usize; pub extern fn fiobj_ary2ptr(ary: FIOBJ) [*c]FIOBJ; pub extern fn fiobj_ary_index(ary: FIOBJ, pos: i64) FIOBJ; pub extern fn fiobj_ary_set(ary: FIOBJ, obj: FIOBJ, pos: i64) void; pub extern fn fiobj_ary_push(ary: FIOBJ, obj: FIOBJ) void; pub extern fn fiobj_ary_pop(ary: FIOBJ) FIOBJ; pub extern fn fiobj_ary_unshift(ary: FIOBJ, obj: FIOBJ) void; pub extern fn fiobj_ary_shift(ary: FIOBJ) FIOBJ; pub extern fn fiobj_ary_replace(ary: FIOBJ, obj: FIOBJ, pos: i64) FIOBJ; pub extern fn fiobj_ary_find(ary: FIOBJ, data: FIOBJ) i64; pub extern fn fiobj_ary_remove(ary: FIOBJ, pos: i64) c_int; pub extern fn fiobj_ary_remove2(ary: FIOBJ, data: FIOBJ) c_int; pub extern fn fiobj_ary_compact(ary: FIOBJ) void; pub extern fn fiobj_float_new(num: f64) FIOBJ; pub extern fn fiobj_num_new_bignum(num: isize) FIOBJ; pub extern fn fiobj_data_newstr() FIOBJ; pub extern fn fiobj_data_newstr2(buffer: ?*anyopaque, length: usize, dealloc: ?*const fn (?*anyopaque) callconv(.C) void) FIOBJ; pub extern fn fiobj_data_newtmpfile() FIOBJ; pub extern fn fiobj_data_newfd(fd: c_int) FIOBJ; pub extern fn fiobj_data_slice(parent: FIOBJ, offset: isize, length: usize) FIOBJ; pub extern fn fiobj_data_save(io: FIOBJ, filename: [*c]const u8) c_int; pub extern fn fiobj_data_read(io: FIOBJ, length: isize) fio_str_info_s; pub extern fn fiobj_data_read2ch(io: FIOBJ, token: u8) fio_str_info_s; pub extern fn fiobj_data_pos(io: FIOBJ) isize; pub extern fn fiobj_data_len(io: FIOBJ) isize; pub extern fn fiobj_data_seek(io: FIOBJ, position: isize) void; pub extern fn fiobj_data_pread(io: FIOBJ, start_at: isize, length: usize) fio_str_info_s; pub extern fn fiobj_data_write(io: FIOBJ, buffer: ?*anyopaque, length: usize) isize; pub extern fn fiobj_data_puts(io: FIOBJ, buffer: ?*anyopaque, length: usize) isize; pub extern fn fiobj_data_assert_dynamic(io: FIOBJ) void; /// Creates a new SSL/TLS context / settings object with a default certificate (if any). /// If a server name is provided, than NULL values can be used to create an anonymous (unverified) /// context / settings object. If all values are NULL, a TLS object will be created without a /// certificate. This could be used for clients together with fio_tls_trust. fio_tls_s * is an /// opaque type used as a handle for the SSL/TLS functions. It shouldn't be directly accessed. pub extern fn fio_tls_new( server_name: ?[*:0]const u8, public_certificate_file: ?[*:0]const u8, private_key_file: ?[*:0]const u8, private_key_password: ?[*:0]const u8, ) ?*anyopaque; /// Increase the reference count for the TLS object. /// Decrease / free with fio_tls_destroy. pub extern fn fio_tls_dup(tls: ?*anyopaque) void; /// Destroys the SSL/TLS context / settings object and frees any related resources / memory. pub extern fn fio_tls_destroy(tls: ?*anyopaque) void; /// Adds a certificate a new SSL/TLS context / settings object (SNI support). /// The private_key_password can be NULL if the private key PEM file isn't password protected. pub extern fn fio_tls_cert_add( tls: ?*anyopaque, server_name: ?[*:0]const u8, public_certificate_file: ?[*:0]const u8, private_key_file: ?[*:0]const u8, private_key_password: ?[*:0]const u8, ) void; /// Adds a certificate to the "trust" list, which automatically adds a peer verification requirement. /// Note: when the fio_tls_s object is used for server connections, this will limit connections to /// clients that connect using a trusted certificate. pub extern fn fio_tls_trust(tls: ?*anyopaque, public_cert_file: ?[*:0]const u8) void; /// Establishes an SSL/TLS connection as an SSL/TLS Server, using the specified context / settings object. /// The uuid should be a socket UUID that is already connected to a peer (i.e., the result of fio_accept). /// The udata is an opaque user data pointer that is passed along to the protocol selected (if any protocols /// were added using fio_tls_alpn_add). pub extern fn fio_tls_accept(uuid: *u32, tls: ?*anyopaque, udata: ?*anyopaque) void; /// Establishes an SSL/TLS connection as an SSL/TLS Client, using the specified context / settings object. /// The uuid should be a socket UUID that is already connected to a peer (i.e., one received by a fio_connect /// specified callback on_connect). /// The udata is an opaque user data pointer that is passed along to the protocol selected (if any protocols /// were added using fio_tls_alpn_add). pub extern fn fio_tls_connect(uuid: *u32, tls: ?*anyopaque, udata: ?*anyopaque) void; pub extern fn fiobj_free_wrapped(o: FIOBJ) callconv(.C) void; pub fn fiobj_null() callconv(.C) FIOBJ { return @as(FIOBJ, @bitCast(@as(c_long, FIOBJ_T_NULL))); } pub fn fiobj_true() callconv(.C) FIOBJ { return @as(FIOBJ, @bitCast(@as(c_long, FIOBJ_T_TRUE))); } pub fn fiobj_false() callconv(.C) FIOBJ { return @as(FIOBJ, @bitCast(@as(c_long, FIOBJ_T_FALSE))); } pub extern fn fiobj_str_new(str: [*c]const u8, len: usize) FIOBJ; pub extern fn fiobj_str_buf(capa: usize) FIOBJ; pub inline fn FIOBJ_TYPE(obj: anytype) @TypeOf(fiobj_type(obj)) { return fiobj_type(obj); } pub inline fn FIOBJ_TYPE_IS(obj: anytype, @"type": anytype) @TypeOf(fiobj_type_is(obj, @"type")) { return fiobj_type_is(obj, @"type"); } pub inline fn FIOBJ_IS_NULL(obj: anytype) @TypeOf(!(obj != 0) or (obj == @import("std").zig.c_translation.cast(FIOBJ, FIOBJ_T_NULL))) { return !(obj != 0) or (obj == @import("std").zig.c_translation.cast(FIOBJ, FIOBJ_T_NULL)); } pub const FIOBJ_INVALID = @as(c_int, 0); pub const FIOBJECT_NUMBER_FLAG = @as(c_int, 1); pub const FIOBJECT_PRIMITIVE_FLAG = @as(c_int, 6); pub const FIOBJECT_STRING_FLAG = @as(c_int, 2); pub const FIOBJECT_HASH_FLAG = @as(c_int, 4); pub const FIOBJECT_TYPE_MASK = ~@import("std").zig.c_translation.cast(usize, @as(c_int, 7)); pub const FIOBJ_NUMBER_SIGN_MASK = ~@import("std").zig.c_translation.cast(usize, @as(c_int, 0)) >> @as(c_int, 1); pub const FIOBJ_NUMBER_SIGN_BIT = ~FIOBJ_NUMBER_SIGN_MASK; pub const FIOBJ_NUMBER_SIGN_EXCLUDE_BIT = FIOBJ_NUMBER_SIGN_BIT >> @as(c_int, 1); pub inline fn FIOBJ_IS_ALLOCATED(o: anytype) @TypeOf(((o != 0) and ((o & FIOBJECT_NUMBER_FLAG) == @as(c_int, 0))) and ((o & FIOBJECT_PRIMITIVE_FLAG) != FIOBJECT_PRIMITIVE_FLAG)) { return ((o != 0) and ((o & FIOBJECT_NUMBER_FLAG) == @as(c_int, 0))) and ((o & FIOBJECT_PRIMITIVE_FLAG) != FIOBJECT_PRIMITIVE_FLAG); } pub inline fn FIOBJ2PTR(o: anytype) ?*anyopaque { return @import("std").zig.c_translation.cast(?*anyopaque, o & FIOBJECT_TYPE_MASK); } pub inline fn FIOBJECT2VTBL(o: anytype) @TypeOf(fiobj_type_vtable(o)) { return fiobj_type_vtable(o); } pub inline fn FIOBJECT2HEAD(o: anytype) [*c]fiobj_object_header_s { return @import("std").zig.c_translation.cast([*c]fiobj_object_header_s, FIOBJ2PTR(o)); } pub inline fn fiobj_ary_entry(a: anytype, p: anytype) @TypeOf(fiobj_ary_index(a, p)) { return fiobj_ary_index(a, p); } pub const FIOBJ_T_NUMBER: c_int = 1; pub const FIOBJ_T_NULL: c_int = 6; pub const FIOBJ_T_TRUE: c_int = 22; pub const FIOBJ_T_FALSE: c_int = 38; pub const FIOBJ_T_FLOAT: c_int = 39; pub const FIOBJ_T_STRING: c_int = 40; pub const FIOBJ_T_ARRAY: c_int = 41; pub const FIOBJ_T_HASH: c_int = 42; pub const FIOBJ_T_DATA: c_int = 43; pub const FIOBJ_T_UNKNOWN: c_int = 44; pub const fiobj_type_enum = u8; pub const fiobj_object_vtable_s = extern struct { class_name: [*c]const u8, dealloc: ?*const fn (FIOBJ, ?*const fn (FIOBJ, ?*anyopaque) callconv(.C) void, ?*anyopaque) callconv(.C) void, count: ?*const fn (FIOBJ) callconv(.C) usize, is_true: ?*const fn (FIOBJ) callconv(.C) usize, is_eq: ?*const fn (FIOBJ, FIOBJ) callconv(.C) usize, each: ?*const fn (FIOBJ, usize, ?*const fn (FIOBJ, ?*anyopaque) callconv(.C) c_int, ?*anyopaque) callconv(.C) usize, to_str: ?*const fn (FIOBJ) callconv(.C) fio_str_info_s, to_i: ?*const fn (FIOBJ) callconv(.C) isize, to_f: ?*const fn (FIOBJ) callconv(.C) f64, }; pub const fiobj_object_header_s = extern struct { type: fiobj_type_enum, ref: u32, }; pub fn fiobj_type_is(arg_o: FIOBJ, arg_type: fiobj_type_enum) callconv(.C) usize { var o = arg_o; var @"type" = arg_type; while (true) { switch (@as(c_int, @bitCast(@as(c_uint, @"type")))) { @as(c_int, 1) => return @as(usize, @bitCast(@as(c_long, @intFromBool(((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) != 0) or (@as(c_int, @bitCast(@as(c_uint, @as([*c]fiobj_type_enum, @ptrFromInt(o))[@as(c_uint, @intCast(@as(c_int, 0)))]))) == FIOBJ_T_NUMBER))))), @as(c_int, 6) => return @as(usize, @bitCast(@as(c_long, @intFromBool(!(o != 0) or (o == fiobj_null()))))), @as(c_int, 22) => return @as(usize, @bitCast(@as(c_long, @intFromBool(o == fiobj_true())))), @as(c_int, 38) => return @as(usize, @bitCast(@as(c_long, @intFromBool(o == fiobj_false())))), @as(c_int, 40) => return @as(usize, @bitCast(@as(c_long, @intFromBool(((true and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 2)))))) or (((@as(c_int, 2) == @as(c_int, 0)) and (((o != 0) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) != @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))))) and (@as(c_int, @bitCast(@as(c_uint, @as([*c]fiobj_type_enum, @ptrCast(@alignCast(@as(?*anyopaque, @ptrFromInt(o & ~@as(usize, @bitCast(@as(c_long, @as(c_int, 7)))))))))[@as(c_uint, @intCast(@as(c_int, 0)))]))) == FIOBJ_T_STRING)))))), @as(c_int, 42) => { if (true) { return @as(usize, @bitCast(@as(c_long, @intFromBool(((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 4))))))))); } return @as(usize, @bitCast(@as(c_long, @intFromBool((((o != 0) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) != @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6)))))) and (@as(c_int, @bitCast(@as(c_uint, @as([*c]fiobj_type_enum, @ptrCast(@alignCast(@as(?*anyopaque, @ptrFromInt(o & ~@as(usize, @bitCast(@as(c_long, @as(c_int, 7)))))))))[@as(c_uint, @intCast(@as(c_int, 0)))]))) == @as(c_int, @bitCast(@as(c_uint, @"type")))))))); }, @as(c_int, 39), @as(c_int, 41), @as(c_int, 43), @as(c_int, 44) => return @as(usize, @bitCast(@as(c_long, @intFromBool((((o != 0) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) != @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6)))))) and (@as(c_int, @bitCast(@as(c_uint, @as([*c]fiobj_type_enum, @ptrCast(@alignCast(@as(?*anyopaque, @ptrFromInt(o & ~@as(usize, @bitCast(@as(c_long, @as(c_int, 7)))))))))[@as(c_uint, @intCast(@as(c_int, 0)))]))) == @as(c_int, @bitCast(@as(c_uint, @"type")))))))), else => {}, } break; } return @as(usize, @bitCast(@as(c_long, @intFromBool((((o != 0) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) != @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6)))))) and (@as(c_int, @bitCast(@as(c_uint, @as([*c]fiobj_type_enum, @ptrCast(@alignCast(@as(?*anyopaque, @ptrFromInt(o & ~@as(usize, @bitCast(@as(c_long, @as(c_int, 7)))))))))[@as(c_uint, @intCast(@as(c_int, 0)))]))) == @as(c_int, @bitCast(@as(c_uint, @"type")))))))); } pub fn fiobj_type(arg_o: FIOBJ) callconv(.C) fiobj_type_enum { var o = arg_o; if (!(o != 0)) return @as(u8, @bitCast(@as(i8, @truncate(FIOBJ_T_NULL)))); if ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) != 0) return @as(u8, @bitCast(@as(i8, @truncate(FIOBJ_T_NUMBER)))); if ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) return @as(u8, @bitCast(@as(u8, @truncate(o)))); if (true and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 2)))))) return @as(u8, @bitCast(@as(i8, @truncate(FIOBJ_T_STRING)))); if (true and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 4)))))) return @as(u8, @bitCast(@as(i8, @truncate(FIOBJ_T_HASH)))); return @as([*c]fiobj_type_enum, @ptrCast(@alignCast(@as(?*anyopaque, @ptrFromInt(o & ~@as(usize, @bitCast(@as(c_long, @as(c_int, 7)))))))))[@as(c_uint, @intCast(@as(c_int, 0)))]; } pub extern const FIOBJECT_VTABLE_NUMBER: fiobj_object_vtable_s; pub extern const FIOBJECT_VTABLE_FLOAT: fiobj_object_vtable_s; pub extern const FIOBJECT_VTABLE_STRING: fiobj_object_vtable_s; pub extern const FIOBJECT_VTABLE_ARRAY: fiobj_object_vtable_s; pub extern const FIOBJECT_VTABLE_HASH: fiobj_object_vtable_s; pub extern const FIOBJECT_VTABLE_DATA: fiobj_object_vtable_s; pub fn fiobj_type_vtable(arg_o: FIOBJ) callconv(.C) [*c]const fiobj_object_vtable_s { var o = arg_o; while (true) { switch (@as(c_int, @bitCast(@as(c_uint, fiobj_type(o))))) { @as(c_int, 1) => return &FIOBJECT_VTABLE_NUMBER, @as(c_int, 39) => return &FIOBJECT_VTABLE_FLOAT, @as(c_int, 40) => return &FIOBJECT_VTABLE_STRING, @as(c_int, 41) => return &FIOBJECT_VTABLE_ARRAY, @as(c_int, 42) => return &FIOBJECT_VTABLE_HASH, @as(c_int, 43) => return &FIOBJECT_VTABLE_DATA, @as(c_int, 6), @as(c_int, 22), @as(c_int, 38), @as(c_int, 44) => return null, else => {}, } break; } return null; } pub fn fiobj_obj2num(o: FIOBJ) callconv(.C) isize { if ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) != 0) { const sign: usize = if ((o & ~(~@as(usize, @bitCast(@as(c_long, @as(c_int, 0)))) >> @as(@import("std").math.Log2Int(usize), @intCast(1)))) != 0) ~(~@as(usize, @bitCast(@as(c_long, @as(c_int, 0)))) >> @as(@import("std").math.Log2Int(usize), @intCast(1))) | (~(~@as(usize, @bitCast(@as(c_long, @as(c_int, 0)))) >> @as(@import("std").math.Log2Int(usize), @intCast(1))) >> @as(@import("std").math.Log2Int(usize), @intCast(1))) else @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))); return @as(isize, @bitCast(((o & (~@as(usize, @bitCast(@as(c_long, @as(c_int, 0)))) >> @as(@import("std").math.Log2Int(usize), @intCast(1)))) >> @as(@import("std").math.Log2Int(c_ulong), @intCast(1))) | sign)); } if (!(o != 0) or !(((o != 0) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 0)))))) and ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) != @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))))) return @as(isize, @bitCast(@as(c_long, @intFromBool(o == @as(c_ulong, @bitCast(@as(c_long, FIOBJ_T_TRUE))))))); return fiobj_type_vtable(o).*.to_i.?(o); } pub fn fiobj_obj2float(o: FIOBJ) callconv(.C) f64 { if ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) != 0) return @as(f64, @floatFromInt(fiobj_obj2num(o))); // the below doesn't parse and we don't support ints here anyway // if (!(o != 0) or ((o & @bitCast(c_ulong, @as(c_long, @as(c_int, 6)))) == @bitCast(c_ulong, @as(c_long, @as(c_int, 6))))) return @intToFloat(f64, o == @bitCast(c_ulong, @as(c_long, FIOBJ_T_TRUE))); return fiobj_type_vtable(o).*.to_f.?(o); } pub extern fn fio_ltocstr(c_long) fio_str_info_s; pub fn fiobj_obj2cstr(o: FIOBJ) callconv(.C) fio_str_info_s { if (!(o != 0)) { var ret: fio_str_info_s = fio_str_info_s{ .capa = @as(usize, @bitCast(@as(c_long, @as(c_int, 0)))), .len = @as(usize, @bitCast(@as(c_long, @as(c_int, 4)))), .data = @as([*c]u8, @ptrFromInt(@intFromPtr("null"))), }; return ret; } if ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 1))))) != 0) return fio_ltocstr(@as(isize, @bitCast(o)) >> @as(@import("std").math.Log2Int(isize), @intCast(1))); if ((o & @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) == @as(c_ulong, @bitCast(@as(c_long, @as(c_int, 6))))) { while (true) { switch (@as(c_int, @bitCast(@as(c_uint, @as(u8, @bitCast(@as(u8, @truncate(o)))))))) { @as(c_int, 6) => { { var ret: fio_str_info_s = fio_str_info_s{ .capa = @as(usize, @bitCast(@as(c_long, @as(c_int, 0)))), .len = @as(usize, @bitCast(@as(c_long, @as(c_int, 4)))), .data = @as([*c]u8, @ptrFromInt(@intFromPtr("null"))), }; return ret; } }, @as(c_int, 38) => { { var ret: fio_str_info_s = fio_str_info_s{ .capa = @as(usize, @bitCast(@as(c_long, @as(c_int, 0)))), .len = @as(usize, @bitCast(@as(c_long, @as(c_int, 5)))), .data = @as([*c]u8, @ptrFromInt(@intFromPtr("false"))), }; return ret; } }, @as(c_int, 22) => { { var ret: fio_str_info_s = fio_str_info_s{ .capa = @as(usize, @bitCast(@as(c_long, @as(c_int, 0)))), .len = @as(usize, @bitCast(@as(c_long, @as(c_int, 4)))), .data = @as([*c]u8, @ptrFromInt(@intFromPtr("true"))), }; return ret; } }, else => break, } break; } } return fiobj_type_vtable(o).*.to_str.?(o); } // pub const http_cookie_args_s = opaque {}; pub extern fn http_set_header(h: [*c]http_s, name: FIOBJ, value: FIOBJ) c_int; pub extern fn http_set_header2(h: [*c]http_s, name: fio_str_info_s, value: fio_str_info_s) c_int; pub extern fn http_set_cookie(h: [*c]http_s, http_cookie_args_s) c_int; pub extern fn http_sendfile(h: [*c]http_s, fd: c_int, length: usize, offset: usize) c_int; pub extern fn http_sendfile2(h: [*c]http_s, prefix: [*c]const u8, prefix_len: usize, encoded: [*c]const u8, encoded_len: usize) c_int; pub extern fn http_send_error(h: [*c]http_s, error_code: usize) c_int; pub extern fn http_finish(h: [*c]http_s) void; pub extern fn http_push_data(h: [*c]http_s, data: ?*anyopaque, length: usize, mime_type: FIOBJ) c_int; pub extern fn http_push_file(h: [*c]http_s, filename: FIOBJ, mime_type: FIOBJ) c_int; pub const struct_http_pause_handle_s = opaque {}; pub const http_pause_handle_s = struct_http_pause_handle_s; pub extern fn http_pause(h: [*c]http_s, task: ?*const fn (?*http_pause_handle_s) callconv(.C) void) void; pub extern fn http_resume(http: ?*http_pause_handle_s, task: ?*const fn ([*c]http_s) callconv(.C) void, fallback: ?*const fn (?*anyopaque) callconv(.C) void) void; pub extern fn http_paused_udata_get(http: ?*http_pause_handle_s) ?*anyopaque; pub extern fn http_paused_udata_set(http: ?*http_pause_handle_s, udata: ?*anyopaque) ?*anyopaque; pub extern fn http_listen(port: [*c]const u8, binding: [*c]const u8, struct_http_settings_s) isize; pub extern fn http_connect(url: [*c]const u8, unix_address: [*c]const u8, struct_http_settings_s) isize; pub extern fn http_settings(h: [*c]http_s) [*c]struct_http_settings_s; pub extern fn http_peer_addr(h: [*c]http_s) fio_str_info_s; pub extern fn http_hijack(h: [*c]http_s, leftover: [*c]fio_str_info_s) isize; pub const struct_ws_s = opaque {}; pub const ws_s = struct_ws_s; pub const websocket_settings_s = extern struct { on_message: ?*const fn (?*ws_s, fio_str_info_s, u8) callconv(.C) void, on_open: ?*const fn (?*ws_s) callconv(.C) void, on_ready: ?*const fn (?*ws_s) callconv(.C) void, on_shutdown: ?*const fn (?*ws_s) callconv(.C) void, on_close: ?*const fn (isize, ?*anyopaque) callconv(.C) void, udata: ?*anyopaque, }; // struct websocket_subscribe_s_zigcompat { // ws_s *ws; // fio_str_info_s channel; // void (*on_message)(ws_s *ws, fio_str_info_s channel, fio_str_info_s msg, void *udata); // void (*on_unsubscribe)(void *udata); // void *udata; // fio_match_fn match; // unsigned char force_binary; // unsigned char force_text; // }; pub const websocket_subscribe_s_zigcompat = extern struct { ws: ?*ws_s, channel: fio_str_info_s, on_message: ?*const fn (?*ws_s, fio_str_info_s, fio_str_info_s, ?*anyopaque) callconv(.C) void, on_unsubscribe: ?*const fn (?*anyopaque) callconv(.C) void, udata: ?*anyopaque, match: fio_match_fn, force_binary: u8, force_text: u8, }; /// 0 on failure pub extern fn websocket_subscribe_zigcompat(websocket_subscribe_s_zigcompat) callconv(.C) usize; pub extern fn http_upgrade2ws(http: [*c]http_s, websocket_settings_s) c_int; pub extern fn websocket_connect(url: [*c]const u8, settings: websocket_settings_s) c_int; pub extern fn websocket_attach(uuid: isize, http_settings: [*c]http_settings_s, args: [*c]websocket_settings_s, data: ?*anyopaque, length: usize) void; pub extern fn websocket_udata_get(ws: ?*ws_s) ?*anyopaque; pub extern fn websocket_udata_set(ws: ?*ws_s, udata: ?*anyopaque) ?*anyopaque; pub extern fn websocket_uuid(ws: ?*ws_s) isize; pub extern fn websocket_is_client(ws: ?*ws_s) u8; pub extern fn websocket_write(ws: ?*ws_s, msg: fio_str_info_s, is_text: u8) c_int; pub extern fn websocket_close(ws: ?*ws_s) void; // zig-cache/i/e0c8a6e617497ade13de512cbe191f23/include/websockets.h:104:12: warning: struct demoted to opaque type - has bitfield pub const struct_websocket_subscribe_s = opaque {}; pub extern fn websocket_subscribe(args: struct_websocket_subscribe_s) usize; pub extern fn websocket_unsubscribe(ws: ?*ws_s, subscription_id: usize) void; pub extern fn websocket_optimize4broadcasts(@"type": isize, enable: c_int) void; pub extern fn fio_publish(args: fio_publish_args_s) void; pub const fio_publish_args_s = struct_fio_publish_args_s; pub const struct_fio_publish_args_s = extern struct { engine: ?*anyopaque = null, // we don't support engines other than default // engine: [*c]const fio_pubsub_engine_s, filter: i32 = 0, channel: fio_str_info_s, message: fio_str_info_s, is_json: u8, }; pub const http_sse_s = struct_http_sse_s; pub const struct_http_sse_s = extern struct { on_open: ?*const fn ([*c]http_sse_s) callconv(.C) void, on_ready: ?*const fn ([*c]http_sse_s) callconv(.C) void, on_shutdown: ?*const fn ([*c]http_sse_s) callconv(.C) void, on_close: ?*const fn ([*c]http_sse_s) callconv(.C) void, udata: ?*anyopaque, }; pub extern fn http_upgrade2sse(h: [*c]http_s, http_sse_s) c_int; pub extern fn http_sse_set_timout(sse: [*c]http_sse_s, timeout: u8) void; pub const fio_match_fn = ?*const fn (fio_str_info_s, fio_str_info_s) callconv(.C) c_int; pub const struct_http_sse_subscribe_args = extern struct { channel: fio_str_info_s, on_message: ?*const fn ([*c]http_sse_s, fio_str_info_s, fio_str_info_s, ?*anyopaque) callconv(.C) void, on_unsubscribe: ?*const fn (?*anyopaque) callconv(.C) void, udata: ?*anyopaque, match: fio_match_fn, }; pub extern fn http_sse_subscribe(sse: [*c]http_sse_s, args: struct_http_sse_subscribe_args) usize; pub extern fn http_sse_unsubscribe(sse: [*c]http_sse_s, subscription: usize) void; pub const struct_http_sse_write_args = extern struct { id: fio_str_info_s, event: fio_str_info_s, data: fio_str_info_s, retry: isize, }; pub extern fn http_sse_write(sse: [*c]http_sse_s, struct_http_sse_write_args) c_int; pub extern fn http_sse2uuid(sse: [*c]http_sse_s) isize; pub extern fn http_sse_close(sse: [*c]http_sse_s) c_int; pub extern fn http_sse_dup(sse: [*c]http_sse_s) [*c]http_sse_s; pub extern fn http_sse_free(sse: [*c]http_sse_s) void; pub extern fn http_parse_body(h: [*c]http_s) c_int; pub extern fn http_parse_query(h: [*c]http_s) void; pub extern fn http_parse_cookies(h: [*c]http_s, is_url_encoded: u8) void; pub extern fn http_add2hash(dest: FIOBJ, name: [*c]u8, name_len: usize, value: [*c]u8, value_len: usize, encoded: u8) c_int; pub extern fn http_add2hash2(dest: FIOBJ, name: [*c]u8, name_len: usize, value: FIOBJ, encoded: u8) c_int; pub extern fn http_status2str(status: usize) fio_str_info_s; pub extern fn http_mimetype_register(file_ext: [*c]u8, file_ext_len: usize, mime_type_str: FIOBJ) void; pub extern fn http_mimetype_find(file_ext: [*c]u8, file_ext_len: usize) FIOBJ; pub extern fn http_mimetype_find2(url: FIOBJ) FIOBJ; pub extern fn http_mimetype_clear() void; pub extern var HTTP_HEADER_ACCEPT: FIOBJ; pub extern var HTTP_HEADER_CACHE_CONTROL: FIOBJ; pub extern var HTTP_HEADER_CONNECTION: FIOBJ; pub extern var HTTP_HEADER_CONTENT_ENCODING: FIOBJ; pub extern var HTTP_HEADER_CONTENT_LENGTH: FIOBJ; pub extern var HTTP_HEADER_CONTENT_RANGE: FIOBJ; pub extern var HTTP_HEADER_CONTENT_TYPE: FIOBJ; pub extern var HTTP_HEADER_COOKIE: FIOBJ; pub extern var HTTP_HEADER_DATE: FIOBJ; pub extern var HTTP_HEADER_ETAG: FIOBJ; pub extern var HTTP_HEADER_HOST: FIOBJ; pub extern var HTTP_HEADER_LAST_MODIFIED: FIOBJ; pub extern var HTTP_HEADER_ORIGIN: FIOBJ; pub extern var HTTP_HEADER_SET_COOKIE: FIOBJ; pub extern var HTTP_HEADER_UPGRADE: FIOBJ; pub extern fn http_req2str(h: [*c]http_s) FIOBJ; pub extern fn http_write_log(h: [*c]http_s) void; pub extern fn http_gmtime(timer: time_t, tmbuf: [*c]struct_tm) [*c]struct_tm; pub extern fn http_date2rfc7231(target: [*c]u8, tmbuf: [*c]struct_tm) usize; pub extern fn http_date2rfc2109(target: [*c]u8, tmbuf: [*c]struct_tm) usize; pub extern fn http_date2rfc2822(target: [*c]u8, tmbuf: [*c]struct_tm) usize; pub fn http_date2str(arg_target: [*c]u8, arg_tmbuf: [*c]struct_tm) callconv(.C) usize { var target = arg_target; var tmbuf = arg_tmbuf; return http_date2rfc7231(target, tmbuf); } pub extern fn http_time2str(target: [*c]u8, t: time_t) usize; pub extern fn http_decode_url_unsafe(dest: [*c]u8, url_data: [*c]const u8) isize; pub extern fn http_decode_url(dest: [*c]u8, url_data: [*c]const u8, length: usize) isize; pub extern fn http_decode_path_unsafe(dest: [*c]u8, url_data: [*c]const u8) isize; pub extern fn http_decode_path(dest: [*c]u8, url_data: [*c]const u8, length: usize) isize; pub const http_url_s = fio_url_s; pub const struct_tm = extern struct { tm_sec: c_int, tm_min: c_int, tm_hour: c_int, tm_mday: c_int, tm_mon: c_int, tm_year: c_int, tm_wday: c_int, tm_yday: c_int, tm_isdst: c_int, tm_gmtoff: c_long, tm_zone: [*c]const u8, };