1
0
mirror of https://github.com/Llewellynvdm/starship.git synced 2024-11-10 15:20:55 +00:00

feat(deno): detect deno.json and deno.jsonc (#3220)

* feat(deno): detect `deno.json` and `deno.jsonc`

* update docs

* update tests

* cargo fmt

* revert lockfile changes

* revert doc updates to non-english files

* Restore README.md

* fmt
This commit is contained in:
Maximous Black 2021-12-30 14:25:46 +05:30 committed by GitHub
parent 67cddb616b
commit f48c7a26cf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 39 additions and 12 deletions

View File

@ -747,20 +747,20 @@ format = "via [🔰 $version](bold red) "
The `deno` module shows you your currently installed version of [Deno](https://deno.land/). The `deno` module shows you your currently installed version of [Deno](https://deno.land/).
By default the module will be shown if any of the following conditions are met: By default the module will be shown if any of the following conditions are met:
- The current directory contains a `mod.ts`, `mod.js`, `deps.ts` or `deps.js` file - The current directory contains a `deno.json`, `deno.jsonc`, `mod.ts`, `mod.js`, `deps.ts` or `deps.js` file
### Options ### Options
| Option | Default | Description | | Option | Default | Description |
| ------------------- | ------------------------------------------------- | ------------------------------------------------------------------------- | | ------------------- | ----------------------------------------------------------------------- | ------------------------------------------------------------------------- |
| `format` | `"via [$symbol($version )]($style)"` | The format for the module. | | `format` | `"via [$symbol($version )]($style)"` | The format for the module. |
| `version_format` | `"v${raw}"` | The version format. Available vars are `raw`, `major`, `minor`, & `patch` | | `version_format` | `"v${raw}"` | The version format. Available vars are `raw`, `major`, `minor`, & `patch` |
| `symbol` | `"🦕 "` | A format string representing the symbol of Deno | | `symbol` | `"🦕 "` | A format string representing the symbol of Deno |
| `detect_extensions` | `[]` | Which extensions should trigger this module. | | `detect_extensions` | `[]` | Which extensions should trigger this module. |
| `detect_files` | `["mod.ts", "mod.js", "deps.ts", "deps.js"]` | Which filenames should trigger this module. | | `detect_files` | `["deno.json", "deno.jsonc", "mod.ts", "mod.js", "deps.ts", "deps.js"]` | Which filenames should trigger this module. |
| `detect_folders` | `[]` | Which folders should trigger this module. | | `detect_folders` | `[]` | Which folders should trigger this module. |
| `style` | `"green bold"` | The style for the module. | | `style` | `"green bold"` | The style for the module. |
| `disabled` | `false` | Disables the `deno` module. | | `disabled` | `false` | Disables the `deno` module. |
### Variables ### Variables

View File

@ -24,7 +24,14 @@ impl<'a> Default for DenoConfig<'a> {
style: "green bold", style: "green bold",
disabled: false, disabled: false,
detect_extensions: vec![], detect_extensions: vec![],
detect_files: vec!["mod.ts", "deps.ts", "mod.js", "deps.js"], detect_files: vec![
"deno.json",
"deno.jsonc",
"mod.ts",
"deps.ts",
"mod.js",
"deps.js",
],
detect_folders: vec![], detect_folders: vec![],
} }
} }

View File

@ -83,6 +83,26 @@ mod tests {
dir.close() dir.close()
} }
#[test]
fn folder_with_deno_json() -> io::Result<()> {
let dir = tempfile::tempdir()?;
File::create(dir.path().join("deno.json"))?.sync_all()?;
let actual = ModuleRenderer::new("deno").path(dir.path()).collect();
let expected = Some(format!("via {}", Color::Green.bold().paint("🦕 v1.8.3 ")));
assert_eq!(expected, actual);
dir.close()
}
#[test]
fn folder_with_deno_jsonc() -> io::Result<()> {
let dir = tempfile::tempdir()?;
File::create(dir.path().join("deno.jsonc"))?.sync_all()?;
let actual = ModuleRenderer::new("deno").path(dir.path()).collect();
let expected = Some(format!("via {}", Color::Green.bold().paint("🦕 v1.8.3 ")));
assert_eq!(expected, actual);
dir.close()
}
#[test] #[test]
fn folder_with_mod_ts() -> io::Result<()> { fn folder_with_mod_ts() -> io::Result<()> {
let dir = tempfile::tempdir()?; let dir = tempfile::tempdir()?;