2020-06-12 15:31:04 +02:00
|
|
|
## Linter
|
|
|
|
|
|
|
|
Deno ships with a built in code linter for JavaScript and TypeScript.
|
|
|
|
|
2020-10-26 13:36:13 +01:00
|
|
|
**Note: linter is a new feature and still unstable thus it requires `--unstable`
|
|
|
|
flag**
|
|
|
|
|
2020-06-12 15:31:04 +02:00
|
|
|
```shell
|
|
|
|
# lint all JS/TS files in the current directory and subdirectories
|
2020-10-26 13:36:13 +01:00
|
|
|
deno lint --unstable
|
2020-06-12 15:31:04 +02:00
|
|
|
# lint specific files
|
2020-10-26 13:36:13 +01:00
|
|
|
deno lint --unstable myfile1.ts myfile2.ts
|
|
|
|
# print result as JSON
|
2020-10-22 21:52:37 +02:00
|
|
|
deno lint --unstable --json
|
2020-10-26 13:36:13 +01:00
|
|
|
# read from stdin
|
|
|
|
cat file.ts | deno lint --unstable -
|
2020-06-12 15:31:04 +02:00
|
|
|
```
|
|
|
|
|
2020-08-31 20:53:42 +09:00
|
|
|
For more detail, run `deno lint --help`.
|
|
|
|
|
2020-06-12 15:31:04 +02:00
|
|
|
### Available rules
|
|
|
|
|
2020-08-29 19:58:20 +09:00
|
|
|
- `adjacent-overload-signatures`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `ban-ts-comment`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `ban-types`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `ban-untagged-ignore`
|
|
|
|
- `constructor-super`
|
|
|
|
- `for-direction`
|
|
|
|
- `getter-return`
|
|
|
|
- `no-array-constructor`
|
|
|
|
- `no-async-promise-executor`
|
|
|
|
- `no-case-declarations`
|
|
|
|
- `no-class-assign`
|
|
|
|
- `no-compare-neg-zero`
|
|
|
|
- `no-cond-assign`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-constant-condition`
|
|
|
|
- `no-control-regex`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-debugger`
|
|
|
|
- `no-delete-var`
|
|
|
|
- `no-dupe-args`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-dupe-class-members`
|
|
|
|
- `no-dupe-else-if`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-dupe-keys`
|
|
|
|
- `no-duplicate-case`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-empty`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-empty-character-class`
|
|
|
|
- `no-empty-interface`
|
|
|
|
- `no-empty-pattern`
|
|
|
|
- `no-ex-assign`
|
|
|
|
- `no-explicit-any`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-extra-boolean-cast`
|
|
|
|
- `no-extra-non-null-assertion`
|
|
|
|
- `no-extra-semi`
|
2020-09-13 15:17:25 +02:00
|
|
|
- `no-fallthrough`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-func-assign`
|
2020-09-13 15:17:25 +02:00
|
|
|
- `no-global-assign`
|
|
|
|
- `no-import-assign`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-inferrable-types`
|
2020-09-13 15:17:25 +02:00
|
|
|
- `no-inner-declarations`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-invalid-regexp`
|
|
|
|
- `no-irregular-whitespace`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-misused-new`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-mixed-spaces-and-tabs`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-namespace`
|
|
|
|
- `no-new-symbol`
|
2020-09-09 23:45:31 +09:00
|
|
|
- `no-obj-calls`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-octal`
|
|
|
|
- `no-prototype-builtins`
|
2020-09-13 15:17:25 +02:00
|
|
|
- `no-redeclare`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-regex-spaces`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-self-assign`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-setter-return`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-shadow-restricted-names`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-this-alias`
|
|
|
|
- `no-this-before-super`
|
2020-09-13 15:17:25 +02:00
|
|
|
- `no-undef`
|
2020-09-09 23:45:31 +09:00
|
|
|
- `no-unreachable`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-unsafe-finally`
|
|
|
|
- `no-unsafe-negation`
|
2020-08-29 19:58:20 +09:00
|
|
|
- `no-unused-labels`
|
2020-06-12 15:31:04 +02:00
|
|
|
- `no-with`
|
|
|
|
- `prefer-as-const`
|
|
|
|
- `prefer-namespace-keyword`
|
|
|
|
- `require-yield`
|
|
|
|
- `triple-slash-reference`
|
|
|
|
- `use-isnan`
|
|
|
|
- `valid-typeof`
|
|
|
|
|
|
|
|
### Ignore directives
|
|
|
|
|
|
|
|
#### Files
|
|
|
|
|
|
|
|
To ignore whole file `// deno-lint-ignore-file` directive should placed at the
|
2020-08-18 01:17:57 +09:00
|
|
|
top of the file:
|
2020-06-12 15:31:04 +02:00
|
|
|
|
|
|
|
```ts
|
|
|
|
// deno-lint-ignore-file
|
|
|
|
|
|
|
|
function foo(): any {
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Ignore directive must be placed before first stament or declaration:
|
|
|
|
|
|
|
|
```ts
|
|
|
|
// Copyright 2020 the Deno authors. All rights reserved. MIT license.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Some JS doc
|
|
|
|
**/
|
|
|
|
|
|
|
|
// deno-lint-ignore-file
|
|
|
|
|
|
|
|
import { bar } from "./bar.js";
|
|
|
|
|
|
|
|
function foo(): any {
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-09-15 10:02:19 +02:00
|
|
|
You can also ignore certain diagnostics in the whole file
|
|
|
|
|
|
|
|
```ts
|
|
|
|
// deno-lint-ignore-file no-explicit-any no-empty
|
|
|
|
|
|
|
|
function foo(): any {
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-06-12 15:31:04 +02:00
|
|
|
#### Diagnostics
|
|
|
|
|
|
|
|
To ignore certain diagnostic `// deno-lint-ignore <codes...>` directive should
|
2020-08-18 01:17:57 +09:00
|
|
|
be placed before offending line. Specifying ignored rule name is required:
|
2020-06-12 15:31:04 +02:00
|
|
|
|
|
|
|
```ts
|
|
|
|
// deno-lint-ignore no-explicit-any
|
|
|
|
function foo(): any {
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
|
|
|
|
// deno-lint-ignore no-explicit-any explicit-function-return-type
|
|
|
|
function bar(a: any) {
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
To provide some compatibility with ESLint `deno lint` also supports
|
2020-09-02 19:03:35 +09:00
|
|
|
`// eslint-disable-next-line` directive. Just like with `// deno-lint-ignore`,
|
2020-08-18 01:17:57 +09:00
|
|
|
it's required to specify the ignored rule name:
|
2020-06-12 15:31:04 +02:00
|
|
|
|
|
|
|
```ts
|
2020-09-02 19:03:35 +09:00
|
|
|
// eslint-disable-next-line no-empty
|
2020-06-12 15:31:04 +02:00
|
|
|
while (true) {}
|
|
|
|
|
2020-11-03 16:19:29 +01:00
|
|
|
// deno-lint-ignore no-explicit-any
|
2020-06-12 15:31:04 +02:00
|
|
|
function bar(a: any) {
|
|
|
|
// ...
|
|
|
|
}
|
|
|
|
```
|