aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--integration/bunjs-only-snippets/ffi-test.c50
-rw-r--r--src/jsc.zig1
-rw-r--r--tcc.zig30
3 files changed, 81 insertions, 0 deletions
diff --git a/integration/bunjs-only-snippets/ffi-test.c b/integration/bunjs-only-snippets/ffi-test.c
new file mode 100644
index 000000000..249a8ca26
--- /dev/null
+++ b/integration/bunjs-only-snippets/ffi-test.c
@@ -0,0 +1,50 @@
+#include <stdbool.h>
+#include <stdint.h>
+
+char identity_char(char a);
+int8_t identity_int8_t(int8_t a);
+uint8_t identity_uint8_t(uint8_t a);
+int16_t identity_int16_t(int16_t a);
+uint16_t identity_uint16_t(uint16_t a);
+int32_t identity_int32_t(int32_t a);
+uint32_t identity_uint32_t(uint32_t a);
+int64_t identity_int64_t(int64_t a);
+uint64_t identity_uint64_t(uint64_t a);
+double identity_double(double a);
+float identity_float(float a);
+
+char add_char(char a, char b);
+int8_t add_int8_t(int8_t a, int8_t b);
+uint8_t add_uint8_t(uint8_t a, uint8_t b);
+int16_t add_int16_t(int16_t a, int16_t b);
+uint16_t add_uint16_t(uint16_t a, uint16_t b);
+int32_t add_int32_t(int32_t a, int32_t b);
+uint32_t add_uint32_t(uint32_t a, uint32_t b);
+int64_t add_int64_t(int64_t a, int64_t b);
+uint64_t add_uint64_t(uint64_t a, uint64_t b);
+double add_double(double a, double b);
+float add_float(float a, float b);
+
+char identity_char(char a) { return a; }
+int8_t identity_int8_t(int8_t a) { return a; }
+uint8_t identity_uint8_t(uint8_t a) { return a; }
+int16_t identity_int16_t(int16_t a) { return a; }
+uint16_t identity_uint16_t(uint16_t a) { return a; }
+int32_t identity_int32_t(int32_t a) { return a; }
+uint32_t identity_uint32_t(uint32_t a) { return a; }
+int64_t identity_int64_t(int64_t a) { return a; }
+uint64_t identity_uint64_t(uint64_t a) { return a; }
+double identity_double(double a) { return a; }
+float identity_float(float a) { return a; }
+
+char add_char(char a, char b) { return a + b; }
+int8_t add_int8_t(int8_t a, int8_t b) { return a + b; }
+uint8_t add_uint8_t(uint8_t a, uint8_t b) { return a + b; }
+int16_t add_int16_t(int16_t a, int16_t b) { return a + b; }
+uint16_t add_uint16_t(uint16_t a, uint16_t b) { return a + b; }
+int32_t add_int32_t(int32_t a, int32_t b) { return a + b; }
+uint32_t add_uint32_t(uint32_t a, uint32_t b) { return a + b; }
+int64_t add_int64_t(int64_t a, int64_t b) { return a + b; }
+uint64_t add_uint64_t(uint64_t a, uint64_t b) { return a + b; }
+double add_double(double a, double b) { return a + b; }
+float add_float(float a, float b) { return a + b; }
diff --git a/src/jsc.zig b/src/jsc.zig
index 539ed98a3..cd31b206c 100644
--- a/src/jsc.zig
+++ b/src/jsc.zig
@@ -30,6 +30,7 @@ pub const API = struct {
pub const Router = @import("./javascript/jsc/api/router.zig");
pub const ServerConfig = @import("./javascript/jsc/api/server.zig").ServerConfig;
};
+pub const FFI = @import("./javascript/jsc/api/ffi.zig").FFI;
pub const Node = struct {
pub usingnamespace @import("./javascript/jsc/node/types.zig");
pub usingnamespace @import("./javascript/jsc/node/node_fs.zig");
diff --git a/tcc.zig b/tcc.zig
new file mode 100644
index 000000000..67c7f0a3d
--- /dev/null
+++ b/tcc.zig
@@ -0,0 +1,30 @@
+pub const TCCState = opaque {};
+pub const TCCErrorFunc = ?fn (?*anyopaque, [*c]const u8) callconv(.C) void;
+pub extern fn tcc_new() ?*TCCState;
+pub extern fn tcc_delete(s: *TCCState) void;
+pub extern fn tcc_set_lib_path(s: *TCCState, path: [*c]const u8) void;
+pub extern fn tcc_set_error_func(s: *TCCState, error_opaque: ?*anyopaque, error_func: TCCErrorFunc) void;
+pub extern fn tcc_get_error_func(s: *TCCState) TCCErrorFunc;
+pub extern fn tcc_get_error_opaque(s: *TCCState) ?*anyopaque;
+pub extern fn tcc_set_options(s: *TCCState, str: [*c]const u8) void;
+pub extern fn tcc_add_include_path(s: *TCCState, pathname: [*c]const u8) c_int;
+pub extern fn tcc_add_sysinclude_path(s: *TCCState, pathname: [*c]const u8) c_int;
+pub extern fn tcc_define_symbol(s: *TCCState, sym: [*c]const u8, value: [*c]const u8) void;
+pub extern fn tcc_undefine_symbol(s: *TCCState, sym: [*c]const u8) void;
+pub extern fn tcc_add_file(s: *TCCState, filename: [*c]const u8) c_int;
+pub extern fn tcc_compile_string(s: *TCCState, buf: [*c]const u8) c_int;
+pub extern fn tcc_set_output_type(s: *TCCState, output_type: c_int) c_int;
+pub extern fn tcc_add_library_path(s: *TCCState, pathname: [*c]const u8) c_int;
+pub extern fn tcc_add_library(s: *TCCState, libraryname: [*c]const u8) c_int;
+pub extern fn tcc_add_symbol(s: *TCCState, name: [*c]const u8, val: ?*const anyopaque) c_int;
+pub extern fn tcc_output_file(s: *TCCState, filename: [*c]const u8) c_int;
+pub extern fn tcc_run(s: *TCCState, argc: c_int, argv: [*c][*c]u8) c_int;
+pub extern fn tcc_relocate(s1: *TCCState, ptr: ?*anyopaque) c_int;
+pub extern fn tcc_get_symbol(s: *TCCState, name: [*c]const u8) ?*anyopaque;
+pub extern fn tcc_list_symbols(s: *TCCState, ctx: ?*anyopaque, symbol_cb: ?fn (?*anyopaque, [*c]const u8, ?*const anyopaque) callconv(.C) void) void;
+pub const TCC_OUTPUT_MEMORY = @as(c_int, 1);
+pub const TCC_OUTPUT_EXE = @as(c_int, 2);
+pub const TCC_OUTPUT_DLL = @as(c_int, 3);
+pub const TCC_OUTPUT_OBJ = @as(c_int, 4);
+pub const TCC_OUTPUT_PREPROCESS = @as(c_int, 5);
+pub const TCC_RELOCATE_AUTO = @import("std").zig.c_translation.cast(?*anyopaque, @as(c_int, 1));