From 1b5ea86b376ddadb7af802ee7aa4856830a1c70c Mon Sep 17 00:00:00 2001 From: Ed Page Date: Thu, 8 Aug 2019 08:37:06 -0500 Subject: [PATCH] feat(parser): Give control over identifier detection --- src/config.rs | 37 +++++++++++++++++++++++++++++++++++++ src/main.rs | 2 ++ 2 files changed, 39 insertions(+) diff --git a/src/config.rs b/src/config.rs index 675f61341..766d65eae 100644 --- a/src/config.rs +++ b/src/config.rs @@ -62,6 +62,16 @@ pub trait FileSource { fn ignore_hex(&self) -> Option { None } + + /// Allow identifiers to include digits, in addition to letters + fn identifier_include_digits(&self) -> Option { + None + } + + /// Specify additional characters to be included in identifiers + fn identifier_include_chars(&self) -> Option<&str> { + None + } } #[derive(Debug, Clone, Default, serde::Serialize, serde::Deserialize)] @@ -227,6 +237,8 @@ pub struct FileConfig { pub check_filename: Option, pub check_file: Option, pub ignore_hex: Option, + pub identifier_include_digits: Option, + pub identifier_include_chars: Option, } impl FileConfig { @@ -240,6 +252,12 @@ impl FileConfig { if let Some(source) = source.ignore_hex() { self.ignore_hex = Some(source); } + if let Some(source) = source.identifier_include_digits() { + self.identifier_include_digits = Some(source); + } + if let Some(source) = source.identifier_include_chars() { + self.identifier_include_chars = Some(source.to_owned()); + } } pub fn check_filename(&self) -> bool { @@ -253,6 +271,17 @@ impl FileConfig { pub fn ignore_hex(&self) -> bool { self.ignore_hex.unwrap_or(true) } + + pub fn identifier_include_digits(&self) -> bool { + self.identifier_include_digits.unwrap_or(true) + } + + pub fn identifier_include_chars(&self) -> &str { + self.identifier_include_chars + .as_ref() + .map(|s| s.as_str()) + .unwrap_or("_'") + } } impl FileSource for FileConfig { @@ -267,6 +296,14 @@ impl FileSource for FileConfig { fn ignore_hex(&self) -> Option { self.ignore_hex } + + fn identifier_include_digits(&self) -> Option { + self.identifier_include_digits + } + + fn identifier_include_chars(&self) -> Option<&str> { + self.identifier_include_chars.as_ref().map(|s| s.as_str()) + } } fn find_project_file(dir: std::path::PathBuf, name: &str) -> Option { diff --git a/src/main.rs b/src/main.rs index e655e7b68..319858c64 100644 --- a/src/main.rs +++ b/src/main.rs @@ -314,6 +314,8 @@ fn run() -> Result { let parser = typos::tokens::ParserBuilder::new() .ignore_hex(config.default.ignore_hex()) + .include_digits(config.default.identifier_include_digits()) + .include_chars(config.default.identifier_include_chars().to_owned()) .build(); let checks = typos::checks::CheckSettings::new()