| // generated by diplomat-tool |
| import { DataError } from "./DataError.mjs" |
| import { DataProvider } from "./DataProvider.mjs" |
| import { GraphemeClusterBreakIteratorUtf16 } from "./GraphemeClusterBreakIteratorUtf16.mjs" |
| import wasm from "./diplomat-wasm.mjs"; |
| import * as diplomatRuntime from "./diplomat-runtime.mjs"; |
| |
| |
| /** An ICU4X grapheme-cluster-break segmenter, capable of finding grapheme cluster breakpoints |
| *in strings. |
| * |
| *See the [Rust documentation for `GraphemeClusterSegmenter`](https://docs.rs/icu/latest/icu/segmenter/struct.GraphemeClusterSegmenter.html) for more information. |
| */ |
| const GraphemeClusterSegmenter_box_destroy_registry = new FinalizationRegistry((ptr) => { |
| wasm.icu4x_GraphemeClusterSegmenter_destroy_mv1(ptr); |
| }); |
| |
| export class GraphemeClusterSegmenter { |
| |
| // Internal ptr reference: |
| #ptr = null; |
| |
| // Lifetimes are only to keep dependencies alive. |
| // Since JS won't garbage collect until there are no incoming edges. |
| #selfEdge = []; |
| |
| #internalConstructor(symbol, ptr, selfEdge) { |
| if (symbol !== diplomatRuntime.internalConstructor) { |
| console.error("GraphemeClusterSegmenter is an Opaque type. You cannot call its constructor."); |
| return; |
| } |
| |
| this.#ptr = ptr; |
| this.#selfEdge = selfEdge; |
| |
| // Are we being borrowed? If not, we can register. |
| if (this.#selfEdge.length === 0) { |
| GraphemeClusterSegmenter_box_destroy_registry.register(this, this.#ptr); |
| } |
| |
| return this; |
| } |
| get ffiValue() { |
| return this.#ptr; |
| } |
| |
| #defaultConstructor() { |
| const result = wasm.icu4x_GraphemeClusterSegmenter_create_mv1(); |
| |
| try { |
| return new GraphemeClusterSegmenter(diplomatRuntime.internalConstructor, result, []); |
| } |
| |
| finally {} |
| } |
| |
| static createWithProvider(provider) { |
| const diplomatReceive = new diplomatRuntime.DiplomatReceiveBuf(wasm, 5, 4, true); |
| |
| const result = wasm.icu4x_GraphemeClusterSegmenter_create_with_provider_mv1(diplomatReceive.buffer, provider.ffiValue); |
| |
| try { |
| if (!diplomatReceive.resultFlag) { |
| const cause = new DataError(diplomatRuntime.internalConstructor, diplomatRuntime.enumDiscriminant(wasm, diplomatReceive.buffer)); |
| throw new globalThis.Error('DataError: ' + cause.value, { cause }); |
| } |
| return new GraphemeClusterSegmenter(diplomatRuntime.internalConstructor, diplomatRuntime.ptrRead(wasm, diplomatReceive.buffer), []); |
| } |
| |
| finally { |
| diplomatReceive.free(); |
| } |
| } |
| |
| segment(input) { |
| let functionGarbageCollectorGrip = new diplomatRuntime.GarbageCollectorGrip(); |
| const inputSlice = functionGarbageCollectorGrip.alloc(diplomatRuntime.DiplomatBuf.str16(wasm, input)); |
| |
| // This lifetime edge depends on lifetimes 'a |
| let aEdges = [this, inputSlice]; |
| |
| const result = wasm.icu4x_GraphemeClusterSegmenter_segment_utf16_mv1(this.ffiValue, ...inputSlice.splat()); |
| |
| try { |
| return new GraphemeClusterBreakIteratorUtf16(diplomatRuntime.internalConstructor, result, [], aEdges); |
| } |
| |
| finally { |
| functionGarbageCollectorGrip.releaseToGarbageCollector(); |
| } |
| } |
| |
| constructor() { |
| if (arguments[0] === diplomatRuntime.exposeConstructor) { |
| return this.#internalConstructor(...Array.prototype.slice.call(arguments, 1)); |
| } else if (arguments[0] === diplomatRuntime.internalConstructor) { |
| return this.#internalConstructor(...arguments); |
| } else { |
| return this.#defaultConstructor(...arguments); |
| } |
| } |
| } |