eslint-plugin-obsidian 2.6.2 → 2.8.0
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/README.md +5 -0
- package/dist/dto/callExpression.d.ts +14 -0
- package/dist/dto/callExpression.d.ts.map +1 -0
- package/dist/dto/callExpression.js +30 -0
- package/dist/dto/callExpression.js.map +1 -0
- package/dist/dto/class.d.ts.map +1 -1
- package/dist/dto/class.js +2 -2
- package/dist/dto/class.js.map +1 -1
- package/dist/dto/classFile.d.ts.map +1 -1
- package/dist/dto/classFile.js.map +1 -1
- package/dist/dto/componentProps.d.ts +8 -0
- package/dist/dto/componentProps.d.ts.map +1 -0
- package/dist/dto/componentProps.js +30 -0
- package/dist/dto/componentProps.js.map +1 -0
- package/dist/dto/context.d.ts.map +1 -1
- package/dist/dto/context.js.map +1 -1
- package/dist/dto/decorator.d.ts.map +1 -1
- package/dist/dto/decorator.js +2 -2
- package/dist/dto/decorator.js.map +1 -1
- package/dist/dto/file.d.ts +3 -1
- package/dist/dto/file.d.ts.map +1 -1
- package/dist/dto/file.js +14 -6
- package/dist/dto/file.js.map +1 -1
- package/dist/dto/functionalComponent.d.ts +8 -0
- package/dist/dto/functionalComponent.d.ts.map +1 -0
- package/dist/dto/functionalComponent.js +14 -0
- package/dist/dto/functionalComponent.js.map +1 -0
- package/dist/dto/generics.d.ts +9 -0
- package/dist/dto/generics.d.ts.map +1 -0
- package/dist/dto/generics.js +24 -0
- package/dist/dto/generics.js.map +1 -0
- package/dist/dto/identifier.d.ts +7 -0
- package/dist/dto/identifier.d.ts.map +1 -0
- package/dist/dto/identifier.js +13 -0
- package/dist/dto/identifier.js.map +1 -0
- package/dist/dto/import.d.ts.map +1 -1
- package/dist/dto/import.js.map +1 -1
- package/dist/dto/method.d.ts.map +1 -1
- package/dist/dto/method.js.map +1 -1
- package/dist/dto/missingType.d.ts +7 -0
- package/dist/dto/missingType.d.ts.map +1 -0
- package/dist/dto/missingType.js +16 -0
- package/dist/dto/missingType.js.map +1 -0
- package/dist/dto/parameter.d.ts.map +1 -1
- package/dist/dto/parameter.js.map +1 -1
- package/dist/dto/property.d.ts.map +1 -1
- package/dist/dto/property.js.map +1 -1
- package/dist/dto/singleType.d.ts +10 -0
- package/dist/dto/singleType.d.ts.map +1 -0
- package/dist/dto/singleType.js +22 -0
- package/dist/dto/singleType.js.map +1 -0
- package/dist/dto/type.d.ts +6 -0
- package/dist/dto/type.d.ts.map +1 -0
- package/dist/dto/type.js +3 -0
- package/dist/dto/type.js.map +1 -0
- package/dist/dto/typeIntersection.d.ts +10 -0
- package/dist/dto/typeIntersection.d.ts.map +1 -0
- package/dist/dto/typeIntersection.js +24 -0
- package/dist/dto/typeIntersection.js.map +1 -0
- package/dist/dto/typeLiteral.d.ts +8 -0
- package/dist/dto/typeLiteral.d.ts.map +1 -0
- package/dist/dto/typeLiteral.js +19 -0
- package/dist/dto/typeLiteral.js.map +1 -0
- package/dist/dto/typeReference.d.ts +10 -0
- package/dist/dto/typeReference.d.ts.map +1 -0
- package/dist/dto/typeReference.js +21 -0
- package/dist/dto/typeReference.js.map +1 -0
- package/dist/dto/variable.d.ts +9 -0
- package/dist/dto/variable.d.ts.map +1 -0
- package/dist/dto/variable.js +25 -0
- package/dist/dto/variable.js.map +1 -0
- package/dist/framework/fileReader.d.ts.map +1 -1
- package/dist/framework/fileReader.js.map +1 -1
- package/dist/framework/pathResolver.d.ts.map +1 -1
- package/dist/framework/pathResolver.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/dist/rules/noCircularDependency/circularDependenciesDetector.d.ts +18 -0
- package/dist/rules/noCircularDependency/circularDependenciesDetector.d.ts.map +1 -0
- package/dist/rules/noCircularDependency/circularDependenciesDetector.js +38 -0
- package/dist/rules/noCircularDependency/circularDependenciesDetector.js.map +1 -0
- package/dist/rules/noCircularDependency/createRule.d.ts +6 -0
- package/dist/rules/noCircularDependency/createRule.d.ts.map +1 -0
- package/dist/rules/noCircularDependency/createRule.js +17 -0
- package/dist/rules/noCircularDependency/createRule.js.map +1 -0
- package/dist/rules/noCircularDependency/errorReporter.d.ts +14 -0
- package/dist/rules/noCircularDependency/errorReporter.d.ts.map +1 -0
- package/dist/rules/noCircularDependency/errorReporter.js +18 -0
- package/dist/rules/noCircularDependency/errorReporter.js.map +1 -0
- package/dist/rules/noCircularDependency/graphHandler.d.ts +11 -0
- package/dist/rules/noCircularDependency/graphHandler.d.ts.map +1 -0
- package/dist/rules/noCircularDependency/graphHandler.js +20 -0
- package/dist/rules/noCircularDependency/graphHandler.js.map +1 -0
- package/dist/rules/noCircularDependency/index.d.ts +3 -0
- package/dist/rules/noCircularDependency/index.d.ts.map +1 -0
- package/dist/rules/noCircularDependency/index.js +29 -0
- package/dist/rules/noCircularDependency/index.js.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/createRule.d.ts +7 -0
- package/dist/rules/stronglyTypedInjectComponent/createRule.d.ts.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/createRule.js +17 -0
- package/dist/rules/stronglyTypedInjectComponent/createRule.js.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/errorReporter.d.ts +9 -0
- package/dist/rules/stronglyTypedInjectComponent/errorReporter.d.ts.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/errorReporter.js +17 -0
- package/dist/rules/stronglyTypedInjectComponent/errorReporter.js.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/index.d.ts +3 -0
- package/dist/rules/stronglyTypedInjectComponent/index.d.ts.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/index.js +29 -0
- package/dist/rules/stronglyTypedInjectComponent/index.js.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/injectComponentHandler.d.ts +11 -0
- package/dist/rules/stronglyTypedInjectComponent/injectComponentHandler.d.ts.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/injectComponentHandler.js +27 -0
- package/dist/rules/stronglyTypedInjectComponent/injectComponentHandler.js.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/typeValidator.d.ts +15 -0
- package/dist/rules/stronglyTypedInjectComponent/typeValidator.d.ts.map +1 -0
- package/dist/rules/stronglyTypedInjectComponent/typeValidator.js +26 -0
- package/dist/rules/stronglyTypedInjectComponent/typeValidator.js.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/createRule.d.ts +2 -2
- package/dist/rules/unresolvedProviderDependencies/createRule.d.ts.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/createRule.js +2 -2
- package/dist/rules/unresolvedProviderDependencies/createRule.js.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/dependencyResolver.d.ts +3 -3
- package/dist/rules/unresolvedProviderDependencies/dependencyResolver.d.ts.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/dependencyResolver.js +1 -1
- package/dist/rules/unresolvedProviderDependencies/dependencyResolver.js.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/errorReporter.d.ts +1 -1
- package/dist/rules/unresolvedProviderDependencies/errorReporter.d.ts.map +1 -0
- package/dist/rules/unresolvedProviderDependencies/errorReporter.js.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/graphHandler.d.ts +3 -3
- package/dist/rules/unresolvedProviderDependencies/graphHandler.d.ts.map +1 -0
- package/dist/rules/unresolvedProviderDependencies/graphHandler.js.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/index.d.ts +1 -1
- package/dist/rules/unresolvedProviderDependencies/index.d.ts.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/index.js +3 -3
- package/dist/rules/unresolvedProviderDependencies/index.js.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/resolvedDependencyChecker.d.ts +1 -1
- package/dist/rules/unresolvedProviderDependencies/resolvedDependencyChecker.d.ts.map +1 -0
- package/dist/rules/unresolvedProviderDependencies/resolvedDependencyChecker.js.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/subgraphResolver.d.ts +2 -2
- package/dist/rules/unresolvedProviderDependencies/subgraphResolver.d.ts.map +1 -0
- package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/subgraphResolver.js +5 -5
- package/dist/rules/unresolvedProviderDependencies/subgraphResolver.js.map +1 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/utils/array.d.ts +2 -0
- package/dist/utils/array.d.ts.map +1 -0
- package/dist/utils/array.js +8 -0
- package/dist/utils/array.js.map +1 -0
- package/dist/utils/assertions.d.ts.map +1 -1
- package/dist/utils/assertions.js.map +1 -1
- package/dist/{ast/utils.d.ts → utils/ast.d.ts} +7 -2
- package/dist/utils/ast.d.ts.map +1 -0
- package/dist/{ast/utils.js → utils/ast.js} +27 -13
- package/dist/utils/ast.js.map +1 -0
- package/package.json +16 -3
- package/dist/ast/utils.d.ts.map +0 -1
- package/dist/ast/utils.js.map +0 -1
- package/dist/unresolvedProviderDependencies/createRule.d.ts.map +0 -1
- package/dist/unresolvedProviderDependencies/createRule.js.map +0 -1
- package/dist/unresolvedProviderDependencies/dependencyResolver.d.ts.map +0 -1
- package/dist/unresolvedProviderDependencies/dependencyResolver.js.map +0 -1
- package/dist/unresolvedProviderDependencies/errorReporter.d.ts.map +0 -1
- package/dist/unresolvedProviderDependencies/errorReporter.js.map +0 -1
- package/dist/unresolvedProviderDependencies/graphHandler.d.ts.map +0 -1
- package/dist/unresolvedProviderDependencies/graphHandler.js.map +0 -1
- package/dist/unresolvedProviderDependencies/index.d.ts.map +0 -1
- package/dist/unresolvedProviderDependencies/index.js.map +0 -1
- package/dist/unresolvedProviderDependencies/resolvedDependencyChecker.d.ts.map +0 -1
- package/dist/unresolvedProviderDependencies/resolvedDependencyChecker.js.map +0 -1
- package/dist/unresolvedProviderDependencies/subgraphResolver.d.ts.map +0 -1
- package/dist/unresolvedProviderDependencies/subgraphResolver.js.map +0 -1
- /package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/errorReporter.js +0 -0
- /package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/graphHandler.js +0 -0
- /package/dist/{unresolvedProviderDependencies → rules/unresolvedProviderDependencies}/resolvedDependencyChecker.js +0 -0
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TypeLiteral = void 0;
|
|
4
|
+
class TypeLiteral {
|
|
5
|
+
static isTypeLiteral(type) {
|
|
6
|
+
return type instanceof TypeLiteral;
|
|
7
|
+
}
|
|
8
|
+
toString() {
|
|
9
|
+
throw new Error('Method not implemented.');
|
|
10
|
+
}
|
|
11
|
+
isEmpty() {
|
|
12
|
+
throw new Error('Method not implemented.');
|
|
13
|
+
}
|
|
14
|
+
equals(types) {
|
|
15
|
+
return types.length === 1 && types[0].toString() === this.toString();
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.TypeLiteral = TypeLiteral;
|
|
19
|
+
//# sourceMappingURL=typeLiteral.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typeLiteral.js","sourceRoot":"","sources":["../../src/dto/typeLiteral.ts"],"names":[],"mappings":";;;AAEA,MAAa,WAAW;IACtB,MAAM,CAAC,aAAa,CAAC,IAAU;QAC7B,OAAO,IAAI,YAAY,WAAW,CAAC;IACrC,CAAC;IAED,QAAQ;QACN,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,OAAO;QACL,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED,MAAM,CAAC,KAAa;QAClB,OAAO,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,QAAQ,EAAE,CAAC;IACvE,CAAC;CACF;AAhBD,kCAgBC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { TSESTree } from '@typescript-eslint/types';
|
|
2
|
+
import type { Type } from './type';
|
|
3
|
+
export declare class TypeReference implements Type {
|
|
4
|
+
private node;
|
|
5
|
+
constructor(node: TSESTree.TSTypeReference);
|
|
6
|
+
toString(): string[];
|
|
7
|
+
isEmpty(): boolean;
|
|
8
|
+
equals(types: Type[]): boolean;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=typeReference.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typeReference.d.ts","sourceRoot":"","sources":["../../src/dto/typeReference.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAGnC,qBAAa,aAAc,YAAW,IAAI;IAC5B,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,QAAQ,CAAC,eAAe;IAElD,QAAQ,IAAI,MAAM,EAAE;IAIpB,OAAO,IAAI,OAAO;IAIlB,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,OAAO;CAG/B"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TypeReference = void 0;
|
|
4
|
+
const lodash_1 = require("lodash");
|
|
5
|
+
const identifier_1 = require("./identifier");
|
|
6
|
+
class TypeReference {
|
|
7
|
+
constructor(node) {
|
|
8
|
+
this.node = node;
|
|
9
|
+
}
|
|
10
|
+
toString() {
|
|
11
|
+
return [new identifier_1.Identifier(this.node.typeName).name];
|
|
12
|
+
}
|
|
13
|
+
isEmpty() {
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
equals(types) {
|
|
17
|
+
return (0, lodash_1.isEqual)(this.toString(), types.map((type) => type.toString()).flat());
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.TypeReference = TypeReference;
|
|
21
|
+
//# sourceMappingURL=typeReference.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typeReference.js","sourceRoot":"","sources":["../../src/dto/typeReference.ts"],"names":[],"mappings":";;;AACA,mCAAiC;AAEjC,6CAA0C;AAE1C,MAAa,aAAa;IACxB,YAAoB,IAA8B;QAA9B,SAAI,GAAJ,IAAI,CAA0B;IAAG,CAAC;IAEtD,QAAQ;QACN,OAAO,CAAC,IAAI,uBAAU,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC;IAED,OAAO;QACL,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,CAAC,KAAa;QAClB,OAAO,IAAA,gBAAO,EAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IAC/E,CAAC;CACF;AAdD,sCAcC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TSESTree } from '@typescript-eslint/types';
|
|
2
|
+
export declare class Variable {
|
|
3
|
+
private node;
|
|
4
|
+
constructor(node: TSESTree.VariableDeclarator);
|
|
5
|
+
get name(): string;
|
|
6
|
+
get isArrowFunction(): boolean;
|
|
7
|
+
get arrowFunction(): TSESTree.ArrowFunctionExpression;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=variable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"variable.d.ts","sourceRoot":"","sources":["../../src/dto/variable.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAGzD,qBAAa,QAAQ;IACP,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,QAAQ,CAAC,kBAAkB;IAErD,IAAI,IAAI,WAEP;IAED,IAAI,eAAe,IAAI,OAAO,CAE7B;IAED,IAAI,aAAa,IAAI,QAAQ,CAAC,uBAAuB,CAGpD;CACF"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Variable = void 0;
|
|
7
|
+
const assert_1 = __importDefault(require("assert"));
|
|
8
|
+
class Variable {
|
|
9
|
+
constructor(node) {
|
|
10
|
+
this.node = node;
|
|
11
|
+
}
|
|
12
|
+
get name() {
|
|
13
|
+
return this.node.id.name;
|
|
14
|
+
}
|
|
15
|
+
get isArrowFunction() {
|
|
16
|
+
var _a;
|
|
17
|
+
return ((_a = this.node.init) === null || _a === void 0 ? void 0 : _a.type) === 'ArrowFunctionExpression';
|
|
18
|
+
}
|
|
19
|
+
get arrowFunction() {
|
|
20
|
+
(0, assert_1.default)(this.isArrowFunction, 'Variable does not represent an arrow function');
|
|
21
|
+
return this.node.init;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.Variable = Variable;
|
|
25
|
+
//# sourceMappingURL=variable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"variable.js","sourceRoot":"","sources":["../../src/dto/variable.ts"],"names":[],"mappings":";;;;;;AACA,oDAA4B;AAE5B,MAAa,QAAQ;IACnB,YAAoB,IAAiC;QAAjC,SAAI,GAAJ,IAAI,CAA6B;IAAG,CAAC;IAEzD,IAAI,IAAI;QACN,OAAQ,IAAI,CAAC,IAAI,CAAC,EAA0B,CAAC,IAAI,CAAC;IACpD,CAAC;IAED,IAAI,eAAe;;QACjB,OAAO,CAAA,MAAA,IAAI,CAAC,IAAI,CAAC,IAAI,0CAAE,IAAI,MAAK,yBAAyB,CAAC;IAC5D,CAAC;IAED,IAAI,aAAa;QACf,IAAA,gBAAM,EAAC,IAAI,CAAC,eAAe,EAAE,+CAA+C,CAAC,CAAC;QAC9E,OAAO,IAAI,CAAC,IAAI,CAAC,IAAwC,CAAC;IAC5D,CAAC;CACF;AAfD,4BAeC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fileReader.d.ts","sourceRoot":"","sources":["../../
|
|
1
|
+
{"version":3,"file":"fileReader.d.ts","sourceRoot":"","sources":["../../src/framework/fileReader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC,qBAAa,UAAU;IACT,OAAO,CAAC,YAAY;gBAAZ,YAAY,EAAE,YAAY;IAEvC,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM;IAO1D,OAAO,CAAC,KAAK;CAmBd"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fileReader.js","sourceRoot":"","sources":["../../
|
|
1
|
+
{"version":3,"file":"fileReader.js","sourceRoot":"","sources":["../../src/framework/fileReader.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,sDAAkD;AAElD,sCAAmC;AAEnC,MAAa,UAAU;IACrB,YAAoB,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;IAAI,CAAC;IAE5C,IAAI,CAAC,YAAoB,EAAE,gBAAwB;QACxD,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QAC3E,MAAM,WAAW,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;QACpE,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAClD,OAAO,IAAI,WAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;IACrC,CAAC;IAEO,KAAK,CAAC,OAAe,EAAE,QAAgB;QAC7C,OAAO,IAAA,cAAK,EACV,OAAO,EACP;YACE,WAAW,EAAE,CAAC;YACd,YAAY,EAAE;gBACZ,YAAY,EAAE,KAAK;gBACnB,GAAG,EAAE,IAAI;aACV;YACD,UAAU,EAAE,QAAQ;YACpB,OAAO,EAAE,IAAI;YACb,aAAa,EAAE,IAAI;YACnB,MAAM,EAAE,IAAI;YACZ,GAAG,EAAE,IAAI;YACT,KAAK,EAAE,IAAI;YACX,QAAQ;SACT,CACF,CAAC;IACJ,CAAC;CACF;AA7BD,gCA6BC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pathResolver.d.ts","sourceRoot":"","sources":["../../
|
|
1
|
+
{"version":3,"file":"pathResolver.d.ts","sourceRoot":"","sources":["../../src/framework/pathResolver.ts"],"names":[],"mappings":"AAEA,qBAAa,YAAY;IAChB,OAAO,CAAC,YAAY,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM;CAG9D"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pathResolver.js","sourceRoot":"","sources":["../../
|
|
1
|
+
{"version":3,"file":"pathResolver.js","sourceRoot":"","sources":["../../src/framework/pathResolver.ts"],"names":[],"mappings":";;;AAAA,6BAA+B;AAE/B,MAAa,YAAY;IAChB,OAAO,CAAC,YAAoB,EAAE,gBAAwB;QAC3D,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,GAAG,gBAAgB,KAAK,CAAC,CAAC;IAC5E,CAAC;CACF;AAJD,oCAIC"}
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
|
package/dist/index.js
CHANGED
|
@@ -1,9 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const { unresolvedProviderDependenciesGenerator } = require('./unresolvedProviderDependencies');
|
|
3
|
+
const { unresolvedProviderDependenciesGenerator } = require('./rules/unresolvedProviderDependencies');
|
|
4
|
+
const { noCircularDependenciesGenerator } = require('./rules/noCircularDependency');
|
|
5
|
+
const { stronglyTypedInjectComponentGenerator } = require('./rules/stronglyTypedInjectComponent');
|
|
4
6
|
module.exports = {
|
|
5
7
|
rules: {
|
|
6
8
|
'unresolved-provider-dependencies': unresolvedProviderDependenciesGenerator(),
|
|
9
|
+
'no-circular-dependencies': noCircularDependenciesGenerator(),
|
|
10
|
+
'strongly-typed-inject-component': stronglyTypedInjectComponentGenerator(),
|
|
7
11
|
},
|
|
8
12
|
};
|
|
9
13
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;AAAA,MAAM,EAAE,uCAAuC,EAAE,GAAG,OAAO,CAAC,wCAAwC,CAAC,CAAC;AACtG,MAAM,EAAE,+BAA+B,EAAE,GAAG,OAAO,CAAC,8BAA8B,CAAC,CAAC;AACpF,MAAM,EAAE,qCAAqC,EAAE,GAAG,OAAO,CAAC,sCAAsC,CAAC,CAAC;AAElG,MAAM,CAAC,OAAO,GAAG;IACf,KAAK,EAAE;QACL,kCAAkC,EAAE,uCAAuC,EAAE;QAC7E,0BAA0B,EAAE,+BAA+B,EAAE;QAC7D,iCAAiC,EAAE,qCAAqC,EAAE;KAC3E;CACF,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { TSESTree } from '@typescript-eslint/types';
|
|
2
|
+
import type { Clazz } from '../../dto/class';
|
|
3
|
+
import type { Method } from '../../dto/method';
|
|
4
|
+
type DetectionResult = {
|
|
5
|
+
hasCircularDependency: true;
|
|
6
|
+
path: string[];
|
|
7
|
+
node: TSESTree.Node;
|
|
8
|
+
} | {
|
|
9
|
+
hasCircularDependency: false;
|
|
10
|
+
path?: never;
|
|
11
|
+
node?: never;
|
|
12
|
+
};
|
|
13
|
+
export declare class CircularDependenciesDetector {
|
|
14
|
+
detect(clazz: Clazz): DetectionResult;
|
|
15
|
+
isCircular(provider: Method, providers: Method[], path: Set<string>): DetectionResult;
|
|
16
|
+
}
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=circularDependenciesDetector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"circularDependenciesDetector.d.ts","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/circularDependenciesDetector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE/C,KAAK,eAAe,GAClB;IAAE,qBAAqB,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE,MAAM,EAAE,CAAC;IAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAA;CAAE,GACpE;IAAE,qBAAqB,EAAE,KAAK,CAAC;IAAC,IAAI,CAAC,EAAE,KAAK,CAAC;IAAC,IAAI,CAAC,EAAE,KAAK,CAAA;CAAE,CAAC;AAE/D,qBAAa,4BAA4B;IAEvC,MAAM,CAAC,KAAK,EAAE,KAAK,GAAG,eAAe;IAgBrC,UAAU,CACR,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EAAE,EACnB,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,GAChB,eAAe;CAsBnB"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CircularDependenciesDetector = void 0;
|
|
4
|
+
class CircularDependenciesDetector {
|
|
5
|
+
detect(clazz) {
|
|
6
|
+
const providers = clazz.getDecoratedMethods('Provides');
|
|
7
|
+
const visited = new Set();
|
|
8
|
+
for (const provider of providers) {
|
|
9
|
+
const result = this.isCircular(provider, providers, visited);
|
|
10
|
+
if (result.hasCircularDependency) {
|
|
11
|
+
return result;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return { hasCircularDependency: false };
|
|
15
|
+
}
|
|
16
|
+
isCircular(provider, providers, path) {
|
|
17
|
+
if (path.has(provider.name)) {
|
|
18
|
+
return {
|
|
19
|
+
hasCircularDependency: true,
|
|
20
|
+
path: [...path, provider.name],
|
|
21
|
+
node: provider.node,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
const newPath = new Set(path);
|
|
25
|
+
newPath.add(provider.name);
|
|
26
|
+
for (const dep of provider.parameters) {
|
|
27
|
+
const depProvider = providers.find(p => p.name === dep.name);
|
|
28
|
+
if (depProvider) {
|
|
29
|
+
const result = this.isCircular(depProvider, providers, newPath);
|
|
30
|
+
if (result.hasCircularDependency)
|
|
31
|
+
return result;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return { hasCircularDependency: false };
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.CircularDependenciesDetector = CircularDependenciesDetector;
|
|
38
|
+
//# sourceMappingURL=circularDependenciesDetector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"circularDependenciesDetector.js","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/circularDependenciesDetector.ts"],"names":[],"mappings":";;;AAQA,MAAa,4BAA4B;IAEvC,MAAM,CAAC,KAAY;QACjB,MAAM,SAAS,GAAG,KAAK,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;QACxD,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;QAClC,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;YAChC,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAC5B,QAAQ,EACR,SAAS,EACT,OAAO,CACR,CAAC;YACF,IAAI,MAAM,CAAC,qBAAqB,EAAE;gBAChC,OAAO,MAAM,CAAC;aACf;SACF;QACD,OAAO,EAAE,qBAAqB,EAAE,KAAK,EAAE,CAAC;IAC1C,CAAC;IAED,UAAU,CACR,QAAgB,EAChB,SAAmB,EACnB,IAAiB;QAEjB,IAAI,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;YAC3B,OAAO;gBACL,qBAAqB,EAAE,IAAI;gBAC3B,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC;gBAC9B,IAAI,EAAE,QAAQ,CAAC,IAAI;aACpB,CAAC;SACH;QAED,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;QAC9B,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAE3B,KAAK,MAAM,GAAG,IAAI,QAAQ,CAAC,UAAU,EAAE;YACrC,MAAM,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC;YAC7D,IAAI,WAAW,EAAE;gBACf,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;gBAChE,IAAI,MAAM,CAAC,qBAAqB;oBAAE,OAAO,MAAM,CAAC;aACjD;SACF;QAED,OAAO,EAAE,qBAAqB,EAAE,KAAK,EAAE,CAAC;IAC1C,CAAC;CACF;AA5CD,oEA4CC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createRule.d.ts","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/createRule.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAK5C,wBAAgB,MAAM,CAAC,OAAO,EAAE,OAAO;2BAOZ,SAAS,gBAAgB;EAInD"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.create = void 0;
|
|
4
|
+
const class_1 = require("../../dto/class");
|
|
5
|
+
const graphHandler_1 = require("./graphHandler");
|
|
6
|
+
const circularDependenciesDetector_1 = require("./circularDependenciesDetector");
|
|
7
|
+
const errorReporter_1 = require("./errorReporter");
|
|
8
|
+
function create(context) {
|
|
9
|
+
const graphHandler = new graphHandler_1.GraphHandler(new circularDependenciesDetector_1.CircularDependenciesDetector(), new errorReporter_1.ErrorReporter(context));
|
|
10
|
+
return {
|
|
11
|
+
ClassDeclaration(node) {
|
|
12
|
+
graphHandler.handle(new class_1.Clazz(node));
|
|
13
|
+
},
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
exports.create = create;
|
|
17
|
+
//# sourceMappingURL=createRule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createRule.js","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/createRule.ts"],"names":[],"mappings":";;;AACA,2CAAwC;AAExC,iDAA8C;AAC9C,iFAA8E;AAC9E,mDAAgD;AAEhD,SAAgB,MAAM,CAAC,OAAgB;IACrC,MAAM,YAAY,GAAG,IAAI,2BAAY,CACnC,IAAI,2DAA4B,EAAE,EAClC,IAAI,6BAAa,CAAC,OAAO,CAAC,CAC3B,CAAC;IAEF,OAAO;QACL,gBAAgB,CAAC,IAA+B;YAC9C,YAAY,CAAC,MAAM,CAAC,IAAI,aAAK,CAAC,IAAI,CAAC,CAAC,CAAC;QACvC,CAAC;KACF,CAAC;AACJ,CAAC;AAXD,wBAWC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { TSESTree } from '@typescript-eslint/types';
|
|
2
|
+
import type { Context } from '../../dto/context';
|
|
3
|
+
type Report = {
|
|
4
|
+
isError: boolean;
|
|
5
|
+
path?: string[];
|
|
6
|
+
node?: TSESTree.Node;
|
|
7
|
+
};
|
|
8
|
+
export declare class ErrorReporter {
|
|
9
|
+
private context;
|
|
10
|
+
constructor(context: Context);
|
|
11
|
+
report({ isError, path, node }: Report): void;
|
|
12
|
+
}
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=errorReporter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorReporter.d.ts","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/errorReporter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAEjD,KAAK,MAAM,GAAG;IACZ,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,IAAI,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC;CACtB,CAAC;AAEF,qBAAa,aAAa;IACZ,OAAO,CAAC,OAAO;gBAAP,OAAO,EAAE,OAAO;IAE7B,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,MAAM;CAY9C"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ErrorReporter = void 0;
|
|
4
|
+
class ErrorReporter {
|
|
5
|
+
constructor(context) {
|
|
6
|
+
this.context = context;
|
|
7
|
+
}
|
|
8
|
+
report({ isError, path, node }) {
|
|
9
|
+
if (isError && path && node) {
|
|
10
|
+
this.context.reportError(node, 'no-circular-dependencies', {
|
|
11
|
+
firstDependency: path[0],
|
|
12
|
+
path: path.join(' -> '),
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.ErrorReporter = ErrorReporter;
|
|
18
|
+
//# sourceMappingURL=errorReporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorReporter.js","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/errorReporter.ts"],"names":[],"mappings":";;;AASA,MAAa,aAAa;IACxB,YAAoB,OAAgB;QAAhB,YAAO,GAAP,OAAO,CAAS;IAAI,CAAC;IAElC,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAU;QAC3C,IAAI,OAAO,IAAI,IAAI,IAAI,IAAI,EAAE;YAC3B,IAAI,CAAC,OAAO,CAAC,WAAW,CACtB,IAAI,EACJ,0BAA0B,EAC1B;gBACE,eAAe,EAAE,IAAI,CAAC,CAAC,CAAC;gBACxB,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;aACxB,CACF,CAAC;SACH;IACH,CAAC;CACF;AAfD,sCAeC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Clazz } from '../../dto/class';
|
|
2
|
+
import type { CircularDependenciesDetector } from './circularDependenciesDetector';
|
|
3
|
+
import type { ErrorReporter } from './errorReporter';
|
|
4
|
+
export declare class GraphHandler {
|
|
5
|
+
private circularDependenciesDetector;
|
|
6
|
+
private errorReporter;
|
|
7
|
+
constructor(circularDependenciesDetector: CircularDependenciesDetector, errorReporter: ErrorReporter);
|
|
8
|
+
handle(clazz: Clazz): void;
|
|
9
|
+
private hasGraphDecorator;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=graphHandler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graphHandler.d.ts","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/graphHandler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,gCAAgC,CAAC;AACnF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD,qBAAa,YAAY;IAErB,OAAO,CAAC,4BAA4B;IACpC,OAAO,CAAC,aAAa;gBADb,4BAA4B,EAAE,4BAA4B,EAC1D,aAAa,EAAE,aAAa;IAG/B,MAAM,CAAC,KAAK,EAAE,KAAK;IAO1B,OAAO,CAAC,iBAAiB;CAG1B"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GraphHandler = void 0;
|
|
4
|
+
class GraphHandler {
|
|
5
|
+
constructor(circularDependenciesDetector, errorReporter) {
|
|
6
|
+
this.circularDependenciesDetector = circularDependenciesDetector;
|
|
7
|
+
this.errorReporter = errorReporter;
|
|
8
|
+
}
|
|
9
|
+
handle(clazz) {
|
|
10
|
+
if (this.hasGraphDecorator(clazz)) {
|
|
11
|
+
const result = this.circularDependenciesDetector.detect(clazz);
|
|
12
|
+
this.errorReporter.report({ isError: result.hasCircularDependency, ...result });
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
hasGraphDecorator(clazz) {
|
|
16
|
+
return clazz.decoratorNames.includes('Graph');
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.GraphHandler = GraphHandler;
|
|
20
|
+
//# sourceMappingURL=graphHandler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graphHandler.js","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/graphHandler.ts"],"names":[],"mappings":";;;AAIA,MAAa,YAAY;IACvB,YACU,4BAA0D,EAC1D,aAA4B;QAD5B,iCAA4B,GAA5B,4BAA4B,CAA8B;QAC1D,kBAAa,GAAb,aAAa,CAAe;IAClC,CAAC;IAEE,MAAM,CAAC,KAAY;QACxB,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE;YACjC,MAAM,MAAM,GAAG,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC/D,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,qBAAqB,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;SACjF;IACH,CAAC;IAEO,iBAAiB,CAAC,KAAY;QACpC,OAAO,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;CACF;AAhBD,oCAgBC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,KAAK,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAWtE,eAAO,MAAM,+BAA+B,kFAmB3C,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.noCircularDependenciesGenerator = void 0;
|
|
4
|
+
const utils_1 = require("@typescript-eslint/utils");
|
|
5
|
+
const createRule_1 = require("./createRule");
|
|
6
|
+
const context_1 = require("../../dto/context");
|
|
7
|
+
const createRule = utils_1.ESLintUtils.RuleCreator((name) => `https://wix-incubator.github.io/obsidian/docs/documentation/meta/eslint#${name}`);
|
|
8
|
+
const noCircularDependenciesGenerator = () => {
|
|
9
|
+
return createRule({
|
|
10
|
+
create: (context) => {
|
|
11
|
+
return (0, createRule_1.create)(new context_1.Context(context));
|
|
12
|
+
},
|
|
13
|
+
name: 'no-circular-dependencies',
|
|
14
|
+
meta: {
|
|
15
|
+
docs: {
|
|
16
|
+
description: 'Dependencies must be defined in the graph or its subgraphs.',
|
|
17
|
+
recommended: 'strict',
|
|
18
|
+
},
|
|
19
|
+
messages: {
|
|
20
|
+
'no-circular-dependencies': 'Circular dependency detected starting from {{firstDependency}}: {{path}}',
|
|
21
|
+
},
|
|
22
|
+
schema: [],
|
|
23
|
+
type: 'problem',
|
|
24
|
+
},
|
|
25
|
+
defaultOptions: [],
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
exports.noCircularDependenciesGenerator = noCircularDependenciesGenerator;
|
|
29
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/rules/noCircularDependency/index.ts"],"names":[],"mappings":";;;AAAA,oDAAsE;AAEtE,6CAAsC;AACtC,+CAA0C;AAI1C,MAAM,UAAU,GAAG,mBAAW,CAAC,WAAW,CACxC,CAAC,IAAI,EAAE,EAAE,CAAC,2EAA2E,IAAI,EAAE,CAC5F,CAAC;AAEK,MAAM,+BAA+B,GAAG,GAAG,EAAE;IAClD,OAAO,UAAU,CAAC;QAChB,MAAM,EAAE,CAAC,OAAoD,EAAE,EAAE;YAC/D,OAAO,IAAA,mBAAM,EAAC,IAAI,iBAAO,CAAC,OAAO,CAAC,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,EAAE,0BAA0B;QAChC,IAAI,EAAE;YACJ,IAAI,EAAE;gBACJ,WAAW,EAAE,6DAA6D;gBAC1E,WAAW,EAAE,QAAQ;aACtB;YACD,QAAQ,EAAE;gBACR,0BAA0B,EAAE,0EAA0E;aACvG;YACD,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,SAAS;SAChB;QACD,cAAc,EAAE,EAAE;KACnB,CAAgB,CAAC;AACpB,CAAC,CAAC;AAnBW,QAAA,+BAA+B,mCAmB1C"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { TSESTree } from '@typescript-eslint/types';
|
|
2
|
+
import { Context } from '../../dto/context';
|
|
3
|
+
import { CallExpression } from '../../dto/callExpression';
|
|
4
|
+
export declare function create(context: Context): {
|
|
5
|
+
CallExpression(node: TSESTree.CallExpression): void;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=createRule.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createRule.d.ts","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/createRule.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAI1D,wBAAgB,MAAM,CAAC,OAAO,EAAE,OAAO;yBAOd,uBAAuB;EAI/C"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.create = void 0;
|
|
4
|
+
const injectComponentHandler_1 = require("./injectComponentHandler");
|
|
5
|
+
const callExpression_1 = require("../../dto/callExpression");
|
|
6
|
+
const errorReporter_1 = require("./errorReporter");
|
|
7
|
+
const typeValidator_1 = require("./typeValidator");
|
|
8
|
+
function create(context) {
|
|
9
|
+
const injectComponentHandler = new injectComponentHandler_1.InjectComponentHandler(new errorReporter_1.ErrorReporter(context), new typeValidator_1.TypeValidator());
|
|
10
|
+
return {
|
|
11
|
+
CallExpression(node) {
|
|
12
|
+
injectComponentHandler.handle(new callExpression_1.CallExpression(node));
|
|
13
|
+
},
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
exports.create = create;
|
|
17
|
+
//# sourceMappingURL=createRule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createRule.js","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/createRule.ts"],"names":[],"mappings":";;;AAEA,qEAAkE;AAClE,6DAA0D;AAC1D,mDAAgD;AAChD,mDAAgD;AAEhD,SAAgB,MAAM,CAAC,OAAgB;IACrC,MAAM,sBAAsB,GAAG,IAAI,+CAAsB,CACvD,IAAI,6BAAa,CAAC,OAAO,CAAC,EAC1B,IAAI,6BAAa,EAAE,CACpB,CAAC;IAEF,OAAO;QACL,cAAc,CAAC,IAA6B;YAC1C,sBAAsB,CAAC,MAAM,CAAC,IAAI,+BAAc,CAAC,IAAI,CAAC,CAAC,CAAC;QAC1D,CAAC;KACF,CAAC;AACJ,CAAC;AAXD,wBAWC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TSESTree } from '@typescript-eslint/types';
|
|
2
|
+
import type { Context } from '../../dto/context';
|
|
3
|
+
import type { Type } from '../../dto/type';
|
|
4
|
+
export declare class ErrorReporter {
|
|
5
|
+
private context;
|
|
6
|
+
constructor(context: Context);
|
|
7
|
+
report(types?: Type, node?: TSESTree.Node): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=errorReporter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorReporter.d.ts","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/errorReporter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE3C,qBAAa,aAAa;IACZ,OAAO,CAAC,OAAO;gBAAP,OAAO,EAAE,OAAO;IAE7B,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,QAAQ,CAAC,IAAI;CAWjD"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ErrorReporter = void 0;
|
|
4
|
+
class ErrorReporter {
|
|
5
|
+
constructor(context) {
|
|
6
|
+
this.context = context;
|
|
7
|
+
}
|
|
8
|
+
report(types, node) {
|
|
9
|
+
if (types && node) {
|
|
10
|
+
this.context.reportError(node, 'strongly-typed-inject-component', {
|
|
11
|
+
expectation: `injectedComponent<${types.toString()}>`,
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.ErrorReporter = ErrorReporter;
|
|
17
|
+
//# sourceMappingURL=errorReporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorReporter.js","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/errorReporter.ts"],"names":[],"mappings":";;;AAIA,MAAa,aAAa;IACxB,YAAoB,OAAgB;QAAhB,YAAO,GAAP,OAAO,CAAS;IAAI,CAAC;IAElC,MAAM,CAAC,KAAY,EAAE,IAAoB;QAC9C,IAAI,KAAK,IAAI,IAAI,EAAE;YACjB,IAAI,CAAC,OAAO,CAAC,WAAW,CACtB,IAAI,EACJ,iCAAiC,EACjC;gBACE,WAAW,EAAE,qBAAqB,KAAK,CAAC,QAAQ,EAAE,GAAG;aACtD,CACF,CAAC;SACH;IACH,CAAC;CACF;AAdD,sCAcC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,KAAK,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAWtE,eAAO,MAAM,qCAAqC,yFAmBjD,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.stronglyTypedInjectComponentGenerator = void 0;
|
|
4
|
+
const utils_1 = require("@typescript-eslint/utils");
|
|
5
|
+
const createRule_1 = require("./createRule");
|
|
6
|
+
const context_1 = require("../../dto/context");
|
|
7
|
+
const createRule = utils_1.ESLintUtils.RuleCreator((name) => `https://wix-incubator.github.io/obsidian/docs/documentation/meta/eslint#${name}`);
|
|
8
|
+
const stronglyTypedInjectComponentGenerator = () => {
|
|
9
|
+
return createRule({
|
|
10
|
+
create: (context) => {
|
|
11
|
+
return (0, createRule_1.create)(new context_1.Context(context));
|
|
12
|
+
},
|
|
13
|
+
name: 'strongly-typed-inject-component',
|
|
14
|
+
meta: {
|
|
15
|
+
docs: {
|
|
16
|
+
description: 'Calling injectComponent without prop types is a bad practice and a common source of bugs.',
|
|
17
|
+
recommended: 'strict',
|
|
18
|
+
},
|
|
19
|
+
messages: {
|
|
20
|
+
'strongly-typed-inject-component': 'The call to injectComponent is missing prop types. It should be typed as: {{expectation}}',
|
|
21
|
+
},
|
|
22
|
+
schema: [],
|
|
23
|
+
type: 'problem',
|
|
24
|
+
},
|
|
25
|
+
defaultOptions: [],
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
exports.stronglyTypedInjectComponentGenerator = stronglyTypedInjectComponentGenerator;
|
|
29
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/index.ts"],"names":[],"mappings":";;;AAAA,oDAAsE;AAEtE,6CAAsC;AACtC,+CAA0C;AAI1C,MAAM,UAAU,GAAG,mBAAW,CAAC,WAAW,CACxC,CAAC,IAAI,EAAE,EAAE,CAAC,2EAA2E,IAAI,EAAE,CAC5F,CAAC;AAEK,MAAM,qCAAqC,GAAG,GAAG,EAAE;IACxD,OAAO,UAAU,CAAC;QAChB,MAAM,EAAE,CAAC,OAA2D,EAAE,EAAE;YACtE,OAAO,IAAA,mBAAM,EAAC,IAAI,iBAAO,CAAC,OAAO,CAAC,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,EAAE,iCAAiC;QACvC,IAAI,EAAE;YACJ,IAAI,EAAE;gBACJ,WAAW,EAAE,2FAA2F;gBACxG,WAAW,EAAE,QAAQ;aACtB;YACD,QAAQ,EAAE;gBACR,iCAAiC,EAAE,2FAA2F;aAC/H;YACD,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,SAAS;SAChB;QACD,cAAc,EAAE,EAAE;KACnB,CAAgB,CAAC;AACpB,CAAC,CAAC;AAnBW,QAAA,qCAAqC,yCAmBhD"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { CallExpression } from '../../dto/callExpression';
|
|
2
|
+
import type { ErrorReporter } from './errorReporter';
|
|
3
|
+
import type { TypeValidator } from './typeValidator';
|
|
4
|
+
export declare class InjectComponentHandler {
|
|
5
|
+
private errorReporter;
|
|
6
|
+
private typeValidator;
|
|
7
|
+
constructor(errorReporter: ErrorReporter, typeValidator: TypeValidator);
|
|
8
|
+
handle(callExpression: CallExpression): void;
|
|
9
|
+
private getInjectedComponent;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=injectComponentHandler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"injectComponentHandler.d.ts","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/injectComponentHandler.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAG/D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD,qBAAa,sBAAsB;IACrB,OAAO,CAAC,aAAa;IAAiB,OAAO,CAAC,aAAa;gBAAnD,aAAa,EAAE,aAAa,EAAU,aAAa,EAAE,aAAa;IAE/E,MAAM,CAAC,cAAc,EAAE,cAAc;IAQ5C,OAAO,CAAC,oBAAoB;CAM7B"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InjectComponentHandler = void 0;
|
|
4
|
+
const ast_1 = require("../../utils/ast");
|
|
5
|
+
const file_1 = require("../../dto/file");
|
|
6
|
+
class InjectComponentHandler {
|
|
7
|
+
constructor(errorReporter, typeValidator) {
|
|
8
|
+
this.errorReporter = errorReporter;
|
|
9
|
+
this.typeValidator = typeValidator;
|
|
10
|
+
}
|
|
11
|
+
handle(callExpression) {
|
|
12
|
+
if (callExpression.isExpression('injectComponent')) {
|
|
13
|
+
const injectedComponent = this.getInjectedComponent(callExpression.node, callExpression.arguments);
|
|
14
|
+
const { isError, componentProps } = this.typeValidator.validate(injectedComponent, callExpression.generics);
|
|
15
|
+
if (isError)
|
|
16
|
+
this.errorReporter.report(componentProps, callExpression.node);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
getInjectedComponent(node, args) {
|
|
20
|
+
return new file_1.File((0, ast_1.requireProgram)(node))
|
|
21
|
+
.variables
|
|
22
|
+
.filter((variable) => variable.isArrowFunction)
|
|
23
|
+
.find((variable) => variable.name === args[0].name);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
exports.InjectComponentHandler = InjectComponentHandler;
|
|
27
|
+
//# sourceMappingURL=injectComponentHandler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"injectComponentHandler.js","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/injectComponentHandler.ts"],"names":[],"mappings":";;;AAEA,yCAAiD;AACjD,yCAAsC;AAKtC,MAAa,sBAAsB;IACjC,YAAoB,aAA4B,EAAU,aAA4B;QAAlE,kBAAa,GAAb,aAAa,CAAe;QAAU,kBAAa,GAAb,aAAa,CAAe;IAAI,CAAC;IAEpF,MAAM,CAAC,cAA8B;QAC1C,IAAI,cAAc,CAAC,YAAY,CAAC,iBAAiB,CAAC,EAAE;YAClD,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC;YACnG,MAAM,EAAE,OAAO,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,iBAAiB,EAAE,cAAc,CAAC,QAAQ,CAAC,CAAC;YAC5G,IAAI,OAAO;gBAAE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,cAAc,EAAE,cAAc,CAAC,IAAI,CAAC,CAAC;SAC7E;IACH,CAAC;IAEO,oBAAoB,CAAC,IAA6B,EAAE,IAAkB;QAC5E,OAAO,IAAI,WAAI,CAAC,IAAA,oBAAc,EAAC,IAAI,CAAC,CAAC;aAClC,SAAS;aACT,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC;aAC9C,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;CACF;AAjBD,wDAiBC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Generics } from '../../dto/generics';
|
|
2
|
+
import type { Variable } from '../../dto/variable';
|
|
3
|
+
import type { Type } from '../../dto/type';
|
|
4
|
+
export declare class TypeValidator {
|
|
5
|
+
validate(injectedComponent?: Variable, generics?: Generics): {
|
|
6
|
+
isError: boolean;
|
|
7
|
+
componentProps?: undefined;
|
|
8
|
+
} | {
|
|
9
|
+
isError: boolean;
|
|
10
|
+
componentProps: Type;
|
|
11
|
+
};
|
|
12
|
+
private comparePropsAndTypes;
|
|
13
|
+
private hasInlineType;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=typeValidator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typeValidator.d.ts","sourceRoot":"","sources":["../../../src/rules/stronglyTypedInjectComponent/typeValidator.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAEnD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAEnD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE3C,qBAAa,aAAa;IACjB,QAAQ,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,QAAQ,CAAC,EAAE,QAAQ;;;;;;;IAOjE,OAAO,CAAC,oBAAoB;IAQ5B,OAAO,CAAC,aAAa;CAGtB"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TypeValidator = void 0;
|
|
4
|
+
const lodash_1 = require("lodash");
|
|
5
|
+
const functionalComponent_1 = require("../../dto/functionalComponent");
|
|
6
|
+
const typeLiteral_1 = require("../../dto/typeLiteral");
|
|
7
|
+
const array_1 = require("../../utils/array");
|
|
8
|
+
class TypeValidator {
|
|
9
|
+
validate(injectedComponent, generics) {
|
|
10
|
+
if (!injectedComponent)
|
|
11
|
+
return { isError: false };
|
|
12
|
+
const componentProps = new functionalComponent_1.FunctionalComponent(injectedComponent.arrowFunction).props.type;
|
|
13
|
+
const injectComponentGenerics = (generics === null || generics === void 0 ? void 0 : generics.types) || [];
|
|
14
|
+
return { isError: !this.comparePropsAndTypes(componentProps, injectComponentGenerics), componentProps };
|
|
15
|
+
}
|
|
16
|
+
comparePropsAndTypes(componentProps, injectComponentGenerics) {
|
|
17
|
+
return (this.hasInlineType(injectComponentGenerics) ||
|
|
18
|
+
componentProps.equals(injectComponentGenerics) ||
|
|
19
|
+
(0, array_1.isEmpty)(injectComponentGenerics) && (0, lodash_1.isEqual)(componentProps.toString(), ['Injected']));
|
|
20
|
+
}
|
|
21
|
+
hasInlineType(injectComponentGenerics) {
|
|
22
|
+
return injectComponentGenerics.some(typeLiteral_1.TypeLiteral.isTypeLiteral);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
exports.TypeValidator = TypeValidator;
|
|
26
|
+
//# sourceMappingURL=typeValidator.js.map
|