Fix #668 - Support eslint for TypeScript
This commit is contained in:
parent
b96f5845ed
commit
a105aa90a5
@ -117,7 +117,7 @@ name. That seems to be the fairest way to arrange this table.
|
|||||||
| Swift | [swiftlint](https://swift.org/) |
|
| Swift | [swiftlint](https://swift.org/) |
|
||||||
| Texinfo | [proselint](http://proselint.com/)|
|
| Texinfo | [proselint](http://proselint.com/)|
|
||||||
| Text^ | [proselint](http://proselint.com/), [vale](https://github.com/ValeLint/vale) |
|
| Text^ | [proselint](http://proselint.com/), [vale](https://github.com/ValeLint/vale) |
|
||||||
| TypeScript | [tslint](https://github.com/palantir/tslint), tsserver, typecheck |
|
| TypeScript | [eslint](http://eslint.org/), [tslint](https://github.com/palantir/tslint), tsserver, typecheck |
|
||||||
| Verilog | [iverilog](https://github.com/steveicarus/iverilog), [verilator](http://www.veripool.org/projects/verilator/wiki/Intro) |
|
| Verilog | [iverilog](https://github.com/steveicarus/iverilog), [verilator](http://www.veripool.org/projects/verilator/wiki/Intro) |
|
||||||
| Vim | [vint](https://github.com/Kuniwak/vint) |
|
| Vim | [vint](https://github.com/Kuniwak/vint) |
|
||||||
| Vim help^ | [proselint](http://proselint.com/)|
|
| Vim help^ | [proselint](http://proselint.com/)|
|
||||||
|
@ -1,92 +1,9 @@
|
|||||||
" Author: w0rp <devw0rp@gmail.com>
|
" Author: w0rp <devw0rp@gmail.com>
|
||||||
" Description: eslint for JavaScript files
|
" Description: eslint for JavaScript files
|
||||||
|
|
||||||
let g:ale_javascript_eslint_options =
|
|
||||||
\ get(g:, 'ale_javascript_eslint_options', '')
|
|
||||||
|
|
||||||
function! ale_linters#javascript#eslint#GetCommand(buffer) abort
|
|
||||||
let l:executable = ale#handlers#eslint#GetExecutable(a:buffer)
|
|
||||||
|
|
||||||
if ale#Has('win32') && l:executable =~? 'eslint\.js$'
|
|
||||||
" For Windows, if we detect an eslint.js script, we need to execute
|
|
||||||
" it with node, or the file can be opened with a text editor.
|
|
||||||
let l:head = 'node ' . ale#Escape(l:executable)
|
|
||||||
else
|
|
||||||
let l:head = ale#Escape(l:executable)
|
|
||||||
endif
|
|
||||||
|
|
||||||
let l:options = ale#Var(a:buffer, 'javascript_eslint_options')
|
|
||||||
|
|
||||||
return l:head
|
|
||||||
\ . (!empty(l:options) ? ' ' . l:options : '')
|
|
||||||
\ . ' -f unix --stdin --stdin-filename %s'
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
let s:col_end_patterns = [
|
|
||||||
\ '\vParsing error: Unexpected token (.+) ',
|
|
||||||
\ '\v''(.+)'' is not defined.',
|
|
||||||
\ '\v%(Unexpected|Redundant use of) [''`](.+)[''`]',
|
|
||||||
\ '\vUnexpected (console) statement',
|
|
||||||
\]
|
|
||||||
|
|
||||||
function! ale_linters#javascript#eslint#Handle(buffer, lines) abort
|
|
||||||
let l:config_error_pattern = '\v^ESLint couldn''t find a configuration file'
|
|
||||||
\ . '|^Cannot read config file'
|
|
||||||
\ . '|^.*Configuration for rule .* is invalid'
|
|
||||||
|
|
||||||
" Look for a message in the first few lines which indicates that
|
|
||||||
" a configuration file couldn't be found.
|
|
||||||
for l:line in a:lines[:10]
|
|
||||||
if len(matchlist(l:line, l:config_error_pattern)) > 0
|
|
||||||
return [{
|
|
||||||
\ 'lnum': 1,
|
|
||||||
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
|
||||||
\ 'detail': join(a:lines, "\n"),
|
|
||||||
\}]
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
|
|
||||||
" Matches patterns line the following:
|
|
||||||
"
|
|
||||||
" /path/to/some-filename.js:47:14: Missing trailing comma. [Warning/comma-dangle]
|
|
||||||
" /path/to/some-filename.js:56:41: Missing semicolon. [Error/semi]
|
|
||||||
let l:pattern = '^.*:\(\d\+\):\(\d\+\): \(.\+\) \[\(.\+\)\]$'
|
|
||||||
" This second pattern matches lines like the following:
|
|
||||||
"
|
|
||||||
" /path/to/some-filename.js:13:3: Parsing error: Unexpected token
|
|
||||||
let l:parsing_pattern = '^.*:\(\d\+\):\(\d\+\): \(.\+\)$'
|
|
||||||
let l:output = []
|
|
||||||
|
|
||||||
for l:match in ale#util#GetMatches(a:lines, [l:pattern, l:parsing_pattern])
|
|
||||||
let l:type = 'Error'
|
|
||||||
let l:text = l:match[3]
|
|
||||||
|
|
||||||
" Take the error type from the output if available.
|
|
||||||
if !empty(l:match[4])
|
|
||||||
let l:type = split(l:match[4], '/')[0]
|
|
||||||
let l:text .= ' [' . l:match[4] . ']'
|
|
||||||
endif
|
|
||||||
|
|
||||||
let l:obj = {
|
|
||||||
\ 'lnum': l:match[1] + 0,
|
|
||||||
\ 'col': l:match[2] + 0,
|
|
||||||
\ 'text': l:text,
|
|
||||||
\ 'type': l:type ==# 'Warning' ? 'W' : 'E',
|
|
||||||
\}
|
|
||||||
|
|
||||||
for l:col_match in ale#util#GetMatches(l:text, s:col_end_patterns)
|
|
||||||
let l:obj.end_col = l:obj.col + len(l:col_match[1]) - 1
|
|
||||||
endfor
|
|
||||||
|
|
||||||
call add(l:output, l:obj)
|
|
||||||
endfor
|
|
||||||
|
|
||||||
return l:output
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
call ale#linter#Define('javascript', {
|
call ale#linter#Define('javascript', {
|
||||||
\ 'name': 'eslint',
|
\ 'name': 'eslint',
|
||||||
\ 'executable_callback': 'ale#handlers#eslint#GetExecutable',
|
\ 'executable_callback': 'ale#handlers#eslint#GetExecutable',
|
||||||
\ 'command_callback': 'ale_linters#javascript#eslint#GetCommand',
|
\ 'command_callback': 'ale#handlers#eslint#GetCommand',
|
||||||
\ 'callback': 'ale_linters#javascript#eslint#Handle',
|
\ 'callback': 'ale#handlers#eslint#Handle',
|
||||||
\})
|
\})
|
||||||
|
9
ale_linters/typescript/eslint.vim
Normal file
9
ale_linters/typescript/eslint.vim
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
" Author: w0rp <devw0rp@gmail.com>
|
||||||
|
" Description: eslint for JavaScript files
|
||||||
|
|
||||||
|
call ale#linter#Define('typescript', {
|
||||||
|
\ 'name': 'eslint',
|
||||||
|
\ 'executable_callback': 'ale#handlers#eslint#GetExecutable',
|
||||||
|
\ 'command_callback': 'ale#handlers#eslint#GetCommand',
|
||||||
|
\ 'callback': 'ale#handlers#eslint#Handle',
|
||||||
|
\})
|
@ -14,7 +14,7 @@ let s:default_registry = {
|
|||||||
\ },
|
\ },
|
||||||
\ 'eslint': {
|
\ 'eslint': {
|
||||||
\ 'function': 'ale#fixers#eslint#Fix',
|
\ 'function': 'ale#fixers#eslint#Fix',
|
||||||
\ 'suggested_filetypes': ['javascript'],
|
\ 'suggested_filetypes': ['javascript', 'typescript'],
|
||||||
\ 'description': 'Apply eslint --fix to a file.',
|
\ 'description': 'Apply eslint --fix to a file.',
|
||||||
\ },
|
\ },
|
||||||
\ 'isort': {
|
\ 'isort': {
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
" Author: w0rp <devw0rp@gmail.com>
|
" Author: w0rp <devw0rp@gmail.com>
|
||||||
" Description: Functions for working with eslint, for checking or fixing files.
|
" Description: Functions for working with eslint, for checking or fixing files.
|
||||||
|
|
||||||
|
call ale#Set('javascript_eslint_options', '')
|
||||||
call ale#Set('javascript_eslint_executable', 'eslint')
|
call ale#Set('javascript_eslint_executable', 'eslint')
|
||||||
call ale#Set('javascript_eslint_use_global', 0)
|
call ale#Set('javascript_eslint_use_global', 0)
|
||||||
|
|
||||||
@ -11,3 +12,98 @@ function! ale#handlers#eslint#GetExecutable(buffer) abort
|
|||||||
\ 'node_modules/.bin/eslint',
|
\ 'node_modules/.bin/eslint',
|
||||||
\])
|
\])
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
function! ale#handlers#eslint#GetCommand(buffer) abort
|
||||||
|
let l:executable = ale#handlers#eslint#GetExecutable(a:buffer)
|
||||||
|
|
||||||
|
if ale#Has('win32') && l:executable =~? 'eslint\.js$'
|
||||||
|
" For Windows, if we detect an eslint.js script, we need to execute
|
||||||
|
" it with node, or the file can be opened with a text editor.
|
||||||
|
let l:head = 'node ' . ale#Escape(l:executable)
|
||||||
|
else
|
||||||
|
let l:head = ale#Escape(l:executable)
|
||||||
|
endif
|
||||||
|
|
||||||
|
let l:options = ale#Var(a:buffer, 'javascript_eslint_options')
|
||||||
|
|
||||||
|
return l:head
|
||||||
|
\ . (!empty(l:options) ? ' ' . l:options : '')
|
||||||
|
\ . ' -f unix --stdin --stdin-filename %s'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
let s:col_end_patterns = [
|
||||||
|
\ '\vParsing error: Unexpected token (.+) ',
|
||||||
|
\ '\v''(.+)'' is not defined.',
|
||||||
|
\ '\v%(Unexpected|Redundant use of) [''`](.+)[''`]',
|
||||||
|
\ '\vUnexpected (console) statement',
|
||||||
|
\]
|
||||||
|
|
||||||
|
function! s:AddHintsForTypeScriptParsingErrors(output) abort
|
||||||
|
for l:item in a:output
|
||||||
|
let l:item.text = substitute(
|
||||||
|
\ l:item.text,
|
||||||
|
\ '^\(Parsing error\)',
|
||||||
|
\ '\1 (You may need configure typescript-eslint-parser)',
|
||||||
|
\ '',
|
||||||
|
\)
|
||||||
|
endfor
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale#handlers#eslint#Handle(buffer, lines) abort
|
||||||
|
let l:config_error_pattern = '\v^ESLint couldn''t find a configuration file'
|
||||||
|
\ . '|^Cannot read config file'
|
||||||
|
\ . '|^.*Configuration for rule .* is invalid'
|
||||||
|
|
||||||
|
" Look for a message in the first few lines which indicates that
|
||||||
|
" a configuration file couldn't be found.
|
||||||
|
for l:line in a:lines[:10]
|
||||||
|
if len(matchlist(l:line, l:config_error_pattern)) > 0
|
||||||
|
return [{
|
||||||
|
\ 'lnum': 1,
|
||||||
|
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
||||||
|
\ 'detail': join(a:lines, "\n"),
|
||||||
|
\}]
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
" Matches patterns line the following:
|
||||||
|
"
|
||||||
|
" /path/to/some-filename.js:47:14: Missing trailing comma. [Warning/comma-dangle]
|
||||||
|
" /path/to/some-filename.js:56:41: Missing semicolon. [Error/semi]
|
||||||
|
let l:pattern = '^.*:\(\d\+\):\(\d\+\): \(.\+\) \[\(.\+\)\]$'
|
||||||
|
" This second pattern matches lines like the following:
|
||||||
|
"
|
||||||
|
" /path/to/some-filename.js:13:3: Parsing error: Unexpected token
|
||||||
|
let l:parsing_pattern = '^.*:\(\d\+\):\(\d\+\): \(.\+\)$'
|
||||||
|
let l:output = []
|
||||||
|
|
||||||
|
for l:match in ale#util#GetMatches(a:lines, [l:pattern, l:parsing_pattern])
|
||||||
|
let l:type = 'Error'
|
||||||
|
let l:text = l:match[3]
|
||||||
|
|
||||||
|
" Take the error type from the output if available.
|
||||||
|
if !empty(l:match[4])
|
||||||
|
let l:type = split(l:match[4], '/')[0]
|
||||||
|
let l:text .= ' [' . l:match[4] . ']'
|
||||||
|
endif
|
||||||
|
|
||||||
|
let l:obj = {
|
||||||
|
\ 'lnum': l:match[1] + 0,
|
||||||
|
\ 'col': l:match[2] + 0,
|
||||||
|
\ 'text': l:text,
|
||||||
|
\ 'type': l:type ==# 'Warning' ? 'W' : 'E',
|
||||||
|
\}
|
||||||
|
|
||||||
|
for l:col_match in ale#util#GetMatches(l:text, s:col_end_patterns)
|
||||||
|
let l:obj.end_col = l:obj.col + len(l:col_match[1]) - 1
|
||||||
|
endfor
|
||||||
|
|
||||||
|
call add(l:output, l:obj)
|
||||||
|
endfor
|
||||||
|
|
||||||
|
if expand('#' . a:buffer . ':t') =~? '\.tsx\?$'
|
||||||
|
call s:AddHintsForTypeScriptParsingErrors(l:output)
|
||||||
|
endif
|
||||||
|
|
||||||
|
return l:output
|
||||||
|
endfunction
|
||||||
|
@ -290,7 +290,7 @@ function! s:GetLinterNames(original_filetype) abort
|
|||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! ale#linter#Get(original_filetypes) abort
|
function! ale#linter#Get(original_filetypes) abort
|
||||||
let l:combined_linters = []
|
let l:possibly_duplicated_linters = []
|
||||||
|
|
||||||
" Handle dot-seperated filetypes.
|
" Handle dot-seperated filetypes.
|
||||||
for l:original_filetype in split(a:original_filetypes, '\.')
|
for l:original_filetype in split(a:original_filetypes, '\.')
|
||||||
@ -315,8 +315,22 @@ function! ale#linter#Get(original_filetypes) abort
|
|||||||
endfor
|
endfor
|
||||||
endif
|
endif
|
||||||
|
|
||||||
call extend(l:combined_linters, l:filetype_linters)
|
call extend(l:possibly_duplicated_linters, l:filetype_linters)
|
||||||
endfor
|
endfor
|
||||||
|
|
||||||
return l:combined_linters
|
let l:name_list = []
|
||||||
|
let l:combined_linters = []
|
||||||
|
|
||||||
|
" Make sure we override linters so we don't get two with the same name,
|
||||||
|
" like 'eslint' for both 'javascript' and 'typescript'
|
||||||
|
"
|
||||||
|
" Note that the reverse calls here modify the List variables.
|
||||||
|
for l:linter in reverse(l:possibly_duplicated_linters)
|
||||||
|
if index(l:name_list, l:linter.name) < 0
|
||||||
|
call add(l:name_list, l:linter.name)
|
||||||
|
call add(l:combined_linters, l:linter)
|
||||||
|
endif
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return reverse(l:combined_linters)
|
||||||
endfunction
|
endfunction
|
||||||
|
@ -2,6 +2,14 @@
|
|||||||
ALE TypeScript Integration *ale-typescript-options*
|
ALE TypeScript Integration *ale-typescript-options*
|
||||||
|
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
eslint *ale-typescript-eslint*
|
||||||
|
|
||||||
|
Becauase of how TypeScript compiles code to JavaScript and how interrelated
|
||||||
|
the two languages are, the `eslint` linter for TypeScript uses the JavaScript
|
||||||
|
options for `eslint` too. See: |ale-javascript-eslint|.
|
||||||
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
tslint *ale-typescript-tslint*
|
tslint *ale-typescript-tslint*
|
||||||
|
|
||||||
|
@ -95,6 +95,7 @@ CONTENTS *ale-contents*
|
|||||||
chktex..............................|ale-tex-chktex|
|
chktex..............................|ale-tex-chktex|
|
||||||
lacheck.............................|ale-tex-lacheck|
|
lacheck.............................|ale-tex-lacheck|
|
||||||
typescript............................|ale-typescript-options|
|
typescript............................|ale-typescript-options|
|
||||||
|
eslint..............................|ale-typescript-eslint|
|
||||||
tslint..............................|ale-typescript-tslint|
|
tslint..............................|ale-typescript-tslint|
|
||||||
tsserver............................|ale-typescript-tsserver|
|
tsserver............................|ale-typescript-tsserver|
|
||||||
vim...................................|ale-vim-options|
|
vim...................................|ale-vim-options|
|
||||||
@ -195,7 +196,7 @@ The following languages and tools are supported.
|
|||||||
* Swift: 'swiftlint'
|
* Swift: 'swiftlint'
|
||||||
* Texinfo: 'proselint'
|
* Texinfo: 'proselint'
|
||||||
* Text: 'proselint', 'vale'
|
* Text: 'proselint', 'vale'
|
||||||
* TypeScript: 'tslint', 'tsserver', 'typecheck'
|
* TypeScript: 'eslint', 'tslint', 'tsserver', 'typecheck'
|
||||||
* Verilog: 'iverilog', 'verilator'
|
* Verilog: 'iverilog', 'verilator'
|
||||||
* Vim: 'vint'
|
* Vim: 'vint'
|
||||||
* Vim help: 'proselint'
|
* Vim help: 'proselint'
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Before:
|
After:
|
||||||
runtime ale_linters/javascript/eslint.vim
|
unlet! g:config_error_lines
|
||||||
|
|
||||||
Execute(The eslint handler should parse lines correctly):
|
Execute(The eslint handler should parse lines correctly):
|
||||||
AssertEqual
|
AssertEqual
|
||||||
@ -23,7 +23,7 @@ Execute(The eslint handler should parse lines correctly):
|
|||||||
\ 'type': 'E',
|
\ 'type': 'E',
|
||||||
\ },
|
\ },
|
||||||
\ ],
|
\ ],
|
||||||
\ ale_linters#javascript#eslint#Handle(347, [
|
\ ale#handlers#eslint#Handle(347, [
|
||||||
\ 'This line should be ignored completely',
|
\ 'This line should be ignored completely',
|
||||||
\ '/path/to/some-filename.js:47:14: Missing trailing comma. [Warning/comma-dangle]',
|
\ '/path/to/some-filename.js:47:14: Missing trailing comma. [Warning/comma-dangle]',
|
||||||
\ '/path/to/some-filename.js:56:41: Missing semicolon. [Error/semi]',
|
\ '/path/to/some-filename.js:56:41: Missing semicolon. [Error/semi]',
|
||||||
@ -51,7 +51,7 @@ Execute(The eslint handler should print a message about a missing configuration
|
|||||||
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
||||||
\ 'detail': join(g:config_error_lines, "\n"),
|
\ 'detail': join(g:config_error_lines, "\n"),
|
||||||
\ }],
|
\ }],
|
||||||
\ ale_linters#javascript#eslint#Handle(347, g:config_error_lines[:])
|
\ ale#handlers#eslint#Handle(347, g:config_error_lines[:])
|
||||||
|
|
||||||
Execute(The eslint handler should print a message for config parsing errors):
|
Execute(The eslint handler should print a message for config parsing errors):
|
||||||
let g:config_error_lines = [
|
let g:config_error_lines = [
|
||||||
@ -79,11 +79,7 @@ Execute(The eslint handler should print a message for config parsing errors):
|
|||||||
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
||||||
\ 'detail': join(g:config_error_lines, "\n"),
|
\ 'detail': join(g:config_error_lines, "\n"),
|
||||||
\ }],
|
\ }],
|
||||||
\ ale_linters#javascript#eslint#Handle(347, g:config_error_lines[:])
|
\ ale#handlers#eslint#Handle(347, g:config_error_lines[:])
|
||||||
|
|
||||||
After:
|
|
||||||
unlet! g:config_error_lines
|
|
||||||
call ale#linter#Reset()
|
|
||||||
|
|
||||||
Execute(The eslint handler should print a message for invalid configuration settings):
|
Execute(The eslint handler should print a message for invalid configuration settings):
|
||||||
let g:config_error_lines = [
|
let g:config_error_lines = [
|
||||||
@ -113,7 +109,7 @@ Execute(The eslint handler should print a message for invalid configuration sett
|
|||||||
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
\ 'text': 'eslint configuration error (type :ALEDetail for more information)',
|
||||||
\ 'detail': join(g:config_error_lines, "\n"),
|
\ 'detail': join(g:config_error_lines, "\n"),
|
||||||
\ }],
|
\ }],
|
||||||
\ ale_linters#javascript#eslint#Handle(347, g:config_error_lines[:])
|
\ ale#handlers#eslint#Handle(347, g:config_error_lines[:])
|
||||||
|
|
||||||
Execute(The eslint handler should output end_col values where appropriate):
|
Execute(The eslint handler should output end_col values where appropriate):
|
||||||
AssertEqual
|
AssertEqual
|
||||||
@ -161,7 +157,7 @@ Execute(The eslint handler should output end_col values where appropriate):
|
|||||||
\ 'type': 'E',
|
\ 'type': 'E',
|
||||||
\ },
|
\ },
|
||||||
\ ],
|
\ ],
|
||||||
\ ale_linters#javascript#eslint#Handle(347, [
|
\ ale#handlers#eslint#Handle(347, [
|
||||||
\ 'app.js:4:3: Parsing error: Unexpected token ''some string'' [Error]',
|
\ 'app.js:4:3: Parsing error: Unexpected token ''some string'' [Error]',
|
||||||
\ 'app.js:70:3: ''foo'' is not defined. [Error/no-undef]',
|
\ 'app.js:70:3: ''foo'' is not defined. [Error/no-undef]',
|
||||||
\ 'app.js:71:2: Unexpected `await` inside a loop. [Error/no-await-in-loop]',
|
\ 'app.js:71:2: Unexpected `await` inside a loop. [Error/no-await-in-loop]',
|
||||||
@ -169,3 +165,20 @@ Execute(The eslint handler should output end_col values where appropriate):
|
|||||||
\ 'app.js:73:4: Unexpected console statement [Error/no-console]',
|
\ 'app.js:73:4: Unexpected console statement [Error/no-console]',
|
||||||
\ 'app.js:74:4: Unexpected ''debugger'' statement. [Error/no-debugger]',
|
\ 'app.js:74:4: Unexpected ''debugger'' statement. [Error/no-debugger]',
|
||||||
\ ])
|
\ ])
|
||||||
|
|
||||||
|
Execute(The eslint hint about using typescript-eslint-parser):
|
||||||
|
silent! noautocmd file foo.ts
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ [
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 451,
|
||||||
|
\ 'col': 2,
|
||||||
|
\ 'end_col': 2,
|
||||||
|
\ 'text': 'Parsing error (You may need configure typescript-eslint-parser): Unexpected token ) [Error]',
|
||||||
|
\ 'type': 'E',
|
||||||
|
\ },
|
||||||
|
\ ],
|
||||||
|
\ ale#handlers#eslint#Handle(bufnr(''), [
|
||||||
|
\ 'foo.ts:451:2: Parsing error: Unexpected token ) [Error]',
|
||||||
|
\ ])
|
||||||
|
@ -74,4 +74,4 @@ Execute(eslint.js executables should be run with node on Windows):
|
|||||||
\ 'node '''
|
\ 'node '''
|
||||||
\ . g:dir . '/eslint-test-files/react-app/node_modules/eslint/bin/eslint.js'
|
\ . g:dir . '/eslint-test-files/react-app/node_modules/eslint/bin/eslint.js'
|
||||||
\ . ''' -f unix --stdin --stdin-filename %s',
|
\ . ''' -f unix --stdin --stdin-filename %s',
|
||||||
\ ale_linters#javascript#eslint#GetCommand(bufnr(''))
|
\ ale#handlers#eslint#GetCommand(bufnr(''))
|
||||||
|
@ -106,3 +106,22 @@ Execute (The local alias option shouldn't completely replace the global one):
|
|||||||
|
|
||||||
Execute (Linters should be loaded from disk appropriately):
|
Execute (Linters should be loaded from disk appropriately):
|
||||||
AssertEqual [{'name': 'testlinter', 'output_stream': 'stdout', 'executable': 'testlinter', 'command': 'testlinter', 'callback': 'testCB', 'read_buffer': 1, 'lint_file': 0, 'aliases': [], 'lsp': ''}], ale#linter#Get('testft')
|
AssertEqual [{'name': 'testlinter', 'output_stream': 'stdout', 'executable': 'testlinter', 'command': 'testlinter', 'callback': 'testCB', 'read_buffer': 1, 'lint_file': 0, 'aliases': [], 'lsp': ''}], ale#linter#Get('testft')
|
||||||
|
|
||||||
|
|
||||||
|
Execute (Linters for later filetypes should replace the former ones):
|
||||||
|
call ale#linter#Define('javascript', {
|
||||||
|
\ 'name': 'eslint',
|
||||||
|
\ 'executable': 'y',
|
||||||
|
\ 'command': 'y',
|
||||||
|
\ 'callback': 'y',
|
||||||
|
\})
|
||||||
|
call ale#linter#Define('typescript', {
|
||||||
|
\ 'name': 'eslint',
|
||||||
|
\ 'executable': 'x',
|
||||||
|
\ 'command': 'x',
|
||||||
|
\ 'callback': 'x',
|
||||||
|
\})
|
||||||
|
|
||||||
|
AssertEqual [
|
||||||
|
\ {'output_stream': 'stdout', 'lint_file': 0, 'read_buffer': 1, 'name': 'eslint', 'executable': 'x', 'lsp': '', 'aliases': [], 'command': 'x', 'callback': 'x'}
|
||||||
|
\], ale#linter#Get('javascript.typescript')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user