auto merge of #8037 : graydon/rust/issue-6416, r=cmr

Errors only turn into failures in the parser when you force them.
This commit is contained in:
bors 2013-07-26 06:13:53 -07:00
commit 382b037252
2 changed files with 24 additions and 9 deletions

View File

@ -384,12 +384,10 @@ mod test {
span:sp(0,6)})
}
// FIXME (#6416): For some reason, this fails and causes a test failure, even though it's
// marked as `#[should_fail]`.
/*#[should_fail]
#[should_fail]
#[test] fn bad_path_expr_1() {
string_to_expr(@"::abc::def::return");
}*/
}
#[test] fn string_to_tts_1 () {
let (tts,_ps) = string_to_tts_and_sess(@"fn a (b : int) { b; }");

View File

@ -33,29 +33,46 @@ pub fn string_to_parser(source_str: @str) -> Parser {
p
}
fn with_error_checking_parse<T>(s: @str, f: &fn(&mut Parser) -> T) -> T {
let mut p = string_to_parser(s);
let x = f(&mut p);
p.abort_if_errors();
x
}
pub fn string_to_crate (source_str : @str) -> @ast::Crate {
string_to_parser(source_str).parse_crate_mod()
do with_error_checking_parse(source_str) |p| {
p.parse_crate_mod()
}
}
// parse a string, return an expr
pub fn string_to_expr (source_str : @str) -> @ast::expr {
string_to_parser(source_str).parse_expr()
do with_error_checking_parse(source_str) |p| {
p.parse_expr()
}
}
// parse a string, return an item
pub fn string_to_item (source_str : @str) -> Option<@ast::item> {
string_to_parser(source_str).parse_item(~[])
do with_error_checking_parse(source_str) |p| {
p.parse_item(~[])
}
}
// parse a string, return an item and the ParseSess
pub fn string_to_item_and_sess (source_str : @str) -> (Option<@ast::item>,@mut ParseSess) {
let (p,ps) = string_to_parser_and_sess(source_str);
(p.parse_item(~[]),ps)
let io = p.parse_item(~[]);
p.abort_if_errors();
(io,ps)
}
// parse a string, return a stmt
pub fn string_to_stmt(source_str : @str) -> @ast::stmt {
string_to_parser(source_str).parse_stmt(~[])
do with_error_checking_parse(source_str) |p| {
p.parse_stmt(~[])
}
}
// parse a string, return a pat. Uses "irrefutable"... which doesn't