From 4af849bc12e8a2ec592074b1470464efa59f06bf Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Tue, 1 Oct 2013 14:41:59 -0700 Subject: Obsolete parsing 'loop' as 'continue' --- src/libsyntax/parse/obsolete.rs | 6 ++++++ src/libsyntax/parse/parser.rs | 1 + 2 files changed, 7 insertions(+) (limited to 'src/libsyntax/parse') diff --git a/src/libsyntax/parse/obsolete.rs b/src/libsyntax/parse/obsolete.rs index adf0c208da4..5a8563f963d 100644 --- a/src/libsyntax/parse/obsolete.rs +++ b/src/libsyntax/parse/obsolete.rs @@ -63,6 +63,7 @@ pub enum ObsoleteSyntax { ObsoleteTraitFuncVisibility, ObsoleteConstPointer, ObsoleteEmptyImpl, + ObsoleteLoopAsContinue, } impl to_bytes::IterBytes for ObsoleteSyntax { @@ -244,6 +245,11 @@ impl ParserObsoleteMethods for Parser { "empty implementation", "instead of `impl A;`, write `impl A {}`" ), + ObsoleteLoopAsContinue => ( + "`loop` instead of `continue`", + "`loop` is now only used for loops and `continue` is used for \ + skipping iterations" + ), }; self.report(sp, kind, kind_str, desc); diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index 4dd09cbcbd2..5c88c617950 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -2597,6 +2597,7 @@ impl Parser { "a label may not be used with a `loop` expression"); } + self.obsolete(*self.last_span, ObsoleteLoopAsContinue); let lo = self.span.lo; let ex = if self.token_is_lifetime(&*self.token) { let lifetime = self.get_lifetime(&*self.token); -- cgit 1.4.1-3-g733a5