Blame view
node_modules/eslint/lib/rules/arrow-spacing.js
3.93 KB
c39994410
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 |
/** * @fileoverview Rule to require parens in arrow function arguments. * @author Jxck * @copyright 2015 Jxck. All rights reserved. */ "use strict"; //------------------------------------------------------------------------------ // Rule Definition //------------------------------------------------------------------------------ module.exports = function(context) { // merge rules with default var rule = { before: true, after: true }; var option = context.options[0] || {}; rule.before = option.before !== false; rule.after = option.after !== false; /** * Get tokens of arrow(`=>`) and before/after arrow. * @param {ASTNode} node The arrow function node. * @returns {Object} Tokens of arrow and before/after arrow. */ function getTokens(node) { var t = context.getFirstToken(node); var before; while (t.type !== "Punctuator" || t.value !== "=>") { before = t; t = context.getTokenAfter(t); } var after = context.getTokenAfter(t); return { before: before, arrow: t, after: after }; } /** * Count spaces before/after arrow(`=>`) token. * @param {Object} tokens Tokens before/after arrow. * @returns {Object} count of space before/after arrow. */ function countSpaces(tokens) { var before = tokens.arrow.range[0] - tokens.before.range[1]; var after = tokens.after.range[0] - tokens.arrow.range[1]; return { before: before, after: after }; } /** * Determines whether space(s) before after arrow(`=>`) is satisfy rule. * if before/after value is `true`, there should be space(s). * if before/after value is `false`, there should be no space. * @param {ASTNode} node The arrow function node. * @returns {void} */ function spaces(node) { var tokens = getTokens(node); var countSpace = countSpaces(tokens); if (rule.before) { // should be space(s) before arrow if (countSpace.before === 0) { context.report({ node: tokens.before, message: "Missing space before =>", fix: function(fixer) { return fixer.insertTextBefore(tokens.arrow, " "); } }); } } else { // should be no space before arrow if (countSpace.before > 0) { context.report({ node: tokens.before, message: "Unexpected space before =>", fix: function(fixer) { return fixer.removeRange([tokens.before.range[1], tokens.arrow.range[0]]); } }); } } if (rule.after) { // should be space(s) after arrow if (countSpace.after === 0) { context.report({ node: tokens.after, message: "Missing space after =>", fix: function(fixer) { return fixer.insertTextAfter(tokens.arrow, " "); } }); } } else { // should be no space after arrow if (countSpace.after > 0) { context.report({ node: tokens.after, message: "Unexpected space after =>", fix: function(fixer) { return fixer.removeRange([tokens.arrow.range[1], tokens.after.range[0]]); } }); } } } return { "ArrowFunctionExpression": spaces }; }; module.exports.schema = [ { "type": "object", "properties": { "before": { "type": "boolean" }, "after": { "type": "boolean" } }, "additionalProperties": false } ]; |