about summary refs log tree commit diff
path: root/src/libsyntax/parse/parser.rs
diff options
context:
space:
mode:
authorF001 <changchun.fan@qq.com>2017-05-02 23:31:47 -0700
committerF001 <changchun.fan@qq.com>2017-05-05 02:38:58 -0700
commita9d3b3498e20a926d5b1662eb576d7db230ca110 (patch)
tree5c287ab6a25b186989c4fcdc580f2f3e53caab12 /src/libsyntax/parse/parser.rs
parent4d81b14b80a076fa249a4b7022688c600f2e9590 (diff)
downloadrust-a9d3b3498e20a926d5b1662eb576d7db230ca110.tar.gz
rust-a9d3b3498e20a926d5b1662eb576d7db230ca110.zip
Suggest `!` for bitwise negation when encountering a `~`
Diffstat (limited to 'src/libsyntax/parse/parser.rs')
-rw-r--r--src/libsyntax/parse/parser.rs13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs
index d252963274e..f99f39dae6b 100644
--- a/src/libsyntax/parse/parser.rs
+++ b/src/libsyntax/parse/parser.rs
@@ -2700,6 +2700,19 @@ impl<'a> Parser<'a> {
                 let (span, e) = self.interpolated_or_expr_span(e)?;
                 (span, self.mk_unary(UnOp::Not, e))
             }
+            // Suggest `!` for bitwise negation when encountering a `~`
+            token::Tilde => {
+                self.bump();
+                let e = self.parse_prefix_expr(None);
+                let (span, e) = self.interpolated_or_expr_span(e)?;
+                let span_of_tilde = lo;
+                let mut err = self.diagnostic().struct_span_err(span_of_tilde,
+                        "`~` can not be used as an unary operator");
+                err.span_label(span_of_tilde, &"did you mean `!`?");
+                err.help("use `!` instead of `~` if you meant to perform bitwise negation");
+                err.emit();
+                (span, self.mk_unary(UnOp::Not, e))
+            }
             token::BinOp(token::Minus) => {
                 self.bump();
                 let e = self.parse_prefix_expr(None);