swc/common/src/pos.rs

88 lines
1.8 KiB
Rust
Raw Normal View History

#[cfg(feature = "fold")]
use crate::fold::{FoldWith, VisitWith};
pub use crate::syntax_pos::{
2019-02-27 11:44:11 +03:00
hygiene, BytePos, CharPos, ExpnInfo, FileName, Globals, Loc, LocWithOpt, Mark, MultiSpan,
SourceFile, SourceFileAndBytePos, SourceFileAndLine, Span, SpanData, SpanLinesError,
2019-04-13 14:55:38 +03:00
SyntaxContext, CM, DUMMY_SP, GLOBALS, NO_EXPANSION,
};
///
/// # Derive
/// This trait can be derived with `#[derive(Spanned)]`.
pub trait Spanned {
/// Get span of `self`.
fn span(&self) -> Span;
}
2018-03-04 08:41:59 +03:00
impl Spanned for Span {
#[inline(always)]
fn span(&self) -> Span {
*self
}
}
impl Spanned for BytePos {
/// Creates a new single-byte span.
#[inline(always)]
fn span(&self) -> Span {
Span::new(*self, *self, Default::default())
}
}
impl<S> Spanned for Option<S>
where
S: Spanned,
{
fn span(&self) -> Span {
match *self {
Some(ref s) => s.span(),
None => DUMMY_SP,
}
}
}
impl<S> Spanned for Box<S>
where
S: ?Sized + Spanned,
{
fn span(&self) -> Span {
<S as Spanned>::span(&*self)
}
}
2018-03-04 08:12:17 +03:00
impl<'a, S> Spanned for &'a S
where
S: ?Sized + Spanned,
{
fn span(&self) -> Span {
<S as Spanned>::span(&*self)
}
}
impl<A, B> Spanned for ::either::Either<A, B>
where
A: Spanned,
B: Spanned,
{
fn span(&self) -> Span {
match *self {
::either::Either::Left(ref n) => n.span(),
::either::Either::Right(ref n) => n.span(),
}
}
}
#[cfg(feature = "fold")]
impl<F> FoldWith<F> for Span {
/// No op as span does not have any child.
fn fold_children(self, _: &mut F) -> Span {
self
}
}
#[cfg(feature = "fold")]
impl<F> VisitWith<F> for Span {
/// No op as span does not have any child.
fn visit_children(&self, _: &mut F) {}
}