Skip to content

Commit

Permalink
syntax: Fix rust-lang#6416 by aborting on errors after test parse.
Browse files Browse the repository at this point in the history
  • Loading branch information
graydon committed Jul 25, 2013
1 parent ba9c3eb commit c3417b8
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 9 deletions.
6 changes: 2 additions & 4 deletions src/libsyntax/parse/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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; }");
Expand Down
27 changes: 22 additions & 5 deletions src/libsyntax/util/parser_testing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down

0 comments on commit c3417b8

Please sign in to comment.