Struct quickjs_runtime::reflection::Proxy
source · pub struct Proxy { /* private fields */ }
Expand description
The Proxy struct can be used to create a class in JavaScript who’s methods can be implemented in rust
§Example
use quickjs_runtime::builder::QuickJsRuntimeBuilder;
use quickjs_runtime::reflection::Proxy;
use quickjs_runtime::quickjsrealmadapter::QuickJsRealmAdapter;
use quickjs_runtime::quickjsvalueadapter::QuickJsValueAdapter;
use std::cell::RefCell;
use std::collections::HashMap;
use quickjs_runtime::quickjs_utils::primitives;
use quickjs_runtime::jsutils::Script;
struct MyFunkyStruct{
name: String
}
impl Drop for MyFunkyStruct {fn drop(&mut self) {
println!("Funky drop: {}", self.name.as_str());
}
}
thread_local! {
static INSTANCES: RefCell<HashMap<usize, MyFunkyStruct>> = RefCell::new(HashMap::new());
}
//create a new EsRuntime
let rt = QuickJsRuntimeBuilder::new().build();
// install our proxy class as com.hirofa.FunkyClass
rt.exe_rt_task_in_event_loop(|q_js_rt| {
let q_ctx = q_js_rt.get_main_realm();
Proxy::new()
.namespace(&["com", "hirofa"])
.name("FunkyClass")
// the constructor is called when a script does new com.hirofa.FunkyClass, the reflection utils
// generate an instance_id which may be used to identify the instance
.constructor(|rt, q_ctx: &QuickJsRealmAdapter, instance_id: usize, args: &[QuickJsValueAdapter]| {
// we'll assume our script always constructs the Proxy with a single name argument
let name = primitives::to_string_q(q_ctx, &args[0]).ok().expect("bad constructor! bad!");
// create a new instance of our struct and store it in a map
let instance = MyFunkyStruct{name};
// store our struct in a thread_local map
INSTANCES.with(move |rc| {
let map = &mut *rc.borrow_mut();
map.insert(instance_id, instance);
});
// return Ok, or Err if the constructor failed (e.g. wrong args were passed)
Ok(())
})
// next we create a simple getName method, this will return a String
.method("getName", |rt, q_ctx, instance_id, args| {
INSTANCES.with(move |rc| {
let map = & *rc.borrow();
let instance = map.get(instance_id).unwrap();
primitives::from_string_q(q_ctx, instance.name.as_str())
})
})
// and lastly (but very important) implement a finalizer so our rust struct may be dropped
.finalizer(|rt, q_ctx, instance_id| {
INSTANCES.with(move |rc| {
let map = &mut *rc.borrow_mut();
map.remove(&instance_id);
});
})
// install the Proxy in the context
.install(q_ctx, true).expect("proxy install failed");
});
match rt.eval_sync(None, Script::new("test_proxy.es",
"{let inst = new com.hirofa.FunkyClass('FooBar'); let name = inst.getName(); inst = null; name;}"
)) {
Ok(name_esvf) => {
// assert correct getName result
assert_eq!(name_esvf.get_str(), "FooBar");
let i_ct = INSTANCES.with(|rc| rc.borrow().len());
// assert instance was finalized
assert_eq!(i_ct, 0);
}
Err(e) => {
panic!("script failed: {}", e);
}
}
rt.gc_sync();
Implementations§
source§impl Proxy
impl Proxy
pub fn new() -> Self
sourcepub fn name(self, name: &str) -> Self
pub fn name(self, name: &str) -> Self
set the name of the proxy class this will indicate how to construct the class from script
sourcepub fn namespace(self, namespace: &[&str]) -> Self
pub fn namespace(self, namespace: &[&str]) -> Self
set the namespace of the proxy class
§Example
use quickjs_runtime::reflection::Proxy;
Proxy::new().namespace(&["com", "hirofa"]).name("SomeClass");
means from script you can access the class by
let instance = new com.hirofa.SomeClass();
sourcepub fn get_class_name(&self) -> String
pub fn get_class_name(&self) -> String
get the canonical classname of a Proxy
§example
use quickjs_runtime::reflection::Proxy;
Proxy::new().namespace(&["com", "hirofa"]).name("SomeClass");
will result in a class_name of “com.hirofa.SomeClass”
sourcepub fn constructor<C>(self, constructor: C) -> Selfwhere
C: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, usize, &[QuickJsValueAdapter]) -> Result<(), JsError> + 'static,
pub fn constructor<C>(self, constructor: C) -> Selfwhere
C: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, usize, &[QuickJsValueAdapter]) -> Result<(), JsError> + 'static,
add a constructor for the Proxy class this will enable a script to create a new instance of a Proxy class if omitted the Proxy class will not be constructable from script
sourcepub fn finalizer<C>(self, finalizer: C) -> Self
pub fn finalizer<C>(self, finalizer: C) -> Self
add a finalizer for the Proxy class this will be called when an instance of the Proxy class is dropped or garbage collected
sourcepub fn method<M>(self, name: &str, method: M) -> Selfwhere
M: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, &[QuickJsValueAdapter]) -> Result<QuickJsValueAdapter, JsError> + 'static,
pub fn method<M>(self, name: &str, method: M) -> Selfwhere
M: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, &[QuickJsValueAdapter]) -> Result<QuickJsValueAdapter, JsError> + 'static,
add a method to the Proxy class, this method will be available as a member of instances of the Proxy class
sourcepub fn native_method(self, name: &str, method: ProxyNativeMethod) -> Self
pub fn native_method(self, name: &str, method: ProxyNativeMethod) -> Self
add a method to the Proxy class, this method will be available as a member of instances of the Proxy class
sourcepub fn static_method<M>(self, name: &str, method: M) -> Selfwhere
M: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &[QuickJsValueAdapter]) -> Result<QuickJsValueAdapter, JsError> + 'static,
pub fn static_method<M>(self, name: &str, method: M) -> Selfwhere
M: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &[QuickJsValueAdapter]) -> Result<QuickJsValueAdapter, JsError> + 'static,
add a static method to the Proxy class, this method will be available as a member of the Proxy class itself
sourcepub fn static_native_method(
self,
name: &str,
method: ProxyStaticNativeMethod,
) -> Self
pub fn static_native_method( self, name: &str, method: ProxyStaticNativeMethod, ) -> Self
add a static method to the Proxy class, this method will be available as a member of the Proxy class itself
sourcepub fn static_getter_setter<G, S>(
self,
name: &str,
getter: G,
setter: S,
) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
pub fn static_getter_setter<G, S>(
self,
name: &str,
getter: G,
setter: S,
) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
add a static getter and setter to the Proxy class
sourcepub fn static_catch_all_getter_setter<G, S>(self, getter: G, setter: S) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &str) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &str, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
pub fn static_catch_all_getter_setter<G, S>(self, getter: G, setter: S) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &str) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &str, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
add a static getter and setter to the Proxy class
sourcepub fn getter_setter<G, S>(self, name: &str, getter: G, setter: S) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
pub fn getter_setter<G, S>(self, name: &str, getter: G, setter: S) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
add a getter and setter to the Proxy class, these will be available as a member of an instance of this Proxy class
sourcepub fn getter<G>(self, name: &str, getter: G) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize) -> Result<QuickJsValueAdapter, JsError> + 'static,
pub fn getter<G>(self, name: &str, getter: G) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize) -> Result<QuickJsValueAdapter, JsError> + 'static,
add a getter and setter to the Proxy class, these will be available as a member of an instance of this Proxy class
sourcepub fn catch_all_getter_setter<G, S>(self, getter: G, setter: S) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, &str) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, &str, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
pub fn catch_all_getter_setter<G, S>(self, getter: G, setter: S) -> Selfwhere
G: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, &str) -> Result<QuickJsValueAdapter, JsError> + 'static,
S: Fn(&QuickJsRuntimeAdapter, &QuickJsRealmAdapter, &usize, &str, QuickJsValueAdapter) -> Result<(), JsError> + 'static,
add a catchall getter and setter to the Proxy class, these will be used for properties which are not specifically defined as getter, setter or method in this Proxy
sourcepub fn event_target(self) -> Self
pub fn event_target(self) -> Self
indicate the Proxy class should implement the EventTarget interface, this will result in the addEventListener, removeEventListener and dispatchEvent methods to be available on instances of the Proxy class
sourcepub fn static_event_target(self) -> Self
pub fn static_event_target(self) -> Self
indicate the Proxy class should implement the EventTarget interface, this will result in the addEventListener, removeEventListener and dispatchEvent methods to be available
sourcepub fn install(
self,
q_ctx: &QuickJsRealmAdapter,
add_variable_to_global: bool,
) -> Result<QuickJsValueAdapter, JsError>
pub fn install( self, q_ctx: &QuickJsRealmAdapter, add_variable_to_global: bool, ) -> Result<QuickJsValueAdapter, JsError>
install the Proxy class in a QuickJsContext, this is always needed as a final step to actually make the Proxy class work
Trait Implementations§
Auto Trait Implementations§
impl !Freeze for Proxy
impl !RefUnwindSafe for Proxy
impl !Send for Proxy
impl !Sync for Proxy
impl Unpin for Proxy
impl !UnwindSafe for Proxy
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<D> OwoColorize for D
impl<D> OwoColorize for D
source§fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
source§fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
source§fn black<'a>(&'a self) -> FgColorDisplay<'a, Black, Self>
fn black<'a>(&'a self) -> FgColorDisplay<'a, Black, Self>
source§fn on_black<'a>(&'a self) -> BgColorDisplay<'a, Black, Self>
fn on_black<'a>(&'a self) -> BgColorDisplay<'a, Black, Self>
source§fn red<'a>(&'a self) -> FgColorDisplay<'a, Red, Self>
fn red<'a>(&'a self) -> FgColorDisplay<'a, Red, Self>
source§fn on_red<'a>(&'a self) -> BgColorDisplay<'a, Red, Self>
fn on_red<'a>(&'a self) -> BgColorDisplay<'a, Red, Self>
source§fn green<'a>(&'a self) -> FgColorDisplay<'a, Green, Self>
fn green<'a>(&'a self) -> FgColorDisplay<'a, Green, Self>
source§fn on_green<'a>(&'a self) -> BgColorDisplay<'a, Green, Self>
fn on_green<'a>(&'a self) -> BgColorDisplay<'a, Green, Self>
source§fn yellow<'a>(&'a self) -> FgColorDisplay<'a, Yellow, Self>
fn yellow<'a>(&'a self) -> FgColorDisplay<'a, Yellow, Self>
source§fn on_yellow<'a>(&'a self) -> BgColorDisplay<'a, Yellow, Self>
fn on_yellow<'a>(&'a self) -> BgColorDisplay<'a, Yellow, Self>
source§fn blue<'a>(&'a self) -> FgColorDisplay<'a, Blue, Self>
fn blue<'a>(&'a self) -> FgColorDisplay<'a, Blue, Self>
source§fn on_blue<'a>(&'a self) -> BgColorDisplay<'a, Blue, Self>
fn on_blue<'a>(&'a self) -> BgColorDisplay<'a, Blue, Self>
source§fn magenta<'a>(&'a self) -> FgColorDisplay<'a, Magenta, Self>
fn magenta<'a>(&'a self) -> FgColorDisplay<'a, Magenta, Self>
source§fn on_magenta<'a>(&'a self) -> BgColorDisplay<'a, Magenta, Self>
fn on_magenta<'a>(&'a self) -> BgColorDisplay<'a, Magenta, Self>
source§fn purple<'a>(&'a self) -> FgColorDisplay<'a, Magenta, Self>
fn purple<'a>(&'a self) -> FgColorDisplay<'a, Magenta, Self>
source§fn on_purple<'a>(&'a self) -> BgColorDisplay<'a, Magenta, Self>
fn on_purple<'a>(&'a self) -> BgColorDisplay<'a, Magenta, Self>
source§fn cyan<'a>(&'a self) -> FgColorDisplay<'a, Cyan, Self>
fn cyan<'a>(&'a self) -> FgColorDisplay<'a, Cyan, Self>
source§fn on_cyan<'a>(&'a self) -> BgColorDisplay<'a, Cyan, Self>
fn on_cyan<'a>(&'a self) -> BgColorDisplay<'a, Cyan, Self>
source§fn white<'a>(&'a self) -> FgColorDisplay<'a, White, Self>
fn white<'a>(&'a self) -> FgColorDisplay<'a, White, Self>
source§fn on_white<'a>(&'a self) -> BgColorDisplay<'a, White, Self>
fn on_white<'a>(&'a self) -> BgColorDisplay<'a, White, Self>
source§fn default_color<'a>(&'a self) -> FgColorDisplay<'a, Default, Self>
fn default_color<'a>(&'a self) -> FgColorDisplay<'a, Default, Self>
source§fn on_default_color<'a>(&'a self) -> BgColorDisplay<'a, Default, Self>
fn on_default_color<'a>(&'a self) -> BgColorDisplay<'a, Default, Self>
source§fn bright_black<'a>(&'a self) -> FgColorDisplay<'a, BrightBlack, Self>
fn bright_black<'a>(&'a self) -> FgColorDisplay<'a, BrightBlack, Self>
source§fn on_bright_black<'a>(&'a self) -> BgColorDisplay<'a, BrightBlack, Self>
fn on_bright_black<'a>(&'a self) -> BgColorDisplay<'a, BrightBlack, Self>
source§fn bright_red<'a>(&'a self) -> FgColorDisplay<'a, BrightRed, Self>
fn bright_red<'a>(&'a self) -> FgColorDisplay<'a, BrightRed, Self>
source§fn on_bright_red<'a>(&'a self) -> BgColorDisplay<'a, BrightRed, Self>
fn on_bright_red<'a>(&'a self) -> BgColorDisplay<'a, BrightRed, Self>
source§fn bright_green<'a>(&'a self) -> FgColorDisplay<'a, BrightGreen, Self>
fn bright_green<'a>(&'a self) -> FgColorDisplay<'a, BrightGreen, Self>
source§fn on_bright_green<'a>(&'a self) -> BgColorDisplay<'a, BrightGreen, Self>
fn on_bright_green<'a>(&'a self) -> BgColorDisplay<'a, BrightGreen, Self>
source§fn bright_yellow<'a>(&'a self) -> FgColorDisplay<'a, BrightYellow, Self>
fn bright_yellow<'a>(&'a self) -> FgColorDisplay<'a, BrightYellow, Self>
source§fn on_bright_yellow<'a>(&'a self) -> BgColorDisplay<'a, BrightYellow, Self>
fn on_bright_yellow<'a>(&'a self) -> BgColorDisplay<'a, BrightYellow, Self>
source§fn bright_blue<'a>(&'a self) -> FgColorDisplay<'a, BrightBlue, Self>
fn bright_blue<'a>(&'a self) -> FgColorDisplay<'a, BrightBlue, Self>
source§fn on_bright_blue<'a>(&'a self) -> BgColorDisplay<'a, BrightBlue, Self>
fn on_bright_blue<'a>(&'a self) -> BgColorDisplay<'a, BrightBlue, Self>
source§fn bright_magenta<'a>(&'a self) -> FgColorDisplay<'a, BrightMagenta, Self>
fn bright_magenta<'a>(&'a self) -> FgColorDisplay<'a, BrightMagenta, Self>
source§fn on_bright_magenta<'a>(&'a self) -> BgColorDisplay<'a, BrightMagenta, Self>
fn on_bright_magenta<'a>(&'a self) -> BgColorDisplay<'a, BrightMagenta, Self>
source§fn bright_purple<'a>(&'a self) -> FgColorDisplay<'a, BrightMagenta, Self>
fn bright_purple<'a>(&'a self) -> FgColorDisplay<'a, BrightMagenta, Self>
source§fn on_bright_purple<'a>(&'a self) -> BgColorDisplay<'a, BrightMagenta, Self>
fn on_bright_purple<'a>(&'a self) -> BgColorDisplay<'a, BrightMagenta, Self>
source§fn bright_cyan<'a>(&'a self) -> FgColorDisplay<'a, BrightCyan, Self>
fn bright_cyan<'a>(&'a self) -> FgColorDisplay<'a, BrightCyan, Self>
source§fn on_bright_cyan<'a>(&'a self) -> BgColorDisplay<'a, BrightCyan, Self>
fn on_bright_cyan<'a>(&'a self) -> BgColorDisplay<'a, BrightCyan, Self>
source§fn bright_white<'a>(&'a self) -> FgColorDisplay<'a, BrightWhite, Self>
fn bright_white<'a>(&'a self) -> FgColorDisplay<'a, BrightWhite, Self>
source§fn on_bright_white<'a>(&'a self) -> BgColorDisplay<'a, BrightWhite, Self>
fn on_bright_white<'a>(&'a self) -> BgColorDisplay<'a, BrightWhite, Self>
source§fn bold<'a>(&'a self) -> BoldDisplay<'a, Self>
fn bold<'a>(&'a self) -> BoldDisplay<'a, Self>
source§fn dimmed<'a>(&'a self) -> DimDisplay<'a, Self>
fn dimmed<'a>(&'a self) -> DimDisplay<'a, Self>
source§fn italic<'a>(&'a self) -> ItalicDisplay<'a, Self>
fn italic<'a>(&'a self) -> ItalicDisplay<'a, Self>
source§fn underline<'a>(&'a self) -> UnderlineDisplay<'a, Self>
fn underline<'a>(&'a self) -> UnderlineDisplay<'a, Self>
source§fn blink<'a>(&'a self) -> BlinkDisplay<'a, Self>
fn blink<'a>(&'a self) -> BlinkDisplay<'a, Self>
source§fn blink_fast<'a>(&'a self) -> BlinkFastDisplay<'a, Self>
fn blink_fast<'a>(&'a self) -> BlinkFastDisplay<'a, Self>
source§fn reversed<'a>(&'a self) -> ReversedDisplay<'a, Self>
fn reversed<'a>(&'a self) -> ReversedDisplay<'a, Self>
source§fn strikethrough<'a>(&'a self) -> StrikeThroughDisplay<'a, Self>
fn strikethrough<'a>(&'a self) -> StrikeThroughDisplay<'a, Self>
source§fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::fg
or
a color-specific method, such as OwoColorize::green
, Read moresource§fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::bg
or
a color-specific method, such as OwoColorize::on_yellow
, Read more