diff options
| author | Brian Anderson <banderson@mozilla.com> | 2012-11-16 14:10:17 -0800 |
|---|---|---|
| committer | Brian Anderson <banderson@mozilla.com> | 2012-11-16 14:10:17 -0800 |
| commit | 2374154ded19a247be0053d71f5bcdd22b95462a (patch) | |
| tree | 88864eee16e69562befe699ebdd66af1b5b91bdc /src/libsyntax/codemap.rs | |
| parent | 81d20156cd44358e47e5081635f28ea31c01a757 (diff) | |
| download | rust-2374154ded19a247be0053d71f5bcdd22b95462a.tar.gz rust-2374154ded19a247be0053d71f5bcdd22b95462a.zip | |
Stop storing char positions in CodeMap
Diffstat (limited to 'src/libsyntax/codemap.rs')
| -rw-r--r-- | src/libsyntax/codemap.rs | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/src/libsyntax/codemap.rs b/src/libsyntax/codemap.rs index 13f2ea4e210..5e600b48965 100644 --- a/src/libsyntax/codemap.rs +++ b/src/libsyntax/codemap.rs @@ -195,15 +195,15 @@ pub struct FileMap { name: FileName, substr: FileSubstr, src: @~str, - start_pos: FilePos, - mut lines: ~[FilePos], + start_pos: BytePos, + mut lines: ~[BytePos], multibyte_chars: DVec<MultiByteChar> } pub impl FileMap { static fn new_w_substr(+filename: FileName, +substr: FileSubstr, src: @~str, - +start_pos: FilePos) + +start_pos: BytePos) -> FileMap { return FileMap { name: filename, substr: substr, src: src, @@ -214,18 +214,18 @@ pub impl FileMap { } static fn new(+filename: FileName, src: @~str, - +start_pos: FilePos) + +start_pos: BytePos) -> FileMap { return FileMap::new_w_substr(filename, FssNone, src, start_pos); } - fn next_line(&self, +pos: FilePos) { + fn next_line(&self, +pos: BytePos) { self.lines.push(pos); } pub fn get_line(&self, line: int) -> ~str unsafe { - let begin: BytePos = self.lines[line].byte - self.start_pos.byte; + let begin: BytePos = self.lines[line] - self.start_pos; let begin = begin.to_uint(); let end = match str::find_char_from(*self.src, '\n', begin) { Some(e) => e, @@ -266,11 +266,11 @@ pub impl CodeMap { let expected_byte_pos = if self.files.len() == 0 { 0 } else { - let last_start = self.files.last().start_pos.byte.to_uint(); + let last_start = self.files.last().start_pos.to_uint(); let last_len = self.files.last().src.len(); last_start + last_len }; - let actual_byte_pos = filemap.start_pos.byte.to_uint(); + let actual_byte_pos = filemap.start_pos.to_uint(); debug!("codemap: adding filemap: %s", filemap.name); debug!("codemap: expected offset: %u", expected_byte_pos); debug!("codemap: actual offset: %u", actual_byte_pos); @@ -301,7 +301,7 @@ pub impl CodeMap { } FssInternal(sp) => { self.lookup_char_pos_adj( - sp.lo + (pos - loc.file.start_pos.byte)) + sp.lo + (pos - loc.file.start_pos)) } FssExternal(eloc) => { {filename: /* FIXME (#2543) */ copy eloc.filename, @@ -318,8 +318,8 @@ pub impl CodeMap { FssNone => sp, FssInternal(s) => { self.adjust_span(span { - lo: s.lo + (sp.lo - line.fm.start_pos.byte), - hi: s.lo + (sp.hi - line.fm.start_pos.byte), + lo: s.lo + (sp.lo - line.fm.start_pos), + hi: s.lo + (sp.hi - line.fm.start_pos), expn_info: sp.expn_info }) } @@ -374,7 +374,7 @@ priv impl CodeMap { let mut b = len; while b - a > 1u { let m = (a + b) / 2u; - if self.files[m].start_pos.byte > pos { + if self.files[m].start_pos > pos { b = m; } else { a = m; @@ -397,7 +397,7 @@ priv impl CodeMap { let mut b = vec::len(f.lines); while b - a > 1u { let m = (a + b) / 2u; - if f.lines[m].byte > pos { b = m; } else { a = m; } + if f.lines[m] > pos { b = m; } else { a = m; } } return {fm: f, line: a}; } @@ -406,7 +406,7 @@ priv impl CodeMap { let {fm: f, line: a} = self.lookup_line(pos); let line = a + 1u; // Line numbers start at 1 let chpos = self.bytepos_to_local_charpos(pos); - let linebpos = f.lines[a].byte; + let linebpos = f.lines[a]; let linechpos = self.bytepos_to_local_charpos(linebpos); debug!("codemap: byte pos %? is on the line at byte pos %?", pos, linebpos); @@ -432,7 +432,7 @@ priv impl CodeMap { -> {fm: @FileMap, pos: BytePos} { let idx = self.lookup_filemap_idx(bpos); let fm = self.files[idx]; - let offset = bpos - fm.start_pos.byte; + let offset = bpos - fm.start_pos; return {fm: fm, pos: offset}; } |
