Skip to content

Commit

Permalink
feature: maven.executable.options configuration as list of strings (#…
Browse files Browse the repository at this point in the history
…1032)

* feature: maven.executable.options configuration as list of strings

Closes #981

* fix json format in README

fix json format in README

---------

Co-authored-by: Jinbo Wang <jinbwan@microsoft.com>
  • Loading branch information
imerljak and testforstephen authored Nov 12, 2024
1 parent 80733c9 commit 43618e6
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 4 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,7 @@ The usage of Maven executable is:
You can use `maven.executable.options` to specify default **options** for all your Maven commands executed in current project.
```json
{
"maven.executable.options": "-o -s ./settings.xml" // work offline, and use an alternative settings file
"maven.executable.options": "-o -s ./settings.xml" // work offline and use an alternative settings file. Can also be defined as an array of strings, e.g. ["-o", "-s ./settings.xml"]
}
```
</details>
Expand Down
14 changes: 12 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -662,7 +662,17 @@
"scope": "machine"
},
"maven.executable.options": {
"type": "string",
"anyOf": [
{
"type": "string"
},
{
"type": "array",
"items": {
"type": "string"
}
}
],
"default": "",
"description": "%configuration.maven.executable.options%",
"scope": "machine-overridable"
Expand Down Expand Up @@ -852,4 +862,4 @@
"which": "^1.3.1",
"xml2js": "^0.5.0"
}
}
}
6 changes: 5 additions & 1 deletion src/Settings.ts
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,11 @@ export class Settings {
return _getMavenSection("executable.path", resourceOrFilepath);
}
public static options(resourceOrFilepath?: Uri | string): string | undefined {
return _getMavenSection("executable.options", resourceOrFilepath);
const options: string | string[] | undefined = _getMavenSection("executable.options", resourceOrFilepath);
if (Array.isArray(options)) {
return options.join(' ');
}
return options;
}
public static preferMavenWrapper(resourceOrFilepath?: Uri | string): boolean {
return !!_getMavenSection<boolean>("executable.preferMavenWrapper", resourceOrFilepath);
Expand Down

0 comments on commit 43618e6

Please sign in to comment.