Skip to content

Commit

Permalink
Use appropriate terminology based on heuristic
Browse files Browse the repository at this point in the history
  • Loading branch information
estebank committed Nov 30, 2018
1 parent 0952856 commit 2645871
Show file tree
Hide file tree
Showing 16 changed files with 58 additions and 29 deletions.
37 changes: 24 additions & 13 deletions src/libsyntax/parse/parser.rs
Expand Up @@ -6134,9 +6134,6 @@ impl<'a> Parser<'a> {

fn consume_block(&mut self, delim: token::DelimToken) {
let mut brace_depth = 0;
if !self.eat(&token::OpenDelim(delim)) {
return;
}
loop {
if self.eat(&token::OpenDelim(delim)) {
brace_depth += 1;
Expand All @@ -6147,7 +6144,7 @@ impl<'a> Parser<'a> {
brace_depth -= 1;
continue;
}
} else if self.eat(&token::Eof) || self.eat(&token::CloseDelim(token::NoDelim)) {
} else if self.token == token::Eof || self.eat(&token::CloseDelim(token::NoDelim)) {
return;
} else {
self.bump();
Expand Down Expand Up @@ -7397,17 +7394,27 @@ impl<'a> Parser<'a> {
return Err(err);
} else if self.look_ahead(1, |t| *t == token::OpenDelim(token::Paren)) {
let ident = self.parse_ident().unwrap();
self.bump(); // `(`
let kw_name = if let Ok(Some(_)) = self.parse_self_arg() {
"method"
} else {
"function"
};
self.consume_block(token::Paren);
let (kw, kw_name, ambiguous) = if self.check(&token::RArrow) ||
self.check(&token::OpenDelim(token::Brace))
{
("fn", "method", false)
let (kw, kw_name, ambiguous) = if self.check(&token::RArrow) {
self.eat_to_tokens(&[&token::OpenDelim(token::Brace)]);
self.bump(); // `{`
("fn", kw_name, false)
} else if self.check(&token::OpenDelim(token::Brace)) {
self.bump(); // `{`
("fn", kw_name, false)
} else if self.check(&token::Colon) {
let kw = "struct";
(kw, kw, false)
} else {
("fn` or `struct", "method or struct", true)
("fn` or `struct", "function or struct", true)
};
self.consume_block(token::Brace);

let msg = format!("missing `{}` for {} definition", kw, kw_name);
let mut err = self.diagnostic().struct_span_err(sp, &msg);
Expand Down Expand Up @@ -7437,13 +7444,17 @@ impl<'a> Parser<'a> {
} else if self.look_ahead(1, |t| *t == token::Lt) {
let ident = self.parse_ident().unwrap();
self.eat_to_tokens(&[&token::Gt]);
self.bump();
let (kw, kw_name, ambiguous) = if self.check(&token::OpenDelim(token::Paren)) {
("fn", "method", false)
self.bump(); // `>`
let (kw, kw_name, ambiguous) = if self.eat(&token::OpenDelim(token::Paren)) {
if let Ok(Some(_)) = self.parse_self_arg() {
("fn", "method", false)
} else {
("fn", "function", false)
}
} else if self.check(&token::OpenDelim(token::Brace)) {
("struct", "struct", false)
} else {
("fn` or `struct", "method or struct", true)
("fn` or `struct", "function or struct", true)
};
let msg = format!("missing `{}` for {} definition", kw, kw_name);
let mut err = self.diagnostic().struct_span_err(sp, &msg);
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn-2.rs
Expand Up @@ -9,7 +9,7 @@
// except according to those terms.

pub foo(s: usize) { bar() }
//~^ ERROR missing `fn` for method definition
//~^ ERROR missing `fn` for function definition

fn main() {
foo(2);
Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/pub/pub-ident-fn-2.stderr
@@ -1,9 +1,9 @@
error: missing `fn` for method definition
error: missing `fn` for function definition
--> $DIR/pub-ident-fn-2.rs:11:4
|
LL | pub foo(s: usize) { bar() }
| ^
help: add `fn` here to parse `foo` as a public method
help: add `fn` here to parse `foo` as a public function
|
LL | pub fn foo(s: usize) { bar() }
| ^^
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn-or-struct-2.rs
Expand Up @@ -9,6 +9,6 @@
// except according to those terms.

pub S();
//~^ ERROR missing `fn` or `struct` for method or struct definition
//~^ ERROR missing `fn` or `struct` for function or struct definition

fn main() {}
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn-or-struct-2.stderr
@@ -1,4 +1,4 @@
error: missing `fn` or `struct` for method or struct definition
error: missing `fn` or `struct` for function or struct definition
--> $DIR/pub-ident-fn-or-struct-2.rs:11:4
|
LL | pub S();
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn-or-struct.rs
Expand Up @@ -9,6 +9,6 @@
// except according to those terms.

pub S (foo) bar
//~^ ERROR missing `fn` or `struct` for method or struct definition
//~^ ERROR missing `fn` or `struct` for function or struct definition

fn main() {}
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn-or-struct.stderr
@@ -1,4 +1,4 @@
error: missing `fn` or `struct` for method or struct definition
error: missing `fn` or `struct` for function or struct definition
--> $DIR/pub-ident-fn-or-struct.rs:11:4
|
LL | pub S (foo) bar
Expand Down
6 changes: 6 additions & 0 deletions src/test/ui/pub/pub-ident-fn-with-lifetime-2.rs
@@ -0,0 +1,6 @@
pub bar<'a>(&self, _s: &'a usize) -> bool { true }
//~^ ERROR missing `fn` for method definition

fn main() {
bar(2);
}
12 changes: 12 additions & 0 deletions src/test/ui/pub/pub-ident-fn-with-lifetime-2.stderr
@@ -0,0 +1,12 @@
error: missing `fn` for method definition
--> $DIR/pub-ident-fn-with-lifetime-2.rs:1:4
|
LL | pub bar<'a>(&self, _s: &'a usize) -> bool { true }
| ^^^
help: add `fn` here to parse `bar` as a public method
|
LL | pub fn bar<'a>(&self, _s: &'a usize) -> bool { true }
| ^^

error: aborting due to previous error

2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn-with-lifetime.rs
@@ -1,5 +1,5 @@
pub foo<'a>(_s: &'a usize) -> bool { true }
//~^ ERROR missing `fn` for method definition
//~^ ERROR missing `fn` for function definition

fn main() {
foo(2);
Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/pub/pub-ident-fn-with-lifetime.stderr
@@ -1,9 +1,9 @@
error: missing `fn` for method definition
error: missing `fn` for function definition
--> $DIR/pub-ident-fn-with-lifetime.rs:1:4
|
LL | pub foo<'a>(_s: &'a usize) -> bool { true }
| ^^^
help: add `fn` here to parse `foo` as a public method
help: add `fn` here to parse `foo` as a public function
|
LL | pub fn foo<'a>(_s: &'a usize) -> bool { true }
| ^^
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn.fixed
Expand Up @@ -11,7 +11,7 @@
// run-rustfix

pub fn foo(_s: usize) -> bool { true }
//~^ ERROR missing `fn` for method definition
//~^ ERROR missing `fn` for function definition

fn main() {
foo(2);
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-fn.rs
Expand Up @@ -11,7 +11,7 @@
// run-rustfix

pub foo(_s: usize) -> bool { true }
//~^ ERROR missing `fn` for method definition
//~^ ERROR missing `fn` for function definition

fn main() {
foo(2);
Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/pub/pub-ident-fn.stderr
@@ -1,9 +1,9 @@
error: missing `fn` for method definition
error: missing `fn` for function definition
--> $DIR/pub-ident-fn.rs:13:4
|
LL | pub foo(_s: usize) -> bool { true }
| ^^^
help: add `fn` here to parse `foo` as a public method
help: add `fn` here to parse `foo` as a public function
|
LL | pub fn foo(_s: usize) -> bool { true }
| ^^
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-with-lifetime-incomplete.rs
Expand Up @@ -2,4 +2,4 @@ fn main() {
}

pub foo<'a>
//~^ ERROR missing `fn` or `struct` for method or struct definition
//~^ ERROR missing `fn` or `struct` for function or struct definition
2 changes: 1 addition & 1 deletion src/test/ui/pub/pub-ident-with-lifetime-incomplete.stderr
@@ -1,4 +1,4 @@
error: missing `fn` or `struct` for method or struct definition
error: missing `fn` or `struct` for function or struct definition
--> $DIR/pub-ident-with-lifetime-incomplete.rs:4:4
|
LL | pub foo<'a>
Expand Down

0 comments on commit 2645871

Please sign in to comment.