Struct texlang::vm::ShutdownSignal

source ·
pub struct ShutdownSignal {}
Expand description

A signal that the VM is shutting down.

A value of this type is returned in the error payload of the Result of Texlang commands and basically all other Texlang functions. The only thing to do with the signal is to propagate it up the Rust call stack using Rust’s ? operator. Eventually the signal will reach the main VM loop, and the VM will stop.

The stop signal should not be ignored or otherwise “handled”. For example, this code is incorrect:

fn execution_primitive_fn<S: TexlangState>(
   token: token::Token,
   input: &mut vm::ExecutionInput<S>,
) -> txl::Result<()> {
    let i = match i32::parse(input) {
        Ok(i) => i,
        Err(_shutdown_signal) => {
            // This is incorrect - the shutdown signal must be propagated!
            0
        }
    };
    println!["Parsed integer {i}"];
    Ok(())
}

In this case the VM will eventually panic when it realizes that the shutdown was ignored. The correct code is this:

fn execution_primitive_fn<S: TexlangState>(
   token: token::Token,
   input: &mut vm::ExecutionInput<S>,
) -> txl::Result<()> {
    let i = i32::parse(input)?;
    println!["Parsed integer {i}"];
    Ok(())
}

§Generating the shutdown signal

The signal can originate either with a fatal error, or from a TeX control sequence that wants to stop execution (e.g. the \end primitive).

Trait Implementations§

source§

impl Debug for ShutdownSignal

source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

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, 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.