Skip to main content

CodecRuntime

Struct CodecRuntime 

Source
pub struct CodecRuntime {
    pub id: CodecId,
    pub symbol: Symbol,
    pub decoder: Option<Arc<dyn Decoder>>,
    pub located_decoder: Option<Arc<dyn LocatedDecoder>>,
    pub tree_decoder: Option<Arc<dyn TreeDecoder>>,
    pub encoder: Option<Arc<dyn Encoder>>,
    pub located_encoder: Option<Arc<dyn LocatedEncoder>>,
    pub tree_encoder: Option<Arc<dyn TreeEncoder>>,
    pub expr_shape: ShapeRef,
    pub options_shape: ShapeRef,
    pub default_decode: CodecDefaultDecode,
}
Expand description

A registered codec as a runtime object: a symbol-named bundle of optional decode/encode capabilities plus the Shapes and default-decode policy it exposes.

This is the value the kernel hands back from a codec lookup. Each capability is optional; the dispatch methods (decode, encode_located, …) pick the richest implementation present and fall back to the plain forms otherwise, failing closed with a codec error when none is provided.

Fields§

§id: CodecId

Stable id of this codec.

§symbol: Symbol

The symbol the codec is registered and looked up under.

§decoder: Option<Arc<dyn Decoder>>

Plain Expr decoder, if the codec can read.

§located_decoder: Option<Arc<dyn LocatedDecoder>>

Origin-preserving decoder, if available.

§tree_decoder: Option<Arc<dyn TreeDecoder>>

Full-tree (lossless) decoder, if available.

§encoder: Option<Arc<dyn Encoder>>

Plain Expr encoder, if the codec can write.

§located_encoder: Option<Arc<dyn LocatedEncoder>>

Origin-aware encoder, if available.

§tree_encoder: Option<Arc<dyn TreeEncoder>>

Full-tree (lossless) encoder, if available.

§expr_shape: ShapeRef

Shape describing the expressions this codec accepts/produces.

§options_shape: ShapeRef

Shape describing this codec’s options table.

§default_decode: CodecDefaultDecode

How this codec maps a DecodePosition to a DecodeTarget.

Implementations§

Source§

impl CodecRuntime

Source

pub fn decode(&self, cx: &mut ReadCx<'_>, input: Input) -> Result<Expr>

Decode input with this codec’s plain decoder, erroring if it has none.

Source

pub fn encode(&self, cx: &mut WriteCx<'_>, expr: &Expr) -> Result<Output>

Encode expr with this codec’s plain encoder, erroring if it has none.

Source

pub fn decode_located( &self, cx: &mut ReadCx<'_>, input: Input, source_id: String, ) -> Result<LocatedExpr>

Decode input preserving origin, falling back to decode with no origin when the codec has no LocatedDecoder.

Source

pub fn decode_tree( &self, cx: &mut ReadCx<'_>, input: Input, source_id: String, ) -> Result<LocatedExprTree>

Decode input into a full tree, falling back to decode_located reconstructed recursively when the codec has no TreeDecoder.

Source

pub fn encode_located( &self, cx: &mut WriteCx<'_>, expr: &LocatedExpr, ) -> Result<Output>

Encode a LocatedExpr, using the origin-aware encoder only when lossless-origin output is requested; otherwise drop the origin and use encode.

Source

pub fn encode_tree( &self, cx: &mut WriteCx<'_>, expr: &LocatedExprTree, ) -> Result<Output>

Encode a LocatedExprTree, preferring the tree encoder then the located encoder for lossless-origin output, and otherwise dropping to encode on the bare expression.

Trait Implementations§

Source§

impl Object for CodecRuntime

Source§

fn display(&self, _cx: &mut Cx) -> Result<String>

Render the object as a human-readable display string.
Source§

fn as_any(&self) -> &dyn Any

Expose the object for Rust downcasting.
Source§

fn header(&self) -> &ObjectHeader

Identity and trust header for the object; defaults to the shared anonymous header.
Source§

fn op(&self, _key: &OpKey) -> Option<&dyn Op>

Resolve the operation registered under key, if any.
Source§

fn claims( &self, _cx: &mut Cx, _pattern: &ClaimPattern, _sink: &mut dyn ClaimSink, ) -> Result<(), Error>

Emit the object’s claims matching pattern into sink.
Source§

fn snapshot(&self, _cx: &mut Cx) -> Result<Option<Datum>, Error>

Optional content-addressable snapshot of the object’s state.
Source§

impl ObjectCompat for CodecRuntime

Source§

fn class(&self, cx: &mut Cx) -> Result<ClassRef>

Class object this value belongs to; defaults to nil.
Source§

fn as_expr(&self, _cx: &mut Cx) -> Result<Expr>

Expression form of the object; defaults to an opaque extension node.
Source§

fn as_table(&self, cx: &mut Cx) -> Result<Value>

Project the object into a table value; the default exposes its display.
Source§

fn as_callable(&self) -> Option<&dyn Callable>

Callable view, if the object can be invoked.
Source§

fn as_class(&self) -> Option<&dyn Class>

Class view, if the object is a class.
Source§

fn as_shape(&self) -> Option<&dyn Shape>

Shape view, if the object is a shape.
Source§

fn as_object_encoder(&self) -> Option<&dyn ObjectEncode>

Object-encoder view, if the object encodes other objects.
Source§

fn as_read_constructor(&self) -> Option<&dyn ReadConstructor>

Read-constructor view, if the object decodes data forms.
Source§

fn as_number_domain(&self) -> Option<&(dyn NumberDomain + 'static)>

Number-domain view, if the object is a number domain.
Source§

fn as_number_value(&self) -> Option<&dyn NumberValue>

Number-value view, if the object is a domain number.
Source§

fn as_eval_fabric(&self) -> Option<&dyn EvalFabric>

Eval-fabric view, if the object is a distributed eval surface.
Source§

fn as_stream(&self) -> Option<&dyn Stream>

Stream view, if the object is a stream.
Source§

fn as_sequence(&self) -> Option<&dyn Sequence>

Sequence view, if the object is a sequence.
Source§

fn as_thunk(&self) -> Option<&dyn Thunk>

Thunk view, if the object is a deferred computation.
Source§

fn as_list(&self) -> Option<&(dyn ListValue + 'static)>

List view, if the object is a list value.
Source§

fn as_table_impl(&self) -> Option<&(dyn Table + 'static)>

Table-implementation view, if the object is a table.
Source§

fn as_dir(&self) -> Option<&(dyn Dir + 'static)>

Directory view, if the object is a directory.
Source§

fn truth(&self, _cx: &mut Cx) -> Result<bool, Error>

Truthiness of the object; defaults to true.
Source§

fn publish_shape_satisfaction_claims( &self, _cx: &mut Cx, _shape: &Ref, ) -> Result<bool, Error>

Publish claims asserting that the object satisfies shape; returns whether any were published.

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> RuntimeObject for T
where T: Object + ObjectCompat + Any + Send + Sync,

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.