diff options
Diffstat (limited to 'intl/icu_capi/js/package/lib/ICU4XWordBreakIteratorUtf16.js')
-rw-r--r-- | intl/icu_capi/js/package/lib/ICU4XWordBreakIteratorUtf16.js | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/intl/icu_capi/js/package/lib/ICU4XWordBreakIteratorUtf16.js b/intl/icu_capi/js/package/lib/ICU4XWordBreakIteratorUtf16.js new file mode 100644 index 0000000000..7dd16d4ef0 --- /dev/null +++ b/intl/icu_capi/js/package/lib/ICU4XWordBreakIteratorUtf16.js @@ -0,0 +1,30 @@ +import wasm from "./diplomat-wasm.mjs" +import * as diplomatRuntime from "./diplomat-runtime.js" +import { ICU4XSegmenterWordType_js_to_rust, ICU4XSegmenterWordType_rust_to_js } from "./ICU4XSegmenterWordType.js" + +const ICU4XWordBreakIteratorUtf16_box_destroy_registry = new FinalizationRegistry(underlying => { + wasm.ICU4XWordBreakIteratorUtf16_destroy(underlying); +}); + +export class ICU4XWordBreakIteratorUtf16 { + #lifetimeEdges = []; + constructor(underlying, owned, edges) { + this.underlying = underlying; + this.#lifetimeEdges.push(...edges); + if (owned) { + ICU4XWordBreakIteratorUtf16_box_destroy_registry.register(this, underlying); + } + } + + next() { + return wasm.ICU4XWordBreakIteratorUtf16_next(this.underlying); + } + + word_type() { + return ICU4XSegmenterWordType_rust_to_js[wasm.ICU4XWordBreakIteratorUtf16_word_type(this.underlying)]; + } + + is_word_like() { + return wasm.ICU4XWordBreakIteratorUtf16_is_word_like(this.underlying); + } +} |