From 81bf0141bf9f53b07facf4d0c470bd6a6c55addb Mon Sep 17 00:00:00 2001 From: Brendan Dahl Date: Tue, 13 Feb 2024 15:11:02 -0600 Subject: [PATCH] embind - Disable wasm2js when emitting types. (#21333) Fixes #21315 --- test/other/embind_tsgen_ignore_3.d.ts | 112 ++++++++++++++++++++++++++ test/test_other.py | 4 + tools/link.py | 2 + 3 files changed, 118 insertions(+) create mode 100644 test/other/embind_tsgen_ignore_3.d.ts diff --git a/test/other/embind_tsgen_ignore_3.d.ts b/test/other/embind_tsgen_ignore_3.d.ts new file mode 100644 index 0000000000000..212a1a0bd6bf6 --- /dev/null +++ b/test/other/embind_tsgen_ignore_3.d.ts @@ -0,0 +1,112 @@ +// TypeScript bindings for emscripten-generated code. Automatically generated at compile time. +interface WasmModule { + _main(_0: number, _1: number): number; +} + +export interface Test { + x: number; + readonly y: number; + functionOne(_0: number, _1: number): number; + functionTwo(_0: number, _1: number): number; + functionFour(_0: boolean): number; + functionFive(x: number, y: number): number; + constFn(): number; + longFn(_0: number): number; + functionThree(_0: ArrayBuffer|Uint8Array|Uint8ClampedArray|Int8Array|string): number; + functionSix(str: ArrayBuffer|Uint8Array|Uint8ClampedArray|Int8Array|string): number; + delete(): void; +} + +export interface BarValue { + value: T; +} +export type Bar = BarValue<0>|BarValue<1>|BarValue<2>; + +export interface EmptyEnumValue { + value: T; +} +export type EmptyEnum = never/* Empty Enumerator */; + +export type ValArrIx = [ Bar, Bar, Bar, Bar ]; + +export interface IntVec { + push_back(_0: number): void; + resize(_0: number, _1: number): void; + size(): number; + get(_0: number): number | undefined; + set(_0: number, _1: number): boolean; + delete(): void; +} + +export interface MapIntInt { + keys(): IntVec; + get(_0: number): number | undefined; + set(_0: number, _1: number): void; + size(): number; + delete(): void; +} + +export interface Foo { + process(_0: Test): void; + delete(): void; +} + +export type ValObj = { + foo: Foo, + bar: Bar +}; + +export interface ClassWithConstructor { + fn(_0: number): number; + delete(): void; +} + +export interface ClassWithTwoConstructors { + delete(): void; +} + +export interface ClassWithSmartPtrConstructor { + fn(_0: number): number; + delete(): void; +} + +export interface BaseClass { + fn(_0: number): number; + delete(): void; +} + +export interface DerivedClass extends BaseClass { + fn2(_0: number): number; + delete(): void; +} + +export type ValArr = [ number, number, number ]; + +interface EmbindModule { + Test: {staticFunction(_0: number): number; staticFunctionWithParam(x: number): number; staticProperty: number}; + class_returning_fn(): Test; + class_unique_ptr_returning_fn(): Test; + a_class_instance: Test; + an_enum: Bar; + Bar: {valueOne: BarValue<0>, valueTwo: BarValue<1>, valueThree: BarValue<2>}; + EmptyEnum: {}; + enum_returning_fn(): Bar; + IntVec: {new(): IntVec}; + MapIntInt: {new(): MapIntInt}; + Foo: {}; + ClassWithConstructor: {new(_0: number, _1: ValArr): ClassWithConstructor}; + ClassWithTwoConstructors: {new(): ClassWithTwoConstructors; new(_0: number): ClassWithTwoConstructors}; + ClassWithSmartPtrConstructor: {new(_0: number, _1: ValArr): ClassWithSmartPtrConstructor}; + BaseClass: {}; + DerivedClass: {}; + a_bool: boolean; + an_int: number; + optional_test(_0: Foo | undefined): number | undefined; + global_fn(_0: number, _1: number): number; + smart_ptr_function(_0: ClassWithSmartPtrConstructor): number; + smart_ptr_function_with_params(foo: ClassWithSmartPtrConstructor): number; + function_with_callback_param(_0: (message: string) => void): number; + string_test(_0: ArrayBuffer|Uint8Array|Uint8ClampedArray|Int8Array|string): string; + wstring_test(_0: string): string; +} +export type MainModule = WasmModule & EmbindModule; diff --git a/test/test_other.py b/test/test_other.py index e19204728e84e..65b9a5ce5367d 100644 --- a/test/test_other.py +++ b/test/test_other.py @@ -3143,6 +3143,10 @@ def test_embind_tsgen_ignore(self): '-sEXPORT_ES6=1'] self.emcc(test_file('other/embind_tsgen.cpp'), extra_args) self.assertFileContents(test_file('other/embind_tsgen_ignore_2.d.ts'), read_file('embind_tsgen.d.ts')) + # Also test this separately since it conflicts with other settings. + extra_args = ['-sWASM=0'] + self.emcc(test_file('other/embind_tsgen.cpp'), extra_args) + self.assertFileContents(test_file('other/embind_tsgen_ignore_3.d.ts'), read_file('embind_tsgen.d.ts')) def test_embind_tsgen_test_embind(self): self.run_process([EMXX, test_file('embind/embind_test.cpp'), diff --git a/tools/link.py b/tools/link.py index 3c1292e92f256..7c8be90a73087 100644 --- a/tools/link.py +++ b/tools/link.py @@ -1904,6 +1904,8 @@ def run_embind_gen(wasm_target, js_syms, extra_settings): # Disable proxying and thread pooling so a worker is not automatically created. settings.PROXY_TO_PTHREAD = False settings.PTHREAD_POOL_SIZE = 0 + # Assume wasm support at binding generation time + settings.WASM2JS = 0 # Disable minify since the binaryen pass has not been run yet to change the # import names. settings.MINIFY_WASM_IMPORTED_MODULES = False