aboutsummaryrefslogtreecommitdiff
path: root/integration
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--integration/bunjs-only-snippets/ffi.test.fixture.callback.c3
-rw-r--r--integration/bunjs-only-snippets/ffi.test.fixture.receiver.c3
-rw-r--r--integration/bunjs-only-snippets/ffi.test.js41
3 files changed, 27 insertions, 20 deletions
diff --git a/integration/bunjs-only-snippets/ffi.test.fixture.callback.c b/integration/bunjs-only-snippets/ffi.test.fixture.callback.c
index 97932e255..3a557e7d5 100644
--- a/integration/bunjs-only-snippets/ffi.test.fixture.callback.c
+++ b/integration/bunjs-only-snippets/ffi.test.fixture.callback.c
@@ -10,7 +10,6 @@
#ifdef IS_CALLBACK
#define INJECT_BEFORE int c = 500; // This is a callback, so we need to inject code before the call
#endif
-
#define IS_BIG_ENDIAN 0
#define USE_JSVALUE64 1
#define USE_JSVALUE32_64 0
@@ -39,8 +38,6 @@ typedef _Bool bool;
#endif
// #include <tcclib.h>
-
-
// This value is 2^49, used to encode doubles such that the encoded value will
// begin with a 15-bit pattern within the range 0x0002..0xFFFC.
#define DoubleEncodeOffsetBit 49
diff --git a/integration/bunjs-only-snippets/ffi.test.fixture.receiver.c b/integration/bunjs-only-snippets/ffi.test.fixture.receiver.c
index 07d44c3a6..8a75e12f9 100644
--- a/integration/bunjs-only-snippets/ffi.test.fixture.receiver.c
+++ b/integration/bunjs-only-snippets/ffi.test.fixture.receiver.c
@@ -11,7 +11,6 @@
#ifdef IS_CALLBACK
#define INJECT_BEFORE int c = 500; // This is a callback, so we need to inject code before the call
#endif
-
#define IS_BIG_ENDIAN 0
#define USE_JSVALUE64 1
#define USE_JSVALUE32_64 0
@@ -40,8 +39,6 @@ typedef _Bool bool;
#endif
// #include <tcclib.h>
-
-
// This value is 2^49, used to encode doubles such that the encoded value will
// begin with a 15-bit pattern within the range 0x0002..0xFFFC.
#define DoubleEncodeOffsetBit 49
diff --git a/integration/bunjs-only-snippets/ffi.test.js b/integration/bunjs-only-snippets/ffi.test.js
index 258ee93ec..9198df3f7 100644
--- a/integration/bunjs-only-snippets/ffi.test.js
+++ b/integration/bunjs-only-snippets/ffi.test.js
@@ -58,8 +58,10 @@ it("ffi print", async () => {
).toBe(true);
});
-it("ffi run", () => {
- const types = {
+function getTypes(fast) {
+ const int64_t = fast ? "i64_fast" : "int64_t";
+ const uint64_t = fast ? "u64_fast" : "uint64_t";
+ return {
returns_true: {
returns: "bool",
args: [],
@@ -97,7 +99,7 @@ it("ffi run", () => {
args: [],
},
returns_42_uint64_t: {
- returns: "uint64_t",
+ returns: uint64_t,
args: [],
},
returns_neg_42_int16_t: {
@@ -109,7 +111,7 @@ it("ffi run", () => {
args: [],
},
returns_neg_42_int64_t: {
- returns: "int64_t",
+ returns: int64_t,
args: [],
},
@@ -142,8 +144,8 @@ it("ffi run", () => {
args: ["int32_t"],
},
identity_int64_t: {
- returns: "int64_t",
- args: ["int64_t"],
+ returns: int64_t,
+ args: [int64_t],
},
identity_uint8_t: {
returns: "uint8_t",
@@ -158,8 +160,8 @@ it("ffi run", () => {
args: ["uint32_t"],
},
identity_uint64_t: {
- returns: "uint64_t",
- args: ["uint64_t"],
+ returns: uint64_t,
+ args: [uint64_t],
},
add_char: {
@@ -187,8 +189,8 @@ it("ffi run", () => {
args: ["int32_t", "int32_t"],
},
add_int64_t: {
- returns: "int64_t",
- args: ["int64_t", "int64_t"],
+ returns: int64_t,
+ args: [int64_t, int64_t],
},
add_uint8_t: {
returns: "uint8_t",
@@ -217,8 +219,8 @@ it("ffi run", () => {
args: ["ptr"],
},
add_uint64_t: {
- returns: "uint64_t",
- args: ["uint64_t", "uint64_t"],
+ returns: uint64_t,
+ args: [uint64_t, uint64_t],
},
cb_identity_true: {
@@ -258,7 +260,7 @@ it("ffi run", () => {
args: ["ptr"],
},
cb_identity_42_uint64_t: {
- returns: "uint64_t",
+ returns: uint64_t,
args: ["ptr"],
},
cb_identity_neg_42_int16_t: {
@@ -270,7 +272,7 @@ it("ffi run", () => {
args: ["ptr"],
},
cb_identity_neg_42_int64_t: {
- returns: "int64_t",
+ returns: int64_t,
args: ["ptr"],
},
@@ -279,6 +281,9 @@ it("ffi run", () => {
args: [],
},
};
+}
+
+function ffiRunner(types) {
const {
symbols: {
returns_true,
@@ -514,4 +519,12 @@ it("ffi run", () => {
// ).toBe(-42);
close();
+}
+
+it("run ffi fast", () => {
+ ffiRunner(getTypes(true));
+});
+
+it("run ffi", () => {
+ ffiRunner(getTypes(false));
});