Expand description
Source positions and related helper functions.
Important concepts in this module include:
- the span, represented by SpanDataand related types;
- source code as represented by a SourceMap; and
- interned strings, represented by Symbols, with some common symbols available statically in thesymmodule.
Unlike most compilers, the span contains not only the position in the source code, but also
various other metadata, such as the edition and macro hygiene. This metadata is stored in
SyntaxContext and ExpnData.
§Note
This API is completely unstable and subject to change.
Re-exports§
- pub use hygiene::DesugaringKind;
- pub use hygiene::ExpnData;
- pub use hygiene::ExpnHash;
- pub use hygiene::ExpnId;
- pub use hygiene::ExpnKind;
- pub use hygiene::LocalExpnId;
- pub use hygiene::MacroKind;
- pub use hygiene::SyntaxContext;
- pub use symbol::ByteSymbol;
- pub use symbol::Ident;
- pub use symbol::MacroRulesNormalizedIdent;
- pub use symbol::Macros20NormalizedIdent;
- pub use symbol::STDLIB_STABLE_CRATES;
- pub use symbol::Symbol;
- pub use symbol::kw;
- pub use symbol::sym;
Modules§
- analyze_source_ 🔒file 
- caching_source_ 🔒map_ view 
- def_id
- edit_distance 
- Edit distances.
- edition
- fatal_error 
- hygiene
- Machinery for hygienic macros.
- profiling
- source_map 
- Types for tracking pieces of source code within a crate.
- span_encoding 🔒
- symbol
- An “interner” is a data structure that associates values with usize tags and allows bidirectional lookup; i.e., given a value, one can easily find the type, and vice versa.
Macros§
- impl_pos 🔒
Structs§
- AttrId
- BytePos
- A byte offset.
- CachingSource MapView 
- CharPos
- A character offset.
- DistinctSources 
- ErrorGuaranteed 
- Useful type to use with Result<>indicate that an error has already been reported to the user, so no need to continue checking.
- FileLines 
- FileName Display 
- InnerSpan 
- Range inside of a Spanused for diagnostics when we only have access to relative positions.
- LineInfo 
- Loc
- A source code location used for error reporting.
- MalformedSource MapPositions 
- MetavarSpans Map 
- MultiByte Char 
- Identifies an offset of a multi-byte character in a SourceFile.
- NormalizedPos 
- Identifies an offset of a character that was normalized away from SourceFile.
- OffsetOverflow Error 
- RelativeByte Pos 
- A byte offset relative to file beginning.
- SessionGlobals 
- Per-session global variables: this struct is stored in thread-local storage in such a way that it is accessible without any kind of handle to all threads within the compilation session, but is not accessible outside the session.
- SourceFile 
- A single source in the SourceMap.
- SourceFile AndByte Pos 
- SourceFile AndLine 
- SourceFile Diffs 
- The source file lines in difference list form. This matches the form used within metadata, which saves space by exploiting the fact that the lines list is sorted and individual lines are usually not that long.
- SourceFile Hash 
- The hash of the on-disk source file used for debug info and cargo freshness checks.
- Span
- A compressed span.
- SpanData 
- Represents a span.
- StableSource File Id 
- This is a SourceFile identifier that is used to correlate source files between subsequent compilation sessions (which is something we need to do during incremental compilation).
Enums§
- ExternalSource 
- ExternalSource Kind 
- The state of the lazy external source loading mechanism of a SourceFile.
- FileName 
- Differentiates between real files and common virtual files.
- FileName Display Preference 
- FileName Embeddable Preference 
- RealFile Name 
- SourceFile Hash Algorithm 
- SourceFile Lines 
- SpanLines Error 
- SpanSnippet Error 
Constants§
- DUMMY_SP 
- The dummy span has zero position, length, and context, and no parent.
Statics§
Traits§
- HashStable Context 
- Requirements for a StableHashingContextto be used in this crate.
- Pos
- SpanDecoder 
- This trait is used to allow decoder specific encodings of certain types. It is similar to rustc_type_ir’s TyDecoder.
- SpanEncoder 
- This trait is used to allow encoder specific encodings of certain types. It is similar to rustc_type_ir’s TyEncoder.
Functions§
- char_width 
- create_default_ session_ globals_ then 
- Default edition, no source map.
- create_session_ globals_ then 
- create_session_ if_ not_ set_ then 
- No source map.
- normalize_newlines 🔒
- Replaces \r\nwith\nin-place insrc.
- normalize_src 🔒
- Normalizes the source code and records the normalizations.
- remove_bom 🔒
- Removes UTF-8 BOM, if any.
- set_session_ globals_ then 
- str_width 
- with_metavar_ spans 
- with_session_ globals