mirror of
				https://git.proxmox.com/git/pve-eslint
				synced 2025-10-25 00:47:35 +00:00 
			
		
		
		
	 eb39fafa4f
			
		
	
	
		eb39fafa4f
		
	
	
	
	
		
			
			includes a (minimal) working wrapper Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
		
			
				
	
	
		
			282 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			282 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # enforce line breaks after opening and before closing array brackets (array-bracket-newline)
 | |
| 
 | |
| A number of style guides require or disallow line breaks inside of array brackets.
 | |
| 
 | |
| ## Rule Details
 | |
| 
 | |
| This rule enforces line breaks after opening and before closing array brackets.
 | |
| 
 | |
| ## Options
 | |
| 
 | |
| This rule has either a string option:
 | |
| 
 | |
| * `"always"` requires line breaks inside brackets
 | |
| * `"never"` disallows line breaks inside brackets
 | |
| * `"consistent"` requires consistent usage of linebreaks for each pair of brackets. It reports an error if one bracket in the pair has a linebreak inside it and the other bracket does not.
 | |
| 
 | |
| Or an object option (Requires line breaks if any of properties is satisfied. Otherwise, disallows line breaks):
 | |
| 
 | |
| * `"multiline": true` (default) requires line breaks if there are line breaks inside elements or between elements. If this is false, this condition is disabled.
 | |
| * `"minItems": null` (default) requires line breaks if the number of elements is at least the given integer. If this is 0, this condition will act the same as the option `"always"`. If this is `null` (the default), this condition is disabled.
 | |
| 
 | |
| ### always
 | |
| 
 | |
| Examples of **incorrect** code for this rule with the `"always"` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", "always"]*/
 | |
| 
 | |
| var a = [];
 | |
| var b = [1];
 | |
| var c = [1, 2];
 | |
| var d = [1,
 | |
|     2];
 | |
| var e = [function foo() {
 | |
|     dosomething();
 | |
| }];
 | |
| ```
 | |
| 
 | |
| Examples of **correct** code for this rule with the `"always"` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", "always"]*/
 | |
| 
 | |
| var a = [
 | |
| ];
 | |
| var b = [
 | |
|     1
 | |
| ];
 | |
| var c = [
 | |
|     1, 2
 | |
| ];
 | |
| var d = [
 | |
|     1,
 | |
|     2
 | |
| ];
 | |
| var e = [
 | |
|     function foo() {
 | |
|         dosomething();
 | |
|     }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| ### never
 | |
| 
 | |
| Examples of **incorrect** code for this rule with the `"never"` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", "never"]*/
 | |
| 
 | |
| var a = [
 | |
| ];
 | |
| var b = [
 | |
|     1
 | |
| ];
 | |
| var c = [
 | |
|     1, 2
 | |
| ];
 | |
| var d = [
 | |
|     1,
 | |
|     2
 | |
| ];
 | |
| var e = [
 | |
|     function foo() {
 | |
|         dosomething();
 | |
|     }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| Examples of **correct** code for this rule with the `"never"` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", "never"]*/
 | |
| 
 | |
| var a = [];
 | |
| var b = [1];
 | |
| var c = [1, 2];
 | |
| var d = [1,
 | |
|     2];
 | |
| var e = [function foo() {
 | |
|     dosomething();
 | |
| }];
 | |
| ```
 | |
| 
 | |
| ### consistent
 | |
| 
 | |
| Examples of **incorrect** code for this rule with the `"consistent"` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", "consistent"]*/
 | |
| 
 | |
| var a = [1
 | |
| ];
 | |
| var b = [
 | |
|     1];
 | |
| var c = [function foo() {
 | |
|     dosomething();
 | |
| }
 | |
| ]
 | |
| var d = [
 | |
|     function foo() {
 | |
|         dosomething();
 | |
|     }]
 | |
| ```
 | |
| 
 | |
| Examples of **correct** code for this rule with the `"consistent"` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", "consistent"]*/
 | |
| 
 | |
| var a = [];
 | |
| var b = [
 | |
| ];
 | |
| var c = [1];
 | |
| var d = [
 | |
|     1
 | |
| ];
 | |
| var e = [function foo() {
 | |
|     dosomething();
 | |
| }];
 | |
| var f = [
 | |
|     function foo() {
 | |
|         dosomething();
 | |
|     }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| ### multiline
 | |
| 
 | |
| Examples of **incorrect** code for this rule with the default `{ "multiline": true }` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", { "multiline": true }]*/
 | |
| 
 | |
| var a = [
 | |
| ];
 | |
| var b = [
 | |
|     1
 | |
| ];
 | |
| var c = [
 | |
|     1, 2
 | |
| ];
 | |
| var d = [1,
 | |
|     2];
 | |
| var e = [function foo() {
 | |
|     dosomething();
 | |
| }];
 | |
| ```
 | |
| 
 | |
| Examples of **correct** code for this rule with the default `{ "multiline": true }` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", { "multiline": true }]*/
 | |
| 
 | |
| var a = [];
 | |
| var b = [1];
 | |
| var c = [1, 2];
 | |
| var d = [
 | |
|     1,
 | |
|     2
 | |
| ];
 | |
| var e = [
 | |
|     function foo() {
 | |
|         dosomething();
 | |
|     }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| ### minItems
 | |
| 
 | |
| Examples of **incorrect** code for this rule with the `{ "minItems": 2 }` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", { "minItems": 2 }]*/
 | |
| 
 | |
| var a = [
 | |
| ];
 | |
| var b = [
 | |
|     1
 | |
| ];
 | |
| var c = [1, 2];
 | |
| var d = [1,
 | |
|     2];
 | |
| var e = [
 | |
|   function foo() {
 | |
|     dosomething();
 | |
|   }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| Examples of **correct** code for this rule with the `{ "minItems": 2 }` option:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", { "minItems": 2 }]*/
 | |
| 
 | |
| var a = [];
 | |
| var b = [1];
 | |
| var c = [
 | |
|     1, 2
 | |
| ];
 | |
| var d = [
 | |
|     1,
 | |
|     2
 | |
| ];
 | |
| var e = [function foo() {
 | |
|     dosomething();
 | |
| }];
 | |
| ```
 | |
| 
 | |
| ### multiline and minItems
 | |
| 
 | |
| Examples of **incorrect** code for this rule with the `{ "multiline": true, "minItems": 2 }` options:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", { "multiline": true, "minItems": 2 }]*/
 | |
| 
 | |
| var a = [
 | |
| ];
 | |
| var b = [
 | |
|     1
 | |
| ];
 | |
| var c = [1, 2];
 | |
| var d = [1,
 | |
|     2];
 | |
| var e = [function foo() {
 | |
|     dosomething();
 | |
| }];
 | |
| ```
 | |
| 
 | |
| Examples of **correct** code for this rule with the `{ "multiline": true, "minItems": 2 }` options:
 | |
| 
 | |
| ```js
 | |
| /*eslint array-bracket-newline: ["error", { "multiline": true, "minItems": 2 }]*/
 | |
| 
 | |
| var a = [];
 | |
| var b = [1];
 | |
| var c = [
 | |
|     1, 2
 | |
| ];
 | |
| var d = [
 | |
|     1,
 | |
|     2
 | |
| ];
 | |
| var e = [
 | |
|     function foo() {
 | |
|         dosomething();
 | |
|     }
 | |
| ];
 | |
| ```
 | |
| 
 | |
| 
 | |
| ## When Not To Use It
 | |
| 
 | |
| If you don't want to enforce line breaks after opening and before closing array brackets, don't enable this rule.
 | |
| 
 | |
| ## Compatibility
 | |
| 
 | |
| * **JSCS:** [validateNewlineAfterArrayElements](https://jscs-dev.github.io/rule/validateNewlineAfterArrayElements)
 | |
| 
 | |
| ## Related Rules
 | |
| 
 | |
| * [array-bracket-spacing](array-bracket-spacing.md)
 |