mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-12 07:43:31 +00:00
Remove dependency on regex
This commit is contained in:
parent
c1aa017645
commit
3dff918c6c
8
src/Cargo.lock
generated
8
src/Cargo.lock
generated
@ -967,11 +967,6 @@ name = "lazy_static"
|
|||||||
version = "0.2.11"
|
version = "0.2.11"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "lazy_static"
|
|
||||||
version = "1.0.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "lazycell"
|
name = "lazycell"
|
||||||
version = "0.5.1"
|
version = "0.5.1"
|
||||||
@ -1868,9 +1863,7 @@ dependencies = [
|
|||||||
name = "rustc_lint"
|
name = "rustc_lint"
|
||||||
version = "0.0.0"
|
version = "0.0.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"lazy_static 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"regex 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"rustc 0.0.0",
|
"rustc 0.0.0",
|
||||||
"rustc_const_eval 0.0.0",
|
"rustc_const_eval 0.0.0",
|
||||||
"syntax 0.0.0",
|
"syntax 0.0.0",
|
||||||
@ -2820,7 +2813,6 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
"checksum kuchiki 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)" = "e03098e8e719c92b7794515dfd5c1724e2b12f5ce1788e61cfa4663f82eba8d8"
|
"checksum kuchiki 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)" = "e03098e8e719c92b7794515dfd5c1724e2b12f5ce1788e61cfa4663f82eba8d8"
|
||||||
"checksum languageserver-types 0.16.0 (registry+https://github.com/rust-lang/crates.io-index)" = "773e175c945800aeea4c21c04090bcb9db987b1a566ad9c6f569972299950e3e"
|
"checksum languageserver-types 0.16.0 (registry+https://github.com/rust-lang/crates.io-index)" = "773e175c945800aeea4c21c04090bcb9db987b1a566ad9c6f569972299950e3e"
|
||||||
"checksum lazy_static 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "76f033c7ad61445c5b347c7382dd1237847eb1bce590fe50365dcb33d546be73"
|
"checksum lazy_static 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "76f033c7ad61445c5b347c7382dd1237847eb1bce590fe50365dcb33d546be73"
|
||||||
"checksum lazy_static 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "c8f31047daa365f19be14b47c29df4f7c3b581832407daabe6ae77397619237d"
|
|
||||||
"checksum lazycell 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)" = "3b585b7a6811fb03aa10e74b278a0f00f8dd9b45dc681f148bb29fa5cb61859b"
|
"checksum lazycell 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)" = "3b585b7a6811fb03aa10e74b278a0f00f8dd9b45dc681f148bb29fa5cb61859b"
|
||||||
"checksum libc 0.2.34 (registry+https://github.com/rust-lang/crates.io-index)" = "36fbc8a8929c632868295d0178dd8f63fc423fd7537ad0738372bd010b3ac9b0"
|
"checksum libc 0.2.34 (registry+https://github.com/rust-lang/crates.io-index)" = "36fbc8a8929c632868295d0178dd8f63fc423fd7537ad0738372bd010b3ac9b0"
|
||||||
"checksum libgit2-sys 0.6.16 (registry+https://github.com/rust-lang/crates.io-index)" = "6f74b4959cef96898f5123148724fc7dee043b9a6b99f219d948851bfbe53cb2"
|
"checksum libgit2-sys 0.6.16 (registry+https://github.com/rust-lang/crates.io-index)" = "6f74b4959cef96898f5123148724fc7dee043b9a6b99f219d948851bfbe53cb2"
|
||||||
|
@ -6,7 +6,7 @@ version = "0.0.0"
|
|||||||
[lib]
|
[lib]
|
||||||
name = "rustc_lint"
|
name = "rustc_lint"
|
||||||
path = "lib.rs"
|
path = "lib.rs"
|
||||||
crate-types = ["rlib", "dylib"]
|
crate-type = ["dylib"]
|
||||||
test = false
|
test = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
@ -15,5 +15,3 @@ rustc = { path = "../librustc" }
|
|||||||
rustc_const_eval = { path = "../librustc_const_eval" }
|
rustc_const_eval = { path = "../librustc_const_eval" }
|
||||||
syntax = { path = "../libsyntax" }
|
syntax = { path = "../libsyntax" }
|
||||||
syntax_pos = { path = "../libsyntax_pos" }
|
syntax_pos = { path = "../libsyntax_pos" }
|
||||||
lazy_static = "1.0"
|
|
||||||
regex = "0.2.3"
|
|
||||||
|
@ -21,13 +21,6 @@ use syntax_pos::Span;
|
|||||||
use rustc::hir::{self, PatKind};
|
use rustc::hir::{self, PatKind};
|
||||||
use rustc::hir::intravisit::FnKind;
|
use rustc::hir::intravisit::FnKind;
|
||||||
|
|
||||||
use regex::Regex;
|
|
||||||
|
|
||||||
lazy_static! {
|
|
||||||
static ref ALPHABETIC_UNDERSCORE: Regex =
|
|
||||||
Regex::new("([[:alpha:]])_+|_+([[:alpha:]])").unwrap();
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(PartialEq)]
|
#[derive(PartialEq)]
|
||||||
pub enum MethodLateContext {
|
pub enum MethodLateContext {
|
||||||
TraitAutoImpl,
|
TraitAutoImpl,
|
||||||
@ -60,6 +53,10 @@ pub struct NonCamelCaseTypes;
|
|||||||
|
|
||||||
impl NonCamelCaseTypes {
|
impl NonCamelCaseTypes {
|
||||||
fn check_case(&self, cx: &LateContext, sort: &str, name: ast::Name, span: Span) {
|
fn check_case(&self, cx: &LateContext, sort: &str, name: ast::Name, span: Span) {
|
||||||
|
fn char_has_case(c: char) -> bool {
|
||||||
|
c.is_lowercase() || c.is_uppercase()
|
||||||
|
}
|
||||||
|
|
||||||
fn is_camel_case(name: ast::Name) -> bool {
|
fn is_camel_case(name: ast::Name) -> bool {
|
||||||
let name = name.as_str();
|
let name = name.as_str();
|
||||||
if name.is_empty() {
|
if name.is_empty() {
|
||||||
@ -70,25 +67,37 @@ impl NonCamelCaseTypes {
|
|||||||
// start with a non-lowercase letter rather than non-uppercase
|
// start with a non-lowercase letter rather than non-uppercase
|
||||||
// ones (some scripts don't have a concept of upper/lowercase)
|
// ones (some scripts don't have a concept of upper/lowercase)
|
||||||
!name.is_empty() && !name.chars().next().unwrap().is_lowercase() &&
|
!name.is_empty() && !name.chars().next().unwrap().is_lowercase() &&
|
||||||
!name.contains("__") && !ALPHABETIC_UNDERSCORE.is_match(name)
|
!name.contains("__") && !name.chars().collect::<Vec<_>>().windows(2).any(|pair| {
|
||||||
|
// contains a capitalisable character followed by, or preceded by, an underscore
|
||||||
|
char_has_case(pair[0]) && pair[1] == '_' ||
|
||||||
|
char_has_case(pair[1]) && pair[0] == '_'
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn to_camel_case(s: &str) -> String {
|
fn to_camel_case(s: &str) -> String {
|
||||||
let s = s.trim_matches('_')
|
s.trim_matches('_')
|
||||||
.split('_')
|
.split('_')
|
||||||
.map(|word| {
|
.map(|word| {
|
||||||
word.chars().enumerate().map(|(i, c)| if i == 0 {
|
word.chars().enumerate().map(|(i, c)| if i == 0 {
|
||||||
c.to_uppercase().collect::<String>()
|
c.to_uppercase().collect::<String>()
|
||||||
} else {
|
} else {
|
||||||
c.to_lowercase().collect()
|
c.to_lowercase().collect()
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>()
|
.collect::<Vec<_>>()
|
||||||
.concat()
|
.concat()
|
||||||
})
|
})
|
||||||
.filter(|x| !x.is_empty())
|
.filter(|x| !x.is_empty())
|
||||||
.collect::<Vec<_>>()
|
.collect::<Vec<_>>()
|
||||||
.join("_");
|
.iter().fold((String::new(), None), |(acc, prev): (String, Option<&String>), next| {
|
||||||
ALPHABETIC_UNDERSCORE.replace_all(s.as_str(), "$1$2").to_string()
|
// separate two components with an underscore if their boundary cannot
|
||||||
|
// be distinguished using a uppercase/lowercase case distinction
|
||||||
|
let join = if let Some(prev) = prev {
|
||||||
|
let l = prev.chars().last().unwrap();
|
||||||
|
let f = next.chars().next().unwrap();
|
||||||
|
!char_has_case(l) && !char_has_case(f)
|
||||||
|
} else { false };
|
||||||
|
(acc + if join { "_" } else { "" } + next, Some(next))
|
||||||
|
}).0
|
||||||
}
|
}
|
||||||
|
|
||||||
if !is_camel_case(name) {
|
if !is_camel_case(name) {
|
||||||
|
@ -41,9 +41,6 @@ extern crate rustc;
|
|||||||
extern crate log;
|
extern crate log;
|
||||||
extern crate rustc_const_eval;
|
extern crate rustc_const_eval;
|
||||||
extern crate syntax_pos;
|
extern crate syntax_pos;
|
||||||
#[macro_use]
|
|
||||||
extern crate lazy_static;
|
|
||||||
extern crate regex;
|
|
||||||
|
|
||||||
use rustc::lint;
|
use rustc::lint;
|
||||||
use rustc::middle;
|
use rustc::middle;
|
||||||
|
Loading…
Reference in New Issue
Block a user