Merge pull request babel/babel-eslint#354 from babel/eslint-config-babel
Use eslint-config-babel
This commit is contained in:
parent
481329a47e
commit
2b812b087c
1
eslint/babel-eslint-parser/.eslintignore
Normal file
1
eslint/babel-eslint-parser/.eslintignore
Normal file
@ -0,0 +1 @@
|
|||||||
|
test/fixtures
|
||||||
@ -1,28 +0,0 @@
|
|||||||
{
|
|
||||||
"root": true,
|
|
||||||
"rules": {
|
|
||||||
"strict": 0,
|
|
||||||
"no-underscore-dangle": 0,
|
|
||||||
"curly": 0,
|
|
||||||
"no-multi-spaces": 0,
|
|
||||||
"key-spacing": 0,
|
|
||||||
"no-return-assign": 0,
|
|
||||||
"consistent-return": 0,
|
|
||||||
"no-shadow": 0,
|
|
||||||
"comma-dangle": 0,
|
|
||||||
"no-use-before-define": 0,
|
|
||||||
"no-empty": 0,
|
|
||||||
"new-parens": 0,
|
|
||||||
"no-cond-assign": 0,
|
|
||||||
"no-fallthrough": 0,
|
|
||||||
"new-cap": 0,
|
|
||||||
"no-loop-func": 0,
|
|
||||||
"no-unreachable": 0,
|
|
||||||
"no-process-exit": 0,
|
|
||||||
"quotes": [1, "double", "avoid-escape"]
|
|
||||||
},
|
|
||||||
"env": {
|
|
||||||
"node": true,
|
|
||||||
"mocha": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
16
eslint/babel-eslint-parser/.eslintrc.js
Normal file
16
eslint/babel-eslint-parser/.eslintrc.js
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
module.exports = {
|
||||||
|
root: true,
|
||||||
|
extends: "babel",
|
||||||
|
parserOptions: {
|
||||||
|
ecmaVersion: 7,
|
||||||
|
sourceType: "module"
|
||||||
|
},
|
||||||
|
rules: {
|
||||||
|
"no-var": 0,
|
||||||
|
"max-len": 0
|
||||||
|
},
|
||||||
|
env: {
|
||||||
|
node: true,
|
||||||
|
mocha: true
|
||||||
|
}
|
||||||
|
};
|
||||||
@ -7,3 +7,5 @@ matrix:
|
|||||||
- node_js: "4"
|
- node_js: "4"
|
||||||
- node_js: "5"
|
- node_js: "5"
|
||||||
- node_js: "6"
|
- node_js: "6"
|
||||||
|
|
||||||
|
script: npm run test-ci
|
||||||
|
|||||||
@ -90,4 +90,4 @@ module.exports = function (tokens, tt) {
|
|||||||
}
|
}
|
||||||
startingToken++;
|
startingToken++;
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|||||||
@ -17,4 +17,4 @@ exports.convertComments = function (comments) {
|
|||||||
comment.range = [comment.start, comment.end];
|
comment.range = [comment.start, comment.end];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|||||||
@ -17,6 +17,18 @@ function changeToLiteral(node) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function changeComments(nodeComments) {
|
||||||
|
for (var i = 0; i < nodeComments.length; i++) {
|
||||||
|
var comment = nodeComments[i];
|
||||||
|
if (comment.type === "CommentLine") {
|
||||||
|
comment.type = "Line";
|
||||||
|
} else if (comment.type === "CommentBlock") {
|
||||||
|
comment.type = "Block";
|
||||||
|
}
|
||||||
|
comment.range = [comment.start, comment.end];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var astTransformVisitor = {
|
var astTransformVisitor = {
|
||||||
noScope: true,
|
noScope: true,
|
||||||
enter: function (path) {
|
enter: function (path) {
|
||||||
@ -33,27 +45,11 @@ var astTransformVisitor = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (node.trailingComments) {
|
if (node.trailingComments) {
|
||||||
for (var i = 0; i < node.trailingComments.length; i++) {
|
changeComments(node.trailingComments);
|
||||||
var comment = node.trailingComments[i];
|
|
||||||
if (comment.type === "CommentLine") {
|
|
||||||
comment.type = "Line";
|
|
||||||
} else if (comment.type === "CommentBlock") {
|
|
||||||
comment.type = "Block";
|
|
||||||
}
|
|
||||||
comment.range = [comment.start, comment.end];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (node.leadingComments) {
|
if (node.leadingComments) {
|
||||||
for (var i = 0; i < node.leadingComments.length; i++) {
|
changeComments(node.leadingComments);
|
||||||
var comment = node.leadingComments[i];
|
|
||||||
if (comment.type === "CommentLine") {
|
|
||||||
comment.type = "Line";
|
|
||||||
} else if (comment.type === "CommentBlock") {
|
|
||||||
comment.type = "Block";
|
|
||||||
}
|
|
||||||
comment.range = [comment.start, comment.end];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// make '_paths' non-enumerable (babel-eslint #200)
|
// make '_paths' non-enumerable (babel-eslint #200)
|
||||||
|
|||||||
@ -388,7 +388,7 @@ exports.parse = function (code, options) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return exports.parseNoPatch(code, options);
|
return exports.parseNoPatch(code, options);
|
||||||
}
|
};
|
||||||
|
|
||||||
exports.parseNoPatch = function (code, options) {
|
exports.parseNoPatch = function (code, options) {
|
||||||
var opts = {
|
var opts = {
|
||||||
@ -458,4 +458,4 @@ exports.parseNoPatch = function (code, options) {
|
|||||||
babylonToEspree.attachComments(ast, ast.comments, ast.tokens);
|
babylonToEspree.attachComments(ast, ast.comments, ast.tokens);
|
||||||
|
|
||||||
return ast;
|
return ast;
|
||||||
}
|
};
|
||||||
|
|||||||
@ -22,6 +22,7 @@
|
|||||||
"bootstrap": "git submodule update --init && cd eslint && npm install",
|
"bootstrap": "git submodule update --init && cd eslint && npm install",
|
||||||
"eslint": "cd eslint && mocha -c tests/lib/rules/*.js -r ../eslint-tester.js",
|
"eslint": "cd eslint && mocha -c tests/lib/rules/*.js -r ../eslint-tester.js",
|
||||||
"test": "mocha",
|
"test": "mocha",
|
||||||
|
"test-ci" "npm test && npm run lint",
|
||||||
"lint": "eslint index.js babylon-to-espree test",
|
"lint": "eslint index.js babylon-to-espree test",
|
||||||
"fix": "eslint index.js babylon-to-espree test --fix",
|
"fix": "eslint index.js babylon-to-espree test --fix",
|
||||||
"preversion": "npm test",
|
"preversion": "npm test",
|
||||||
@ -38,6 +39,7 @@
|
|||||||
"homepage": "https://github.com/babel/babel-eslint",
|
"homepage": "https://github.com/babel/babel-eslint",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"eslint": "^3.0.0",
|
"eslint": "^3.0.0",
|
||||||
|
"eslint-config-babel": "^1.0.1",
|
||||||
"espree": "^3.0.0",
|
"espree": "^3.0.0",
|
||||||
"mocha": "^3.0.0"
|
"mocha": "^3.0.0"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -36,7 +36,7 @@ function lookup(obj, keypath, backwardsDepth) {
|
|||||||
if (!keypath) { return obj; }
|
if (!keypath) { return obj; }
|
||||||
|
|
||||||
return keypath.split(".").slice(0, -1 * backwardsDepth)
|
return keypath.split(".").slice(0, -1 * backwardsDepth)
|
||||||
.reduce(function (base, segment) { return base && base[segment], obj });
|
.reduce(function (base, segment) { return base && base[segment], obj; });
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseAndAssertSame(code) {
|
function parseAndAssertSame(code) {
|
||||||
@ -199,19 +199,19 @@ describe("babylon-to-esprima", function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("default import", function () {
|
it("default import", function () {
|
||||||
parseAndAssertSame('import foo from "foo";');
|
parseAndAssertSame("import foo from \"foo\";");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("import specifier", function () {
|
it("import specifier", function () {
|
||||||
parseAndAssertSame('import { foo } from "foo";');
|
parseAndAssertSame("import { foo } from \"foo\";");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("import specifier with name", function () {
|
it("import specifier with name", function () {
|
||||||
parseAndAssertSame('import { foo as bar } from "foo";');
|
parseAndAssertSame("import { foo as bar } from \"foo\";");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("import bare", function () {
|
it("import bare", function () {
|
||||||
parseAndAssertSame('import "foo";');
|
parseAndAssertSame("import \"foo\";");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("export default class declaration", function () {
|
it("export default class declaration", function () {
|
||||||
@ -231,7 +231,7 @@ describe("babylon-to-esprima", function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("export all", function () {
|
it("export all", function () {
|
||||||
parseAndAssertSame('export * from "foo";');
|
parseAndAssertSame("export * from \"foo\";");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("export named", function () {
|
it("export named", function () {
|
||||||
@ -316,7 +316,7 @@ describe("babylon-to-esprima", function () {
|
|||||||
"};",
|
"};",
|
||||||
"module.exports = test;"
|
"module.exports = test;"
|
||||||
].join("\n"));
|
].join("\n"));
|
||||||
})
|
});
|
||||||
|
|
||||||
it("empty block with comment", function () {
|
it("empty block with comment", function () {
|
||||||
parseAndAssertSame([
|
parseAndAssertSame([
|
||||||
@ -394,7 +394,7 @@ describe("babylon-to-esprima", function () {
|
|||||||
it("do not allow import export everywhere", function() {
|
it("do not allow import export everywhere", function() {
|
||||||
assert.throws(function () {
|
assert.throws(function () {
|
||||||
parseAndAssertSame("function F() { import a from \"a\"; }");
|
parseAndAssertSame("function F() { import a from \"a\"; }");
|
||||||
}, /SyntaxError: 'import' and 'export' may only appear at the top level/)
|
}, /SyntaxError: 'import' and 'export' may only appear at the top level/);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("return outside function", function () {
|
it("return outside function", function () {
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
"use strict";;
|
"use strict";
|
||||||
/*
|
/*
|
||||||
The empty statement is intentional. As of now, ESLint won't enforce
|
The empty statement is intentional. As of now, ESLint won't enforce
|
||||||
string: [2, "global"] on a program with an empty body. A test for that without
|
string: [2, "global"] on a program with an empty body. A test for that without
|
||||||
|
|||||||
@ -23,7 +23,7 @@ function verifyAndAssertMessages(code, rules, expectedMessages, sourceType, over
|
|||||||
|
|
||||||
if (overrideConfig) {
|
if (overrideConfig) {
|
||||||
for (var key in overrideConfig) {
|
for (var key in overrideConfig) {
|
||||||
config[key] = overrideConfig[key]
|
config[key] = overrideConfig[key];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1261,7 +1261,7 @@ describe("verify", function () {
|
|||||||
].join("\n"),
|
].join("\n"),
|
||||||
{ "space-in-parens": 1 },
|
{ "space-in-parens": 1 },
|
||||||
[ ]
|
[ ]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("block comment space-in-parens #124", function () {
|
it("block comment space-in-parens #124", function () {
|
||||||
@ -1279,21 +1279,21 @@ describe("verify", function () {
|
|||||||
].join("\n"),
|
].join("\n"),
|
||||||
{ "space-in-parens": 1 },
|
{ "space-in-parens": 1 },
|
||||||
[ ]
|
[ ]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("no no-undef error with rest #11", function () {
|
it("no no-undef error with rest #11", function () {
|
||||||
verifyAndAssertMessages("const [a, ...rest] = ['1', '2', '3']; a; rest;",
|
verifyAndAssertMessages("const [a, ...rest] = ['1', '2', '3']; a; rest;",
|
||||||
{ "no-undef": 1, "no-unused-vars": 1 },
|
{ "no-undef": 1, "no-unused-vars": 1 },
|
||||||
[ ]
|
[ ]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("async function with space-before-function-paren #168", function () {
|
it("async function with space-before-function-paren #168", function () {
|
||||||
verifyAndAssertMessages("it('handles updates', async function() {});",
|
verifyAndAssertMessages("it('handles updates', async function() {});",
|
||||||
{ "space-before-function-paren": [1, "never"] },
|
{ "space-before-function-paren": [1, "never"] },
|
||||||
[ ]
|
[ ]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("default param flow type no-unused-vars #184", function () {
|
it("default param flow type no-unused-vars #184", function () {
|
||||||
@ -1312,7 +1312,7 @@ describe("verify", function () {
|
|||||||
].join("\n"),
|
].join("\n"),
|
||||||
{ "no-unused-vars": 1, "no-undef": 1 },
|
{ "no-unused-vars": 1, "no-undef": 1 },
|
||||||
[ ]
|
[ ]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("no-use-before-define #192", function () {
|
it("no-use-before-define #192", function () {
|
||||||
@ -1322,8 +1322,8 @@ describe("verify", function () {
|
|||||||
"var x = 1;"
|
"var x = 1;"
|
||||||
].join("\n"),
|
].join("\n"),
|
||||||
{ "no-use-before-define": 1 },
|
{ "no-use-before-define": 1 },
|
||||||
[ "1:13 'x' was used before it was defined no-use-before-define" ]
|
[ "1:13 'x' was used before it was defined. no-use-before-define" ]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("jsx and stringliteral #216", function () {
|
it("jsx and stringliteral #216", function () {
|
||||||
@ -1331,7 +1331,7 @@ describe("verify", function () {
|
|||||||
"<div className=''></div>",
|
"<div className=''></div>",
|
||||||
{},
|
{},
|
||||||
[]
|
[]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("getter/setter #218", function () {
|
it("getter/setter #218", function () {
|
||||||
@ -1342,7 +1342,7 @@ describe("verify", function () {
|
|||||||
].join("\n"),
|
].join("\n"),
|
||||||
{ "space-before-function-paren": 1, "keyword-spacing": [1, {"before": true}], "indent": 1 },
|
{ "space-before-function-paren": 1, "keyword-spacing": [1, {"before": true}], "indent": 1 },
|
||||||
[]
|
[]
|
||||||
)
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("getter/setter #220", function () {
|
it("getter/setter #220", function () {
|
||||||
@ -1380,7 +1380,7 @@ describe("verify", function () {
|
|||||||
"var a = 123;",
|
"var a = 123;",
|
||||||
].join("\n"),
|
].join("\n"),
|
||||||
{ "no-redeclare": 1 },
|
{ "no-redeclare": 1 },
|
||||||
[ "2:5 'a' is already defined no-redeclare" ],
|
[ "2:5 'a' is already defined. no-redeclare" ],
|
||||||
"script"
|
"script"
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
@ -1391,7 +1391,7 @@ describe("verify", function () {
|
|||||||
"var a = 123;",
|
"var a = 123;",
|
||||||
].join("\n"),
|
].join("\n"),
|
||||||
{ "no-redeclare": 1 },
|
{ "no-redeclare": 1 },
|
||||||
[ "2:5 'a' is already defined no-redeclare" ],
|
[ "2:5 'a' is already defined. no-redeclare" ],
|
||||||
"module"
|
"module"
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user