summaryrefslogtreecommitdiffstats
path: root/intl/icu_capi/js/package/lib/ICU4XIanaToBcp47Mapper.js
diff options
context:
space:
mode:
Diffstat (limited to 'intl/icu_capi/js/package/lib/ICU4XIanaToBcp47Mapper.js')
-rw-r--r--intl/icu_capi/js/package/lib/ICU4XIanaToBcp47Mapper.js35
1 files changed, 35 insertions, 0 deletions
diff --git a/intl/icu_capi/js/package/lib/ICU4XIanaToBcp47Mapper.js b/intl/icu_capi/js/package/lib/ICU4XIanaToBcp47Mapper.js
new file mode 100644
index 0000000000..ee2c931898
--- /dev/null
+++ b/intl/icu_capi/js/package/lib/ICU4XIanaToBcp47Mapper.js
@@ -0,0 +1,35 @@
+import wasm from "./diplomat-wasm.mjs"
+import * as diplomatRuntime from "./diplomat-runtime.js"
+import { ICU4XError_js_to_rust, ICU4XError_rust_to_js } from "./ICU4XError.js"
+
+const ICU4XIanaToBcp47Mapper_box_destroy_registry = new FinalizationRegistry(underlying => {
+ wasm.ICU4XIanaToBcp47Mapper_destroy(underlying);
+});
+
+export class ICU4XIanaToBcp47Mapper {
+ #lifetimeEdges = [];
+ constructor(underlying, owned, edges) {
+ this.underlying = underlying;
+ this.#lifetimeEdges.push(...edges);
+ if (owned) {
+ ICU4XIanaToBcp47Mapper_box_destroy_registry.register(this, underlying);
+ }
+ }
+
+ static create(arg_provider) {
+ return (() => {
+ const diplomat_receive_buffer = wasm.diplomat_alloc(5, 4);
+ wasm.ICU4XIanaToBcp47Mapper_create(diplomat_receive_buffer, arg_provider.underlying);
+ const is_ok = diplomatRuntime.resultFlag(wasm, diplomat_receive_buffer, 4);
+ if (is_ok) {
+ const ok_value = new ICU4XIanaToBcp47Mapper(diplomatRuntime.ptrRead(wasm, diplomat_receive_buffer), true, []);
+ wasm.diplomat_free(diplomat_receive_buffer, 5, 4);
+ return ok_value;
+ } else {
+ const throw_value = ICU4XError_rust_to_js[diplomatRuntime.enumDiscriminant(wasm, diplomat_receive_buffer)];
+ wasm.diplomat_free(diplomat_receive_buffer, 5, 4);
+ throw new diplomatRuntime.FFIError(throw_value);
+ }
+ })();
+ }
+}