wolfram_wxf

Crates.iowolfram_wxf
lib.rswolfram_wxf
version0.7.0
sourcesrc
created_at2020-03-21 16:13:02.070404
updated_at2024-01-05 07:01:03.594177
descriptionConvert a value to the Wolfram Language WXF format.
homepage
repositoryhttps://github.com/oovm/wolfram-exchange
max_upload_size
id221009
size235,988
SasakiSaki (oovm)

documentation

https://docs.rs/wolfram_wxf

README

Wolfram Exchange Format with Rust

Design

To support format conversion, just implement the ToWolfram trait.

pub trait ToWolfram {
    fn to_wolfram(&self) -> WolframValue;
    fn to_wolfram_string(&self) -> String {self.to_wolfram().to_string()}
    fn to_wolfram_bytes(&self) -> Vec<u8> {self.to_wolfram().to_bytes()}
    fn to_wolfram_solid(&self) -> Vec<u8> {self.to_wolfram().to_compressed()}
}

WolframValue consists of the following legal elements:

pub enum WolframValue {
    /// Function with name, args
    Boolean(bool),
    Function(Box<str>, Vec<WolframValue>),
    String(Box<str>),
    Bytes(Vec<u8>),
    Symbol(Box<str>),
    Integer8(i8),
    Integer16(i16),
    Integer32(i32),
    Integer64(i64),
    BigInteger(BigInt),
    /// Do not use `f64`, because partial order cannot be defined
    Decimal64([u8; 8]),
    BigDecimal(Box<str>),
    /// Need to optimize
    PackedArray(Vec<WolframValue>),
    /// Need to optimize
    NumericArray(Vec<WolframValue>),
    /// Record with key, rule, value
    Association(BTreeMap<WolframValue, (WolframValue, WolframValue)>),
    Rule,
    RuleDelayed,
}

Extension

Here are some common formats supported now:

pub enum SupportedFormat {
    JSON, //json
    TOML, //toml
    YAML, //yaml, yml
    Pickle, //pkl
}

Because rust cannot define traits and structs externally at the same time, supporting new formats needs to be done within this project.

See From Traits Extension to learn how to support new format

Tools

  • wex: A command line tool that can convert wxf format
Commit count: 30

cargo fmt