Config

Struct Config 

Source
pub struct Config {
    pub imports: Vec<String>,
    pub before: Vec<String>,
    pub repl_code: String,
    pub after: Vec<String>,
    pub copy_dirs: Vec<String>,
    pub path_to_node_modules: Option<String>,
    /* private fields */
}
Expand description

Configurating for Repl. Usually you will want to setup the REPL context by importing some modules and doing some setup. Then maybe, run some teardown code after the REPL closes. Do this by giving JavaScript strings to Config::imports, Config::before, and Config::after fields.

The Node.js script will look something like:

// eval Config::imports

(async () => {
    // eval Config::before

   for await (const line of repl()) {
        eval(line)
   }

   // eval Config::after
})()

You will probably want to provide Config::path_to_node_modules so use can use npm packages .

Fields§

§imports: Vec<String>

JS imports

§before: Vec<String>

Code that runs before the REPL in an async context. setup, etc.

§repl_code: String

Define and run the REPL.

§after: Vec<String>

Code that runs after the REPL. teardown, etc. Run in reverse order.

§copy_dirs: Vec<String>

A list paths that will be copied into the tempfile::TempDir alongside the REPL script. Useful for importing custom code.

§path_to_node_modules: Option<String>

Path to a node_modules directory which node will use.

Implementations§

Source§

impl Config

Source

pub fn build() -> Result<Self>

Build a default Config.

Source

pub async fn start(&mut self) -> Result<Repl>

Start Node.js and return Repl.

Trait Implementations§

Source§

impl Debug for Config

Source§

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

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

impl Default for Config

Source§

fn default() -> Config

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl Freeze for Config

§

impl !RefUnwindSafe for Config

§

impl !Send for Config

§

impl !Sync for Config

§

impl Unpin for Config

§

impl !UnwindSafe for Config

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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, 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> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more