summaryrefslogtreecommitdiff
path: root/ale_linters/typescript
diff options
context:
space:
mode:
authorAlvin Chan <chaucerbao@users.noreply.github.com>2019-05-02 03:59:18 -0700
committerw0rp <w0rp@users.noreply.github.com>2019-05-02 11:59:18 +0100
commit7f0954b89ef7c43e5fb7b6490665e9814c8205b2 (patch)
tree2d3b23fe57d84e73eb8732717a4c0b3f309692af /ale_linters/typescript
parentc6aae3bcfcba862028180ca6ff04242c309a767a (diff)
downloadale-7f0954b89ef7c43e5fb7b6490665e9814c8205b2.zip
Add XO as a linter/fixer for TypeScript files (#2453)
Diffstat (limited to 'ale_linters/typescript')
-rw-r--r--ale_linters/typescript/xo.vim23
1 files changed, 23 insertions, 0 deletions
diff --git a/ale_linters/typescript/xo.vim b/ale_linters/typescript/xo.vim
new file mode 100644
index 00000000..8b015efd
--- /dev/null
+++ b/ale_linters/typescript/xo.vim
@@ -0,0 +1,23 @@
+call ale#Set('typescript_xo_executable', 'xo')
+call ale#Set('typescript_xo_use_global', get(g:, 'ale_use_global_executables', 0))
+call ale#Set('typescript_xo_options', '')
+
+function! ale_linters#typescript#xo#GetExecutable(buffer) abort
+ return ale#node#FindExecutable(a:buffer, 'typescript_xo', [
+ \ 'node_modules/.bin/xo',
+ \])
+endfunction
+
+function! ale_linters#typescript#xo#GetCommand(buffer) abort
+ return ale#Escape(ale_linters#typescript#xo#GetExecutable(a:buffer))
+ \ . ale#Pad(ale#Var(a:buffer, 'typescript_xo_options'))
+ \ . ' --reporter unix --stdin --stdin-filename %s'
+endfunction
+
+" xo uses eslint and the output format is the same
+call ale#linter#Define('typescript', {
+\ 'name': 'xo',
+\ 'executable': function('ale_linters#typescript#xo#GetExecutable'),
+\ 'command': function('ale_linters#typescript#xo#GetCommand'),
+\ 'callback': 'ale#handlers#eslint#Handle',
+\})