Struct Ctx

Source
pub struct Ctx<'js> { /* private fields */ }
Expand description

Context in use, passed to Context::with.

Implementations§

Source§

impl<'js> Ctx<'js>

Source

pub fn eval<V, S>(&self, source: S) -> Result<V, Error>
where V: FromJs<'js>, S: Into<Vec<u8>>,

Evaluate a script in global context.

Source

pub fn eval_promise<S>(&self, source: S) -> Result<Promise<'js>, Error>
where S: Into<Vec<u8>>,

Evaluate a script in global context with top level await support.

This function always returns a promise which resolves to the result of the evaluated expression.

Source

pub fn eval_with_options<V, S>( &self, source: S, options: EvalOptions, ) -> Result<V, Error>
where V: FromJs<'js>, S: Into<Vec<u8>>,

Evaluate a script with the given options.

Source

pub fn eval_file<V, P>(&self, path: P) -> Result<V, Error>
where V: FromJs<'js>, P: AsRef<Path>,

Evaluate a script directly from a file.

Source

pub fn eval_file_with_options<V, P>( &self, path: P, options: EvalOptions, ) -> Result<V, Error>
where V: FromJs<'js>, P: AsRef<Path>,

Source

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

Returns the global object of this context.

Source

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

Returns the last raised JavaScript exception, if there is no exception the JavaScript value null is returned.

§Usage
if let Err(Error::Exception) = ctx.eval::<(),_>("throw 3"){
    assert_eq!(ctx.catch().as_int(),Some(3));
}
Source

pub fn throw(&self, value: Value<'js>) -> Error

Throws a JavaScript value as a new exception. Always returns Error::Exception;

Source

pub fn json_parse<S>(&self, json: S) -> Result<Value<'js>, Error>
where S: Into<Vec<u8>>,

Parse json into a JavaScript value.

Source

pub fn json_stringify<V>(&self, value: V) -> Result<Option<String<'js>>, Error>
where V: IntoJs<'js>,

Stringify a JavaScript value into its JSON representation

Source

pub fn json_stringify_replacer<V, R>( &self, value: V, replacer: R, ) -> Result<Option<String<'js>>, Error>
where V: IntoJs<'js>, R: IntoJs<'js>,

Stringify a JavaScript value into its JSON representation with a possible replacer.

The replacer is the same as the replacer argument for JSON.stringify. It is is a function that alters the behavior of the stringification process.

Source

pub fn json_stringify_replacer_space<V, R, S>( &self, value: V, replacer: R, space: S, ) -> Result<Option<String<'js>>, Error>
where V: IntoJs<'js>, R: IntoJs<'js>, S: IntoJs<'js>,

Stringify a JavaScript value into its JSON representation with a possible replacer and spaces

The replacer is the same as the replacer argument for JSON.stringify. It is is a function that alters the behavior of the stringification process.

Space is either a number or a string which is used to insert whitespace into the output string for readability purposes. This behaves the same as the space argument for JSON.stringify.

Source

pub fn promise( &self, ) -> Result<(Promise<'js>, Function<'js>, Function<'js>), Error>

Creates javascipt promise along with its reject and resolve functions.

Source

pub fn execute_pending_job(&self) -> bool

Executes a quickjs job.

Returns wether a job was actually executed. If this function returned false, no job was pending.

Source

pub fn spawn<F>(&self, future: F)
where F: Future<Output = ()> + 'js,

Available on crate feature futures only.

Spawn future using configured async runtime

Source

pub unsafe fn from_raw_invariant( ctx: NonNull<JSContext>, inv: Invariant<'js>, ) -> Ctx<'js>

Create a new Ctx from a pointer to the context and a invariant lifetime.

§Safety

User must ensure that a lock was acquired over the runtime and that invariant is a unique lifetime which can’t be coerced to a lifetime outside the scope of the lock of to the lifetime of another runtime.

Source

pub unsafe fn from_raw(ctx: NonNull<JSContext>) -> Ctx<'js>

Create a new Ctx from a pointer to the context and a invariant lifetime.

§Safety

User must ensure that a lock was acquired over the runtime and that invariant is a unique lifetime which can’t be coerced to a lifetime outside the scope of the lock of to the lifetime of another runtime.

Source

pub fn script_or_module_name(&self, stack_level: isize) -> Option<Atom<'js>>

Returns the name of the current module or script that is running.

It called from a javascript callback it will return the current running javascript script name. Otherwise it will return none.

Source

pub fn run_gc(&self)

Runs the quickjs garbage collector for a cycle.

Quickjs uses reference counting with a collection cycle for cyclic references. This runs the cyclic reference collector cycle, types which are not part of a reference cycle will be freed the momement their reference count becomes zero.

Source

pub fn store_userdata<U>( &self, data: U, ) -> Result<Option<Box<U>>, UserDataError<U>>
where U: JsLifetime<'js>, <U as JsLifetime<'js>>::Changed<'static>: Any,

Store a type in the runtime which can be retrieved later with Ctx::userdata.

Returns the value from the argument if the userdata is currently being accessed and insertion is not possible. Otherwise returns the exising value for this type if it existed.

Source

pub fn remove_userdata<U>(&self) -> Result<Option<Box<U>>, UserDataError<()>>
where U: JsLifetime<'js>, <U as JsLifetime<'js>>::Changed<'static>: Any,

Remove the userdata of the given type from the userdata storage.

Returns Err(()) if the userdata is currently being accessed and removing isn’t possible. Returns Ok(None) if userdata of the given type wasn’t inserted.

Source

pub fn userdata<U>(&self) -> Option<UserDataGuard<'_, U>>
where U: JsLifetime<'js>, <U as JsLifetime<'js>>::Changed<'static>: Any,

Retrieves a borrow to the userdata of the given type from the userdata storage.

Returns None if userdata of the given type wasn’t inserted.

Source

pub fn as_raw(&self) -> NonNull<JSContext>

Returns the pointer to the C library context.

Trait Implementations§

Source§

impl<'js> Clone for Ctx<'js>

Source§

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

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<'js> Debug for Ctx<'js>

Source§

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

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

impl<'js> Drop for Ctx<'js>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<'js> FromParam<'js> for Ctx<'js>

Source§

fn param_requirement() -> ParamRequirement

The parameters requirements this value requires.
Source§

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

Convert from a parameter value.
Source§

impl<'js> Trace<'js> for Ctx<'js>

Source§

fn trace<'a>(&self, tracer: Tracer<'a, 'js>)

Source§

impl Send for Ctx<'_>

Auto Trait Implementations§

§

impl<'js> Freeze for Ctx<'js>

§

impl<'js> RefUnwindSafe for Ctx<'js>

§

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

§

impl<'js> Unpin for Ctx<'js>

§

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

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

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
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, 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<T> ParallelSend for T
where T: Send,