Symbol

Struct Symbol 

Source
pub struct Symbol(/* private fields */);
Expand description

Wolfram Language symbol.

§PartialOrd sorting order

The comparison behavior of this type is NOT guaranteed to match the behavior of System`Order for symbols (and does not match it at the moment).

This type implements PartialOrd/Ord primarily for the purposes of allowing instances of this type to be included in ordered sets (e.g. BTreeMap).

Implementations§

Source§

impl Symbol

Source

pub fn try_new(input: &str) -> Option<Symbol>

Attempt to parse input as an absolute symbol.

An absolute symbol is a symbol with an explicit context path. "System`Plus" is an absolute symbol, "Plus" is a relative symbol and/or a SymbolName. "`Plus" is also a relative symbol.

Source

pub fn new(input: &str) -> Symbol

Construct a symbol from input.

§Panics

This function will panic if input is not a valid Wolfram Language symbol. Symbol::try_new(input) must succeed.

This method is intended to be used for convenient construction of symbols from string literals, where an error is unlikely to occur, e.g.:

let expr = Expr::normal(Symbol::new("MyPackage`Foo"), vec![]);

If not using a string literal as the argument, prefer to use Symbol::try_new and handle the error condition.

Examples found in repository?
examples/docs/convert/using_expr.rs (line 24)
21    fn to_expr(&self) -> Expr {
22        let Point { x, y } = *self;
23
24        Expr::normal(Symbol::new("System`Point"), vec![Expr::list(vec![
25            Expr::real(x),
26            Expr::real(y),
27        ])])
28    }
More examples
Hide additional examples
examples/tests/test_threading.rs (line 10)
9fn test_runtime_function_from_main_thread() -> bool {
10    let expr = Expr::normal(Symbol::new("System`Plus"), vec![
11        Expr::from(2),
12        Expr::from(2),
13    ]);
14
15    wll::evaluate(&expr) == Expr::from(4)
16}
17
18#[wll::export]
19fn test_runtime_function_from_non_main_thread() -> String {
20    let child = std::thread::spawn(|| {
21        panic::set_hook(Box::new(|_| {
22            // Do nothing, just to avoid printing panic message to stderr.
23        }));
24
25        let result = panic::catch_unwind(|| {
26            wll::evaluate(&Expr::normal(Symbol::new("System`Plus"), vec![
27                Expr::from(2),
28                Expr::from(2),
29            ]))
30        });
31
32        // Restore the previous (default) hook.
33        let _ = panic::take_hook();
34
35        result
36    });
37
38    let result = child.join().unwrap();
39
40    match result {
41        Ok(_) => "didn't panic".to_owned(),
42        // We expect the thread to panic
43        Err(panic) => {
44            if let Some(str) = panic.downcast_ref::<&str>() {
45                format!("PANIC: {}", str)
46            } else if let Some(string) = panic.downcast_ref::<String>() {
47                format!("PANIC: {}", string)
48            } else {
49                "PANIC".to_owned()
50            }
51        },
52    }
53}
examples/exprs/basic_expressions.rs (line 22)
17pub fn echo_arguments(args: Vec<Expr>) -> Expr {
18    let arg_count = args.len();
19
20    for arg in args {
21        // Echo[<arg>]
22        wll::evaluate(&Expr::normal(Symbol::new("System`Echo"), vec![arg]));
23    }
24
25    Expr::string(format!("finished echoing {} argument(s)", arg_count))
26}
examples/wstp.rs (line 180)
176fn expr_string_join(link: &mut Link) {
177    let expr = link.get_expr().unwrap();
178
179    let list = expr.try_as_normal().unwrap();
180    assert!(list.has_head(&Symbol::new("System`List")));
181
182    let mut buffer = String::new();
183    for elem in list.elements() {
184        match elem.kind() {
185            ExprKind::String(str) => buffer.push_str(str),
186            _ => panic!("expected String argument, got: {:?}", elem),
187        }
188    }
189
190    link.put_str(buffer.as_str()).unwrap()
191}
examples/docs/evaluate_wolfram_code_from_rust/generate_message.rs (line 9)
7fn generate_message(_: Vec<Expr>) {
8    // Construct the expression `Message[MySymbol::msg, "..."]`.
9    let message = Expr::normal(Symbol::new("System`Message"), vec![
10        // MySymbol::msg is MessageName[MySymbol, "msg"]
11        Expr::normal(Symbol::new("System`MessageName"), vec![
12            Expr::from(Symbol::new("Global`MySymbol")),
13            Expr::string("msg"),
14        ]),
15        Expr::string("a Rust LibraryLink function"),
16    ]);
17
18    // Evaluate the message expression.
19    let _: Expr = wll::evaluate(&message);
20}
examples/exprs/managed.rs (line 84)
70fn get_instance_data(args: Vec<Expr>) -> Expr {
71    assert!(args.len() == 1, "get_instance_data: expected 1 argument");
72
73    let id: u32 = unwrap_id_arg(&args[0]);
74
75    let MyObject { value } = {
76        let instances = INSTANCES.lock().unwrap();
77
78        instances
79            .get(&id)
80            .cloned()
81            .expect("instance does not exist")
82    };
83
84    Expr::normal(Symbol::new("System`Association"), vec![Expr::normal(
85        Symbol::new("System`Rule"),
86        vec![Expr::string("Value"), Expr::string(value)],
87    )])
88}
Source

pub fn as_symbol_ref(&self) -> SymbolRef<'_>

Get a borrowed SymbolRef from this Symbol.

Source

pub fn context(&self) -> ContextRef<'_>

Get the context path part of a symbol as an ContextRef.

Source

pub fn symbol_name(&self) -> SymbolNameRef<'_>

Get the symbol name part of a symbol as a SymbolNameRef.

Source§

impl Symbol

Source

pub fn as_str(&self) -> &str

Get the underlying &str representation of this type.

Trait Implementations§

Source§

impl Clone for Symbol

Source§

fn clone(&self) -> Symbol

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 Debug for Symbol

Source§

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

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

impl Display for Symbol

Source§

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

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

impl From<&Symbol> for Expr

Source§

fn from(sym: &Symbol) -> Expr

Converts to this type from the input type.
Source§

impl From<&Symbol> for Symbol

Source§

fn from(sym: &Symbol) -> Symbol

Converts to this type from the input type.
Source§

impl From<Symbol> for Expr

Source§

fn from(sym: Symbol) -> Expr

Converts to this type from the input type.
Source§

impl Hash for Symbol

Source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Ord for Symbol

Source§

fn cmp(&self, other: &Symbol) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq<Symbol> for Expr

Source§

fn eq(&self, other: &Symbol) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq for Symbol

Source§

fn eq(&self, other: &Symbol) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for Symbol

Source§

fn partial_cmp(&self, other: &Symbol) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Eq for Symbol

Source§

impl StructuralPartialEq for Symbol

Auto Trait Implementations§

§

impl Freeze for Symbol

§

impl RefUnwindSafe for Symbol

§

impl Send for Symbol

§

impl Sync for Symbol

§

impl Unpin for Symbol

§

impl UnwindSafe for Symbol

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> 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.