pub struct Span(/* private fields */);Expand description
Defines a range in a file.
This is used throughout the compiler to track which source section an element stems from or an error applies to.
- The .id()function can be used to get theFileIdfor the span and, by extension, its file system path.
- The WorldExt::rangefunction can be used to map the span to aRange<usize>.
This type takes up 8 bytes and is copyable and null-optimized (i.e.
Option<Span> also takes 8 bytes).
Spans come in two flavors: Numbered spans and raw range spans. The
WorldExt::range function automatically handles both cases, yielding a
Range<usize>.
§Numbered spans
Typst source files use numbered spans. Rather than using byte ranges, which shift a lot as you type, each AST node gets a unique number.
During editing, the span numbers stay mostly stable, even for nodes behind an insertion. This is not true for simple ranges as they would shift. Spans can be used as inputs to memoized functions without hurting cache performance when text is inserted somewhere in the document other than the end.
Span ids are ordered in the syntax tree to enable quickly finding the node with some id:
- The id of a parent is always smaller than the ids of any of its children.
- The id of a node is always greater than any id in the subtrees of any left sibling and smaller than any id in the subtrees of any right sibling.
§Raw range spans
Non Typst-files use raw ranges instead of numbered spans. The maximum encodable value for start and end is 2^23. Larger values will be saturated.
Implementations§
Source§impl Span
 
impl Span
Sourcepub const fn from_range(id: FileId, range: Range<usize>) -> Self
 
pub const fn from_range(id: FileId, range: Range<usize>) -> Self
Create a new span from a raw byte range instead of a span number.
If one of the range’s parts exceeds the maximum value (2^23), it is saturated.
Sourcepub const fn from_raw(v: NonZeroU64) -> Self
 
pub const fn from_raw(v: NonZeroU64) -> Self
Construct from a raw number.
Should only be used with numbers retrieved via
into_raw. Misuse may results in panics, but no
unsafety.
Sourcepub const fn is_detached(self) -> bool
 
pub const fn is_detached(self) -> bool
Whether the span is detached.
Sourcepub const fn id(self) -> Option<FileId>
 
pub const fn id(self) -> Option<FileId>
The id of the file the span points into.
Returns None if the span is detached.
Sourcepub const fn range(self) -> Option<Range<usize>>
 
pub const fn range(self) -> Option<Range<usize>>
Extract a raw byte range from the span, if it is a raw range span.
Typically, you should use WorldExt::range instead.
Sourcepub const fn into_raw(self) -> NonZeroU64
 
pub const fn into_raw(self) -> NonZeroU64
Extract the raw underlying number.
Sourcepub fn find(iter: impl IntoIterator<Item = Self>) -> Self
 
pub fn find(iter: impl IntoIterator<Item = Self>) -> Self
Find the first non-detached span in the iterator.
Trait Implementations§
impl Copy for Span
impl Eq for Span
impl StructuralPartialEq for Span
Auto Trait Implementations§
impl Freeze for Span
impl RefUnwindSafe for Span
impl Send for Span
impl Sync for Span
impl Unpin for Span
impl UnwindSafe for Span
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
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
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>
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>
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