Struct rquickjs_core::class::Class
source · pub struct Class<'js, C: JsClass<'js>>(_, _);
Expand description
A object which is instance of a rust class.
Implementations§
source§impl<'js, C: JsClass<'js>> Class<'js, C>
impl<'js, C: JsClass<'js>> Class<'js, C>
sourcepub fn instance(ctx: Ctx<'js>, value: C) -> Result<Class<'js, C>>
pub fn instance(ctx: Ctx<'js>, value: C) -> Result<Class<'js, C>>
Create a class from a rust object.
sourcepub fn instance_proto(value: C, proto: Object<'js>) -> Result<Class<'js, C>>
pub fn instance_proto(value: C, proto: Object<'js>) -> Result<Class<'js, C>>
Create a class from a rust object with a given prototype
sourcepub fn prototype(ctx: Ctx<'js>) -> Option<Object<'js>>
pub fn prototype(ctx: Ctx<'js>) -> Option<Object<'js>>
Returns the prototype for the class.
Returns None if the class is not yet registered or if the class doesn’t have a prototype
sourcepub fn create_constructor(ctx: &Ctx<'js>) -> Result<Option<Constructor<'js>>>
pub fn create_constructor(ctx: &Ctx<'js>) -> Result<Option<Constructor<'js>>>
Create a constructor for the current class using its definition.
sourcepub fn define(object: &Object<'js>) -> Result<()>
pub fn define(object: &Object<'js>) -> Result<()>
Defines the predefined constructor of this class, if there is one, onto the given object.
sourcepub fn is_registered(ctx: &Ctx<'js>) -> bool
pub fn is_registered(ctx: &Ctx<'js>) -> bool
Returns if the class is registered in the runtime.
sourcepub fn register(ctx: &Ctx<'js>) -> Result<()>
pub fn register(ctx: &Ctx<'js>) -> Result<()>
Registers the class C
into the runtime.
It is required to call this function on every context in which the class is used before using the class. Otherwise the class
sourcepub fn get_cell<'a>(&self) -> &'a JsCell<'js, C>
pub fn get_cell<'a>(&self) -> &'a JsCell<'js, C>
Returns a reference to the underlying object contained in a cell.
sourcepub fn borrow_mut<'a>(&'a self) -> BorrowMut<'a, 'js, C>
pub fn borrow_mut<'a>(&'a self) -> BorrowMut<'a, 'js, C>
Borrow the rust class type mutably.
Javascript classes behave similar to Rc
in rust, you can essentially think
of a class object as a Rc<RefCell<C>>
and with similar borrowing functionality.
Panic
This function panics if the class is already borrowed mutably or immutably, or the Class can’t be borrowed mutably.
sourcepub fn try_borrow<'a>(&'a self) -> Result<Borrow<'a, 'js, C>>
pub fn try_borrow<'a>(&'a self) -> Result<Borrow<'a, 'js, C>>
Try to borrow the rust class type.
Javascript classes behave similar to Rc
in rust, you can essentially think
of a class object as a Rc<RefCell<C>>
and with similar borrowing functionality.
This returns an error when the class is already borrowed mutably.
sourcepub fn try_borrow_mut<'a>(&'a self) -> Result<BorrowMut<'a, 'js, C>>
pub fn try_borrow_mut<'a>(&'a self) -> Result<BorrowMut<'a, 'js, C>>
Try to borrow the rust class type mutably.
Javascript classes behave similar to Rc
in rust, you can essentially think
of a class object as a Rc<RefCell<C>>
and with similar borrowing functionality.
This returns an error when the class is already borrowed mutably, immutably or the class can’t be borrowed mutably.
sourcepub fn into_object(self) -> Object<'js>
pub fn into_object(self) -> Object<'js>
Turns the class back into a generic object.
sourcepub fn from_object(object: Object<'js>) -> Option<Self>
pub fn from_object(object: Object<'js>) -> Option<Self>
Converts a generic object into a class if the object is of the right class.
sourcepub fn into_value(self) -> Value<'js>
pub fn into_value(self) -> Value<'js>
Turn the class into a value.
Methods from Deref<Target = Object<'js>>§
sourcepub 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.
pub fn prop<K, V, P>(&self, key: K, prop: V) -> Result<()>where K: IntoAtom<'js>, V: AsProperty<'js, P>,
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();
sourcepub fn contains_key<K>(&self, k: K) -> Result<bool>where
K: IntoAtom<'js>,
pub fn contains_key<K>(&self, k: K) -> Result<bool>where K: IntoAtom<'js>,
check wether the object contains a certain key.
sourcepub fn set<K: IntoAtom<'js>, V: IntoJs<'js>>(
&self,
key: K,
value: V
) -> Result<()>
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
sourcepub fn keys<K: FromAtom<'js>>(&self) -> ObjectKeysIter<'js, K> ⓘ
pub fn keys<K: FromAtom<'js>>(&self) -> ObjectKeysIter<'js, K> ⓘ
Get own string enumerable property names of an object
sourcepub fn own_keys<K: FromAtom<'js>>(
&self,
filter: Filter
) -> ObjectKeysIter<'js, K> ⓘ
pub fn own_keys<K: FromAtom<'js>>( &self, filter: Filter ) -> ObjectKeysIter<'js, K> ⓘ
Get own property names of an object
sourcepub fn props<K: FromAtom<'js>, V: FromJs<'js>>(&self) -> ObjectIter<'js, K, V> ⓘ
pub fn props<K: FromAtom<'js>, V: FromJs<'js>>(&self) -> ObjectIter<'js, K, V> ⓘ
Get own string enumerable properties of an object
sourcepub fn own_props<K: FromAtom<'js>, V: FromJs<'js>>(
&self,
filter: Filter
) -> ObjectIter<'js, K, V> ⓘ
pub fn own_props<K: FromAtom<'js>, V: FromJs<'js>>( &self, filter: Filter ) -> ObjectIter<'js, K, V> ⓘ
Get own properties of an object
sourcepub fn values<K: FromAtom<'js>>(&self) -> ObjectValuesIter<'js, K> ⓘ
pub fn values<K: FromAtom<'js>>(&self) -> ObjectValuesIter<'js, K> ⓘ
Get own string enumerable property values of an object
sourcepub fn own_values<K: FromAtom<'js>>(
&self,
filter: Filter
) -> ObjectValuesIter<'js, K> ⓘ
pub fn own_values<K: FromAtom<'js>>( &self, filter: Filter ) -> ObjectValuesIter<'js, K> ⓘ
Get own property values of an object
sourcepub fn get_prototype(&self) -> Option<Object<'js>>
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.
sourcepub fn set_prototype(&self, proto: Option<&Object<'js>>) -> Result<()>
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.
sourcepub fn is_instance_of(&self, class: impl AsRef<Value<'js>>) -> bool
pub fn is_instance_of(&self, class: impl AsRef<Value<'js>>) -> bool
Check instance of object
sourcepub fn instance_of<C: JsClass<'js>>(&self) -> bool
pub fn instance_of<C: JsClass<'js>>(&self) -> bool
Returns if the object is of a certain rust class.
Methods from Deref<Target = Value<'js>>§
sourcepub fn is_undefined(&self) -> bool
pub fn is_undefined(&self) -> bool
Returns if the value is the JavaScript undefined value.
sourcepub fn is_function(&self) -> bool
pub fn is_function(&self) -> bool
Check if the value is a function
sourcepub fn is_constructor(&self) -> bool
pub fn is_constructor(&self) -> bool
Check if the value is a constructor function
sourcepub fn is_exception(&self) -> bool
pub fn is_exception(&self) -> bool
Check if the value is a constructor function
sourcepub unsafe fn ref_string(&self) -> &String<'js>
pub unsafe fn ref_string(&self) -> &String<'js>
sourcepub unsafe fn ref_symbol(&self) -> &Symbol<'js>
pub unsafe fn ref_symbol(&self) -> &Symbol<'js>
sourcepub unsafe fn ref_object(&self) -> &Object<'js>
pub unsafe fn ref_object(&self) -> &Object<'js>
sourcepub unsafe fn ref_function(&self) -> &Function<'js>
pub unsafe fn ref_function(&self) -> &Function<'js>
sourcepub fn as_function(&self) -> Option<&Function<'js>>
pub fn as_function(&self) -> Option<&Function<'js>>
Try reinterprete as
sourcepub unsafe fn ref_constructor(&self) -> &Constructor<'js>
pub unsafe fn ref_constructor(&self) -> &Constructor<'js>
sourcepub fn as_constructor(&self) -> Option<&Constructor<'js>>
pub fn as_constructor(&self) -> Option<&Constructor<'js>>
Try reinterprete as
sourcepub unsafe fn ref_exception(&self) -> &Exception<'js>
pub unsafe fn ref_exception(&self) -> &Exception<'js>
sourcepub fn as_exception(&self) -> Option<&Exception<'js>>
pub fn as_exception(&self) -> Option<&Exception<'js>>
Try reinterprete as
sourcepub unsafe fn ref_big_int(&self) -> &BigInt<'js>
pub unsafe fn ref_big_int(&self) -> &BigInt<'js>
sourcepub fn as_big_int(&self) -> Option<&BigInt<'js>>
pub fn as_big_int(&self) -> Option<&BigInt<'js>>
Try reinterprete as