Skip to main content

LanguageProfile

Struct LanguageProfile 

Source
pub struct LanguageProfile {
    pub symbol: Symbol,
    pub reader: Symbol,
    pub lowering: Symbol,
    pub eval_policy: Symbol,
    pub organs: Vec<OrganUse>,
    pub numeric_tower: Option<Symbol>,
    pub capabilities: Vec<CapabilityName>,
    pub unsupported_forms: Vec<Symbol>,
    pub conformance_tests: Vec<Symbol>,
    pub fidelity_badges: Vec<FidelityBadge>,
}
Expand description

A language profile: the reader, lowering, eval-policy, organs, and metadata that present one surface language over the shared Expr graph.

Profiles are the unit the standard distribution installs, diffs, and tests; the per-language sim-lib-lang-* crates build one each.

§Examples

use sim_kernel::Symbol;
use sim_lib_standard_core::{LanguageProfile, OrganUse, standard_control_organ_symbol};

let profile = LanguageProfile::new(Symbol::qualified("lang", "demo/v1"))
    .with_reader(Symbol::qualified("codec", "lisp"))
    .with_eval_policy(Symbol::qualified("eval", "default"))
    .with_organ(OrganUse::new(standard_control_organ_symbol()));

assert_eq!(profile.reader, Symbol::qualified("codec", "lisp"));
assert_eq!(profile.organs.len(), 1);

Fields§

§symbol: Symbol

Symbol naming the profile.

§reader: Symbol

Reader (codec) symbol the profile parses with.

§lowering: Symbol

Lowering symbol mapping surface forms onto the shared graph.

§eval_policy: Symbol

Eval-policy symbol the profile evaluates under.

§organs: Vec<OrganUse>

Organs the profile uses.

§numeric_tower: Option<Symbol>

Optional numeric tower symbol.

§capabilities: Vec<CapabilityName>

Capabilities the profile requires.

§unsupported_forms: Vec<Symbol>

Surface forms the profile does not support.

§conformance_tests: Vec<Symbol>

Conformance tests covering the profile.

§fidelity_badges: Vec<FidelityBadge>

Fidelity badges declared for the profile.

Implementations§

Source§

impl LanguageProfile

Source

pub fn new(symbol: Symbol) -> Self

Start a profile named symbol with unspecified reader/lowering/eval-policy and no organs.

Source

pub fn with_reader(self, reader: Symbol) -> Self

Set the reader symbol.

Source

pub fn with_lowering(self, lowering: Symbol) -> Self

Set the lowering symbol.

Source

pub fn with_eval_policy(self, eval_policy: Symbol) -> Self

Set the eval-policy symbol.

Source

pub fn with_organ(self, organ: OrganUse) -> Self

Add an organ use.

Source

pub fn with_numeric_tower(self, numeric_tower: Symbol) -> Self

Set the numeric tower symbol.

Source

pub fn requiring(self, capability: CapabilityName) -> Self

Add a required capability.

Source

pub fn with_unsupported_form(self, form: Symbol) -> Self

Add an unsupported surface form.

Source

pub fn with_conformance_test(self, test: Symbol) -> Self

Add a conformance test.

Source

pub fn with_fidelity_badge(self, badge: FidelityBadge) -> Self

Add a fidelity badge.

Source

pub fn to_constructor_args(&self) -> Vec<Expr>

Encode this profile as constructor arguments for the standard/Profile class.

Source

pub fn from_constructor_args(args: Vec<Expr>) -> Result<Self>

Decode a profile from standard/Profile constructor arguments.

Trait Implementations§

Source§

impl Clone for LanguageProfile

Source§

fn clone(&self) -> LanguageProfile

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for LanguageProfile

Source§

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

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

impl Eq for LanguageProfile

Source§

impl PartialEq for LanguageProfile

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · 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 StructuralPartialEq for LanguageProfile

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> 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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
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, 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.