@definitelytyped/dtslint 0.0.168-next.0 → 0.0.168
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lint.js +1 -3
- package/dist/lint.js.map +1 -1
- package/dist/util.d.ts +0 -4
- package/dist/util.js +1 -23
- package/dist/util.js.map +1 -1
- package/package.json +6 -6
- package/src/lint.ts +1 -3
- package/src/util.ts +0 -25
- package/tsconfig.tsbuildinfo +1 -1
- package/dist/rules/dt-header.d.ts +0 -2
- package/dist/rules/dt-header.js +0 -62
- package/dist/rules/dt-header.js.map +0 -1
- package/dist/rules/export-just-namespace.d.ts +0 -2
- package/dist/rules/export-just-namespace.js +0 -70
- package/dist/rules/export-just-namespace.js.map +0 -1
- package/dist/rules/no-any-union.d.ts +0 -4
- package/dist/rules/no-any-union.js +0 -34
- package/dist/rules/no-any-union.js.map +0 -1
- package/dist/rules/no-bad-reference.d.ts +0 -2
- package/dist/rules/no-bad-reference.js +0 -55
- package/dist/rules/no-bad-reference.js.map +0 -1
- package/dist/rules/no-const-enum.d.ts +0 -4
- package/dist/rules/no-const-enum.js +0 -30
- package/dist/rules/no-const-enum.js.map +0 -1
- package/dist/rules/no-dead-reference.d.ts +0 -2
- package/dist/rules/no-dead-reference.js +0 -44
- package/dist/rules/no-dead-reference.js.map +0 -1
- package/dist/rules/no-declare-current-package.d.ts +0 -4
- package/dist/rules/no-declare-current-package.js +0 -43
- package/dist/rules/no-declare-current-package.js.map +0 -1
- package/dist/rules/no-import-default-of-export-equals.d.ts +0 -4
- package/dist/rules/no-import-default-of-export-equals.js +0 -87
- package/dist/rules/no-import-default-of-export-equals.js.map +0 -1
- package/dist/rules/no-outside-dependencies.d.ts +0 -2
- package/dist/rules/no-outside-dependencies.js +0 -41
- package/dist/rules/no-outside-dependencies.js.map +0 -1
- package/dist/rules/no-self-import.d.ts +0 -4
- package/dist/rules/no-self-import.js +0 -38
- package/dist/rules/no-self-import.js.map +0 -1
- package/dist/rules/no-single-element-tuple-type.d.ts +0 -5
- package/dist/rules/no-single-element-tuple-type.js +0 -30
- package/dist/rules/no-single-element-tuple-type.js.map +0 -1
- package/dist/rules/no-unnecessary-generics.d.ts +0 -8
- package/dist/rules/no-unnecessary-generics.js +0 -135
- package/dist/rules/no-unnecessary-generics.js.map +0 -1
- package/dist/rules/no-useless-files.d.ts +0 -2
- package/dist/rules/no-useless-files.js +0 -53
- package/dist/rules/no-useless-files.js.map +0 -1
- package/dist/rules/prefer-declare-function.d.ts +0 -5
- package/dist/rules/prefer-declare-function.js +0 -35
- package/dist/rules/prefer-declare-function.js.map +0 -1
- package/dist/rules/redundant-undefined.d.ts +0 -4
- package/dist/rules/redundant-undefined.js +0 -53
- package/dist/rules/redundant-undefined.js.map +0 -1
- package/dist/rules/trim-file.d.ts +0 -2
- package/dist/rules/trim-file.js +0 -43
- package/dist/rules/trim-file.js.map +0 -1
- package/docs/dt-header.md +0 -88
- package/docs/export-just-namespace.md +0 -29
- package/docs/no-any-union.md +0 -27
- package/docs/no-bad-reference.md +0 -28
- package/docs/no-const-enum.md +0 -16
- package/docs/no-dead-reference.md +0 -17
- package/docs/no-declare-current-package.md +0 -35
- package/docs/no-import-default-of-export-equals.md +0 -22
- package/docs/no-outside-dependencies.md +0 -23
- package/docs/no-self-import.md +0 -27
- package/docs/no-single-element-tuple-type.md +0 -15
- package/docs/no-unnecessary-generics.md +0 -69
- package/docs/no-useless-files.md +0 -14
- package/docs/prefer-declare-function.md +0 -15
- package/docs/redundant-undefined.md +0 -15
- package/docs/trim-file.md +0 -17
- package/src/rules/dt-header.ts +0 -74
- package/src/rules/export-just-namespace.ts +0 -83
- package/src/rules/no-any-union.ts +0 -34
- package/src/rules/no-bad-reference.ts +0 -62
- package/src/rules/no-const-enum.ts +0 -30
- package/src/rules/no-dead-reference.ts +0 -46
- package/src/rules/no-declare-current-package.ts +0 -45
- package/src/rules/no-import-default-of-export-equals.ts +0 -68
- package/src/rules/no-outside-dependencies.ts +0 -42
- package/src/rules/no-self-import.ts +0 -40
- package/src/rules/no-single-element-tuple-type.ts +0 -31
- package/src/rules/no-unnecessary-generics.ts +0 -126
- package/src/rules/no-useless-files.ts +0 -58
- package/src/rules/prefer-declare-function.ts +0 -37
- package/src/rules/redundant-undefined.ts +0 -62
- package/src/rules/trim-file.ts +0 -45
- package/test/dt-header.test.ts +0 -189
- package/test/export-just-namespace.test.ts +0 -70
- package/test/no-any-union.test.ts +0 -22
- package/test/no-bad-reference.test.ts +0 -66
- package/test/no-const-enum.test.ts +0 -22
- package/test/no-dead-reference.test.ts +0 -66
- package/test/no-declare-current-package.test.ts +0 -61
- package/test/no-import-default-of-export-equals.test.ts +0 -49
- package/test/no-self-import.test.ts +0 -47
- package/test/no-single-element-tuple-type.test.ts +0 -28
- package/test/no-unnecessary-generics.test.ts +0 -152
- package/test/no-useless-files.test.ts +0 -42
- package/test/prefer-declare-function.test.ts +0 -66
- package/test/redundant-undefined.test.ts +0 -39
- package/test/trim-file.test.ts +0 -46
- package/test/tsconfig.json +0 -10
- package/test/tsconfig.no-declare-current-package.json +0 -11
- package/test/tsconfig.no-declare-current-package2.json +0 -11
- package/test/tsconfig.no-import-default-of-export-equals.json +0 -11
- package/test/tsconfig.no-self-import.json +0 -7
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
3
|
-
const util_1 = require("../util");
|
|
4
|
-
const rule = (0, util_1.createRule)({
|
|
5
|
-
name: "export-just-namespace",
|
|
6
|
-
defaultOptions: [],
|
|
7
|
-
meta: {
|
|
8
|
-
type: "problem",
|
|
9
|
-
docs: {
|
|
10
|
-
description: "Forbids `export = foo` where `foo` is a namespace and isn't merged with a function/class/type/interface.",
|
|
11
|
-
recommended: "error",
|
|
12
|
-
},
|
|
13
|
-
messages: {
|
|
14
|
-
useTheBody: "Instead of `export =`-ing a namespace, use the body of the namespace as the module body.",
|
|
15
|
-
},
|
|
16
|
-
schema: [],
|
|
17
|
-
},
|
|
18
|
-
create(context) {
|
|
19
|
-
const ast = context.getSourceCode().ast;
|
|
20
|
-
const exportEqualsNode = ast.body.find(isExportEqualsWithIdentifier);
|
|
21
|
-
if (!exportEqualsNode) {
|
|
22
|
-
return {};
|
|
23
|
-
}
|
|
24
|
-
if (isJustNamespace(ast.body, exportEqualsNode.expression.name)) {
|
|
25
|
-
context.report({
|
|
26
|
-
messageId: "useTheBody",
|
|
27
|
-
node: exportEqualsNode,
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
return {};
|
|
31
|
-
},
|
|
32
|
-
});
|
|
33
|
-
/**
|
|
34
|
-
* @returns Where there is a namespace but there are no functions/classes/etc. with the same name.
|
|
35
|
-
*/
|
|
36
|
-
function isJustNamespace(statements, exportEqualsName) {
|
|
37
|
-
let anyNamespace = false;
|
|
38
|
-
for (const statement of statements) {
|
|
39
|
-
switch (statement.type) {
|
|
40
|
-
case utils_1.AST_NODE_TYPES.TSModuleDeclaration:
|
|
41
|
-
anyNamespace || (anyNamespace = nameMatches(statement.id));
|
|
42
|
-
break;
|
|
43
|
-
case utils_1.AST_NODE_TYPES.VariableDeclaration:
|
|
44
|
-
if (statement.declarations.some((d) => nameMatches(d.id))) {
|
|
45
|
-
// OK. It's merged with a variable.
|
|
46
|
-
return false;
|
|
47
|
-
}
|
|
48
|
-
break;
|
|
49
|
-
case utils_1.AST_NODE_TYPES.ClassDeclaration:
|
|
50
|
-
case utils_1.AST_NODE_TYPES.FunctionDeclaration:
|
|
51
|
-
case utils_1.AST_NODE_TYPES.TSDeclareFunction:
|
|
52
|
-
case utils_1.AST_NODE_TYPES.TSTypeAliasDeclaration:
|
|
53
|
-
case utils_1.AST_NODE_TYPES.TSInterfaceDeclaration:
|
|
54
|
-
if (nameMatches(statement.id)) {
|
|
55
|
-
// OK. It's merged with a function/class/type/interface.
|
|
56
|
-
return false;
|
|
57
|
-
}
|
|
58
|
-
break;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return anyNamespace;
|
|
62
|
-
function nameMatches(nameNode) {
|
|
63
|
-
return !!nameNode && nameNode.type === utils_1.AST_NODE_TYPES.Identifier && nameNode.name === exportEqualsName;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
function isExportEqualsWithIdentifier(node) {
|
|
67
|
-
return node.type === utils_1.AST_NODE_TYPES.TSExportAssignment && node.expression.type === utils_1.AST_NODE_TYPES.Identifier;
|
|
68
|
-
}
|
|
69
|
-
module.exports = rule;
|
|
70
|
-
//# sourceMappingURL=export-just-namespace.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"export-just-namespace.js","sourceRoot":"","sources":["../../src/rules/export-just-namespace.ts"],"names":[],"mappings":";AAAA,oDAAoE;AACpE,kCAAqC;AAMrC,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,uBAAuB;IAC7B,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EACT,0GAA0G;YAC5G,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,UAAU,EAAE,0FAA0F;SACvG;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,MAAM,GAAG,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,GAAG,CAAC;QAExC,MAAM,gBAAgB,GAAG,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;QACrE,IAAI,CAAC,gBAAgB,EAAE;YACrB,OAAO,EAAE,CAAC;SACX;QAED,IAAI,eAAe,CAAC,GAAG,CAAC,IAAI,EAAE,gBAAgB,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YAC/D,OAAO,CAAC,MAAM,CAAC;gBACb,SAAS,EAAE,YAAY;gBACvB,IAAI,EAAE,gBAAgB;aACvB,CAAC,CAAC;SACJ;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;CACF,CAAC,CAAC;AAEH;;GAEG;AACH,SAAS,eAAe,CAAC,UAAuC,EAAE,gBAAwB;IACxF,IAAI,YAAY,GAAG,KAAK,CAAC;IAEzB,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE;QAClC,QAAQ,SAAS,CAAC,IAAI,EAAE;YACtB,KAAK,sBAAc,CAAC,mBAAmB;gBACrC,YAAY,KAAZ,YAAY,GAAK,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,EAAC;gBAC3C,MAAM;YACR,KAAK,sBAAc,CAAC,mBAAmB;gBACrC,IAAI,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE;oBACzD,mCAAmC;oBACnC,OAAO,KAAK,CAAC;iBACd;gBACD,MAAM;YACR,KAAK,sBAAc,CAAC,gBAAgB,CAAC;YACrC,KAAK,sBAAc,CAAC,mBAAmB,CAAC;YACxC,KAAK,sBAAc,CAAC,iBAAiB,CAAC;YACtC,KAAK,sBAAc,CAAC,sBAAsB,CAAC;YAC3C,KAAK,sBAAc,CAAC,sBAAsB;gBACxC,IAAI,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE;oBAC7B,wDAAwD;oBACxD,OAAO,KAAK,CAAC;iBACd;gBACD,MAAM;SACT;KACF;IAED,OAAO,YAAY,CAAC;IAEpB,SAAS,WAAW,CAAC,QAA0C;QAC7D,OAAO,CAAC,CAAC,QAAQ,IAAI,QAAQ,CAAC,IAAI,KAAK,sBAAc,CAAC,UAAU,IAAI,QAAQ,CAAC,IAAI,KAAK,gBAAgB,CAAC;IACzG,CAAC;AACH,CAAC;AAED,SAAS,4BAA4B,CAAC,IAAmB;IACvD,OAAO,IAAI,CAAC,IAAI,KAAK,sBAAc,CAAC,kBAAkB,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,sBAAc,CAAC,UAAU,CAAC;AAC/G,CAAC;AAED,iBAAS,IAAI,CAAC"}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const util_1 = require("../util");
|
|
3
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
4
|
-
const rule = (0, util_1.createRule)({
|
|
5
|
-
name: "no-any-union",
|
|
6
|
-
defaultOptions: [],
|
|
7
|
-
meta: {
|
|
8
|
-
type: "problem",
|
|
9
|
-
docs: {
|
|
10
|
-
description: "Forbid a union to contain `any`",
|
|
11
|
-
recommended: "error",
|
|
12
|
-
},
|
|
13
|
-
messages: {
|
|
14
|
-
anyUnion: "Including `any` in a union will override all other members of the union.",
|
|
15
|
-
},
|
|
16
|
-
schema: [],
|
|
17
|
-
},
|
|
18
|
-
create(context) {
|
|
19
|
-
return {
|
|
20
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
21
|
-
TSUnionType(node) {
|
|
22
|
-
const hasAnyType = node.types.some((t) => t.type === utils_1.AST_NODE_TYPES.TSAnyKeyword);
|
|
23
|
-
if (hasAnyType) {
|
|
24
|
-
context.report({
|
|
25
|
-
messageId: "anyUnion",
|
|
26
|
-
node,
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
},
|
|
30
|
-
};
|
|
31
|
-
},
|
|
32
|
-
});
|
|
33
|
-
module.exports = rule;
|
|
34
|
-
//# sourceMappingURL=no-any-union.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-any-union.js","sourceRoot":"","sources":["../../src/rules/no-any-union.ts"],"names":[],"mappings":";AAAA,kCAAqC;AACrC,oDAA0D;AAE1D,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,cAAc;IACpB,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,iCAAiC;YAC9C,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,QAAQ,EAAE,0EAA0E;SACrF;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,gEAAgE;YAChE,WAAW,CAAC,IAAI;gBACd,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,sBAAc,CAAC,YAAY,CAAC,CAAC;gBAClF,IAAI,UAAU,EAAE;oBACd,OAAO,CAAC,MAAM,CAAC;wBACb,SAAS,EAAE,UAAU;wBACrB,IAAI;qBACL,CAAC,CAAC;iBACJ;YACH,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const util_1 = require("../util");
|
|
3
|
-
const rule = (0, util_1.createRule)({
|
|
4
|
-
name: "no-bad-reference",
|
|
5
|
-
defaultOptions: [],
|
|
6
|
-
meta: {
|
|
7
|
-
type: "problem",
|
|
8
|
-
docs: {
|
|
9
|
-
description: `Forbids <reference path="../etc"/> in any file, and forbid <reference path> in test files.`,
|
|
10
|
-
recommended: "error",
|
|
11
|
-
},
|
|
12
|
-
messages: {
|
|
13
|
-
referencePathPackage: "Don't use <reference path> to reference another package. Use an import or <reference types> instead.",
|
|
14
|
-
referencePathTest: "Don't use <reference path> in test files. Use <reference types> or include the file in 'tsconfig.json'.",
|
|
15
|
-
},
|
|
16
|
-
schema: [],
|
|
17
|
-
},
|
|
18
|
-
create(context) {
|
|
19
|
-
var _a;
|
|
20
|
-
const { comments } = context.getSourceCode().ast;
|
|
21
|
-
const isDeclarationFile = context.getFilename().endsWith(".d.ts");
|
|
22
|
-
for (const comment of comments) {
|
|
23
|
-
const referenceMatch = (_a = comment.value.match(/<reference\s+path\s*=\s*"(.+)"\s*\/>/)) === null || _a === void 0 ? void 0 : _a[1];
|
|
24
|
-
if (!referenceMatch) {
|
|
25
|
-
continue;
|
|
26
|
-
}
|
|
27
|
-
if (isDeclarationFile) {
|
|
28
|
-
if (referenceMatch.startsWith("..")) {
|
|
29
|
-
report(comment, "referencePathPackage");
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
else {
|
|
33
|
-
report(comment, "referencePathTest");
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
return {};
|
|
37
|
-
function report(comment, messageId) {
|
|
38
|
-
context.report({
|
|
39
|
-
loc: {
|
|
40
|
-
end: {
|
|
41
|
-
column: comment.value.lastIndexOf(`"`),
|
|
42
|
-
line: comment.loc.end.line,
|
|
43
|
-
},
|
|
44
|
-
start: {
|
|
45
|
-
column: comment.value.indexOf(`"`) + 1,
|
|
46
|
-
line: comment.loc.start.line,
|
|
47
|
-
},
|
|
48
|
-
},
|
|
49
|
-
messageId,
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
},
|
|
53
|
-
});
|
|
54
|
-
module.exports = rule;
|
|
55
|
-
//# sourceMappingURL=no-bad-reference.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-bad-reference.js","sourceRoot":"","sources":["../../src/rules/no-bad-reference.ts"],"names":[],"mappings":";AACA,kCAAqC;AAIrC,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,kBAAkB;IACxB,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,4FAA4F;YACzG,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,oBAAoB,EAClB,sGAAsG;YACxG,iBAAiB,EACf,yGAAyG;SAC5G;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;;QACZ,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,GAAG,CAAC;QACjD,MAAM,iBAAiB,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAElE,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE;YAC9B,MAAM,cAAc,GAAG,MAAA,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,sCAAsC,CAAC,0CAAG,CAAC,CAAC,CAAC;YACxF,IAAI,CAAC,cAAc,EAAE;gBACnB,SAAS;aACV;YAED,IAAI,iBAAiB,EAAE;gBACrB,IAAI,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;oBACnC,MAAM,CAAC,OAAO,EAAE,sBAAsB,CAAC,CAAC;iBACzC;aACF;iBAAM;gBACL,MAAM,CAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;aACtC;SACF;QAED,OAAO,EAAE,CAAC;QAEV,SAAS,MAAM,CAAC,OAAyB,EAAE,SAAoB;YAC7D,OAAO,CAAC,MAAM,CAAC;gBACb,GAAG,EAAE;oBACH,GAAG,EAAE;wBACH,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC;wBACtC,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI;qBAC3B;oBACD,KAAK,EAAE;wBACL,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC;wBACtC,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI;qBAC7B;iBACF;gBACD,SAAS;aACV,CAAC,CAAC;QACL,CAAC;IACH,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const util_1 = require("../util");
|
|
3
|
-
const rule = (0, util_1.createRule)({
|
|
4
|
-
name: "no-const-enum",
|
|
5
|
-
defaultOptions: [],
|
|
6
|
-
meta: {
|
|
7
|
-
type: "problem",
|
|
8
|
-
docs: {
|
|
9
|
-
description: "Forbid `const enum`",
|
|
10
|
-
recommended: "error",
|
|
11
|
-
},
|
|
12
|
-
messages: {
|
|
13
|
-
constEnum: "Use of `const enum` is forbidden.",
|
|
14
|
-
},
|
|
15
|
-
schema: [],
|
|
16
|
-
},
|
|
17
|
-
create(context) {
|
|
18
|
-
return {
|
|
19
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
20
|
-
"TSEnumDeclaration[const]"(node) {
|
|
21
|
-
context.report({
|
|
22
|
-
messageId: "constEnum",
|
|
23
|
-
node,
|
|
24
|
-
});
|
|
25
|
-
},
|
|
26
|
-
};
|
|
27
|
-
},
|
|
28
|
-
});
|
|
29
|
-
module.exports = rule;
|
|
30
|
-
//# sourceMappingURL=no-const-enum.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-const-enum.js","sourceRoot":"","sources":["../../src/rules/no-const-enum.ts"],"names":[],"mappings":";AAAA,kCAAqC;AAErC,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,eAAe;IACrB,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,qBAAqB;YAClC,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,SAAS,EAAE,mCAAmC;SAC/C;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,gEAAgE;YAChE,0BAA0B,CAAC,IAAI;gBAC7B,OAAO,CAAC,MAAM,CAAC;oBACb,SAAS,EAAE,WAAW;oBACtB,IAAI;iBACL,CAAC,CAAC;YACL,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const util_1 = require("../util");
|
|
3
|
-
const rule = (0, util_1.createRule)({
|
|
4
|
-
name: "no-dead-reference",
|
|
5
|
-
defaultOptions: [],
|
|
6
|
-
meta: {
|
|
7
|
-
type: "problem",
|
|
8
|
-
docs: {
|
|
9
|
-
description: "Ensures that all `/// <reference>` comments go at the top of the file.",
|
|
10
|
-
recommended: "error",
|
|
11
|
-
},
|
|
12
|
-
messages: {
|
|
13
|
-
referenceAtTop: "`/// <reference>` directive must be at top of file to take effect.",
|
|
14
|
-
},
|
|
15
|
-
schema: [],
|
|
16
|
-
},
|
|
17
|
-
create(context) {
|
|
18
|
-
var _a, _b;
|
|
19
|
-
const source = context.getSourceCode();
|
|
20
|
-
if (source.ast.body.length) {
|
|
21
|
-
// 'm' flag makes it multiline, so `^` matches the beginning of any line.
|
|
22
|
-
// 'g' flag lets us set rgx.lastIndex
|
|
23
|
-
const rgx = /^\s*(\/\/\/ <reference)/gm;
|
|
24
|
-
// Start search at the first statement. (`/// <reference>` before that is OK.)
|
|
25
|
-
rgx.lastIndex = (_b = (_a = source.ast.body[0].range) === null || _a === void 0 ? void 0 : _a[0]) !== null && _b !== void 0 ? _b : 0;
|
|
26
|
-
// eslint-disable-next-line no-constant-condition
|
|
27
|
-
while (true) {
|
|
28
|
-
const match = rgx.exec(source.text);
|
|
29
|
-
if (match === null) {
|
|
30
|
-
break;
|
|
31
|
-
}
|
|
32
|
-
const length = match[1].length;
|
|
33
|
-
const start = match.index + match[0].length - length;
|
|
34
|
-
context.report({
|
|
35
|
-
messageId: "referenceAtTop",
|
|
36
|
-
loc: source.getLocFromIndex(start),
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
return {};
|
|
41
|
-
},
|
|
42
|
-
});
|
|
43
|
-
module.exports = rule;
|
|
44
|
-
//# sourceMappingURL=no-dead-reference.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-dead-reference.js","sourceRoot":"","sources":["../../src/rules/no-dead-reference.ts"],"names":[],"mappings":";AAAA,kCAAqC;AAErC,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,mBAAmB;IACzB,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,wEAAwE;YACrF,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,cAAc,EAAE,oEAAoE;SACrF;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;;QACZ,MAAM,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;QACvC,IAAI,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE;YAC1B,yEAAyE;YACzE,qCAAqC;YACrC,MAAM,GAAG,GAAG,2BAA2B,CAAC;YAExC,8EAA8E;YAC9E,GAAG,CAAC,SAAS,GAAG,MAAA,MAAA,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,0CAAG,CAAC,CAAC,mCAAI,CAAC,CAAC;YAEnD,iDAAiD;YACjD,OAAO,IAAI,EAAE;gBACX,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBACpC,IAAI,KAAK,KAAK,IAAI,EAAE;oBAClB,MAAM;iBACP;gBAED,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;gBAC/B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;gBACrD,OAAO,CAAC,MAAM,CAAC;oBACb,SAAS,EAAE,gBAAgB;oBAC3B,GAAG,EAAE,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC;iBACnC,CAAC,CAAC;aACJ;SACF;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const util_1 = require("../util");
|
|
3
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
4
|
-
const rule = (0, util_1.createRule)({
|
|
5
|
-
name: "no-declare-current-package",
|
|
6
|
-
defaultOptions: [],
|
|
7
|
-
meta: {
|
|
8
|
-
type: "problem",
|
|
9
|
-
docs: {
|
|
10
|
-
description: "Don't use an ambient module declaration of the current package; use a normal module.",
|
|
11
|
-
recommended: "error",
|
|
12
|
-
},
|
|
13
|
-
messages: {
|
|
14
|
-
noDeclareCurrentPackage: `Instead of declaring a module with \`declare module "{{ text }}"\`, ` +
|
|
15
|
-
`write its contents in directly in {{ preferred }}.`,
|
|
16
|
-
},
|
|
17
|
-
schema: [],
|
|
18
|
-
},
|
|
19
|
-
create(context) {
|
|
20
|
-
if (!context.getFilename().endsWith(".d.ts")) {
|
|
21
|
-
return {};
|
|
22
|
-
}
|
|
23
|
-
const parserServices = utils_1.ESLintUtils.getParserServices(context);
|
|
24
|
-
const packageName = (0, util_1.getCommonDirectoryName)(parserServices.program.getRootFileNames());
|
|
25
|
-
return {
|
|
26
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
27
|
-
TSModuleDeclaration(node) {
|
|
28
|
-
if (node.id.type === utils_1.AST_NODE_TYPES.Literal &&
|
|
29
|
-
(node.id.value === packageName || node.id.value.startsWith(packageName + "/"))) {
|
|
30
|
-
const text = node.id.value;
|
|
31
|
-
const preferred = text === packageName ? '"index.d.ts"' : `"${text}.d.ts" or "${text}/index.d.ts`;
|
|
32
|
-
context.report({
|
|
33
|
-
messageId: "noDeclareCurrentPackage",
|
|
34
|
-
data: { text, preferred },
|
|
35
|
-
node,
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
},
|
|
39
|
-
};
|
|
40
|
-
},
|
|
41
|
-
});
|
|
42
|
-
module.exports = rule;
|
|
43
|
-
//# sourceMappingURL=no-declare-current-package.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-declare-current-package.js","sourceRoot":"","sources":["../../src/rules/no-declare-current-package.ts"],"names":[],"mappings":";AAAA,kCAA6D;AAC7D,oDAAuE;AACvE,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,4BAA4B;IAClC,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,sFAAsF;YACnG,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,uBAAuB,EACrB,sEAAsE;gBACtE,oDAAoD;SACvD;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YAC5C,OAAO,EAAE,CAAC;SACX;QACD,MAAM,cAAc,GAAG,mBAAW,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAC9D,MAAM,WAAW,GAAG,IAAA,6BAAsB,EAAC,cAAc,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACtF,OAAO;YACL,gEAAgE;YAChE,mBAAmB,CAAC,IAAI;gBACtB,IACE,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,sBAAc,CAAC,OAAO;oBACvC,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,KAAK,WAAW,IAAI,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,WAAW,GAAG,GAAG,CAAC,CAAC,EAC9E;oBACA,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;oBAC3B,MAAM,SAAS,GAAG,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,IAAI,cAAc,IAAI,aAAa,CAAC;oBAClG,OAAO,CAAC,MAAM,CAAC;wBACb,SAAS,EAAE,yBAAyB;wBACpC,IAAI,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE;wBACzB,IAAI;qBACL,CAAC,CAAC;iBACJ;YACH,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
const util_1 = require("../util");
|
|
26
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
27
|
-
const ts = __importStar(require("typescript"));
|
|
28
|
-
const rule = (0, util_1.createRule)({
|
|
29
|
-
name: "no-import-default-of-export-equals",
|
|
30
|
-
defaultOptions: [],
|
|
31
|
-
meta: {
|
|
32
|
-
type: "problem",
|
|
33
|
-
docs: {
|
|
34
|
-
description: "Forbid a default import to reference an `export =` module.",
|
|
35
|
-
recommended: "error",
|
|
36
|
-
},
|
|
37
|
-
messages: {
|
|
38
|
-
noImportDefaultOfExportEquals: `The module {{moduleName}} uses \`export = \`. Import with \`import {{importName}} = require({{moduleName}})\`.`,
|
|
39
|
-
},
|
|
40
|
-
schema: [],
|
|
41
|
-
},
|
|
42
|
-
create(context) {
|
|
43
|
-
const parserServices = utils_1.ESLintUtils.getParserServices(context);
|
|
44
|
-
const checker = parserServices.program.getTypeChecker();
|
|
45
|
-
if (context.getFilename().endsWith(".d.ts")) {
|
|
46
|
-
return {
|
|
47
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
48
|
-
ImportDeclaration(node) {
|
|
49
|
-
var _a, _b;
|
|
50
|
-
const defaultName = (_a = node.specifiers.find((spec) => spec.type === "ImportDefaultSpecifier")) === null || _a === void 0 ? void 0 : _a.local;
|
|
51
|
-
if (!defaultName) {
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
const importName = defaultName.name;
|
|
55
|
-
const source = parserServices.esTreeNodeToTSNodeMap.get(node.source);
|
|
56
|
-
const sym = checker.getSymbolAtLocation(source);
|
|
57
|
-
if ((_b = sym === null || sym === void 0 ? void 0 : sym.declarations) === null || _b === void 0 ? void 0 : _b.some((d) => { var _a; return (_a = getStatements(d)) === null || _a === void 0 ? void 0 : _a.some((s) => ts.isExportAssignment(s) && !!s.isExportEquals); })) {
|
|
58
|
-
context.report({
|
|
59
|
-
messageId: "noImportDefaultOfExportEquals",
|
|
60
|
-
data: { moduleName: node.source.value, importName },
|
|
61
|
-
node: defaultName,
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
},
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
return {};
|
|
69
|
-
}
|
|
70
|
-
},
|
|
71
|
-
});
|
|
72
|
-
function getStatements(decl) {
|
|
73
|
-
return ts.isSourceFile(decl)
|
|
74
|
-
? decl.statements
|
|
75
|
-
: ts.isModuleDeclaration(decl)
|
|
76
|
-
? getModuleDeclarationStatements(decl)
|
|
77
|
-
: undefined;
|
|
78
|
-
}
|
|
79
|
-
function getModuleDeclarationStatements(node) {
|
|
80
|
-
let { body } = node;
|
|
81
|
-
while (body && body.kind === ts.SyntaxKind.ModuleDeclaration) {
|
|
82
|
-
body = body.body;
|
|
83
|
-
}
|
|
84
|
-
return body && ts.isModuleBlock(body) ? body.statements : undefined;
|
|
85
|
-
}
|
|
86
|
-
module.exports = rule;
|
|
87
|
-
//# sourceMappingURL=no-import-default-of-export-equals.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-import-default-of-export-equals.js","sourceRoot":"","sources":["../../src/rules/no-import-default-of-export-equals.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,kCAAqC;AACrC,oDAAuD;AACvD,+CAAiC;AAEjC,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,oCAAoC;IAC1C,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,4DAA4D;YACzE,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,6BAA6B,EAAE,gHAAgH;SAChJ;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,MAAM,cAAc,GAAG,mBAAW,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAC9D,MAAM,OAAO,GAAG,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;QACxD,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YAC3C,OAAO;gBACL,gEAAgE;gBAChE,iBAAiB,CAAC,IAAI;;oBACpB,MAAM,WAAW,GAAG,MAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,wBAAwB,CAAC,0CAAE,KAAK,CAAC;oBAClG,IAAI,CAAC,WAAW,EAAE;wBAChB,OAAO;qBACR;oBACD,MAAM,UAAU,GAAG,WAAW,CAAC,IAAI,CAAC;oBACpC,MAAM,MAAM,GAAG,cAAc,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACrE,MAAM,GAAG,GAAG,OAAO,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;oBAChD,IACE,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,YAAY,0CAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,WAC5B,OAAA,MAAA,aAAa,CAAC,CAAC,CAAC,0CAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAA,EAAA,CAC9E,EACD;wBACA,OAAO,CAAC,MAAM,CAAC;4BACb,SAAS,EAAE,+BAA+B;4BAC1C,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE;4BACnD,IAAI,EAAE,WAAW;yBAClB,CAAC,CAAC;qBACJ;gBACH,CAAC;aACF,CAAC;SACH;aAAM;YACL,OAAO,EAAE,CAAC;SACX;IACH,CAAC;CACF,CAAC,CAAC;AAEH,SAAS,aAAa,CAAC,IAAoB;IACzC,OAAO,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC;QAC1B,CAAC,CAAC,IAAI,CAAC,UAAU;QACjB,CAAC,CAAC,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC;YAC9B,CAAC,CAAC,8BAA8B,CAAC,IAAI,CAAC;YACtC,CAAC,CAAC,SAAS,CAAC;AAChB,CAAC;AAED,SAAS,8BAA8B,CAAC,IAA0B;IAChE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC;IACpB,OAAO,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,EAAE,CAAC,UAAU,CAAC,iBAAiB,EAAE;QAC5D,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;KAClB;IACD,OAAO,IAAI,IAAI,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;AACtE,CAAC;AAED,iBAAS,IAAI,CAAC"}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const util_1 = require("../util");
|
|
3
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
4
|
-
const rule = (0, util_1.createRule)({
|
|
5
|
-
name: "no-outside-dependencies",
|
|
6
|
-
defaultOptions: [],
|
|
7
|
-
meta: {
|
|
8
|
-
type: "problem",
|
|
9
|
-
docs: {
|
|
10
|
-
description: "Don't import things in `DefinitelyTyped/node_modules`.",
|
|
11
|
-
recommended: "error",
|
|
12
|
-
},
|
|
13
|
-
messages: {
|
|
14
|
-
noOutsideDependencies: `File {{fileName}} comes from a \`node_modules\` but is not declared in this type's \`package.json\`. `,
|
|
15
|
-
},
|
|
16
|
-
schema: [],
|
|
17
|
-
},
|
|
18
|
-
create(context) {
|
|
19
|
-
if ((0, util_1.isMainFile)(context.getFilename(), /*allowNested*/ true)) {
|
|
20
|
-
const parserServices = utils_1.ESLintUtils.getParserServices(context);
|
|
21
|
-
const hasNodeReference = parserServices.program
|
|
22
|
-
.getSourceFiles()
|
|
23
|
-
.some((f) => f.typeReferenceDirectives.some((dir) => dir.fileName === "node"));
|
|
24
|
-
for (const sourceFile of parserServices.program.getSourceFiles()) {
|
|
25
|
-
const fileName = sourceFile.fileName;
|
|
26
|
-
if (fileName.includes("/DefinitelyTyped/node_modules/") &&
|
|
27
|
-
!parserServices.program.isSourceFileDefaultLibrary(sourceFile) &&
|
|
28
|
-
!(hasNodeReference && fileName.includes("buffer"))) {
|
|
29
|
-
context.report({
|
|
30
|
-
messageId: "noOutsideDependencies",
|
|
31
|
-
data: { fileName },
|
|
32
|
-
loc: { column: 0, line: 1 },
|
|
33
|
-
});
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
return {};
|
|
38
|
-
},
|
|
39
|
-
});
|
|
40
|
-
module.exports = rule;
|
|
41
|
-
//# sourceMappingURL=no-outside-dependencies.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-outside-dependencies.js","sourceRoot":"","sources":["../../src/rules/no-outside-dependencies.ts"],"names":[],"mappings":";AAAA,kCAAiD;AACjD,oDAAuD;AACvD,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,yBAAyB;IAC/B,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,wDAAwD;YACrE,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,qBAAqB,EAAE,uGAAuG;SAC/H;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,IAAI,IAAA,iBAAU,EAAC,OAAO,CAAC,WAAW,EAAE,EAAE,eAAe,CAAC,IAAI,CAAC,EAAE;YAC3D,MAAM,cAAc,GAAG,mBAAW,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;YAC9D,MAAM,gBAAgB,GAAG,cAAc,CAAC,OAAO;iBAC5C,cAAc,EAAE;iBAChB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC;YACjF,KAAK,MAAM,UAAU,IAAI,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE,EAAE;gBAChE,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC;gBACrC,IACE,QAAQ,CAAC,QAAQ,CAAC,gCAAgC,CAAC;oBACnD,CAAC,cAAc,CAAC,OAAO,CAAC,0BAA0B,CAAC,UAAU,CAAC;oBAC9D,CAAC,CAAC,gBAAgB,IAAI,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,EAClD;oBACA,OAAO,CAAC,MAAM,CAAC;wBACb,SAAS,EAAE,uBAAuB;wBAClC,IAAI,EAAE,EAAE,QAAQ,EAAE;wBAClB,GAAG,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;qBAC5B,CAAC,CAAC;iBACJ;aACF;SACF;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const utils_1 = require("@typescript-eslint/utils");
|
|
3
|
-
const util_1 = require("../util");
|
|
4
|
-
const rule = (0, util_1.createRule)({
|
|
5
|
-
name: "no-self-import",
|
|
6
|
-
defaultOptions: [],
|
|
7
|
-
meta: {
|
|
8
|
-
type: "problem",
|
|
9
|
-
docs: {
|
|
10
|
-
description: "Forbids declaration files to import the current package using a global import.",
|
|
11
|
-
recommended: "error",
|
|
12
|
-
},
|
|
13
|
-
messages: {
|
|
14
|
-
useRelativeImport: "Declaration file should not use a global import of itself. Use a relative import.",
|
|
15
|
-
},
|
|
16
|
-
schema: [],
|
|
17
|
-
},
|
|
18
|
-
create(context) {
|
|
19
|
-
if (!context.getFilename().endsWith(".d.ts")) {
|
|
20
|
-
return {};
|
|
21
|
-
}
|
|
22
|
-
const services = utils_1.ESLintUtils.getParserServices(context);
|
|
23
|
-
const packageName = (0, util_1.getCommonDirectoryName)(services.program.getRootFileNames());
|
|
24
|
-
return {
|
|
25
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
26
|
-
ImportDeclaration(node) {
|
|
27
|
-
if (node.source.value === packageName || node.source.value.startsWith(packageName + "/")) {
|
|
28
|
-
context.report({
|
|
29
|
-
messageId: "useRelativeImport",
|
|
30
|
-
node,
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
},
|
|
34
|
-
};
|
|
35
|
-
},
|
|
36
|
-
});
|
|
37
|
-
module.exports = rule;
|
|
38
|
-
//# sourceMappingURL=no-self-import.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-self-import.js","sourceRoot":"","sources":["../../src/rules/no-self-import.ts"],"names":[],"mappings":";AAAA,oDAAuD;AACvD,kCAA6D;AAE7D,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,gBAAgB;IACtB,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,gFAAgF;YAC7F,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,iBAAiB,EAAE,mFAAmF;SACvG;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YAC5C,OAAO,EAAE,CAAC;SACX;QAED,MAAM,QAAQ,GAAG,mBAAW,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QACxD,MAAM,WAAW,GAAG,IAAA,6BAAsB,EAAC,QAAQ,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAEhF,OAAO;YACL,gEAAgE;YAChE,iBAAiB,CAAC,IAAI;gBACpB,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,WAAW,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,WAAW,GAAG,GAAG,CAAC,EAAE;oBACxF,OAAO,CAAC,MAAM,CAAC;wBACb,SAAS,EAAE,mBAAmB;wBAC9B,IAAI;qBACL,CAAC,CAAC;iBACJ;YACH,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import { TSESTree } from "@typescript-eslint/utils";
|
|
2
|
-
declare const rule: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"singleElementTupleType", never[], {
|
|
3
|
-
"TSTupleType[elementTypes.length=1]"(node: TSESTree.TSTupleType): void;
|
|
4
|
-
}>;
|
|
5
|
-
export = rule;
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const util_1 = require("../util");
|
|
3
|
-
const rule = (0, util_1.createRule)({
|
|
4
|
-
name: "no-single-element-tuple-type",
|
|
5
|
-
defaultOptions: [],
|
|
6
|
-
meta: {
|
|
7
|
-
type: "problem",
|
|
8
|
-
docs: {
|
|
9
|
-
description: "Forbids `[T]`, which should be `T[]`.",
|
|
10
|
-
recommended: "error",
|
|
11
|
-
},
|
|
12
|
-
messages: {
|
|
13
|
-
singleElementTupleType: `Type [T] is a single-element tuple type. You probably meant T[].`,
|
|
14
|
-
},
|
|
15
|
-
schema: [],
|
|
16
|
-
},
|
|
17
|
-
create(context) {
|
|
18
|
-
return {
|
|
19
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
20
|
-
"TSTupleType[elementTypes.length=1]"(node) {
|
|
21
|
-
context.report({
|
|
22
|
-
messageId: "singleElementTupleType",
|
|
23
|
-
node,
|
|
24
|
-
});
|
|
25
|
-
},
|
|
26
|
-
};
|
|
27
|
-
},
|
|
28
|
-
});
|
|
29
|
-
module.exports = rule;
|
|
30
|
-
//# sourceMappingURL=no-single-element-tuple-type.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-single-element-tuple-type.js","sourceRoot":"","sources":["../../src/rules/no-single-element-tuple-type.ts"],"names":[],"mappings":";AAAA,kCAAqC;AAGrC,MAAM,IAAI,GAAG,IAAA,iBAAU,EAAC;IACtB,IAAI,EAAE,8BAA8B;IACpC,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACJ,IAAI,EAAE,SAAS;QACf,IAAI,EAAE;YACJ,WAAW,EAAE,uCAAuC;YACpD,WAAW,EAAE,OAAO;SACrB;QACD,QAAQ,EAAE;YACR,sBAAsB,EAAE,kEAAkE;SAC3F;QACD,MAAM,EAAE,EAAE;KACX;IACD,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,gEAAgE;YAChE,oCAAoC,CAAC,IAA0B;gBAC7D,OAAO,CAAC,MAAM,CAAC;oBACb,SAAS,EAAE,wBAAwB;oBACnC,IAAI;iBACL,CAAC,CAAC;YACL,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC;AAEH,iBAAS,IAAI,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { TSESTree } from "@typescript-eslint/utils";
|
|
2
|
-
type ESTreeFunctionLikeWithTypeParameters = TSESTree.FunctionLike & {
|
|
3
|
-
typeParameters: {};
|
|
4
|
-
};
|
|
5
|
-
declare const rule: import("@typescript-eslint/utils/dist/ts-eslint/Rule").RuleModule<"never" | "sole", never[], {
|
|
6
|
-
[x: string]: (esNode: ESTreeFunctionLikeWithTypeParameters) => void;
|
|
7
|
-
}>;
|
|
8
|
-
export = rule;
|