kitchensink
Version:
Dispatch's awesome components and style guide
66 lines (60 loc) • 1.25 kB
JavaScript
/**
* Requires that a function expression be named.
* Named functions provide more information in the error stack trace than anonymous functions.
*
* This option does not help if you use Arrow functions (ES6) which are always anonymous.
*
* Type: `Boolean`
*
* Value: `true`
*
* #### Example
*
* ```js
* "disallowAnonymousFunctions": true
* ```
*
* ##### Valid
*
* ```js
* var a = function foo(){
*
* };
*
* $('#foo').click(function bar(){
*
* });
* ```
*
* ##### Invalid
*
* ```js
* var a = function(){
*
* };
*
* $('#foo').click(function(){
*
* });
* ```
*/
var assert = require('assert');
module.exports = function() {};
module.exports.prototype = {
configure: function(options) {
assert(
options === true,
this.getOptionName() + ' option requires a true value or should be removed'
);
},
getOptionName: function() {
return 'disallowAnonymousFunctions';
},
check: function(file, errors) {
file.iterateNodesByType(['FunctionExpression', 'FunctionDeclaration'], function(node) {
if (node.id === null) {
errors.add('Anonymous functions need to be named', node.loc.start);
}
});
}
};