Permalink
Jump to Line
Branch:
master
Switch branches/tags
dollar-ignores
feature/new-rule-require-new-lines-in-array
gh-pages
issues/1242
issues/1271-related
master
mdevils/cst
Nothing to show
Nothing to show
| /** | |
| * Disallows commas as last token on a line in lists. | |
| * | |
| * Type: `Boolean`, `Object` | |
| * | |
| * Values: | |
| * - `true` for default behavior (strict mode, comma on the same line) | |
| * - `Object`: | |
| * - `'allExcept'` array of exceptions: | |
| * - `'function'` ignores objects if one of their values is a function expression | |
| * | |
| * JSHint: [`laxcomma`](http://www.jshint.com/docs/options/#laxcomma) | |
| * | |
| * #### Example | |
| * | |
| * ```js | |
| * "disallowCommaBeforeLineBreak": true | |
| * ``` | |
| * | |
| * ##### Valid for `true` | |
| * | |
| * ```js | |
| * var x = { | |
| * one: 1 | |
| * , two: 2 | |
| * }; | |
| * var y = {three: 3, four: 4}; | |
| * ``` | |
| * | |
| * ##### Invalid | |
| * | |
| * ```js | |
| * var x = { | |
| * one: 1, | |
| * two: 2 | |
| * }; | |
| * ``` | |
| * | |
| * ##### Valid for `{"allExcept": ["function"]}` | |
| * | |
| * ```js | |
| * var x = { | |
| * one: 1, | |
| * two: function() {} | |
| * }; | |
| * ``` | |
| * | |
| */ | |
| var assert = require('assert'); | |
| module.exports = function() {}; | |
| module.exports.prototype = { | |
| configure: function(options) { | |
| var optionName = this.getOptionName(); | |
| if (typeof options !== 'object') { | |
| assert( | |
| options === true, | |
| optionName + ' option requires either a true value or an object' | |
| ); | |
| var _options = {allExcept: []}; | |
| return this.configure(_options); | |
| } | |
| assert( | |
| Array.isArray(options.allExcept), | |
| 'Property `allExcept` in ' + optionName + ' should be an array of strings' | |
| ); | |
| this._exceptFunction = options.allExcept.indexOf('function') > -1; | |
| }, | |
| getOptionName: function() { | |
| return 'disallowCommaBeforeLineBreak'; | |
| }, | |
| check: function(file, errors) { | |
| var exceptFunction = this._exceptFunction; | |
| function canSkip(token) { | |
| var node = file.getNodeByRange(token.range[0]); | |
| if (node.loc.start.line === node.loc.end.line) { | |
| return true; | |
| } | |
| // See #1841 | |
| if (!exceptFunction || !node.properties) { | |
| return false; | |
| } | |
| return node.properties.some(function(property) { | |
| return property.value.type === 'FunctionExpression'; | |
| }); | |
| } | |
| file.iterateTokensByTypeAndValue('Punctuator', ',', function(token) { | |
| if (canSkip(token)) { | |
| return; | |
| } | |
| errors.assert.sameLine({ | |
| token: token, | |
| nextToken: file.getNextToken(token), | |
| message: 'Commas should be placed on the same line as value' | |
| }); | |
| errors.assert.differentLine({ | |
| token: file.getPrevToken(token), | |
| nextToken: token, | |
| message: 'Commas should be placed on new line' | |
| }); | |
| }); | |
| } | |
| }; |