diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /intl/icu_capi/js/package/lib/ICU4XIsoDate.js | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'intl/icu_capi/js/package/lib/ICU4XIsoDate.js')
-rw-r--r-- | intl/icu_capi/js/package/lib/ICU4XIsoDate.js | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/intl/icu_capi/js/package/lib/ICU4XIsoDate.js b/intl/icu_capi/js/package/lib/ICU4XIsoDate.js new file mode 100644 index 0000000000..6fcfaf2b09 --- /dev/null +++ b/intl/icu_capi/js/package/lib/ICU4XIsoDate.js @@ -0,0 +1,104 @@ +import wasm from "./diplomat-wasm.mjs" +import * as diplomatRuntime from "./diplomat-runtime.js" +import { ICU4XDate } from "./ICU4XDate.js" +import { ICU4XError_js_to_rust, ICU4XError_rust_to_js } from "./ICU4XError.js" +import { ICU4XIsoWeekday_js_to_rust, ICU4XIsoWeekday_rust_to_js } from "./ICU4XIsoWeekday.js" +import { ICU4XWeekOf } from "./ICU4XWeekOf.js" +import { ICU4XWeekRelativeUnit_js_to_rust, ICU4XWeekRelativeUnit_rust_to_js } from "./ICU4XWeekRelativeUnit.js" + +const ICU4XIsoDate_box_destroy_registry = new FinalizationRegistry(underlying => { + wasm.ICU4XIsoDate_destroy(underlying); +}); + +export class ICU4XIsoDate { + #lifetimeEdges = []; + constructor(underlying, owned, edges) { + this.underlying = underlying; + this.#lifetimeEdges.push(...edges); + if (owned) { + ICU4XIsoDate_box_destroy_registry.register(this, underlying); + } + } + + static create(arg_year, arg_month, arg_day) { + return (() => { + const diplomat_receive_buffer = wasm.diplomat_alloc(5, 4); + wasm.ICU4XIsoDate_create(diplomat_receive_buffer, arg_year, arg_month, arg_day); + const is_ok = diplomatRuntime.resultFlag(wasm, diplomat_receive_buffer, 4); + if (is_ok) { + const ok_value = new ICU4XIsoDate(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); + } + })(); + } + + static create_for_unix_epoch() { + return new ICU4XIsoDate(wasm.ICU4XIsoDate_create_for_unix_epoch(), true, []); + } + + to_calendar(arg_calendar) { + return new ICU4XDate(wasm.ICU4XIsoDate_to_calendar(this.underlying, arg_calendar.underlying), true, []); + } + + to_any() { + return new ICU4XDate(wasm.ICU4XIsoDate_to_any(this.underlying), true, []); + } + + day_of_month() { + return wasm.ICU4XIsoDate_day_of_month(this.underlying); + } + + day_of_week() { + return ICU4XIsoWeekday_rust_to_js[wasm.ICU4XIsoDate_day_of_week(this.underlying)]; + } + + week_of_month(arg_first_weekday) { + return wasm.ICU4XIsoDate_week_of_month(this.underlying, ICU4XIsoWeekday_js_to_rust[arg_first_weekday]); + } + + week_of_year(arg_calculator) { + return (() => { + const diplomat_receive_buffer = wasm.diplomat_alloc(9, 4); + wasm.ICU4XIsoDate_week_of_year(diplomat_receive_buffer, this.underlying, arg_calculator.underlying); + const is_ok = diplomatRuntime.resultFlag(wasm, diplomat_receive_buffer, 8); + if (is_ok) { + const ok_value = new ICU4XWeekOf(diplomat_receive_buffer); + wasm.diplomat_free(diplomat_receive_buffer, 9, 4); + return ok_value; + } else { + const throw_value = ICU4XError_rust_to_js[diplomatRuntime.enumDiscriminant(wasm, diplomat_receive_buffer)]; + wasm.diplomat_free(diplomat_receive_buffer, 9, 4); + throw new diplomatRuntime.FFIError(throw_value); + } + })(); + } + + month() { + return wasm.ICU4XIsoDate_month(this.underlying); + } + + year() { + return wasm.ICU4XIsoDate_year(this.underlying); + } + + is_in_leap_year() { + return wasm.ICU4XIsoDate_is_in_leap_year(this.underlying); + } + + months_in_year() { + return wasm.ICU4XIsoDate_months_in_year(this.underlying); + } + + days_in_month() { + return wasm.ICU4XIsoDate_days_in_month(this.underlying); + } + + days_in_year() { + return wasm.ICU4XIsoDate_days_in_year(this.underlying); + } +} |