Expand description
Utilities for the swc project
§Cargo features
§tty-emitter
Adds default implementation of Emitter. Enabling this feature will add tty-related dependencies.
§sourcemap
Adds methods to generate web sourcemap.
§plugin-base
Base mode for plugins, which can be enabled by plugin-mode or plugin-rt.
This mode creates a trait which can be used to override swc_common itself.
§plugin-rt
Creates an implementation for the plugin trait. This implements simply
invokes thread-locals declared in swc_common.
§plugin-mode
Allows replacing operations related to thread-local variables with a trait.
Re-exports§
pub use self::errors::SourceMapper;pub use self::errors::SourceMapperDyn;pub use self::source_map::FileLines;pub use self::source_map::FileLoader;pub use self::source_map::FilePathMapping;pub use self::source_map::SourceMap;pub use self::source_map::SpanSnippetError;
Modules§
- cache
- comments
- errors
- hygiene
- Machinery for hygienic macros, inspired by the
MTWT[1]paper. - input
- iter
- pass
- This module reexports items from
swc_visitwith some swc-specific traits. - plugin
- serializer
Deprecated - source_
map - The SourceMap tracks all the source code used within a single crate.
- sync
- This module defines types which are thread safe if
cfg!(feature = "concurrent")is true. - util
Macros§
Structs§
- BytePos
- A byte offset. Keep this small (currently 32-bits), as AST contains a lot of them.
- CharPos
- A character offset. Because of multibyte utf8 characters, a byte offset is not equivalent to a character offset. The SourceMap will convert BytePos values to CharPos values as necessary.
- Globals
- LineCol
- Used to create a
.mapfile. - Loc
- A source code location used for error reporting.
- LocWith
Opt - A source code location used as the result of
lookup_char_pos_adj - Mark
- A mark is a unique id associated with a macro expansion.
- Multi
Span - A collection of spans. Spans have two orthogonal attributes:
- Source
File - A single source in the SourceMap.
- Source
File AndByte Pos - Source
File AndLine - Span
- Spans represent a region of code, used for error reporting.
- Syntax
Context - A SyntaxContext represents a chain of macro expansions (represented by marks).
Enums§
Constants§
- DUMMY_
SP - Dummy span, both position and length are zero, syntax context is zero as well.
- NO_
EXPANSION
Statics§
- GLOBALS
- Storage for span hygiene data.
Traits§
- AstNode
- A trait for ast nodes.
- EqIgnore
Span - Derive with
#[derive(EqIgnoreSpan)]. - Spanned
- Derive
- TypeEq
- Derive with
#[derive(TypeEq)].
Attribute Macros§
- ast_
node - Alias for
#[derive(Spanned, Fold, Clone, Debug, PartialEq)]for a struct and#[derive(Spanned, Fold, Clone, Debug, PartialEq, FromVariant)]for an enum. - ast_
serde - Derives
serde::Serializeandserde::Deserialize.
Derive Macros§
- Deserialize
Enum - Derives
serde::Deserializewhich is aware oftagbased deserialization. - EqIgnore
Span - Derives
swc_common::EqIgnoreSpan. - From
Variant - Derives [
From] for all variants. This only supports an enum where every variant has a single field. - Spanned
- Derives [
swc_common::Spanned]. See [swc_common::Spanned] for documentation. - TypeEq
- Derives
swc_common::TypeEq.