From 0ae61d8779244d951c36a2f26c8aa45149d8e939 Mon Sep 17 00:00:00 2001 From: "Zack M. Davis" Date: Sat, 15 Jun 2019 20:22:07 -0700 Subject: [PATCH] in which the `non_ascii_idents` lint appears (RFC 2457) RFC 2457 declares: "A `non_ascii_idents` lint is added to the compiler. This lint is allow by default." --- src/librustc_lint/lib.rs | 3 ++ src/librustc_lint/non_ascii_idents.rs | 23 +++++++++++++ src/test/ui/lint/lint-non-ascii-idents.rs | 11 +++++++ src/test/ui/lint/lint-non-ascii-idents.stderr | 32 +++++++++++++++++++ 4 files changed, 69 insertions(+) create mode 100644 src/librustc_lint/non_ascii_idents.rs create mode 100644 src/test/ui/lint/lint-non-ascii-idents.rs create mode 100644 src/test/ui/lint/lint-non-ascii-idents.stderr diff --git a/src/librustc_lint/lib.rs b/src/librustc_lint/lib.rs index 5eff28b194b98..74a159920c6aa 100644 --- a/src/librustc_lint/lib.rs +++ b/src/librustc_lint/lib.rs @@ -31,6 +31,7 @@ mod nonstandard_style; pub mod builtin; mod types; mod unused; +mod non_ascii_idents; use rustc::lint; use rustc::lint::{EarlyContext, LateContext, LateLintPass, EarlyLintPass, LintPass, LintArray}; @@ -63,6 +64,7 @@ use nonstandard_style::*; use builtin::*; use types::*; use unused::*; +use non_ascii_idents::*; use rustc::lint::internal::*; /// Useful for other parts of the compiler. @@ -98,6 +100,7 @@ macro_rules! early_lint_passes { EllipsisInclusiveRangePatterns: EllipsisInclusiveRangePatterns::default(), NonCamelCaseTypes: NonCamelCaseTypes, DeprecatedAttr: DeprecatedAttr::new(), + NonAsciiIdents: NonAsciiIdents, ]); ) } diff --git a/src/librustc_lint/non_ascii_idents.rs b/src/librustc_lint/non_ascii_idents.rs new file mode 100644 index 0000000000000..dd876505d3e44 --- /dev/null +++ b/src/librustc_lint/non_ascii_idents.rs @@ -0,0 +1,23 @@ +use crate::lint::{EarlyContext, EarlyLintPass, LintArray, LintContext, LintPass}; +use syntax::ast; + +declare_lint! { + pub NON_ASCII_IDENTS, + Allow, + "detects non-ASCII identifiers" +} + +declare_lint_pass!(NonAsciiIdents => [NON_ASCII_IDENTS]); + +impl EarlyLintPass for NonAsciiIdents { + fn check_ident(&mut self, cx: &EarlyContext<'_>, ident: ast::Ident) { + if !ident.name.as_str().is_ascii() { + let mut err = cx.struct_span_lint( + NON_ASCII_IDENTS, + ident.span, + "identifier contains non-ASCII characters", + ); + err.emit(); + } + } +} diff --git a/src/test/ui/lint/lint-non-ascii-idents.rs b/src/test/ui/lint/lint-non-ascii-idents.rs new file mode 100644 index 0000000000000..057329a0a650c --- /dev/null +++ b/src/test/ui/lint/lint-non-ascii-idents.rs @@ -0,0 +1,11 @@ +#![feature(non_ascii_idents)] +#![deny(non_ascii_idents)] + +const חלודה: usize = 2; //~ ERROR identifier contains non-ASCII characters + +fn coöperation() {} //~ ERROR identifier contains non-ASCII characters + +fn main() { + let naïveté = 2; //~ ERROR identifier contains non-ASCII characters + println!("{}", naïveté); //~ ERROR identifier contains non-ASCII characters +} diff --git a/src/test/ui/lint/lint-non-ascii-idents.stderr b/src/test/ui/lint/lint-non-ascii-idents.stderr new file mode 100644 index 0000000000000..56925846e956b --- /dev/null +++ b/src/test/ui/lint/lint-non-ascii-idents.stderr @@ -0,0 +1,32 @@ +error: identifier contains non-ASCII characters + --> $DIR/lint-non-ascii-idents.rs:4:7 + | +LL | const חלודה: usize = 2; + | ^^^^^ + | +note: lint level defined here + --> $DIR/lint-non-ascii-idents.rs:2:9 + | +LL | #![deny(non_ascii_idents)] + | ^^^^^^^^^^^^^^^^ + +error: identifier contains non-ASCII characters + --> $DIR/lint-non-ascii-idents.rs:6:4 + | +LL | fn coöperation() {} + | ^^^^^^^^^^^ + +error: identifier contains non-ASCII characters + --> $DIR/lint-non-ascii-idents.rs:9:9 + | +LL | let naïveté = 2; + | ^^^^^^^ + +error: identifier contains non-ASCII characters + --> $DIR/lint-non-ascii-idents.rs:10:20 + | +LL | println!("{}", naïveté); + | ^^^^^^^ + +error: aborting due to 4 previous errors +