import { viewSource, dlopen, CString, ptr, toBuffer, toArrayBuffer, FFIType, callback, } from "bun:ffi"; import { bench, group, run } from "mitata"; const types = { returns_true: { returns: "bool", args: [], }, returns_false: { returns: "bool", args: [], }, returns_42_char: { returns: "char", args: [], }, returns_42_float: { returns: "float", args: [], }, returns_42_double: { returns: "double", args: [], }, returns_42_uint8_t: { returns: "uint8_t", args: [], }, returns_neg_42_int8_t: { returns: "int8_t", args: [], }, returns_42_uint16_t: { returns: "uint16_t", args: [], }, returns_42_uint32_t: { returns: "uint32_t", args: [], }, // // returns_42_uint64_t: { // // returns: "uint64_t", // // args: [], // // }, returns_neg_42_int16_t: { returns: "int16_t", args: [], }, returns_neg_42_int32_t: { returns: "int32_t", args: [], }, // returns_neg_42_int64_t: { // returns: "int64_t", // args: [], // }, identity_char: { returns: "char", args: ["char"], }, identity_float: { returns: "float", args: ["float"], }, identity_bool: { returns: "bool", args: ["bool"], }, identity_double: { returns: "double", args: ["double"], }, identity_int8_t: { returns: "int8_t", args: ["int8_t"], }, identity_int16_t: { returns: "int16_t", args: ["int16_t"], }, identity_int32_t: { returns: "int32_t", args: ["int32_t"], }, // identity_int64_t: { // returns: "int64_t", // args: ["int64_t"], // }, identity_uint8_t: { returns: "uint8_t", args: ["uint8_t"], }, identity_uint16_t: { returns: "uint16_t", args: ["uint16_t"], }, identity_uint32_t: { returns: "uint32_t", args: ["uint32_t"], }, // identity_uint64_t: { // returns: "uint64_t", // args: ["uint64_t"], // }, add_char: { returns: "char", args: ["char", "char"], }, add_float: { returns: "float", args: ["float", "float"], }, add_double: { returns: "double", args: ["double", "double"], }, add_int8_t: { returns: "int8_t", args: ["int8_t", "int8_t"], }, add_int16_t: { returns: "int16_t", args: ["int16_t", "int16_t"], }, add_int32_t: { returns: "int32_t", args: ["int32_t", "int32_t"], }, // add_int64_t: { // returns: "int64_t", // args: ["int64_t", "int64_t"], // }, add_uint8_t: { returns: "uint8_t", args: ["uint8_t", "uint8_t"], }, add_uint16_t: { returns: "uint16_t", args: ["uint16_t", "uint16_t"], }, add_uint32_t: { returns: "uint32_t", args: ["uint32_t", "uint32_t"], }, does_pointer_equal_42_as_int32_t: { returns: "bool", args: ["ptr"], }, ptr_should_point_to_42_as_int32_t: { returns: "ptr", args: [], }, identity_ptr: { returns: "ptr", args: ["ptr"], }, // add_uint64_t: { // returns: "uint64_t", // args: ["uint64_t", "uint64_t"], // }, cb_identity_true: { returns: "bool", args: ["ptr"], }, cb_identity_false: { returns: "bool", args: ["ptr"], }, cb_identity_42_char: { returns: "char", args: ["ptr"], }, // cb_identity_42_float: { // returns: "float", // args: ["ptr"], // }, // cb_identity_42_double: { // returns: "double", // args: ["ptr"], // }, cb_identity_42_uint8_t: { returns: "uint8_t", args: ["ptr"], }, cb_identity_neg_42_int8_t: { returns: "int8_t", args: ["ptr"], }, cb_identity_42_uint16_t: { returns: "uint16_t", args: ["ptr"], }, cb_identity_42_uint32_t: { returns: "uint32_t", args: ["ptr"], }, // cb_identity_42_uint64_t: { // returns: "uint64_t", // args: ["ptr"], // }, cb_identity_neg_42_int16_t: { returns: "int16_t", args: ["ptr"], }, cb_identity_neg_42_int32_t: { returns: "int32_t", args: ["ptr"], }, // cb_identity_neg_42_int64_t: { // returns: "int64_t", // args: ["ptr"], // }, return_a_function_ptr_to_function_that_returns_true: { returns: "ptr", args: [], }, }; var opened; try { opened = dlopen("/tmp/bun-ffi-test.dylib", types); } catch (e) { throw new Error( "Please run `make compile-ffi-test` to compile the ffi test library" ); } const { symbols: { returns_true, returns_false, return_a_function_ptr_to_function_that_returns_true, returns_42_char, returns_42_float, returns_42_double, returns_42_uint8_t, returns_neg_42_int8_t, returns_42_uint16_t, returns_42_uint32_t, returns_42_uint64_t, returns_neg_42_int16_t, returns_neg_42_int32_t, returns_neg_42_int64_t, identity_char, identity_float, identity_bool, identity_double, identity_int8_t, identity_int16_t, identity_int32_t, identity_int64_t, identity_uint8_t, identity_uint16_t, identity_uint32_t, identity_uint64_t, add_char, add_float, add_double, add_int8_t, add_int16_t, add_int32_t, add_int64_t, add_uint8_t, add_uint16_t, identity_ptr, add_uint32_t, add_uint64_t, does_pointer_equal_42_as_int32_t, ptr_should_point_to_42_as_int32_t, cb_identity_true, cb_identity_false, cb_identity_42_char, cb_identity_42_float, cb_identity_42_double, cb_identity_42_uint8_t, cb_identity_neg_42_int8_t, cb_identity_42_uint16_t, cb_identity_42_uint32_t, cb_identity_42_uint64_t, cb_identity_neg_42_int16_t, cb_identity_neg_42_int32_t, cb_identity_neg_42_int64_t, }, close, } = opened; group("add_int16_t", () => { bench("add_int16_t (raw)", () => raw_add_int16_t(1, 1)); bench("add_int16_t", () => add_int16_t(1, 1)); }); group("add_char", () => { bench("add_char (raw)", () => raw_add_char(1, 1)); bench("add_char", () => add_char(1, 1)); }); group("add_int16_t", () => { bench("add_int16_t (raw)", () => raw_add_int16_t(1, 1)); bench("add_int16_t", () => add_int16_t(1, 1)); }); group("add_int32_t", () => { bench("add_int32_t (raw)", () => raw_add_int32_t(1, 1)); bench("add_int32_t", () => add_int32_t(1, 1)); }); group("add_int8_t", () => { bench("add_int8_t (raw)", () => raw_add_int8_t(1, 1)); bench("add_int8_t", () => add_int8_t(1, 1)); }); group("add_uint16_t", () => { bench("add_uint16_t (raw)", () => raw_add_uint16_t(1, 1)); bench("add_uint16_t", () => add_uint16_t(1, 1)); }); group("add_uint32_t", () => { bench("add_uint32_t (raw)", () => raw_add_uint32_t(1, 1)); bench("add_uint32_t", () => add_uint32_t(1, 1)); }); group("add_uint8_t", () => { bench("add_uint8_t (raw)", () => raw_add_uint8_t(1, 1)); bench("add_uint8_t", () => add_uint8_t(1, 1)); }); group("identity_bool", () => { bench("identity_bool (raw)", () => raw_identity_bool(false)); bench("identity_bool", () => identity_bool(true)); }); group("identity_char", () => { bench("identity_char (raw)", () => raw_identity_char(10)); bench("identity_char", () => identity_char(10)); }); group("identity_int16_t", () => { bench("identity_int16_t (raw)", () => raw_identity_int16_t(10)); bench("identity_int16_t", () => identity_int16_t(10)); }); group("identity_int32_t", () => { bench("identity_int32_t (raw)", () => raw_identity_int32_t(10)); bench("identity_int32_t", () => identity_int32_t(10)); }); group("identity_int8_t", () => { bench("identity_int8_t (raw)", () => raw_identity_int8_t(10)); bench("identity_int8_t", () => identity_int8_t(10)); }); group("identity_uint16_t", () => { bench("identity_uint16_t (raw)", () => raw_identity_uint16_t(10)); bench("identity_uint16_t", () => identity_uint16_t(10)); }); group("identity_uint32_t", () => { bench("identity_uint32_t (raw)", () => raw_identity_uint32_t(10)); bench("identity_uint32_t", () => identity_uint32_t(10)); }); group("identity_uint8_t", () => { bench("identity_uint8_t (raw)", () => raw_identity_uint8_t(10)); bench("identity_uint8_t", () => identity_uint8_t(10)); }); group("returns_42_char", () => { bench("returns_42_char (raw)", () => raw_returns_42_char()); bench("returns_42_char", () => returns_42_char()); }); group("returns_42_uint16_t", () => { bench("returns_42_uint16_t (raw)", () => raw_returns_42_uint16_t()); bench("returns_42_uint16_t", () => returns_42_uint16_t()); }); group("returns_42_uint32_t", () => { bench("returns_42_uint32_t (raw)", () => raw_returns_42_uint32_t()); bench("returns_42_uint32_t", () => returns_42_uint32_t()); }); group("returns_42_uint8_t", () => { bench("returns_42_uint8_t (raw)", () => raw_returns_42_uint8_t()); bench("returns_42_uint8_t", () => returns_42_uint8_t()); }); group("returns_false", () => { bench("returns_false (raw)", () => raw_returns_false()); bench("returns_false", () => returns_false()); }); group("returns_neg_42_int16_t", () => { bench("returns_neg_42_int16_t (raw)", () => raw_returns_neg_42_int16_t()); bench("returns_neg_42_int16_t", () => returns_neg_42_int16_t()); }); group("returns_neg_42_int32_t", () => { bench("returns_neg_42_int32_t (raw)", () => raw_returns_neg_42_int32_t()); bench("returns_neg_42_int32_t", () => returns_neg_42_int32_t()); }); group("returns_neg_42_int8_t", () => { bench("returns_neg_42_int8_t (raw)", () => raw_returns_neg_42_int8_t()); bench("returns_neg_42_int8_t", () => returns_neg_42_int8_t()); }); group("returns_true", () => { bench("returns_true (raw)", () => raw_returns_true()); bench("returns_true", () => returns_true()); }); group("return_a_function_ptr_to_function_that_returns_true", () => { bench("return_a_function_ptr_to_function_that_returns_true (raw)", () => raw_return_a_function_ptr_to_function_that_returns_true() ); bench("return_a_function_ptr_to_function_that_returns_true", () => return_a_function_ptr_to_function_that_returns_true() ); }); group("returns_42_float", () => { bench("returns_42_float (raw)", () => raw_returns_42_float()); bench("returns_42_float", () => returns_42_float()); }); group("returns_42_double", () => { bench("returns_42_double (raw)", () => raw_returns_42_double(42)); bench("returns_42_double", () => returns_42_double()); }); group("identity_float", () => { bench("identity_float (raw)", () => raw_identity_float(42.42)); bench("identity_float", () => identity_float()); }); group("identity_double", () => { bench("identity_double (raw)", () => raw_identity_double(42.42)); bench("identity_double", () => identity_double()); }); var raw_return_a_function_ptr_to_function_that_returns_true = return_a_function_ptr_to_function_that_returns_true.native ?? return_a_function_ptr_to_function_that_returns_true; var raw_returns_42_float = returns_42_float.native ?? returns_42_float; var raw_returns_42_double = returns_42_double.native ?? returns_42_double; var raw_identity_float = identity_float.native ?? identity_float; var raw_identity_double = identity_double.native ?? identity_double; var raw_returns_true = returns_true.native ?? returns_true; var raw_returns_false = returns_false.native ?? returns_false; var raw_returns_42_char = returns_42_char.native ?? returns_42_char; var raw_returns_42_uint8_t = returns_42_uint8_t.native ?? returns_42_uint8_t; var raw_returns_neg_42_int8_t = returns_neg_42_int8_t.native ?? returns_neg_42_int8_t; var raw_returns_42_uint16_t = returns_42_uint16_t.native ?? returns_42_uint16_t; var raw_returns_42_uint32_t = returns_42_uint32_t.native ?? returns_42_uint32_t; var raw_returns_neg_42_int16_t = returns_neg_42_int16_t.native ?? returns_neg_42_int16_t; var raw_returns_neg_42_int32_t = returns_neg_42_int32_t.native ?? returns_neg_42_int32_t; var raw_identity_char = identity_char.native ?? identity_char; var raw_identity_bool = identity_bool.native ?? identity_bool; var raw_identity_bool = identity_bool.native ?? identity_bool; var raw_identity_int8_t = identity_int8_t.native ?? identity_int8_t; var raw_identity_int16_t = identity_int16_t.native ?? identity_int16_t; var raw_identity_int32_t = identity_int32_t.native ?? identity_int32_t; var raw_identity_uint8_t = identity_uint8_t.native ?? identity_uint8_t; var raw_identity_uint16_t = identity_uint16_t.native ?? identity_uint16_t; var raw_identity_uint32_t = identity_uint32_t.native ?? identity_uint32_t; var raw_add_char = add_char.native ?? add_char; var raw_add_int8_t = add_int8_t.native ?? add_int8_t; var raw_add_int16_t = add_int16_t.native ?? add_int16_t; var raw_add_int32_t = add_int32_t.native ?? add_int32_t; var raw_add_uint8_t = add_uint8_t.native ?? add_uint8_t; var raw_add_uint16_t = add_uint16_t.native ?? add_uint16_t; var raw_add_uint32_t = add_uint32_t.native ?? add_uint32_t; run({ collect: false, percentiles: true }); -call Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/packages/integrations (unfollow)
AgeCommit message (Collapse)AuthorFilesLines
2022-12-12[ci] release (#5561)astro@1.6.15@astrojs/vue@1.2.2@astrojs/node@3.1.1@astrojs/mdx@0.12.2Gravatar Fred K. Bot 8-6/+29
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2022-12-12Fix link in MDX integration README (#5586)Gravatar Chris Swithinbank 2-1/+6
2022-12-10Updated magic-string to 0.27.0 (#5577)Gravatar Martin J 3-3/+15
2022-12-10Update deno integration dependencies (#5573)Gravatar Lino Le Van 2-2/+2
* Update deno integration dependencies * Update dependency in docs
2022-12-10[ci] formatGravatar matthewp 2-8/+8
2022-12-10Include base in 'page' stage injected scripts (#5572)Gravatar Matthew Phillips 4-9/+32
* Include base in 'page' stage injected scripts * Add changeset
2022-12-09Add primevue as an external Vue package (#5571)Gravatar Matthew Phillips 2-1/+6
2022-12-09[docs] MDX README update (#5570)Gravatar Sarah Rainsberger 2-401/+65
Co-authored-by: Chris Swithinbank <swithinbank@gmail.com>
2022-12-08[ci] formatGravatar natemoo-re 1-1/+3
2022-12-08Node: better serverEntrypoint error (#5560)Gravatar Nate Moore 2-4/+13
* fix(node): better entrypoint error * fix(node): surface start errors during preview Co-authored-by: Nate Moore <nate@astro.build>
2022-12-08Update compiler (#5554)Gravatar Nate Moore 3-5/+10
* chore: update compiler * chore: add changeset Co-authored-by: Nate Moore <nate@astro.build>
2022-12-08docs: How to access base config in the app (#5482)Gravatar Alvin Bryan 1-0/+2
2022-12-08Improve README install guide (#5479)Gravatar Nyx Iskandar 1-2/+5
* Improve README install guide * Fix punctuations
2022-12-08[ci] release (#5544)astro@1.6.14@astrojs/rss@1.1.0@astrojs/netlify@1.2.2@astrojs/deno@2.0.1@astrojs/cloudflare@4.1.1Gravatar Fred K. Bot 48-121/+121
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2022-12-08[ci] formatGravatar matthewp 2-2/+4
2022-12-08fix: Error reporting fails on undefined error index (#5539)Gravatar wulinsheng123 2-1/+6
* fix: Error reporting fails on undefined error index * fix: add changeset * Update .changeset/slow-cherries-bake.md Co-authored-by: Nate Moore <natemoo-re@users.noreply.github.com>
2022-12-08astro-rss: Generate feed with proper XML escaping (#5550)Gravatar Anders Kaseorg 5-36/+57
* test(astro-rss): Compare XML using chai-xml Signed-off-by: Anders Kaseorg <andersk@mit.edu> * fix(astro-rss): Generate feed with proper XML escaping Signed-off-by: Anders Kaseorg <andersk@mit.edu> Signed-off-by: Anders Kaseorg <andersk@mit.edu>
2022-12-08Fix Astro.params not having values when using base in SSR (#5553)Gravatar Matthew Phillips 6-4/+66
* Fix Astro.params not having values when using base in SSR * Adding a changeseet
2022-12-07Allow all redirection status codes in redirect() (#5446)Gravatar Jeffrey Yasskin 2-1/+6
See https://developer.mozilla.org/en-US/docs/Web/HTTP/Status#redirection_messages for the list.
2022-12-06feat(astro-rss): generate post content in feed (#5366)Gravatar Ben Smith 4-1/+46
2022-12-06[ci] formatGravatar matthewp 2-7/+6
2022-12-06Use accumulated sort order when order production CSS (#5549)Gravatar Matthew Phillips 15-2/+180
* Use accumulated sort order when order production CSS * Adding a changeset * Fix lockfile issue
2022-12-06[ci] formatGravatar matthewp 22-158/+171
2022-12-06Head propagation (#5511)Gravatar Matthew Phillips 36-279/+804
* Head propagation * Adding a changeset * Fix broken build * Self review stuff * Use compiler prerelease exact version * new compiler version * Update packages/astro/src/vite-plugin-head-propagation/index.ts Co-authored-by: Bjorn Lu <bjornlu.dev@gmail.com> * Use getAstroMetadata * add .js * make relative lookup work on win * Use compiler@0.30.0 * PR review comments * Make renderHead an alias for a better named function Co-authored-by: Bjorn Lu <bjornlu.dev@gmail.com>
2022-12-06[ci] formatGravatar matthewp 1-7/+7
2022-12-06Removed premature optimization (#5548)Gravatar Ido S 2-37/+35
2022-12-06Exclude astro from Vite optimization (#5545)Gravatar Bjorn Lu 2-1/+6
2022-12-06bench workflow - use bash as shell (#5546)Gravatar Matthew Phillips 1-2/+4
2022-12-06bench workflow - pipe stderr (#5543)Gravatar Matthew Phillips 1-2/+4
2022-12-06Update esbuild dependency (#5534)Gravatar Bjorn Lu 7-18/+275
2022-12-06Fix tests with node 18 (#5528)Gravatar Bjorn Lu 1-9/+14