Skip to main content

ArrayTuple

Struct ArrayTuple 

Source
pub struct ArrayTuple<T: JsTuple = (JsValue,)> { /* private fields */ }

Implementations§

Source§

impl ArrayTuple

Source

pub fn new1<T1>(t1: &T1) -> ArrayTuple<(T1,)>
where T1: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1,)>: ErasableGenericOwn<ArrayTuple<(JsValue,)>>,

Creates a new JS array typed as a 1-tuple.

Source§

impl ArrayTuple

Source

pub fn new2<T1, T2>(t1: &T1, t2: &T2) -> ArrayTuple<(T1, T2)>
where T1: ErasableGenericBorrow<JsValue>, T2: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1, T2)>: ErasableGenericOwn<ArrayTuple<(JsValue, JsValue)>>,

Creates a new JS array typed as a 2-tuple.

Source§

impl ArrayTuple

Source

pub fn new3<T1, T2, T3>(t1: &T1, t2: &T2, t3: &T3) -> ArrayTuple<(T1, T2, T3)>
where T1: ErasableGenericBorrow<JsValue>, T2: ErasableGenericBorrow<JsValue>, T3: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1, T2, T3)>: ErasableGenericOwn<ArrayTuple<(JsValue, JsValue, JsValue)>>,

Creates a new JS array typed as a 3-tuple.

Source§

impl ArrayTuple

Source

pub fn new4<T1, T2, T3, T4>( t1: &T1, t2: &T2, t3: &T3, t4: &T4, ) -> ArrayTuple<(T1, T2, T3, T4)>
where T1: ErasableGenericBorrow<JsValue>, T2: ErasableGenericBorrow<JsValue>, T3: ErasableGenericBorrow<JsValue>, T4: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1, T2, T3, T4)>: ErasableGenericOwn<ArrayTuple<(JsValue, JsValue, JsValue, JsValue)>>,

Creates a new JS array typed as a 4-tuple.

Source§

impl ArrayTuple

Source

pub fn new5<T1, T2, T3, T4, T5>( t1: &T1, t2: &T2, t3: &T3, t4: &T4, t5: &T5, ) -> ArrayTuple<(T1, T2, T3, T4, T5)>
where T1: ErasableGenericBorrow<JsValue>, T2: ErasableGenericBorrow<JsValue>, T3: ErasableGenericBorrow<JsValue>, T4: ErasableGenericBorrow<JsValue>, T5: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1, T2, T3, T4, T5)>: ErasableGenericOwn<ArrayTuple<(JsValue, JsValue, JsValue, JsValue, JsValue)>>,

Creates a new JS array typed as a 5-tuple.

Source§

impl ArrayTuple

Source

pub fn new6<T1, T2, T3, T4, T5, T6>( t1: &T1, t2: &T2, t3: &T3, t4: &T4, t5: &T5, t6: &T6, ) -> ArrayTuple<(T1, T2, T3, T4, T5, T6)>
where T1: ErasableGenericBorrow<JsValue>, T2: ErasableGenericBorrow<JsValue>, T3: ErasableGenericBorrow<JsValue>, T4: ErasableGenericBorrow<JsValue>, T5: ErasableGenericBorrow<JsValue>, T6: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1, T2, T3, T4, T5, T6)>: ErasableGenericOwn<ArrayTuple<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue)>>,

Creates a new JS array typed as a 6-tuple.

Source§

impl ArrayTuple

Source

pub fn new7<T1, T2, T3, T4, T5, T6, T7>( t1: &T1, t2: &T2, t3: &T3, t4: &T4, t5: &T5, t6: &T6, t7: &T7, ) -> ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>
where T1: ErasableGenericBorrow<JsValue>, T2: ErasableGenericBorrow<JsValue>, T3: ErasableGenericBorrow<JsValue>, T4: ErasableGenericBorrow<JsValue>, T5: ErasableGenericBorrow<JsValue>, T6: ErasableGenericBorrow<JsValue>, T7: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>: ErasableGenericOwn<ArrayTuple<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue)>>,

Creates a new JS array typed as a 7-tuple.

Source§

impl ArrayTuple

Source

pub fn new8<T1, T2, T3, T4, T5, T6, T7, T8>( t1: &T1, t2: &T2, t3: &T3, t4: &T4, t5: &T5, t6: &T6, t7: &T7, t8: &T8, ) -> ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>
where T1: ErasableGenericBorrow<JsValue>, T2: ErasableGenericBorrow<JsValue>, T3: ErasableGenericBorrow<JsValue>, T4: ErasableGenericBorrow<JsValue>, T5: ErasableGenericBorrow<JsValue>, T6: ErasableGenericBorrow<JsValue>, T7: ErasableGenericBorrow<JsValue>, T8: ErasableGenericBorrow<JsValue>, ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>: ErasableGenericOwn<ArrayTuple<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue)>>,

Creates a new JS array typed as a 8-tuple.

Source§

impl<T> ArrayTuple<T>
where T: JsTuple1,

Source

pub fn get0(&self) -> <T as JsTuple1>::T1
where <T as JsTuple1>::T1: ErasableGenericOwn<<(JsValue,) as JsTuple1>::T1>,

Gets the 1st item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple2,

Source

pub fn get1(&self) -> <T as JsTuple2>::T2
where <T as JsTuple2>::T2: ErasableGenericOwn<<(JsValue, JsValue) as JsTuple2>::T2>,

Gets the 2nd item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple3,

Source

pub fn get2(&self) -> <T as JsTuple3>::T3
where <T as JsTuple3>::T3: ErasableGenericOwn<<(JsValue, JsValue, JsValue) as JsTuple3>::T3>,

Gets the 3rd item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple4,

Source

pub fn get3(&self) -> <T as JsTuple4>::T4
where <T as JsTuple4>::T4: ErasableGenericOwn<<(JsValue, JsValue, JsValue, JsValue) as JsTuple4>::T4>,

Gets the 4th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple5,

Source

pub fn get4(&self) -> <T as JsTuple5>::T5
where <T as JsTuple5>::T5: ErasableGenericOwn<<(JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple5>::T5>,

Gets the 5th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple6,

Source

pub fn get5(&self) -> <T as JsTuple6>::T6
where <T as JsTuple6>::T6: ErasableGenericOwn<<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple6>::T6>,

Gets the 6th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple7,

Source

pub fn get6(&self) -> <T as JsTuple7>::T7
where <T as JsTuple7>::T7: ErasableGenericOwn<<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple7>::T7>,

Gets the 7th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple8,

Source

pub fn get7(&self) -> <T as JsTuple8>::T8
where <T as JsTuple8>::T8: ErasableGenericOwn<<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple8>::T8>,

Gets the 8th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple1,

Source

pub fn set0(&self, value: &<T as JsTuple1>::T1)
where <T as JsTuple1>::T1: ErasableGenericBorrow<<(JsValue,) as JsTuple1>::T1>,

Sets the 1st item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple2,

Source

pub fn set1(&self, value: &<T as JsTuple2>::T2)
where <T as JsTuple2>::T2: ErasableGenericBorrow<<(JsValue, JsValue) as JsTuple2>::T2>,

Sets the 2nd item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple3,

Source

pub fn set2(&self, value: &<T as JsTuple3>::T3)
where <T as JsTuple3>::T3: ErasableGenericBorrow<<(JsValue, JsValue, JsValue) as JsTuple3>::T3>,

Sets the 3rd item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple4,

Source

pub fn set3(&self, value: &<T as JsTuple4>::T4)
where <T as JsTuple4>::T4: ErasableGenericBorrow<<(JsValue, JsValue, JsValue, JsValue) as JsTuple4>::T4>,

Sets the 4th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple5,

Source

pub fn set4(&self, value: &<T as JsTuple5>::T5)
where <T as JsTuple5>::T5: ErasableGenericBorrow<<(JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple5>::T5>,

Sets the 5th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple6,

Source

pub fn set5(&self, value: &<T as JsTuple6>::T6)
where <T as JsTuple6>::T6: ErasableGenericBorrow<<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple6>::T6>,

Sets the 6th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple7,

Source

pub fn set6(&self, value: &<T as JsTuple7>::T7)
where <T as JsTuple7>::T7: ErasableGenericBorrow<<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple7>::T7>,

Sets the 7th item

Source§

impl<T> ArrayTuple<T>
where T: JsTuple8,

Source

pub fn set7(&self, value: &<T as JsTuple8>::T8)
where <T as JsTuple8>::T8: ErasableGenericBorrow<<(JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue, JsValue) as JsTuple8>::T8>,

Sets the 8th item

Source§

impl<T: JsTuple> ArrayTuple<T>

Source

pub fn len(&self) -> usize

Get the static arity of the ArrayTuple type.

Source§

impl<T1: JsGeneric> ArrayTuple<(T1,)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T1

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1,)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new(get0: &T1) -> ArrayTuple<(T1,)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Source§

impl<T1: JsGeneric, T2: JsGeneric> ArrayTuple<(T1, T2)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T2

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1, T2)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new(get0: &T1, get1: &T2) -> ArrayTuple<(T1, T2)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric> ArrayTuple<(T1, T2, T3)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T3

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1, T2, T3)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new(get0: &T1, get1: &T2, get2: &T3) -> ArrayTuple<(T1, T2, T3)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric> ArrayTuple<(T1, T2, T3, T4)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T4

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1, T2, T3, T4)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new( get0: &T1, get1: &T2, get2: &T3, get3: &T4, ) -> ArrayTuple<(T1, T2, T3, T4)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric> ArrayTuple<(T1, T2, T3, T4, T5)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T5

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1, T2, T3, T4, T5)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new( get0: &T1, get1: &T2, get2: &T3, get3: &T4, get4: &T5, ) -> ArrayTuple<(T1, T2, T3, T4, T5)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric, T6: JsGeneric> ArrayTuple<(T1, T2, T3, T4, T5, T6)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T6

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1, T2, T3, T4, T5, T6)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new( get0: &T1, get1: &T2, get2: &T3, get3: &T4, get4: &T5, get5: &T6, ) -> ArrayTuple<(T1, T2, T3, T4, T5, T6)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric, T6: JsGeneric, T7: JsGeneric> ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T7

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1, T2, T3, T4, T5, T6, T7)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new( get0: &T1, get1: &T2, get2: &T3, get3: &T4, get4: &T5, get5: &T6, get6: &T7, ) -> ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric, T6: JsGeneric, T7: JsGeneric, T8: JsGeneric> ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>

Source

pub fn first(&self) -> T1

Get the first element of the ArrayTuple

Source

pub fn last(&self) -> T8

Get the last element of the ArrayTuple

Source

pub fn into_parts(self) -> (T1, T2, T3, T4, T5, T6, T7, T8)

Convert the ArrayTuple into its corresponding Rust tuple

Source

pub fn new( get0: &T1, get1: &T2, get2: &T3, get3: &T4, get4: &T5, get5: &T6, get6: &T7, get7: &T8, ) -> ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>

Create a new ArrayTuple from the corresponding parts.

§Example
use js_sys::{ArrayTuple, JsString};

let tuple = ArrayTuple::<JsString, JsString>::new(&"a".into(), &"b".into());

Note: You must specify the T using ::<...> syntax on ArrayTuple. Alternatively, use new1, new2, etc. for type inference from the left-hand side.

Methods from Deref<Target = Object>§

Source

pub fn constructor(&self) -> Function

The constructor property returns a reference to the Object constructor function that created the instance object.

MDN documentation

Source

pub fn has_own_property(&self, property: &JsValue) -> bool

👎Deprecated: Use Object::hasOwn instead.

The hasOwnProperty() method returns a boolean indicating whether the object has the specified property as its own property (as opposed to inheriting it).

MDN documentation

Source

pub fn is_prototype_of(&self, value: &JsValue) -> bool

The isPrototypeOf() method checks if an object exists in another object’s prototype chain.

MDN documentation

Source

pub fn property_is_enumerable(&self, property: &JsValue) -> bool

The propertyIsEnumerable() method returns a Boolean indicating whether the specified property is enumerable.

MDN documentation

Source

pub fn to_locale_string(&self) -> JsString

The toLocaleString() method returns a string representing the object. This method is meant to be overridden by derived objects for locale-specific purposes.

MDN documentation

Source

pub fn to_string(&self) -> JsString

The toString() method returns a string representing the object.

MDN documentation

Source

pub fn to_js_string(&self) -> JsString

The toString() method returns a string representing the object.

MDN documentation

Source

pub fn value_of(&self) -> Object

The valueOf() method returns the primitive value of the specified object.

MDN documentation

Methods from Deref<Target = JsValue>§

Source

pub const NULL: JsValue

Source

pub const UNDEFINED: JsValue

Source

pub const TRUE: JsValue

Source

pub const FALSE: JsValue

Source

pub fn as_f64(&self) -> Option<f64>

Returns the f64 value of this JS value if it’s an instance of a number.

If this JS value is not an instance of a number then this returns None.

Source

pub fn is_string(&self) -> bool

Tests whether this JS value is a JS string.

Source

pub fn as_string(&self) -> Option<String>

If this JS value is a string value, this function copies the JS string value into Wasm linear memory, encoded as UTF-8, and returns it as a Rust String.

To avoid the copying and re-encoding, consider the JsString::try_from() function from js-sys instead.

If this JS value is not an instance of a string or if it’s not valid utf-8 then this returns None.

§UTF-16 vs UTF-8

JavaScript strings in general are encoded as UTF-16, but Rust strings are encoded as UTF-8. This can cause the Rust string to look a bit different than the JS string sometimes. For more details see the documentation about the str type which contains a few caveats about the encodings.

Source

pub fn as_bool(&self) -> Option<bool>

Returns the bool value of this JS value if it’s an instance of a boolean.

If this JS value is not an instance of a boolean then this returns None.

Source

pub fn is_null(&self) -> bool

Tests whether this JS value is null

Source

pub fn is_undefined(&self) -> bool

Tests whether this JS value is undefined

Source

pub fn is_null_or_undefined(&self) -> bool

Tests whether this JS value is null or undefined

Source

pub fn is_symbol(&self) -> bool

Tests whether the type of this JS value is symbol

Source

pub fn is_object(&self) -> bool

Tests whether typeof self == "object" && self !== null.

Source

pub fn is_array(&self) -> bool

Tests whether this JS value is an instance of Array.

Source

pub fn is_function(&self) -> bool

Tests whether the type of this JS value is function.

Source

pub fn is_bigint(&self) -> bool

Tests whether the type of this JS value is bigint.

Source

pub fn js_typeof(&self) -> JsValue

Applies the unary typeof JS operator on a JsValue.

MDN documentation

Source

pub fn js_in(&self, obj: &JsValue) -> bool

Applies the binary in JS operator on the two JsValues.

MDN documentation

Source

pub fn is_truthy(&self) -> bool

Tests whether the value is “truthy”.

Source

pub fn is_falsy(&self) -> bool

Tests whether the value is “falsy”.

Source

pub fn loose_eq(&self, other: &JsValue) -> bool

Compare two JsValues for equality, using the == operator in JS.

MDN documentation

Source

pub fn bit_not(&self) -> JsValue

Applies the unary ~ JS operator on a JsValue.

MDN documentation

Source

pub fn unsigned_shr(&self, rhs: &JsValue) -> u32

Applies the binary >>> JS operator on the two JsValues.

MDN documentation

Source

pub fn checked_div(&self, rhs: &JsValue) -> JsValue

Applies the binary / JS operator on two JsValues, catching and returning any RangeError thrown.

MDN documentation

Source

pub fn pow(&self, rhs: &JsValue) -> JsValue

Applies the binary ** JS operator on the two JsValues.

MDN documentation

Source

pub fn lt(&self, other: &JsValue) -> bool

Applies the binary < JS operator on the two JsValues.

MDN documentation

Source

pub fn le(&self, other: &JsValue) -> bool

Applies the binary <= JS operator on the two JsValues.

MDN documentation

Source

pub fn ge(&self, other: &JsValue) -> bool

Applies the binary >= JS operator on the two JsValues.

MDN documentation

Source

pub fn gt(&self, other: &JsValue) -> bool

Applies the binary > JS operator on the two JsValues.

MDN documentation

Source

pub fn unchecked_into_f64(&self) -> f64

Applies the unary + JS operator on a JsValue. Can throw.

MDN documentation

Trait Implementations§

Source§

impl<T: JsTuple> AsRef<ArrayTuple<T>> for ArrayTuple<T>

Source§

fn as_ref(&self) -> &ArrayTuple<T>

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T: JsTuple> AsRef<JsValue> for ArrayTuple<T>

Source§

fn as_ref(&self) -> &JsValue

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T: JsTuple> AsRef<Object> for ArrayTuple<T>

Source§

fn as_ref(&self) -> &Object

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T: Clone + JsTuple> Clone for ArrayTuple<T>

Source§

fn clone(&self) -> ArrayTuple<T>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: Debug + JsTuple> Debug for ArrayTuple<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T1: JsGeneric + Default> Default for ArrayTuple<(T1,)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T1: JsGeneric + Default, T2: JsGeneric + Default> Default for ArrayTuple<(T1, T2)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T1: JsGeneric + Default, T2: JsGeneric + Default, T3: JsGeneric + Default> Default for ArrayTuple<(T1, T2, T3)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T1: JsGeneric + Default, T2: JsGeneric + Default, T3: JsGeneric + Default, T4: JsGeneric + Default> Default for ArrayTuple<(T1, T2, T3, T4)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T1: JsGeneric + Default, T2: JsGeneric + Default, T3: JsGeneric + Default, T4: JsGeneric + Default, T5: JsGeneric + Default> Default for ArrayTuple<(T1, T2, T3, T4, T5)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T1: JsGeneric + Default, T2: JsGeneric + Default, T3: JsGeneric + Default, T4: JsGeneric + Default, T5: JsGeneric + Default, T6: JsGeneric + Default> Default for ArrayTuple<(T1, T2, T3, T4, T5, T6)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T1: JsGeneric + Default, T2: JsGeneric + Default, T3: JsGeneric + Default, T4: JsGeneric + Default, T5: JsGeneric + Default, T6: JsGeneric + Default, T7: JsGeneric + Default> Default for ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T1: JsGeneric + Default, T2: JsGeneric + Default, T3: JsGeneric + Default, T4: JsGeneric + Default, T5: JsGeneric + Default, T6: JsGeneric + Default, T7: JsGeneric + Default, T8: JsGeneric + Default> Default for ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<T: JsTuple> Deref for ArrayTuple<T>

Source§

type Target = Object

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Object

Dereferences the value.
Source§

impl<T: JsTuple> ErasableGeneric for ArrayTuple<T>

Source§

type Repr = JsValue

The singular concrete type that all generic variants can be transmuted on
Source§

impl<T1: JsGeneric> From<(T1,)> for ArrayTuple<(T1,)>

Source§

fn from((get0): (T1,)) -> Self

Converts to this type from the input type.
Source§

impl<T1: JsGeneric, T2: JsGeneric> From<(T1, T2)> for ArrayTuple<(T1, T2)>

Source§

fn from((get0, get1): (T1, T2)) -> Self

Converts to this type from the input type.
Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric> From<(T1, T2, T3)> for ArrayTuple<(T1, T2, T3)>

Source§

fn from((get0, get1, get2): (T1, T2, T3)) -> Self

Converts to this type from the input type.
Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric> From<(T1, T2, T3, T4)> for ArrayTuple<(T1, T2, T3, T4)>

Source§

fn from((get0, get1, get2, get3): (T1, T2, T3, T4)) -> Self

Converts to this type from the input type.
Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric> From<(T1, T2, T3, T4, T5)> for ArrayTuple<(T1, T2, T3, T4, T5)>

Source§

fn from((get0, get1, get2, get3, get4): (T1, T2, T3, T4, T5)) -> Self

Converts to this type from the input type.
Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric, T6: JsGeneric> From<(T1, T2, T3, T4, T5, T6)> for ArrayTuple<(T1, T2, T3, T4, T5, T6)>

Source§

fn from((get0, get1, get2, get3, get4, get5): (T1, T2, T3, T4, T5, T6)) -> Self

Converts to this type from the input type.
Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric, T6: JsGeneric, T7: JsGeneric> From<(T1, T2, T3, T4, T5, T6, T7)> for ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>

Source§

fn from( (get0, get1, get2, get3, get4, get5, get6): (T1, T2, T3, T4, T5, T6, T7), ) -> Self

Converts to this type from the input type.
Source§

impl<T1: JsGeneric, T2: JsGeneric, T3: JsGeneric, T4: JsGeneric, T5: JsGeneric, T6: JsGeneric, T7: JsGeneric, T8: JsGeneric> From<(T1, T2, T3, T4, T5, T6, T7, T8)> for ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>

Source§

fn from( (get0, get1, get2, get3, get4, get5, get6, get7): (T1, T2, T3, T4, T5, T6, T7, T8), ) -> Self

Converts to this type from the input type.
Source§

impl<T: JsTuple> From<ArrayTuple<T>> for JsValue

Source§

fn from(obj: ArrayTuple<T>) -> JsValue

Converts to this type from the input type.
Source§

impl<T: JsTuple> From<ArrayTuple<T>> for Object

Source§

fn from(obj: ArrayTuple<T>) -> Object

Converts to this type from the input type.
Source§

impl From<JsValue> for ArrayTuple

Source§

fn from(obj: JsValue) -> Self

Converts to this type from the input type.
Source§

impl<T: JsTuple> FromWasmAbi for ArrayTuple<T>

Source§

type Abi = <JsValue as FromWasmAbi>::Abi

The Wasm ABI type that this converts from when coming back out from the ABI boundary.
Source§

unsafe fn from_abi(js: Self::Abi) -> Self

Recover a Self from Self::Abi. Read more
Source§

impl<'a, T: JsTuple> IntoWasmAbi for &'a ArrayTuple<T>

Source§

type Abi = <&'a JsValue as IntoWasmAbi>::Abi

The Wasm ABI type that this converts into when crossing the ABI boundary.
Source§

fn into_abi(self) -> Self::Abi

Convert self into Self::Abi so that it can be sent across the wasm ABI boundary.
Source§

impl<T: JsTuple> IntoWasmAbi for ArrayTuple<T>

Source§

type Abi = <JsValue as IntoWasmAbi>::Abi

The Wasm ABI type that this converts into when crossing the ABI boundary.
Source§

fn into_abi(self) -> Self::Abi

Convert self into Self::Abi so that it can be sent across the wasm ABI boundary.
Source§

impl<T: JsTuple> Iterable for ArrayTuple<T>

Source§

type Item = JsValue

The type of values yielded by this iterable.
Source§

impl<T: JsTuple> JsCast for ArrayTuple<T>

Source§

fn instanceof(val: &JsValue) -> bool

Performs a dynamic instanceof check to see whether the JsValue provided is an instance of this type. Read more
Source§

fn is_type_of(val: &JsValue) -> bool

Performs a dynamic check to see whether the JsValue provided is a value of this type. Read more
Source§

fn unchecked_from_js(val: JsValue) -> Self

Performs a zero-cost unchecked conversion from a JsValue into an instance of Self Read more
Source§

fn unchecked_from_js_ref(val: &JsValue) -> &Self

Performs a zero-cost unchecked conversion from a &JsValue into an instance of &Self. Read more
Source§

fn has_type<T>(&self) -> bool
where T: JsCast,

Test whether this JS value has a type T. Read more
Source§

fn dyn_into<T>(self) -> Result<T, Self>
where T: JsCast,

Performs a dynamic cast (checked at runtime) of this value into the target type T. Read more
Source§

fn dyn_ref<T>(&self) -> Option<&T>
where T: JsCast,

Performs a dynamic cast (checked at runtime) of this value into the target type T. Read more
Source§

fn unchecked_into<T>(self) -> T
where T: JsCast,

Performs a zero-cost unchecked cast into the specified type. Read more
Source§

fn unchecked_ref<T>(&self) -> &T
where T: JsCast,

Performs a zero-cost unchecked cast into a reference to the specified type. Read more
Source§

fn is_instance_of<T>(&self) -> bool
where T: JsCast,

Test whether this JS value is an instance of the type T. Read more
Source§

impl<T: JsTuple> LongRefFromWasmAbi for ArrayTuple<T>

Source§

type Abi = <JsValue as LongRefFromWasmAbi>::Abi

Same as RefFromWasmAbi::Abi
Source§

type Anchor = ArrayTuple<T>

Same as RefFromWasmAbi::Anchor
Source§

unsafe fn long_ref_from_abi(js: Self::Abi) -> Self::Anchor

Same as RefFromWasmAbi::ref_from_abi
Source§

impl<T: JsTuple> OptionFromWasmAbi for ArrayTuple<T>

Source§

fn is_none(abi: &Self::Abi) -> bool

Tests whether the argument is a “none” instance. If so it will be deserialized as None, and otherwise it will be passed to FromWasmAbi.
Source§

impl<'a, T: JsTuple> OptionIntoWasmAbi for &'a ArrayTuple<T>

Source§

fn none() -> Self::Abi

Returns an ABI instance indicating “none”, which JS will interpret as the None branch of this option. Read more
Source§

impl<T: JsTuple> OptionIntoWasmAbi for ArrayTuple<T>

Source§

fn none() -> Self::Abi

Returns an ABI instance indicating “none”, which JS will interpret as the None branch of this option. Read more
Source§

impl<T: JsTuple> Promising for ArrayTuple<T>

Source§

type Resolution = ArrayTuple<T>

The type that this value resolves to.
Source§

impl<T: JsTuple> RefFromWasmAbi for ArrayTuple<T>

Source§

type Abi = <JsValue as RefFromWasmAbi>::Abi

The Wasm ABI type references to Self are recovered from.
Source§

type Anchor = ManuallyDrop<ArrayTuple<T>>

The type that holds the reference to Self for the duration of the invocation of the function that has an &Self parameter. This is required to ensure that the lifetimes don’t persist beyond one function call, and so that they remain anonymous.
Source§

unsafe fn ref_from_abi(js: Self::Abi) -> Self::Anchor

Recover a Self::Anchor from Self::Abi. Read more
Source§

impl<T: JsTuple> WasmDescribe for ArrayTuple<T>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>,)>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>, JsOption<T>)>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>, JsOption<T>, JsOption<T>)>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>)>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>)>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>)>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>)>

Source§

impl<T: JsGeneric> UpcastFrom<Array<T>> for ArrayTuple<(JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>, JsOption<T>)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T,)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T, T)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T, T, T)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T, T, T, T)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T, T, T, T, T)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T, T, T, T, T, T)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T, T, T, T, T, T, T)>

Source§

impl<T> UpcastFrom<Array<T>> for ArrayTuple<(T, T, T, T, T, T, T, T)>

Source§

impl<T1, Target> UpcastFrom<ArrayTuple<(T1,)>> for Array<Target>
where Target: UpcastFrom<T1>,

Source§

impl<T1, Target> UpcastFrom<ArrayTuple<(T1,)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1>,

Source§

impl<T1, T2, Target> UpcastFrom<ArrayTuple<(T1, T2)>> for Array<Target>
where Target: UpcastFrom<T1> + UpcastFrom<T2>,

Source§

impl<T1, T2, Target> UpcastFrom<ArrayTuple<(T1, T2)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1> + UpcastFrom<T2>,

Source§

impl<T1, T2, T3, Target> UpcastFrom<ArrayTuple<(T1, T2, T3)>> for Array<Target>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3>,

Source§

impl<T1, T2, T3, Target> UpcastFrom<ArrayTuple<(T1, T2, T3)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3>,

Source§

impl<T1, T2, T3, T4, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4)>> for Array<Target>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4>,

Source§

impl<T1, T2, T3, T4, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4>,

Source§

impl<T1, T2, T3, T4, T5, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5)>> for Array<Target>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5>,

Source§

impl<T1, T2, T3, T4, T5, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5>,

Source§

impl<T1, T2, T3, T4, T5, T6, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5, T6)>> for Array<Target>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5> + UpcastFrom<T6>,

Source§

impl<T1, T2, T3, T4, T5, T6, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5, T6)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5> + UpcastFrom<T6>,

Source§

impl<T1, T2, T3, T4, T5, T6, T7, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>> for Array<Target>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5> + UpcastFrom<T6> + UpcastFrom<T7>,

Source§

impl<T1, T2, T3, T4, T5, T6, T7, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5, T6, T7)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5> + UpcastFrom<T6> + UpcastFrom<T7>,

Source§

impl<T1, T2, T3, T4, T5, T6, T7, T8, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>> for Array<Target>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5> + UpcastFrom<T6> + UpcastFrom<T7> + UpcastFrom<T8>,

Source§

impl<T1, T2, T3, T4, T5, T6, T7, T8, Target> UpcastFrom<ArrayTuple<(T1, T2, T3, T4, T5, T6, T7, T8)>> for JsOption<Array<Target>>
where Target: UpcastFrom<T1> + UpcastFrom<T2> + UpcastFrom<T3> + UpcastFrom<T4> + UpcastFrom<T5> + UpcastFrom<T6> + UpcastFrom<T7> + UpcastFrom<T8>,

Source§

impl<T: JsTuple, U> UpcastFrom<ArrayTuple<T>> for ArrayTuple<U>
where U: UpcastFrom<T> + JsTuple,

Source§

impl<T: JsTuple> UpcastFrom<ArrayTuple<T>> for JsOption<JsValue>

Source§

impl<T: JsTuple> UpcastFrom<ArrayTuple<T>> for JsValue

Auto Trait Implementations§

§

impl<T> Freeze for ArrayTuple<T>

§

impl<T> RefUnwindSafe for ArrayTuple<T>
where T: RefUnwindSafe,

§

impl<T> Send for ArrayTuple<T>
where T: Send,

§

impl<T> Sync for ArrayTuple<T>
where T: Sync,

§

impl<T> Unpin for ArrayTuple<T>
where T: Unpin,

§

impl<T> UnsafeUnpin for ArrayTuple<T>

§

impl<T> UnwindSafe for ArrayTuple<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> ReturnWasmAbi for T
where T: IntoWasmAbi,

Source§

type Abi = <T as IntoWasmAbi>::Abi

Same as IntoWasmAbi::Abi
Source§

fn return_abi(self) -> <T as ReturnWasmAbi>::Abi

Same as IntoWasmAbi::into_abi, except that it may throw and never return in the case of Err.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T> TryFromJsValue for T
where T: JsCast,

Source§

fn try_from_js_value(val: JsValue) -> Result<T, JsValue>

Performs the conversion.
Source§

fn try_from_js_value_ref(val: &JsValue) -> Option<T>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<S, T> Upcast<T> for S
where T: UpcastFrom<S> + ?Sized, S: ?Sized,

Source§

fn upcast(&self) -> &T
where Self: ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider ref type within the Wasm bindgen generics type system. Read more
Source§

fn upcast_into(self) -> T
where Self: Sized + ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider type within the Wasm bindgen generics type system. Read more
Source§

impl<T> VectorFromWasmAbi for T
where T: ErasableGeneric<Repr = JsValue> + WasmDescribe,

Source§

impl<T> VectorIntoWasmAbi for T
where T: ErasableGeneric<Repr = JsValue> + WasmDescribe,

Source§

impl<T> JsGeneric for T
where T: ErasableGeneric<Repr = JsValue> + UpcastFrom<T> + Upcast<JsValue> + 'static,