diff options
Diffstat (limited to 'vendor/js-sys/src')
-rw-r--r-- | vendor/js-sys/src/lib.rs | 232 |
1 files changed, 231 insertions, 1 deletions
diff --git a/vendor/js-sys/src/lib.rs b/vendor/js-sys/src/lib.rs index 12fef1cb7..92890a62b 100644 --- a/vendor/js-sys/src/lib.rs +++ b/vendor/js-sys/src/lib.rs @@ -29,7 +29,6 @@ use std::str; use std::str::FromStr; use wasm_bindgen::prelude::*; -use wasm_bindgen::JsCast; // When adding new imports: // @@ -448,6 +447,19 @@ extern "C" { #[wasm_bindgen(method, getter, structural)] pub fn length(this: &Array) -> u32; + /// Sets the length of the array. + /// + /// If it is set to less than the current length of the array, it will + /// shrink the array. + /// + /// If it is set to more than the current length of the array, it will + /// increase the length of the array, filling the new space with empty + /// slots. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/length) + #[wasm_bindgen(method, setter)] + pub fn set_length(this: &Array, value: u32); + /// `map()` calls a provided callback function once for each element in an array, /// in order, and constructs a new array from the results. callback is invoked /// only for indexes of the array which have assigned values, including undefined. @@ -823,20 +835,47 @@ pub mod Atomics { /// This atomic operation guarantees that no other write happens /// until the modified value is written back. /// + /// You should use `add_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/add) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn add(typed_array: &JsValue, index: u32, value: i32) -> Result<i32, JsValue>; + /// The static `Atomics.add()` method adds a given value at a given + /// position in the array and returns the old value at that position. + /// This atomic operation guarantees that no other write happens + /// until the modified value is written back. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/add) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = add)] + pub fn add_bigint(typed_array: &JsValue, index: u32, value: i64) -> Result<i64, JsValue>; + /// The static `Atomics.and()` method computes a bitwise AND with a given /// value at a given position in the array, and returns the old value /// at that position. /// This atomic operation guarantees that no other write happens /// until the modified value is written back. /// + /// You should use `and_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/and) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn and(typed_array: &JsValue, index: u32, value: i32) -> Result<i32, JsValue>; + /// The static `Atomics.and()` method computes a bitwise AND with a given + /// value at a given position in the array, and returns the old value + /// at that position. + /// This atomic operation guarantees that no other write happens + /// until the modified value is written back. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/and) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = and)] + pub fn and_bigint(typed_array: &JsValue, index: u32, value: i64) -> Result<i64, JsValue>; + /// The static `Atomics.compareExchange()` method exchanges a given /// replacement value at a given position in the array, if a given expected /// value equals the old value. It returns the old value at that position @@ -844,6 +883,8 @@ pub mod Atomics { /// This atomic operation guarantees that no other write happens /// until the modified value is written back. /// + /// You should use `compare_exchange_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/compareExchange) #[wasm_bindgen(js_namespace = Atomics, catch, js_name = compareExchange)] pub fn compare_exchange( @@ -853,15 +894,50 @@ pub mod Atomics { replacement_value: i32, ) -> Result<i32, JsValue>; + /// The static `Atomics.compareExchange()` method exchanges a given + /// replacement value at a given position in the array, if a given expected + /// value equals the old value. It returns the old value at that position + /// whether it was equal to the expected value or not. + /// This atomic operation guarantees that no other write happens + /// until the modified value is written back. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/compareExchange) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = compareExchange)] + pub fn compare_exchange_bigint( + typed_array: &JsValue, + index: u32, + expected_value: i64, + replacement_value: i64, + ) -> Result<i64, JsValue>; + /// The static `Atomics.exchange()` method stores a given value at a given /// position in the array and returns the old value at that position. /// This atomic operation guarantees that no other write happens /// until the modified value is written back. /// + /// You should use `exchange_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/exchange) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn exchange(typed_array: &JsValue, index: u32, value: i32) -> Result<i32, JsValue>; + /// The static `Atomics.exchange()` method stores a given value at a given + /// position in the array and returns the old value at that position. + /// This atomic operation guarantees that no other write happens + /// until the modified value is written back. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/exchange) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = exchange)] + pub fn exchange_bigint( + typed_array: &JsValue, + index: u32, + value: i64, + ) -> Result<i64, JsValue>; + /// The static `Atomics.isLockFree()` method is used to determine /// whether to use locks or atomic operations. It returns true, /// if the given size is one of the `BYTES_PER_ELEMENT` property @@ -874,10 +950,21 @@ pub mod Atomics { /// The static `Atomics.load()` method returns a value at a given /// position in the array. /// + /// You should use `load_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/load) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn load(typed_array: &JsValue, index: u32) -> Result<i32, JsValue>; + /// The static `Atomics.load()` method returns a value at a given + /// position in the array. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/load) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = load)] + pub fn load_bigint(typed_array: &JsValue, index: i64) -> Result<i64, JsValue>; + /// The static `Atomics.notify()` method notifies up some agents that /// are sleeping in the wait queue. /// Note: This operation works with a shared `Int32Array` only. @@ -900,26 +987,63 @@ pub mod Atomics { /// This atomic operation guarantees that no other write happens /// until the modified value is written back. /// + /// You should use `or_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/or) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn or(typed_array: &JsValue, index: u32, value: i32) -> Result<i32, JsValue>; + /// The static `Atomics.or()` method computes a bitwise OR with a given value + /// at a given position in the array, and returns the old value at that position. + /// This atomic operation guarantees that no other write happens + /// until the modified value is written back. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/or) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = or)] + pub fn or_bigint(typed_array: &JsValue, index: u32, value: i64) -> Result<i64, JsValue>; + /// The static `Atomics.store()` method stores a given value at the given /// position in the array and returns that value. /// + /// You should use `store_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/store) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn store(typed_array: &JsValue, index: u32, value: i32) -> Result<i32, JsValue>; + /// The static `Atomics.store()` method stores a given value at the given + /// position in the array and returns that value. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/store) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = store)] + pub fn store_bigint(typed_array: &JsValue, index: u32, value: i64) -> Result<i64, JsValue>; + /// The static `Atomics.sub()` method substracts a given value at a /// given position in the array and returns the old value at that position. /// This atomic operation guarantees that no other write happens /// until the modified value is written back. /// + /// You should use `sub_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/sub) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn sub(typed_array: &JsValue, index: u32, value: i32) -> Result<i32, JsValue>; + /// The static `Atomics.sub()` method substracts a given value at a + /// given position in the array and returns the old value at that position. + /// This atomic operation guarantees that no other write happens + /// until the modified value is written back. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/sub) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = sub)] + pub fn sub_bigint(typed_array: &JsValue, index: u32, value: i64) -> Result<i64, JsValue>; + /// The static `Atomics.wait()` method verifies that a given /// position in an `Int32Array` still contains a given value /// and if so sleeps, awaiting a wakeup or a timeout. @@ -927,12 +1051,33 @@ pub mod Atomics { /// Note: This operation only works with a shared `Int32Array` /// and may not be allowed on the main thread. /// + /// You should use `wait_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/wait) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn wait(typed_array: &Int32Array, index: u32, value: i32) -> Result<JsString, JsValue>; + /// The static `Atomics.wait()` method verifies that a given + /// position in an `Int32Array` still contains a given value + /// and if so sleeps, awaiting a wakeup or a timeout. + /// It returns a string which is either "ok", "not-equal", or "timed-out". + /// Note: This operation only works with a shared `Int32Array` + /// and may not be allowed on the main thread. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/wait) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = wait)] + pub fn wait_bigint( + typed_array: &Int32Array, + index: u32, + value: i64, + ) -> Result<JsString, JsValue>; + /// Like `wait()`, but with timeout /// + /// You should use `wait_with_timeout_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/wait) #[wasm_bindgen(js_namespace = Atomics, catch, js_name = wait)] pub fn wait_with_timeout( @@ -942,15 +1087,42 @@ pub mod Atomics { timeout: f64, ) -> Result<JsString, JsValue>; + /// Like `wait()`, but with timeout + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/wait) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = wait)] + pub fn wait_with_timeout_bigint( + typed_array: &Int32Array, + index: u32, + value: i64, + timeout: f64, + ) -> Result<JsString, JsValue>; + /// The static `Atomics.xor()` method computes a bitwise XOR /// with a given value at a given position in the array, /// and returns the old value at that position. /// This atomic operation guarantees that no other write happens /// until the modified value is written back. /// + /// You should use `xor_bigint` to operate on a `BigInt64Array` or a `BigUint64Array`. + /// /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/xor) #[wasm_bindgen(js_namespace = Atomics, catch)] pub fn xor(typed_array: &JsValue, index: u32, value: i32) -> Result<i32, JsValue>; + + /// The static `Atomics.xor()` method computes a bitwise XOR + /// with a given value at a given position in the array, + /// and returns the old value at that position. + /// This atomic operation guarantees that no other write happens + /// until the modified value is written back. + /// + /// This method is used to operate on a `BigInt64Array` or a `BigUint64Array`. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/xor) + #[wasm_bindgen(js_namespace = Atomics, catch, js_name = xor)] + pub fn xor_bigint(typed_array: &JsValue, index: u32, value: i64) -> Result<i64, JsValue>; } } @@ -5368,6 +5540,64 @@ pub mod Intl { ) } } + + // Intl.RelativeTimeFormat + #[wasm_bindgen] + extern "C" { + /// The `Intl.RelativeTimeFormat` object is a constructor for objects + /// that enable language-sensitive relative time formatting. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat) + #[wasm_bindgen(extends = Object, js_namespace = Intl, typescript_type = "Intl.RelativeTimeFormat")] + #[derive(Clone, Debug)] + pub type RelativeTimeFormat; + + /// The `Intl.RelativeTimeFormat` object is a constructor for objects + /// that enable language-sensitive relative time formatting. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat) + #[wasm_bindgen(constructor, js_namespace = Intl)] + pub fn new(locales: &Array, options: &Object) -> RelativeTimeFormat; + + /// The `Intl.RelativeTimeFormat.prototype.format` method formats a `value` and `unit` + /// according to the locale and formatting options of this Intl.RelativeTimeFormat object. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/format) + #[wasm_bindgen(method, js_class = "Intl.RelativeTimeFormat")] + pub fn format(this: &RelativeTimeFormat, value: f64, unit: &str) -> JsString; + + /// The `Intl.RelativeTimeFormat.prototype.formatToParts()` method returns an array of + /// objects representing the relative time format in parts that can be used for custom locale-aware formatting. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/formatToParts) + #[wasm_bindgen(method, js_class = "Intl.RelativeTimeFormat", js_name = formatToParts)] + pub fn format_to_parts(this: &RelativeTimeFormat, value: f64, unit: &str) -> Array; + + /// The `Intl.RelativeTimeFormat.prototype.resolvedOptions()` method returns a new + /// object with properties reflecting the locale and relative time formatting + /// options computed during initialization of this RelativeTimeFormat object. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/resolvedOptions) + #[wasm_bindgen(method, js_namespace = Intl, js_name = resolvedOptions)] + pub fn resolved_options(this: &RelativeTimeFormat) -> Object; + + /// The `Intl.RelativeTimeFormat.supportedLocalesOf()` method returns an array + /// containing those of the provided locales that are supported in date and time + /// formatting without having to fall back to the runtime's default locale. + /// + /// [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RelativeTimeFormat/supportedLocalesOf) + #[wasm_bindgen(static_method_of = RelativeTimeFormat, js_namespace = Intl, js_name = supportedLocalesOf)] + pub fn supported_locales_of(locales: &Array, options: &Object) -> Array; + } + + impl Default for RelativeTimeFormat { + fn default() -> Self { + Self::new( + &JsValue::UNDEFINED.unchecked_into(), + &JsValue::UNDEFINED.unchecked_into(), + ) + } + } } // Promise |