Skip to content

Commit

Permalink
feat(config): Add new file types
Browse files Browse the repository at this point in the history
Fixes #220
  • Loading branch information
Ed Page committed Apr 7, 2021
1 parent c71c9f4 commit 2a7bd5b
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 4 deletions.
3 changes: 2 additions & 1 deletion docs/reference.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,4 +31,5 @@ Configuration is read from the following (in precedence order)
| default.locale | --locale | en, en-us, en-gb, en-ca, en-au | English dialect to correct to. |
| default.extend-identifiers | \- | table of strings | Corrections for identifiers. When the correction is blank, the word is never valid. When the correction is the key, the word is always valid. |
| default.extend-words | \- | table of strings | Corrections for identifiers. When the correction is blank, the word is never valid. When the correction is the key, the word is always valid. |
| type.<name>.binary | <varied> | <varied> | See `default.` for child keys. Run with `--type-list` to see available `<name>`s |
| type.<name>.<field> | <varied> | <varied> | See `default.` for child keys. Run with `--type-list` to see available `<name>`s |
| type.<name>.extend_globs | \- | list of strings | File globs for matching `<name>` |
20 changes: 18 additions & 2 deletions src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ pub struct Config {
pub files: Walk,
pub default: EngineConfig,
#[serde(rename = "type")]
pub type_: std::collections::HashMap<kstring::KString, EngineConfig>,
pub type_: std::collections::HashMap<kstring::KString, TypeEngineConfig>,
#[serde(skip)]
pub overrides: EngineConfig,
}
Expand Down Expand Up @@ -49,7 +49,7 @@ impl Config {
for (type_name, engine) in source.type_.iter() {
self.type_
.entry(type_name.to_owned())
.or_insert_with(EngineConfig::default)
.or_insert_with(TypeEngineConfig::default)
.update(engine);
}
self.overrides.update(&source.overrides);
Expand Down Expand Up @@ -137,6 +137,22 @@ impl Walk {
}
}

#[derive(Debug, Clone, Default, serde::Serialize, serde::Deserialize)]
#[serde(deny_unknown_fields, default)]
#[serde(rename_all = "kebab-case")]
pub struct TypeEngineConfig {
pub extend_glob: Vec<kstring::KString>,
#[serde(flatten)]
pub engine: EngineConfig,
}

impl TypeEngineConfig {
pub fn update(&mut self, source: &TypeEngineConfig) {
self.extend_glob.extend(source.extend_glob.iter().cloned());
self.engine.update(&source.engine);
}
}

#[derive(Debug, Clone, Default, serde::Serialize, serde::Deserialize)]
#[serde(deny_unknown_fields, default)]
#[serde(rename_all = "kebab-case")]
Expand Down
6 changes: 5 additions & 1 deletion src/policy.rs
Original file line number Diff line number Diff line change
Expand Up @@ -153,8 +153,12 @@ impl<'s> ConfigEngine<'s> {
type_matcher.add_defaults();
let mut types: std::collections::HashMap<_, _> = Default::default();
for (type_name, type_engine) in type_.into_iter() {
for glob in type_engine.extend_glob.iter() {
type_matcher.add(type_name.as_str(), glob.as_str())?;
}

let mut new_type_engine = default.clone();
new_type_engine.update(&type_engine);
new_type_engine.update(&type_engine.engine);
new_type_engine.update(&overrides);
let type_config = self.init_file_config(new_type_engine);
types.insert(type_name, type_config);
Expand Down

0 comments on commit 2a7bd5b

Please sign in to comment.