mirror of
https://github.com/crate-ci/typos.git
synced 2024-11-22 09:01:04 -05:00
Merge pull request #756 from epage/types
fix(config): User file types override default file types
This commit is contained in:
commit
a2074608f6
4 changed files with 46 additions and 7 deletions
|
@ -4,7 +4,7 @@ use kstring::KString;
|
||||||
|
|
||||||
#[derive(Default, Clone, Debug)]
|
#[derive(Default, Clone, Debug)]
|
||||||
pub struct TypesBuilder {
|
pub struct TypesBuilder {
|
||||||
definitions: BTreeMap<KString, Vec<KString>>,
|
definitions: BTreeMap<KString, Vec<(KString, usize)>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TypesBuilder {
|
impl TypesBuilder {
|
||||||
|
@ -18,7 +18,7 @@ impl TypesBuilder {
|
||||||
.iter()
|
.iter()
|
||||||
.map(|(name, glob)| {
|
.map(|(name, glob)| {
|
||||||
let name = KString::from(*name);
|
let name = KString::from(*name);
|
||||||
let globs = glob.iter().map(|s| KString::from(*s)).collect();
|
let globs = glob.iter().map(|s| (KString::from(*s), 0)).collect();
|
||||||
(name, globs)
|
(name, globs)
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
|
@ -31,7 +31,11 @@ impl TypesBuilder {
|
||||||
pub fn add(&mut self, name: impl Into<KString>, glob: impl Into<KString>) {
|
pub fn add(&mut self, name: impl Into<KString>, glob: impl Into<KString>) {
|
||||||
let name = name.into();
|
let name = name.into();
|
||||||
let glob = glob.into();
|
let glob = glob.into();
|
||||||
self.definitions.entry(name).or_default().push(glob);
|
let weight = self.definitions.len();
|
||||||
|
self.definitions
|
||||||
|
.entry(name)
|
||||||
|
.or_default()
|
||||||
|
.push((glob, weight));
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn build(self) -> Result<Types, anyhow::Error> {
|
pub fn build(self) -> Result<Types, anyhow::Error> {
|
||||||
|
@ -39,17 +43,29 @@ impl TypesBuilder {
|
||||||
.definitions
|
.definitions
|
||||||
.iter()
|
.iter()
|
||||||
.flat_map(|(name, globs)| {
|
.flat_map(|(name, globs)| {
|
||||||
globs.iter().map(move |glob| {
|
globs.iter().map(move |(glob, weight)| {
|
||||||
let sort = sort_key(glob);
|
let sort = sort_key(glob);
|
||||||
(sort, name, glob)
|
(sort, weight, name, glob)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
definitions.sort();
|
definitions.sort();
|
||||||
|
|
||||||
|
let rev_definitions = definitions
|
||||||
|
.iter()
|
||||||
|
.map(|(_, _, name, glob)| (*glob, *name))
|
||||||
|
.collect::<BTreeMap<_, _>>();
|
||||||
|
let mut unique_definitions = BTreeMap::<KString, Vec<KString>>::new();
|
||||||
|
for (glob, name) in rev_definitions {
|
||||||
|
unique_definitions
|
||||||
|
.entry(name.clone())
|
||||||
|
.or_default()
|
||||||
|
.push(glob.clone());
|
||||||
|
}
|
||||||
|
|
||||||
let mut glob_to_name = Vec::new();
|
let mut glob_to_name = Vec::new();
|
||||||
let mut build_set = globset::GlobSetBuilder::new();
|
let mut build_set = globset::GlobSetBuilder::new();
|
||||||
for (_, name, glob) in definitions {
|
for (_, _, name, glob) in definitions {
|
||||||
glob_to_name.push(name.clone());
|
glob_to_name.push(name.clone());
|
||||||
build_set.add(
|
build_set.add(
|
||||||
globset::GlobBuilder::new(glob)
|
globset::GlobBuilder::new(glob)
|
||||||
|
@ -60,7 +76,7 @@ impl TypesBuilder {
|
||||||
let set = build_set.build()?;
|
let set = build_set.build()?;
|
||||||
|
|
||||||
Ok(Types {
|
Ok(Types {
|
||||||
definitions: self.definitions,
|
definitions: unique_definitions,
|
||||||
glob_to_name,
|
glob_to_name,
|
||||||
set,
|
set,
|
||||||
matches: std::sync::Arc::new(thread_local::ThreadLocal::default()),
|
matches: std::sync::Arc::new(thread_local::ThreadLocal::default()),
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
[type.asc] # GPG keys
|
||||||
|
extend-glob = ["*.asc"]
|
||||||
|
check-file = false
|
||||||
|
|
||||||
|
[default.extend-words]
|
||||||
|
foo = "bar"
|
||||||
|
|
||||||
|
[files]
|
||||||
|
extend-exclude = [
|
||||||
|
"_typos.toml"
|
||||||
|
]
|
|
@ -0,0 +1 @@
|
||||||
|
foo
|
11
crates/typos-cli/tests/cmd/override-default-type.toml
Normal file
11
crates/typos-cli/tests/cmd/override-default-type.toml
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
bin.name = "typos"
|
||||||
|
args = "--file-types"
|
||||||
|
status.code = 0
|
||||||
|
stdin = '''
|
||||||
|
\n\n
|
||||||
|
Destory
|
||||||
|
'''
|
||||||
|
stdout = """
|
||||||
|
./key.asc:asc
|
||||||
|
"""
|
||||||
|
stderr = ""
|
Loading…
Reference in a new issue