diff --git a/src/libsyntax/codemap.rs b/src/libsyntax/codemap.rs index d2fe667339c..592fdd7207c 100644 --- a/src/libsyntax/codemap.rs +++ b/src/libsyntax/codemap.rs @@ -52,35 +52,71 @@ impl Pos for BytePos { fn to_uint(&self) -> uint { let BytePos(n) = *self; n as uint } } +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Add for BytePos { fn add(&self, rhs: &BytePos) -> BytePos { BytePos((self.to_uint() + rhs.to_uint()) as u32) } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Add for BytePos { + fn add(self, rhs: BytePos) -> BytePos { + BytePos((self.to_uint() + rhs.to_uint()) as u32) + } +} + +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Sub for BytePos { fn sub(&self, rhs: &BytePos) -> BytePos { BytePos((self.to_uint() - rhs.to_uint()) as u32) } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Sub for BytePos { + fn sub(self, rhs: BytePos) -> BytePos { + BytePos((self.to_uint() - rhs.to_uint()) as u32) + } +} + impl Pos for CharPos { fn from_uint(n: uint) -> CharPos { CharPos(n) } fn to_uint(&self) -> uint { let CharPos(n) = *self; n } } +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Add for CharPos { fn add(&self, rhs: &CharPos) -> CharPos { CharPos(self.to_uint() + rhs.to_uint()) } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Add for CharPos { + fn add(self, rhs: CharPos) -> CharPos { + CharPos(self.to_uint() + rhs.to_uint()) + } +} + +// NOTE(stage0): Remove impl after a snapshot +#[cfg(stage0)] impl Sub for CharPos { fn sub(&self, rhs: &CharPos) -> CharPos { CharPos(self.to_uint() - rhs.to_uint()) } } +#[cfg(not(stage0))] // NOTE(stage0): Remove cfg after a snapshot +impl Sub for CharPos { + fn sub(self, rhs: CharPos) -> CharPos { + CharPos(self.to_uint() - rhs.to_uint()) + } +} + /// Spans represent a region of code, used for error reporting. Positions in spans /// are *absolute* positions from the beginning of the codemap, not positions /// relative to FileMaps. Methods on the CodeMap can be used to relate spans back