npm-groovy-lint 11.1.1 → 11.1.2-beta202310271757.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +16 -15
- package/lib/.groovylintrc-all.json +393 -393
- package/lib/codenarc-caller.js +58 -22
- package/lib/codenarc-factory.js +23 -21
- package/lib/groovy-lint-fix.js +12 -4
- package/lib/groovy-lint.js +13 -13
- package/lib/index.js +0 -0
- package/lib/java/CodeNarcServer.jar +0 -0
- package/lib/java/groovy/lib/commons-cli-1.4.jar +0 -0
- package/lib/java/groovy/lib/groovy-cli-commons-3.0.9.jar +0 -0
- package/lib/java/slf4j-api-2.0.9.jar +0 -0
- package/lib/java/slf4j-simple-2.0.9.jar +0 -0
- package/lib/options.js +15 -5
- package/lib/output.js +3 -3
- package/lib/utils.js +5 -4
- package/package.json +17 -12
- package/CHANGELOG.md +0 -623
- package/lib/java/log4j-api-2.18.0.jar +0 -0
- package/lib/java/log4j-core-2.18.0.jar +0 -0
- package/lib/java/log4j-slf4j-impl-2.18.0.jar +0 -0
- package/lib/java/slf4j-api-1.7.9.jar +0 -0
package/README.md
CHANGED
|
@@ -16,14 +16,14 @@
|
|
|
16
16
|
|
|
17
17
|
## Groovy & Jenkinsfile Linter, Formatter and Auto-fixer
|
|
18
18
|
|
|
19
|
-
|
|
19
|
+
***New: The [article about the story of npm-groovy-lint](https://nicolas.vuillamy.fr/a-groovy-journey-to-open-source-during-covid-19-npm-groovy-lint-8d88c7eecebc), and why you should dive in open-source community !***
|
|
20
20
|
|
|
21
21
|
Based on [CodeNarc](http://codenarc.github.io/CodeNarc/) , this out of the box package allows to **track groovy errors** and **correct a part of them**
|
|
22
22
|
|
|
23
23
|
- Use option **--format** to format & prettify source code
|
|
24
24
|
- Use option **--fix** to activate autofixing of fixable rules
|
|
25
25
|
|
|
26
|
-
Easy to integrate in a CD
|
|
26
|
+
Easy to integrate in a CI/CD process (Jenkins Pipeline,CircleCI...) to lint your groovy or Jenkinsfile at each build :)
|
|
27
27
|
|
|
28
28
|
You can also use this package in :
|
|
29
29
|
|
|
@@ -45,14 +45,14 @@ Any **question**, **problem** or **enhancement request** ? Ask [**here**](https:
|
|
|
45
45
|
|
|
46
46
|
| Parameter | Type | Description |
|
|
47
47
|
|-------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
|
48
|
-
| -o<br/> --output | String | Output format (txt,json,sarif,html,xml), or path to a file with one of these extensions<br/> Default: `txt`<br/> Examples:<br/> - `"txt"`<br/> - `"json"`<br/> - `"./logs/myLintResults.txt"`<br/> - `"./logs/myLintResults.sarif"`<br/> - `"./logs/myLintResults.html"`<br/> - `"./logs/myLintResults.xml"
|
|
48
|
+
| -o<br/> --output | String | Output format (txt,json,sarif,html,xml), or path to a file with one of these extensions<br/> Default: `txt`<br/> Examples:<br/> - `"txt"`<br/> - `"json"`<br/> - `"./logs/myLintResults.txt"`<br/> - `"./logs/myLintResults.sarif"`<br/> - `"./logs/myLintResults.html"`<br/> - `"./logs/myLintResults.xml"`<br/>Note: HTML and XML are directly from CodeNarc so using these formats will disable many npm-groovy-lint features |
|
|
49
49
|
| -l<br/> --loglevel | String | Log level (error,warning or info)<br/>Default: info |
|
|
50
50
|
| --failon | String | Defines the error level where CLI will fail (return code = 1). error,warning,info or none. Each failure level includes the more critical ones. |
|
|
51
|
-
| -c<br/> --config | String | Custom path to [GroovyLint config file](#
|
|
51
|
+
| -c<br/> --config | String | Custom path to [GroovyLint config file](#configuration), or preset config `recommended|recommended-jenkinsfile|all`<br/> Default: Browse current directory to find`.groovylintrc.json|js|yml|package.json` config file, or default npm-groovy-lint config if not defined.<br/>Note: command-line arguments have priority on config file properties |
|
|
52
52
|
| --parse | Boolean | Try to compile the source code and return parse errors (since v5.7.0, default to true, use --no-parse to deactivate) |
|
|
53
53
|
| --format | Boolean | Format source code |
|
|
54
|
-
| --fix | Boolean | Automatically fix problems when possible<br/> See [
|
|
55
|
-
| -x<br/> --fixrules | String | Option for --fix argument: List of rule identifiers to fix (if not specified, all available fixes will be applied). See [
|
|
54
|
+
| --fix | Boolean | Automatically fix problems when possible<br/> See [Auto-fixable rules](#auto-fixable-rules) |
|
|
55
|
+
| -x<br/> --fixrules | String | Option for --fix argument: List of rule identifiers to fix (if not specified, all available fixes will be applied). See [Auto-fixable rules](#auto-fixable-rules) <br/> Examples:<br/> - `"SpaceBeforeClosingBrace,SpaceAfterClosingBrace,UnusedImport"`<br/> - `"Indentation"`<br/> |
|
|
56
56
|
| --nolintafter | Boolean | When format or fix is called, a new lint is performed after the fixes to update the returned error list. If you just want the updated source code and do not care about the error logs, use this parameter to improve performances |
|
|
57
57
|
| -r<br/> --rulesets | String | [RuleSet file(s)](http://codenarc.github.io/CodeNarc/codenarc-creating-ruleset.html) to use for linting, if you do not want to use recommended rules or .groovylintrc.js defined rules.<br/>If list of comma separated strings corresponding to CodeNarc rules, a RuleSet file will be dynamically generated </br> Examples:<br/> - `"./config/codenarc/RuleSet-Custom.groovy"`<br/> - `"./path/to/my/ruleset/files"`<br/>- `Indentation{"spacesPerIndentLevel":2,"severity":"warning"},UnnecessarySemicolon,UnnecessaryGString` |
|
|
58
58
|
| --rulesetsoverridetype | String | If list of rules sent in rulesets option, defines if they replace rules defined in .groovylintrc.json, or if they are appended<br/> Values: `replaceConfig` (default), `appendConfig` |
|
|
@@ -137,6 +137,7 @@ Any **question**, **problem** or **enhancement request** ? Ask [**here**](https:
|
|
|
137
137
|
```shell
|
|
138
138
|
npm install -g npm-groovy-lint
|
|
139
139
|
```
|
|
140
|
+
|
|
140
141
|
- If you have issues with v9, install previous version with `npm install -g npm-groovy-lint@8.2.0`
|
|
141
142
|
- Node.js >= 12 is required to run this package. If you can't upgrade, you can use [nvm](https://github.com/nvm-sh/nvm) to have [different node versions on your computer](https://www.sitepoint.com/quick-tip-multiple-versions-node-nvm/)
|
|
142
143
|
- If you do not have java (from 8 to 14) installed on your computer npm-groovy-lint will install them for you, so the first run may be long.
|
|
@@ -152,16 +153,16 @@ Create a file named **.groovylintrc.json** in the current or any parent director
|
|
|
152
153
|
- groovy
|
|
153
154
|
- mygroovyfile.groovy
|
|
154
155
|
- Jenkinsfile
|
|
155
|
-
- **.groovylintrc.json**
|
|
156
|
+
- **.groovylintrc.json** *(do not forget the dot at the beginning of the file name)*
|
|
156
157
|
|
|
157
|
-
*If you are using [VsCode Groovy Lint extension](https://marketplace.visualstudio.com/items?itemName=NicolasVuillamy.vscode-groovy-lint), just use QuickFix
|
|
158
|
+
*If you are using [VsCode Groovy Lint extension](https://marketplace.visualstudio.com/items?itemName=NicolasVuillamy.vscode-groovy-lint), just use QuickFix **Ignore in all files** and it will generate groovylintrc.json file.*
|
|
158
159
|
|
|
159
160
|
### Format
|
|
160
161
|
|
|
161
162
|
- **extends**: Name of a base configuration ([`recommended`](https://github.com/nvuillam/npm-groovy-lint/blob/master/lib/.groovylintrc-recommended.json), [`recommended-jenkinsfile`](https://github.com/nvuillam/npm-groovy-lint/blob/master/lib/.groovylintrc-recommended-jenkinsfile.json), [`all`](https://github.com/nvuillam/npm-groovy-lint/blob/master/lib/.groovylintrc-all.json))
|
|
162
163
|
- **rules**: List of rules definition, following format `"RuleSection.RuleName": ruleParameters` or `"RuleName": ruleParameters`
|
|
163
|
-
-
|
|
164
|
-
-
|
|
164
|
+
- *RuleName*: any of the **[CodeNarc rules](https://codenarc.github.io/CodeNarc/codenarc-rule-index.html)**
|
|
165
|
+
- *ruleParameters*: can be just a severity override ( `"off"`, `"error"`, `"warning"`, `"info"` ) , or a property list :
|
|
165
166
|
- severity : off,error,warning,info
|
|
166
167
|
- enabled : true (default) or false
|
|
167
168
|
- any of the [rule advanced properties](https://codenarc.github.io/CodeNarc/codenarc-rule-index.html)
|
|
@@ -341,9 +342,9 @@ def variable = 1;
|
|
|
341
342
|
- UnnecessaryToString
|
|
342
343
|
- UnusedImport
|
|
343
344
|
|
|
344
|
-
[Contribute](#
|
|
345
|
+
[Contribute](#contribute) to add more [rules](http://codenarc.github.io/CodeNarc/codenarc-rule-index.html) fixes :)
|
|
345
346
|
|
|
346
|
-
## CD
|
|
347
|
+
## CI/CD
|
|
347
348
|
|
|
348
349
|
### Mega-Linter
|
|
349
350
|
|
|
@@ -445,9 +446,9 @@ Please follow [Contribution instructions](https://github.com/nvuillam/npm-groovy
|
|
|
445
446
|
|
|
446
447
|
### Contributors
|
|
447
448
|
|
|
448
|
-
[<img alt="nvuillam" src="https://avatars1.githubusercontent.com/u/17500430?v=4&s=50 width=50">](https://github.com/nvuillam) | [<img alt="Dave Gallant" src="https://avatars2.githubusercontent.com/u/4519234?v=4&s=50 width=50">](https://github.com/davegallant) | [<img alt="warhod" src="https://avatars1.githubusercontent.com/u/1305176?v=4&s=50 width=50">](https://github.com/warhod) | [<img alt="pawelkopka" src="https://avatars1.githubusercontent.com/u/17784034?v=4&s=50 width=50">](https://github.com/pawelkopka) | [<img alt="docwhat" src="https://avatars1.githubusercontent.com/u/40799?v=4&s=50 width=50">](https://github.com/docwhat) | [<img alt="CatSue" src="https://avatars3.githubusercontent.com/u/26134618?v=4&s=50 width=50">](https://github.com/CatSue)
|
|
449
|
-
|
|
450
|
-
|
|
449
|
+
| [<img alt="nvuillam" src="https://avatars1.githubusercontent.com/u/17500430?v=4&s=50 width=50">](https://github.com/nvuillam) | [<img alt="Dave Gallant" src="https://avatars2.githubusercontent.com/u/4519234?v=4&s=50 width=50">](https://github.com/davegallant) | [<img alt="warhod" src="https://avatars1.githubusercontent.com/u/1305176?v=4&s=50 width=50">](https://github.com/warhod) | [<img alt="pawelkopka" src="https://avatars1.githubusercontent.com/u/17784034?v=4&s=50 width=50">](https://github.com/pawelkopka) | [<img alt="docwhat" src="https://avatars1.githubusercontent.com/u/40799?v=4&s=50 width=50">](https://github.com/docwhat) | [<img alt="CatSue" src="https://avatars3.githubusercontent.com/u/26134618?v=4&s=50 width=50">](https://github.com/CatSue) |
|
|
450
|
+
|:-----------------------------------------------------------------------------------------------------------------------------:|:-----------------------------------------------------------------------------------------------------------------------------------:|:------------------------------------------------------------------------------------------------------------------------:|:---------------------------------------------------------------------------------------------------------------------------------:|:------------------------------------------------------------------------------------------------------------------------:|:-------------------------------------------------------------------------------------------------------------------------:|
|
|
451
|
+
| [Nicolas Vuillamy](https://github.com/nvuillam) | [Dave Gallant](https://github.com/davegallant) | [Howard Lo](https://github.com/warhod) | [Pawel Kopka](https://github.com/pawelkopka) | [docwhat](https://github.com/docwhat) | [CatSue](https://github.com/CatSue) |
|
|
451
452
|
|
|
452
453
|
## Release notes
|
|
453
454
|
|