Skip to content

Commit

Permalink
docs(readme): Document the parser config
Browse files Browse the repository at this point in the history
Signed-off-by: dark0dave <dark0dave@mykolab.com>
  • Loading branch information
dark0dave committed Sep 11, 2024
1 parent 260d2ae commit aea4d63
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 4 deletions.
2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -29,4 +29,4 @@ serde_derive = "^1.0.152"
walkdir = "^2.3.2"

[dev-dependencies]
pretty_assertions = "1.3.0"
pretty_assertions = "^1.3.0"
38 changes: 37 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -180,9 +180,43 @@ Here's a detailed explanation of all the options you can use:
How to use it: Just add this option to your command if you want to check the version.
Example: mod_installer --version

### Configuring the Parser

See the `example_config.toml` for defaults parser uses. Here we provide a brief breakdown of what each configuration does:

Name|Category|Description|Example
----|----|:----|----
| in_progress_words | A list of words | Checks if weidu is currently running | ["installing", "creating",]
| useful_status_words | A list of words | Provides feedback on the weidu process | ["copied", "copying",]
| choice_words | A list of words | Words which check if weidu wants user input | ["choice", "choose",]
| choice_phrase | A list of phrases | Phrases which check if weidu wants user input | ["do you want", "would you like",]
| completed_with_warnings | A single word | Standard phrase wiedu uses if it finishes with warning | "installed with warnings"
| failed_with_error | A single word | Standard phrase wiedu uses if it finishes with an error | "not installed due to errors"
| finished | A single word | Standard phrase wiedu uses if it finishes successfully | "successfully installed"
| eet_finished | A single word | A special exemption for EET for EET Core install | "process ended"
|||

Note:

All words/phrases are compared in lowercase ascii.

If you wish to changes the above; or you are using a different game language (apologies for not translating all of this); have found a exemption; or just want to change the way the parser works you'll need to create your own mod_installer.toml.

We use the rust crate [`confy`](https://crates.io/crates/confy) to load configuration. Confy uses the rust crate [`directories`](https://crates.io/crates/directories) to find the the expected place for your operating system. The `directories` crate uses:

- the XDG base directory and the XDG user directory specifications on Linux
- the Known Folder API on Windows
- the Standard Directories guidelines on macOS

In order to save you some time reading all the above we will put the expected locations below:

- Windows: `{FOLDERID_RoamingAppData}\mod_installer\config`
- Macos: `$HOME/Library/Application Support/mod_installer/config.toml`
- Linux: `$XDG_CONFIG_HOME/mod_installer/config.toml` or `$HOME/.config/mod_installer/config.toml`

### Logging

You can make the program show more information by setting the RUST_LOG environment variable. Here are three levels you can use:
You can show more install information by setting the `RUST_LOG` environment variable. Here are some of the levels you can use:

For some additional information:

Expand All @@ -199,3 +233,5 @@ For absolutely everything, including WeiDU logs:
```sh
RUST_LOG=TRACE mod_installer [OPTIONS]
```

For more information on logging visit the rust crate [`log`](https://crates.io/crates/log).
File renamed without changes.
2 changes: 1 addition & 1 deletion src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ fn main() -> ExitCode {
"
);
let args = Args::parse();
let parser_config: Arc<ParserConfig> = match confy::load(CARGO_PKG_NAME, None) {
let parser_config: Arc<ParserConfig> = match confy::load(CARGO_PKG_NAME, "config") {
Ok(config) => Arc::new(config),
Err(err) => {
log::error!("Internal error with config crate, {:?}", err);
Expand Down
2 changes: 1 addition & 1 deletion src/parser_config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,7 @@ Example: C:\\Program Files (x86)\\BeamDog\\Games\\00806", "[N]o, [Q]uit or choos
#[test]
fn load_config() -> Result<(), Box<dyn Error>> {
let root = std::env::current_dir()?;
let config_path = Path::join(&root, Path::new("example_parser_config.toml"));
let config_path = Path::join(&root, Path::new("example_config.toml"));
let config: ParserConfig = confy::load_path(config_path)?;
let expected = ParserConfig::default();
assert_eq!(expected, config);
Expand Down

0 comments on commit aea4d63

Please sign in to comment.