Object

Struct Object 

Source
pub struct Object<'o> {
    obj: Local<'o, *mut JSObject>,
}
Expand description

Represents an Object in the JS Runtime.

Refer to MDN for more details.

Fields§

§obj: Local<'o, *mut JSObject>

Implementations§

Source§

impl<'o> Object<'o>

Source

pub fn new(cx: &'o Context) -> Object<'o>

Creates a plain empty Object.

Source

pub fn null(cx: &'o Context) -> Object<'o>

Creates a null “Object”.

Most operations on this will result in an error, so be wary of where it is used.

Source

pub fn global(cx: &'o Context) -> Object<'o>

Returns the current global object or null if one has not been initialised yet.

Source

pub fn has<'cx, K: ToPropertyKey<'cx>>(&self, cx: &'cx Context, key: K) -> bool

Checks if the Object has a value at the given key.

Source

pub fn has_own<'cx, K: ToPropertyKey<'cx>>( &self, cx: &'cx Context, key: K, ) -> bool

Checks if the Object has its own value at the given key.

An object owns its properties if they are not inherited from a prototype.

Source

pub fn get<'cx, K: ToPropertyKey<'cx>>( &self, cx: &'cx Context, key: K, ) -> Result<Option<Value<'cx>>>

Gets the Value at the given key of the Object.

Returns None if there is no value at the given key.

Source

pub fn get_as<'cx, K: ToPropertyKey<'cx>, T: FromValue<'cx>>( &self, cx: &'cx Context, key: K, strict: bool, config: T::Config, ) -> Result<Option<T>>

Gets the value at the given key of the Object. as a Rust type. Returns None if the object does not contain the key or conversion to the Rust type fails.

Source

pub fn get_descriptor<'cx, K: ToPropertyKey<'cx>>( &self, cx: &'cx Context, key: K, ) -> Result<Option<PropertyDescriptor<'cx>>>

Gets the descriptor at the given key of the Object. Returns None if the object does not contain the key.

Source

pub fn set<'cx, K: ToPropertyKey<'cx>>( &self, cx: &'cx Context, key: K, value: &Value<'_>, ) -> bool

Sets the Value at the given key of the Object.

Returns false if the property cannot be set.

Source

pub fn set_as<'cx, K: ToPropertyKey<'cx>, T: ToValue<'cx> + ?Sized>( &self, cx: &'cx Context, key: K, value: &T, ) -> bool

Sets the Rust type at the given key of the Object.

Returns false if the property cannot be set.

Source

pub fn define<'cx, K: ToPropertyKey<'cx>>( &self, cx: &'cx Context, key: K, value: &Value<'_>, attrs: PropertyFlags, ) -> bool

Defines the Value at the given key of the Object with the given attributes.

Returns false if the property cannot be defined.

Source

pub fn define_as<'cx, K: ToPropertyKey<'cx>, T: ToValue<'cx> + ?Sized>( &self, cx: &'cx Context, key: K, value: &T, attrs: PropertyFlags, ) -> bool

Defines the Rust type at the given key of the Object with the given attributes.

Returns false if the property cannot be defined.

Source

pub fn define_method<'cx, K: ToPropertyKey<'cx>>( &self, cx: &'cx Context, key: K, method: NativeFunction, nargs: u32, attrs: PropertyFlags, ) -> Function<'cx>

Defines a method with the given name, and the given number of arguments and attributes on the Object.

Parameters are similar to create_function_spec.

Source

pub unsafe fn define_methods( &self, cx: &Context, methods: &[JSFunctionSpec], ) -> bool

Defines methods on the objects using the given specs.

The final element of the methods slice must be JSFunctionSpec::ZERO. They can be created through function_spec.

Source

pub unsafe fn define_methods_with_help( &self, cx: &Context, methods: &[JSFunctionSpecWithHelp], ) -> bool

Defines methods on the objects using the given specs, with help.

The final element of the methods slice must be JSFunctionSpecWithHelp::ZERO.

Source

pub unsafe fn define_properties( &self, cx: &Context, properties: &[JSPropertySpec], ) -> bool

Defines properties on the object using the given specs.

The final element of the properties slice must be JSPropertySpec::ZERO.

Source

pub fn delete<'cx, K: ToPropertyKey<'cx>>( &self, cx: &'cx Context, key: K, ) -> bool

Deletes the Value at the given index.

Returns false if the element cannot be deleted.

Source

pub fn get_builtin_class(&self, cx: &Context) -> ESClass

Gets the builtin class of the object as described in the ECMAScript specification.

Returns ESClass::Other for other projects or proxies that cannot be unwrapped.

Source

pub fn is_boxed_primitive(&self, cx: &Context) -> Option<ESClass>

Returns the builtin class of the object if it a wrapper around a primitive.

The boxed types are Boolean, Number, String and BigInt

Source

pub fn unbox_primitive<'cx>(&self, cx: &'cx Context) -> Option<Value<'cx>>

Unboxes primitive wrappers. See Object::is_boxed_primitive for details.

Source

pub fn keys<'cx>( &self, cx: &'cx Context, flags: Option<IteratorFlags>, ) -> ObjectKeysIter<'cx>

Returns an iterator of the keys of the Object. Each key can be a String, Symbol or integer.

Source

pub fn iter<'cx, 's>( &'s self, cx: &'cx Context, flags: Option<IteratorFlags>, ) -> ObjectIter<'cx, 's>
where 'o: 'cx,

Source

pub fn to_hashmap<'cx>( &self, cx: &'cx Context, flags: Option<IteratorFlags>, ) -> Result<HashMap<OwnedKey<'cx>, Value<'cx>>>
where 'o: 'cx,

Source

pub fn into_local(self) -> Local<'o, *mut JSObject>

Methods from Deref<Target = Local<'o, *mut JSObject>>§

Source

pub fn handle(&self) -> Handle<'local, T>

Forms a Handle to the Local which can be passed to SpiderMonkey APIs.

Source

pub fn handle_mut(&mut self) -> MutableHandle<'local, T>

Forms a Handle to the Local which can be passed to SpiderMonkey APIs.

§Panics

Panics when a Local::Handle is passed.

Source

pub fn get(&self) -> T

Trait Implementations§

Source§

impl<'o> Debug for Object<'o>

Source§

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

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

impl<'o> Deref for Object<'o>

Source§

type Target = Local<'o, *mut JSObject>

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl DerefMut for Object<'_>

Source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
Source§

impl<'o> From<Local<'o, *mut JSObject>> for Object<'o>

Source§

fn from(obj: Local<'o, *mut JSObject>) -> Object<'o>

Converts to this type from the input type.
Source§

impl<'cx> FromValue<'cx> for Object<'cx>

Source§

type Config = ()

Source§

fn from_value( cx: &'cx Context, value: &Value<'_>, _: bool, _: (), ) -> Result<Object<'cx>>

Converts value to the desired type. strict and config determine the strictness of the conversion and specify additional conversion constraints respectively. Returns Err with the error if conversion fails.
Source§

impl<'cx> ToValue<'cx> for Object<'cx>

Source§

fn to_value(&self, cx: &'cx Context, value: &mut Value<'_>)

Converts self to a Value and stores it in value.
Source§

fn as_value(&self, cx: &'cx Context) -> Value<'cx>

Converts self to a new Value.

Auto Trait Implementations§

§

impl<'o> Freeze for Object<'o>

§

impl<'o> RefUnwindSafe for Object<'o>

§

impl<'o> !Send for Object<'o>

§

impl<'o> !Sync for Object<'o>

§

impl<'o> Unpin for Object<'o>

§

impl<'o> !UnwindSafe for Object<'o>

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

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> Filterable for T

Source§

fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>

Creates a filterable data provider with the given name for debugging. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<'cx, T> FromArgument<'_, 'cx> for T
where T: FromValue<'cx>,

Source§

type Config = <T as FromValue<'cx>>::Config

Source§

fn from_argument( accessor: &mut Accessor<'_, 'cx>, config: <T as FromValue<'cx>>::Config, ) -> Result<T, Error>

Converts from an argument.
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<'cx, T> IntoValue<'cx> for T
where T: ToValue<'cx>,

Source§

fn into_value(self: Box<T>, cx: &'cx Context, value: &mut Value<'_>)

Converts self into a Value and stores it in value.
Source§

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

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
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> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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, 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 16 bytes