#[repr(transparent)]
pub struct Constructor<'js>(_);

Implementations§

source§

impl<'js> Constructor<'js>

source

pub fn new_class<C, F, P>(ctx: Ctx<'js>, f: F) -> Result<Self>where F: IntoJsFunc<'js, P> + 'js, C: JsClass<'js>,

Creates a rust constructor function for a rust class.

Note that this function creates a constructor from a given function, the returned constructor is thus not the same as the one returned from JsClass::constructor.

source

pub fn new_prototype<F, P>( ctx: &Ctx<'js>, prototype: Object<'js>, f: F ) -> Result<Self>where F: IntoJsFunc<'js, P> + 'js,

Create a new rust constructor function with a given prototype.

Usefull if the function does not return a rust class.

source

pub fn construct<A, R>(&self, args: A) -> Result<R>where A: IntoArgs<'js>, R: FromJs<'js>,

Call the constructor as a constructor.

Equivalent to calling any constructor function with the new keyword..

source

pub fn construct_args<R>(&self, args: Args<'js>) -> Result<R>where R: FromJs<'js>,

Call the constructor as a constructor with an Args object.

Equivalent to calling any constructor function with the new keyword..

source§

impl<'js> Constructor<'js>

source

pub fn as_value(&self) -> &Value<'js>

Reference to value

source

pub fn into_value(self) -> Value<'js>

Convert into value

source

pub fn into_inner(self) -> Function<'js>

Returns the underlying super type.

source

pub fn as_inner(&self) -> &Function<'js>

Returns a reference to the underlying super type.

source

pub fn ctx(&self) -> &Ctx<'js>

Returns the Ctx object associated with this value

source

pub fn from_value(value: Value<'js>) -> Result<Self>

Convert from value

Methods from Deref<Target = Function<'js>>§

source

pub fn call<A, R>(&self, args: A) -> Result<R>where A: IntoArgs<'js>, R: FromJs<'js>,

Call the function with given arguments.

source

pub fn call_arg<R>(&self, args: Args<'js>) -> Result<R>where R: FromJs<'js>,

Call the function with given arguments in the form of an Args object.

source

pub fn defer<A>(&self, args: A) -> Result<()>where A: IntoArgs<'js>,

Defer call the function with given arguments.

Calling a function with defer is equivalent to calling a javascript function with setTimeout(func,0).

source

pub fn defer_arg(&self, args: Args<'js>) -> Result<()>

Defer a function call with given arguments.

source

pub fn set_name<S: AsRef<str>>(&self, name: S) -> Result<()>

Set the name property of this function

source

pub fn set_length(&self, len: usize) -> Result<()>

Sets the length property of the function.

source

pub fn is_constructor(&self) -> bool

Returns wether this function is an constructor.

source

pub fn set_constructor(&self, is_constructor: bool)

Set whether this function is a constructor or not.

source

pub fn as_value(&self) -> &Value<'js>

Reference to value

source

pub fn as_inner(&self) -> &Object<'js>

Returns a reference to the underlying super type.

source

pub fn ctx(&self) -> &Ctx<'js>

Returns the Ctx object associated with this value

Methods from Deref<Target = Object<'js>>§

source

pub fn prop<K, V, P>(&self, key: K, prop: V) -> Result<()>where K: IntoAtom<'js>, V: AsProperty<'js, P>,

Available on crate feature properties only.

Define a property of an object

// Define readonly property without value
obj.prop("no_val", ()).unwrap();
// Define readonly property with value
obj.prop("ro_str", "Some const text").unwrap();
// Define readonly property with value and make it to be writable
obj.prop("ro_str2", Property::from("Some const text").writable()).unwrap();
// Define readonly property using getter and make it to be enumerable
obj.prop("ro_str_get", Accessor::from(|| "Some readable text").enumerable()).unwrap();
// Define readonly property using getter and setter
obj.prop("ro_str_get_set",
    Accessor::from(|| "Some text")
        .set(|new_val: String| { /* do something */ })
).unwrap();
source

pub fn get<K: IntoAtom<'js>, V: FromJs<'js>>(&self, k: K) -> Result<V>

Get a new value

source

pub fn contains_key<K>(&self, k: K) -> Result<bool>where K: IntoAtom<'js>,

check wether the object contains a certain key.

source

pub fn set<K: IntoAtom<'js>, V: IntoJs<'js>>( &self, key: K, value: V ) -> Result<()>

Set a member of an object to a certain value

source

pub fn remove<K: IntoAtom<'js>>(&self, key: K) -> Result<()>

Remove a member of an object

source

pub fn is_empty(&self) -> bool

Check the object for empty

source

pub fn len(&self) -> usize

Get the number of properties

source

pub fn keys<K: FromAtom<'js>>(&self) -> ObjectKeysIter<'js, K>

Get own string enumerable property names of an object

source

pub fn own_keys<K: FromAtom<'js>>( &self, filter: Filter ) -> ObjectKeysIter<'js, K>

Get own property names of an object

source

pub fn props<K: FromAtom<'js>, V: FromJs<'js>>(&self) -> ObjectIter<'js, K, V>

Get own string enumerable properties of an object

source

pub fn own_props<K: FromAtom<'js>, V: FromJs<'js>>( &self, filter: Filter ) -> ObjectIter<'js, K, V>

Get own properties of an object

source

pub fn values<K: FromAtom<'js>>(&self) -> ObjectValuesIter<'js, K>

Get own string enumerable property values of an object

source

pub fn own_values<K: FromAtom<'js>>( &self, filter: Filter ) -> ObjectValuesIter<'js, K>

Get own property values of an object

source

pub fn get_prototype(&self) -> Option<Object<'js>>

Get an object prototype

Objects can have no prototype, in this case this function will return null.

source

pub fn set_prototype(&self, proto: Option<&Object<'js>>) -> Result<()>

Set an object prototype

If called with None the function will set the prototype of the object to null.

This function will error if setting the prototype causes a cycle in the prototype chain.

source

pub fn is_instance_of(&self, class: impl AsRef<Value<'js>>) -> bool

Check instance of object

source

pub fn is_array_buffer(&self) -> bool

Returns wether the object is an instance of ArrayBuffer.

source

pub unsafe fn ref_array_buffer(&self) -> &ArrayBuffer<'_>

Interprete as ArrayBuffer

Safety

Yous should be sure that the object actually is the required type.

source

pub fn as_array_buffer(&self) -> Option<&ArrayBuffer<'_>>

Turn the object into an array buffer if the object is an instance of ArrayBUuffer

source

pub fn is_typed_array<T: TypedArrayItem>(&self) -> bool

source

pub unsafe fn ref_typed_array<'a, T: TypedArrayItem>( &'a self ) -> &'a TypedArray<'_, T>

Interprete as TypedArray

Safety

Yous should be sure that the object actually is the required type.

source

pub fn as_typed_array<T: TypedArrayItem>(&self) -> Option<&TypedArray<'_, T>>

source

pub fn as_value(&self) -> &Value<'js>

Reference to value

source

pub fn as_inner(&self) -> &Value<'js>

Returns a reference to the underlying super type.

source

pub fn ctx(&self) -> &Ctx<'js>

Returns the Ctx object associated with this value

source

pub fn instance_of<C: JsClass<'js>>(&self) -> bool

Returns if the object is of a certain rust class.

source

pub fn as_class<C: JsClass<'js>>(&self) -> Option<&Class<'js, C>>

Turn the object into the class if it is an instance of that class.

Methods from Deref<Target = Value<'js>>§

source

pub fn ctx(&self) -> &Ctx<'js>

Returns the Ctx object associated with this value.

source

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

Try get bool from value

source

pub fn as_int(&self) -> Option<i32>

Try get int from value

source

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

Try get float from value

source

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

Try get any number from value

source

pub fn is_null(&self) -> bool

Returns if the value is the JavaScript null value.

source

pub fn is_undefined(&self) -> bool

Returns if the value is the JavaScript undefined value.

source

pub fn is_bool(&self) -> bool

Check if the value is a bool

source

pub fn is_int(&self) -> bool

Check if the value is an int

source

pub fn is_float(&self) -> bool

Check if the value is a float

source

pub fn is_number(&self) -> bool

Check if the value is an any number

source

pub fn is_string(&self) -> bool

Check if the value is a string

source

pub fn is_symbol(&self) -> bool

Check if the value is a symbol

source

pub fn is_object(&self) -> bool

Check if the value is an object

source

pub fn is_module(&self) -> bool

Check if the value is a module

source

pub fn is_array(&self) -> bool

Check if the value is an array

source

pub fn is_function(&self) -> bool

Check if the value is a function

source

pub fn is_constructor(&self) -> bool

Check if the value is a constructor function

source

pub fn is_exception(&self) -> bool

Check if the value is a constructor function

source

pub fn is_error(&self) -> bool

Check if the value is an error

source

pub fn as_value(&self) -> &Self

Reference as value

source

pub fn get<T: FromJs<'js>>(&self) -> Result<T>

Convert from value to specified type

source

pub fn as_raw(&self) -> JSValue

Returns the raw C library javascript value.

source

pub fn type_of(&self) -> Type

Get the type of value

source

pub fn type_name(&self) -> &'static str

Get the name of type

source

pub unsafe fn ref_string(&self) -> &String<'js>

Interprete as String

Safety

You should be sure that the value already is of required type before to do it.

source

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

Try reinterprete as String

source

pub unsafe fn ref_symbol(&self) -> &Symbol<'js>

Interprete as Symbol

Safety

You should be sure that the value already is of required type before to do it.

source

pub fn as_symbol(&self) -> Option<&Symbol<'js>>

Try reinterprete as Symbol

source

pub unsafe fn ref_object(&self) -> &Object<'js>

Interprete as Object

Safety

You should be sure that the value already is of required type before to do it.

source

pub fn as_object(&self) -> Option<&Object<'js>>

Try reinterprete as Object

source

pub unsafe fn ref_function(&self) -> &Function<'js>

Interprete as Function

Safety

You should be sure that the value already is of required type before to do it.

source

pub fn as_function(&self) -> Option<&Function<'js>>

Try reinterprete as Function

source

pub unsafe fn ref_constructor(&self) -> &Constructor<'js>

Interprete as Constructor

Safety

You should be sure that the value already is of required type before to do it.

source

pub fn as_constructor(&self) -> Option<&Constructor<'js>>

Try reinterprete as Constructor

source

pub unsafe fn ref_array(&self) -> &Array<'js>

Interprete as Array

Safety

You should be sure that the value already is of required type before to do it.

source

pub fn as_array(&self) -> Option<&Array<'js>>

Try reinterprete as Array

source

pub unsafe fn ref_exception(&self) -> &Exception<'js>

Interprete as Exception

Safety

You should be sure that the value already is of required type before to do it.

source

pub fn as_exception(&self) -> Option<&Exception<'js>>

Try reinterprete as Exception

source

pub unsafe fn ref_big_int(&self) -> &BigInt<'js>

Interprete as BigInt

Safety

You should be sure that the value already is of required type before to do it.

source

pub fn as_big_int(&self) -> Option<&BigInt<'js>>

Try reinterprete as BigInt

Trait Implementations§

source§

impl<'js> AsRef<Function<'js>> for Constructor<'js>

source§

fn as_ref(&self) -> &Function<'js>

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

impl<'js> AsRef<Value<'js>> for Constructor<'js>

source§

fn as_ref(&self) -> &Value<'js>

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

impl<'js> Clone for Constructor<'js>

source§

fn clone(&self) -> Constructor<'js>

Returns a copy 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<'js> Debug for Constructor<'js>

source§

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

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

impl<'js> Deref for Constructor<'js>

§

type Target = Function<'js>

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl<'js> From<Constructor<'js>> for Value<'js>

source§

fn from(value: Constructor<'js>) -> Self

Converts to this type from the input type.
source§

impl<'js> FromJs<'js> for Constructor<'js>

source§

fn from_js(_: &Ctx<'js>, value: Value<'js>) -> Result<Self>

source§

impl<'js> IntoAtom<'js> for Constructor<'js>

source§

fn into_atom(self, ctx: &Ctx<'js>) -> Result<Atom<'js>>

source§

impl<'js> IntoJs<'js> for Constructor<'js>

source§

fn into_js(self, _ctx: &Ctx<'js>) -> Result<Value<'js>>

source§

impl<'js> Outlive<'js> for Constructor<'js>

§

type Target<'to> = Constructor<'to>

The target which has the same type as a Self but with another lifetime 't

Auto Trait Implementations§

§

impl<'js> RefUnwindSafe for Constructor<'js>

§

impl<'js> !Send for Constructor<'js>

§

impl<'js> !Sync for Constructor<'js>

§

impl<'js> Unpin for Constructor<'js>

§

impl<'js> !UnwindSafe for Constructor<'js>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<'js, T> AsProperty<'js, T> for Twhere T: IntoJs<'js>,

source§

fn config( self, ctx: &Ctx<'js> ) -> Result<(i32, Value<'js>, Value<'js>, Value<'js>), Error>

Available on crate feature properties only.
Property configuration Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<'js, T> FromParam<'js> for Twhere T: FromJs<'js>,

source§

fn param_requirement() -> ParamRequirement

The parameters requirements this value requires.
source§

fn from_param<'a>(params: &mut ParamsAccessor<'a, 'js>) -> Result<T, Error>

Convert from a parameter value.
source§

impl<T, U> Into<U> for Twhere 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<'js, T> IntoArg<'js> for Twhere T: IntoJs<'js>,

source§

fn num_args(&self) -> usize

The number of arguments this value produces.
source§

fn into_arg(self, args: &mut Args<'js>) -> Result<(), Error>

Convert the value into an argument.
source§

impl<T> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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, U> TryInto<U> for Twhere U: TryFrom<T>,

§

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<T> ParallelSend for T