pub struct Type<'ast> {
pub typ: TypeUnr<'ast>,
pub pos: TermPos,
}Expand description
Concrete, recursive type for a Nickel type.
Fields§
§typ: TypeUnr<'ast>§pos: TermPosImplementations§
Trait Implementations§
Source§impl CloneTo for Type<'_>
impl CloneTo for Type<'_>
Source§impl<'ast> From<TypeF<&'ast Type<'ast>, RecordRows<'ast>, EnumRows<'ast>, &'ast Ast<'ast>>> for Type<'ast>
impl<'ast> From<TypeF<&'ast Type<'ast>, RecordRows<'ast>, EnumRows<'ast>, &'ast Ast<'ast>>> for Type<'ast>
Source§impl<'ast> TraverseAlloc<'ast, Ast<'ast>> for Type<'ast>
impl<'ast> TraverseAlloc<'ast, Ast<'ast>> for Type<'ast>
Source§fn traverse<F, E>(
self,
alloc: &'ast AstAlloc,
f: &mut F,
order: TraverseOrder,
) -> Result<Self, E>
fn traverse<F, E>( self, alloc: &'ast AstAlloc, f: &mut F, order: TraverseOrder, ) -> Result<Self, E>
Same as Traverse::traverse, but takes an additional AST allocator.
Source§fn traverse_ref<S, U>(
&'ast self,
f: &mut dyn FnMut(&'ast Ast<'ast>, &S) -> TraverseControl<S, U>,
state: &S,
) -> Option<U>
fn traverse_ref<S, U>( &'ast self, f: &mut dyn FnMut(&'ast Ast<'ast>, &S) -> TraverseControl<S, U>, state: &S, ) -> Option<U>
Same as Traverse::traverse_ref, but takes an additional AST allocator. Read more
fn find_map<S>(&'ast self, pred: impl FnMut(&'ast T) -> Option<S>) -> Option<S>where
T: Clone + 'ast,
Source§impl<'ast> TraverseAlloc<'ast, Type<'ast>> for Ast<'ast>
impl<'ast> TraverseAlloc<'ast, Type<'ast>> for Ast<'ast>
Source§fn traverse<F, E>(
self,
alloc: &'ast AstAlloc,
f: &mut F,
order: TraverseOrder,
) -> Result<Ast<'ast>, E>
fn traverse<F, E>( self, alloc: &'ast AstAlloc, f: &mut F, order: TraverseOrder, ) -> Result<Ast<'ast>, E>
Same as Traverse::traverse, but takes an additional AST allocator.
Source§fn traverse_ref<S, U>(
&'ast self,
f: &mut dyn FnMut(&'ast Type<'ast>, &S) -> TraverseControl<S, U>,
state: &S,
) -> Option<U>
fn traverse_ref<S, U>( &'ast self, f: &mut dyn FnMut(&'ast Type<'ast>, &S) -> TraverseControl<S, U>, state: &S, ) -> Option<U>
Same as Traverse::traverse_ref, but takes an additional AST allocator. Read more
fn find_map<S>(&'ast self, pred: impl FnMut(&'ast T) -> Option<S>) -> Option<S>where
T: Clone + 'ast,
Source§impl<'ast> TraverseAlloc<'ast, Type<'ast>> for RecordRows<'ast>
impl<'ast> TraverseAlloc<'ast, Type<'ast>> for RecordRows<'ast>
Source§fn traverse<F, E>(
self,
alloc: &'ast AstAlloc,
f: &mut F,
order: TraverseOrder,
) -> Result<RecordRows<'ast>, E>
fn traverse<F, E>( self, alloc: &'ast AstAlloc, f: &mut F, order: TraverseOrder, ) -> Result<RecordRows<'ast>, E>
Same as Traverse::traverse, but takes an additional AST allocator.
Source§fn traverse_ref<S, U>(
&'ast self,
f: &mut dyn FnMut(&'ast Type<'ast>, &S) -> TraverseControl<S, U>,
state: &S,
) -> Option<U>
fn traverse_ref<S, U>( &'ast self, f: &mut dyn FnMut(&'ast Type<'ast>, &S) -> TraverseControl<S, U>, state: &S, ) -> Option<U>
Same as Traverse::traverse_ref, but takes an additional AST allocator. Read more
fn find_map<S>(&'ast self, pred: impl FnMut(&'ast T) -> Option<S>) -> Option<S>where
T: Clone + 'ast,
Source§impl<'ast> TraverseAlloc<'ast, Type<'ast>> for Type<'ast>
impl<'ast> TraverseAlloc<'ast, Type<'ast>> for Type<'ast>
Source§fn traverse<F, E>(
self,
alloc: &'ast AstAlloc,
f: &mut F,
order: TraverseOrder,
) -> Result<Self, E>
fn traverse<F, E>( self, alloc: &'ast AstAlloc, f: &mut F, order: TraverseOrder, ) -> Result<Self, E>
Same as Traverse::traverse, but takes an additional AST allocator.
Source§fn traverse_ref<S, U>(
&'ast self,
f: &mut dyn FnMut(&'ast Type<'ast>, &S) -> TraverseControl<S, U>,
state: &S,
) -> Option<U>
fn traverse_ref<S, U>( &'ast self, f: &mut dyn FnMut(&'ast Type<'ast>, &S) -> TraverseControl<S, U>, state: &S, ) -> Option<U>
Same as Traverse::traverse_ref, but takes an additional AST allocator. Read more
fn find_map<S>(&'ast self, pred: impl FnMut(&'ast T) -> Option<S>) -> Option<S>where
T: Clone + 'ast,
impl Allocable for Type<'_>
impl<'ast> Eq for Type<'ast>
impl<'ast> StructuralPartialEq for Type<'ast>
Auto Trait Implementations§
impl<'ast> Freeze for Type<'ast>
impl<'ast> RefUnwindSafe for Type<'ast>
impl<'ast> Send for Type<'ast>
impl<'ast> Sync for Type<'ast>
impl<'ast> Unpin for Type<'ast>
impl<'ast> UnsafeUnpin for Type<'ast>
impl<'ast> UnwindSafe for Type<'ast>
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more