pub struct TableShape { /* private fields */ }Expand description
Shape for table values or map expressions with named field constraints.
Required fields must be present and accepted by their field shapes. Extra
fields are controlled by TableExtraPolicy.
let shape = TableShape::single(
Symbol::new("ok"),
Arc::new(ExprKindShape::new(ExprKind::Bool)),
);
let expr = Expr::Map(vec![(Expr::Symbol(Symbol::new("ok")), Expr::Bool(true))]);
assert!(shape.check_expr(&mut cx, &expr).unwrap().accepted);Implementations§
Source§impl TableShape
impl TableShape
Sourcepub fn single(key: Symbol, shape: Arc<dyn Shape>) -> Self
pub fn single(key: Symbol, shape: Arc<dyn Shape>) -> Self
Build a table shape requiring a single named field, allowing extras.
Sourcepub fn new(fields: Vec<TableFieldSpec>, extra: TableExtraPolicy) -> Self
pub fn new(fields: Vec<TableFieldSpec>, extra: TableExtraPolicy) -> Self
Build a table shape from explicit field specs and an extra-key policy.
Sourcepub fn fields(&self) -> &[TableFieldSpec]
pub fn fields(&self) -> &[TableFieldSpec]
Return the field constraints in declaration order.
Sourcepub fn extra(&self) -> &TableExtraPolicy
pub fn extra(&self) -> &TableExtraPolicy
Return the policy applied to keys not listed in the field specs.
Trait Implementations§
Source§impl Clone for TableShape
impl Clone for TableShape
Source§fn clone(&self) -> TableShape
fn clone(&self) -> TableShape
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Shape for TableShape
impl Shape for TableShape
Source§fn is_total(&self) -> bool
fn is_total(&self) -> bool
Whether this shape accepts every input in its domain;
false by default.Source§fn is_effectful(&self) -> bool
fn is_effectful(&self) -> bool
Whether matching this shape may run effects;
false by default.Source§fn is_subshape_of(
&self,
cx: &mut Cx,
parent: &dyn Shape,
) -> Result<Option<bool>>
fn is_subshape_of( &self, cx: &mut Cx, parent: &dyn Shape, ) -> Result<Option<bool>>
Return a concrete implication answer when this shape owns the semantics. Read more
Source§fn check_value(&self, cx: &mut Cx, value: Value) -> Result<ShapeMatch>
fn check_value(&self, cx: &mut Cx, value: Value) -> Result<ShapeMatch>
Check a
Value against this shape, yielding a ShapeMatch.Source§fn check_expr(&self, cx: &mut Cx, expr: &Expr) -> Result<ShapeMatch>
fn check_expr(&self, cx: &mut Cx, expr: &Expr) -> Result<ShapeMatch>
Check an
Expr against this shape, yielding a ShapeMatch.Source§fn describe(&self, cx: &mut Cx) -> Result<ShapeDoc>
fn describe(&self, cx: &mut Cx) -> Result<ShapeDoc>
Produce the human-facing
ShapeDoc for this shape.Auto Trait Implementations§
impl !RefUnwindSafe for TableShape
impl !UnwindSafe for TableShape
impl Freeze for TableShape
impl Send for TableShape
impl Sync for TableShape
impl Unpin for TableShape
impl UnsafeUnpin for TableShape
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Callable for Twhere
T: Shape,
impl<T> Callable for Twhere
T: Shape,
Source§fn call(&self, cx: &mut Cx, args: Args) -> Result<Value, Error>
fn call(&self, cx: &mut Cx, args: Args) -> Result<Value, Error>
Invoke the callable with already-evaluated, checked
Args.Source§fn call_exprs(&self, cx: &mut Cx, args: RawArgs) -> Result<Value, Error>
fn call_exprs(&self, cx: &mut Cx, args: RawArgs) -> Result<Value, Error>
Invoke the callable on raw, unevaluated argument expressions. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Object for T
impl<T> Object for T
Source§fn display(&self, cx: &mut Cx) -> Result<String, Error>
fn display(&self, cx: &mut Cx) -> Result<String, Error>
Render the object as a human-readable display string.
Source§fn header(&self) -> &ObjectHeader
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>
fn op(&self, _key: &OpKey) -> Option<&dyn Op>
Resolve the operation registered under
key, if any.Source§impl<T> ObjectCompat for T
impl<T> ObjectCompat for T
Source§fn class(&self, cx: &mut Cx) -> Result<Value, Error>
fn class(&self, cx: &mut Cx) -> Result<Value, Error>
Class object this value belongs to; defaults to nil.
Source§fn as_table(&self, cx: &mut Cx) -> Result<Value, Error>
fn as_table(&self, cx: &mut Cx) -> Result<Value, Error>
Project the object into a table value; the default exposes its display.
Source§fn as_callable(&self) -> Option<&dyn Callable>
fn as_callable(&self) -> Option<&dyn Callable>
Callable view, if the object can be invoked.
Source§fn as_object_encoder(&self) -> Option<&dyn ObjectEncode>
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>
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)>
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>
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>
fn as_eval_fabric(&self) -> Option<&dyn EvalFabric>
Eval-fabric view, if the object is a distributed eval surface.
Source§fn as_sequence(&self) -> Option<&dyn Sequence>
fn as_sequence(&self) -> Option<&dyn Sequence>
Sequence view, if the object is a sequence.
Source§fn as_list(&self) -> Option<&(dyn ListValue + 'static)>
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)>
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)>
fn as_dir(&self) -> Option<&(dyn Dir + 'static)>
Directory view, if the object is a directory.
Source§fn as_expr(&self, cx: &mut Cx) -> Result<Expr, Error>
fn as_expr(&self, cx: &mut Cx) -> Result<Expr, Error>
Expression form of the object; defaults to an opaque extension node.