Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kentor/eslint-plugin-brackets
ESLint style rules for minimizing diffs with line breaks around brackets
https://github.com/kentor/eslint-plugin-brackets
eslint eslint-plugin
Last synced: 2 months ago
JSON representation
ESLint style rules for minimizing diffs with line breaks around brackets
- Host: GitHub
- URL: https://github.com/kentor/eslint-plugin-brackets
- Owner: kentor
- License: mit
- Created: 2016-11-18T06:14:08.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2017-11-09T01:39:37.000Z (about 7 years ago)
- Last Synced: 2024-09-15T18:15:22.854Z (4 months ago)
- Topics: eslint, eslint-plugin
- Language: JavaScript
- Size: 54.7 KB
- Stars: 5
- Watchers: 3
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# eslint-plugin-brackets
[![Build Status](https://travis-ci.org/kentor/eslint-plugin-brackets.svg)](https://travis-ci.org/kentor/eslint-plugin-brackets) [![codecov](https://codecov.io/gh/kentor/eslint-plugin-brackets/branch/master/graph/badge.svg)](https://codecov.io/gh/kentor/eslint-plugin-brackets) [![npm](https://img.shields.io/npm/v/eslint-plugin-brackets.svg)](https://www.npmjs.com/package/eslint-plugin-brackets)
Opinionated ESLint style rules dealing with line breaks after opening
brackets and before closing brackets of objects, arrays, conditionals, and
functions.## Overview
This project is opinionated, meaning there are no options for any of the rules.
However, this may change in the future.The general goal of these rules is to enforce a coding style that minimizes
diffs when items are added to lists (be it arrays, objects, parameter lists,
etc.)For example, we want to avoid this:
```js
// Badarray = ['a',
'b',
'c'];array2 = ["this is a long string" +
"spanning multiple lines"];object = { a: 'a',
b: 'b' };function foo(bar,
baz) {
}call('a',
'b');if (test &&
test2 &&
test3) {
}
```And instead prefer this:
```js
// Goodarray = [
'a',
'b',
'c',
];array2 = [
"this is a long string" +
"spanning multiple lines"
];object = {
a: 'a',
b: 'b'
};function foo(
bar,
baz
) {
}call(
'a',
'b'
);if (
test &&
test2 &&
test3
) {
}
```Why?
- Adding an item to the top of the list or to the bottom of the list will afford
smaller diffs.
- Changing the name of the assigned variable/callee won't require shifting every
other item in the list to fix indentation.
- There's an argument for symmetry somewhere.In other words, there shouldn't be items on the same line as the opening bracket
or closing bracket enclosing the list if the list spans multiple line.**However**, there is an exception to this: if the last token of the line
containing the opening bracket is another opening bracket, or if the first token
of the line containing the closing bracket is another closing bracket, then that
is allowed:```js
// Finearray = ['a', function() { // ends with an opening bracket
}];call('a', {
b: 'c',
});if (confirm(
'are you sure?'
)) {
}
```The exception to _that_ is it's not allowed for objects:
```js
// Badobj = { a: 'b', c: {
d: 'e',
} };
```Preferring this:
```js
// Goodobj = {
a: 'b',
c: {
d: 'e',
},
};
```## Note on auto-fixing
All rules can be auto-fixed (running eslint with `--fix`). The fix will add
appropriate line breaks after the opening bracket and before the closing bracket
at violation sites. This may produce code with bad indentation. We rely on
eslint's `indent` rule to fix the indentation in a second pass.Currently (as of ESLint 3.10) the `indent` rule is broken for params inside call
expressions and expressions inside conditionals, but this should be fixed soon.## List of rules
- brackets/array-bracket-newline
- brackets/call-parens-newline
- brackets/conditional-parens-newline
- brackets/func-parens-newline
- brackets/object-curly-newlineTake a look at the [rule tests](lib/rules/__tests__) to see valid and invalid
patterns for each rule.## Installation
You'll first need to install [ESLint](http://eslint.org):
```
$ npm install eslint
```Next, install `eslint-plugin-brackets`:
```
$ npm install eslint-plugin-brackets
```**Note:** If you installed ESLint globally (using the `-g` flag) then you must
also install `eslint-plugin-brackets` globally.## Usage
Add `brackets` to the plugins section of your `.eslintrc` configuration
file. You can omit the `eslint-plugin-` prefix:```json
{
"plugins": [
"brackets"
]
}
```Then configure the rules you want to use under the rules section.
```json
{
"rules": {
"brackets/array-bracket-newline": 2,
"brackets/object-curly-newline": 2,
}
}
```## Development
- Install packages with `npm install` or `yarn`.
- Run `npm run test:watch` to continually run the tests## License
[MIT](LICENSE.txt)