aboutsummaryrefslogtreecommitdiffstats
path: root/packages/tslint-config/rules/walkers
diff options
context:
space:
mode:
authorLeonid <logvinov.leon@gmail.com>2017-12-15 05:34:54 +0800
committerGitHub <noreply@github.com>2017-12-15 05:34:54 +0800
commitde8c445f961e1a09bed6a01397e36b96e0ea3d9a (patch)
tree14a3a89988f2eb283f0c80ca9d70e3a20296b98f /packages/tslint-config/rules/walkers
parenta0aa21103b51ad287de1579832a4a490ca90175a (diff)
parentc23d42fea5ca817a5cfb4f7b03ae723cb607f887 (diff)
downloaddexon-sol-tools-de8c445f961e1a09bed6a01397e36b96e0ea3d9a.tar
dexon-sol-tools-de8c445f961e1a09bed6a01397e36b96e0ea3d9a.tar.gz
dexon-sol-tools-de8c445f961e1a09bed6a01397e36b96e0ea3d9a.tar.bz2
dexon-sol-tools-de8c445f961e1a09bed6a01397e36b96e0ea3d9a.tar.lz
dexon-sol-tools-de8c445f961e1a09bed6a01397e36b96e0ea3d9a.tar.xz
dexon-sol-tools-de8c445f961e1a09bed6a01397e36b96e0ea3d9a.tar.zst
dexon-sol-tools-de8c445f961e1a09bed6a01397e36b96e0ea3d9a.zip
Merge pull request #265 from 0xProject/feature/custom-linter-rule
Implement first custom linter rule async-suffix
Diffstat (limited to 'packages/tslint-config/rules/walkers')
-rw-r--r--packages/tslint-config/rules/walkers/async_suffix.ts23
1 files changed, 23 insertions, 0 deletions
diff --git a/packages/tslint-config/rules/walkers/async_suffix.ts b/packages/tslint-config/rules/walkers/async_suffix.ts
new file mode 100644
index 000000000..0c89bd99f
--- /dev/null
+++ b/packages/tslint-config/rules/walkers/async_suffix.ts
@@ -0,0 +1,23 @@
+import * as _ from 'lodash';
+import * as Lint from 'tslint';
+import * as ts from 'typescript';
+
+export class AsyncSuffixWalker extends Lint.RuleWalker {
+ public static FAILURE_STRING = 'async functions must have an Async suffix';
+ public visitMethodDeclaration(node: ts.MethodDeclaration): void {
+ const methodNameNode = node.name;
+ const methodName = methodNameNode.getText();
+ if (!_.isUndefined(node.type)) {
+ if (node.type.kind === ts.SyntaxKind.TypeReference) {
+ const returnTypeName = (node.type as ts.TypeReferenceNode).typeName.getText();
+ if (returnTypeName === 'Promise' && !methodName.endsWith('Async')) {
+ const failure = this.createFailure(
+ methodNameNode.getStart(), methodNameNode.getWidth(), AsyncSuffixWalker.FAILURE_STRING,
+ );
+ this.addFailure(failure);
+ }
+ }
+ }
+ super.visitMethodDeclaration(node);
+ }
+}