2012-12-03 16:48:01 -08:00
|
|
|
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
2013-05-17 15:28:44 -07:00
|
|
|
use core::prelude::*;
|
|
|
|
|
2013-05-24 19:35:29 -07:00
|
|
|
use core::io;
|
|
|
|
use core::str;
|
|
|
|
|
2013-01-30 14:10:03 -08:00
|
|
|
pub struct ExpectedError { line: uint, kind: ~str, msg: ~str }
|
2012-01-03 21:01:48 -08:00
|
|
|
|
|
|
|
// Load any test directives embedded in the file
|
2013-01-30 14:10:03 -08:00
|
|
|
pub fn load_errors(testfile: &Path) -> ~[ExpectedError] {
|
2012-06-29 16:26:56 -07:00
|
|
|
let mut error_patterns = ~[];
|
2012-09-25 16:23:04 -07:00
|
|
|
let rdr = io::file_reader(testfile).get();
|
2012-03-22 08:39:41 -07:00
|
|
|
let mut line_num = 1u;
|
2012-01-03 21:01:48 -08:00
|
|
|
while !rdr.eof() {
|
|
|
|
let ln = rdr.read_line();
|
|
|
|
error_patterns += parse_expected(line_num, ln);
|
|
|
|
line_num += 1u;
|
|
|
|
}
|
2012-08-01 17:30:05 -07:00
|
|
|
return error_patterns;
|
2012-01-03 21:01:48 -08:00
|
|
|
}
|
|
|
|
|
2013-01-25 22:51:32 -08:00
|
|
|
fn parse_expected(line_num: uint, line: ~str) -> ~[ExpectedError] {
|
2013-04-09 02:08:16 -04:00
|
|
|
let error_tag = ~"//~";
|
|
|
|
let mut idx;
|
|
|
|
match str::find_str(line, error_tag) {
|
|
|
|
None => return ~[],
|
2013-06-10 00:44:58 +10:00
|
|
|
Some(nn) => { idx = (nn as uint) + error_tag.len(); }
|
2013-04-09 02:08:16 -04:00
|
|
|
}
|
2012-01-03 21:01:48 -08:00
|
|
|
|
2013-04-09 02:08:16 -04:00
|
|
|
// "//~^^^ kind msg" denotes a message expected
|
|
|
|
// three lines above current line:
|
|
|
|
let mut adjust_line = 0u;
|
2013-06-10 00:44:58 +10:00
|
|
|
let len = line.len();
|
2013-04-09 02:08:16 -04:00
|
|
|
while idx < len && line[idx] == ('^' as u8) {
|
|
|
|
adjust_line += 1u;
|
|
|
|
idx += 1u;
|
|
|
|
}
|
2012-01-03 21:01:48 -08:00
|
|
|
|
2013-04-09 02:08:16 -04:00
|
|
|
// Extract kind:
|
|
|
|
while idx < len && line[idx] == (' ' as u8) { idx += 1u; }
|
|
|
|
let start_kind = idx;
|
|
|
|
while idx < len && line[idx] != (' ' as u8) { idx += 1u; }
|
2013-04-23 11:08:13 +02:00
|
|
|
|
2013-04-23 18:20:55 +02:00
|
|
|
// FIXME: #4318 Instead of to_ascii and to_str_ascii, could use
|
|
|
|
// to_ascii_consume and to_str_consume to not do a unnecessary copy.
|
2013-06-10 00:44:58 +10:00
|
|
|
let kind = line.slice(start_kind, idx);
|
2013-04-23 18:20:55 +02:00
|
|
|
let kind = kind.to_ascii().to_lower().to_str_ascii();
|
2012-01-03 21:01:48 -08:00
|
|
|
|
2013-04-09 02:08:16 -04:00
|
|
|
// Extract msg:
|
|
|
|
while idx < len && line[idx] == (' ' as u8) { idx += 1u; }
|
2013-06-10 00:44:58 +10:00
|
|
|
let msg = line.slice(idx, len).to_owned();
|
2012-01-03 21:01:48 -08:00
|
|
|
|
2013-04-09 02:08:16 -04:00
|
|
|
debug!("line=%u kind=%s msg=%s", line_num - adjust_line, kind, msg);
|
2012-01-03 21:01:48 -08:00
|
|
|
|
2013-04-09 02:08:16 -04:00
|
|
|
return ~[ExpectedError{line: line_num - adjust_line, kind: kind,
|
|
|
|
msg: msg}];
|
2012-01-03 21:01:48 -08:00
|
|
|
}
|