mirror of
https://github.com/dense-analysis/ale
synced 2025-02-17 04:36:56 +00:00
add support for svelte via svelteserver language server (#3644)
* add support for svelte via svelteserver language server * svelte: fix Vint error and add a `svelteserver` simple test. Co-authored-by: Joakim Repomaa <mail@j.repomaa.com> Co-authored-by: Joakim Repomaa <mail@jreinert.com>
This commit is contained in:
parent
b1d833417b
commit
4411b4d751
21
ale_linters/svelte/svelteserver.vim
Normal file
21
ale_linters/svelte/svelteserver.vim
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
" Author: Joakim Repomaa <joakim@repomaa.com>
|
||||||
|
" Description: Svelte Language Server integration for ALE
|
||||||
|
|
||||||
|
call ale#Set('svelte_svelteserver_executable', 'svelteserver')
|
||||||
|
call ale#Set('svelte_svelteserver_use_global', get(g:, 'ale_use_global_executables', 0))
|
||||||
|
|
||||||
|
function! ale_linters#svelte#svelteserver#GetProjectRoot(buffer) abort
|
||||||
|
let l:package_path = ale#path#FindNearestFile(a:buffer, 'package.json')
|
||||||
|
|
||||||
|
return !empty(l:package_path) ? fnamemodify(l:package_path, ':h') : ''
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call ale#linter#Define('svelte', {
|
||||||
|
\ 'name': 'svelteserver',
|
||||||
|
\ 'lsp': 'stdio',
|
||||||
|
\ 'executable': {b -> ale#node#FindExecutable(b, 'svelte_svelteserver', [
|
||||||
|
\ 'node_modules/.bin/svelteserver',
|
||||||
|
\ ])},
|
||||||
|
\ 'command': '%e --stdio',
|
||||||
|
\ 'project_root': function('ale_linters#svelte#svelteserver#GetProjectRoot'),
|
||||||
|
\})
|
@ -112,7 +112,7 @@ let s:default_registry = {
|
|||||||
\ },
|
\ },
|
||||||
\ 'prettier': {
|
\ 'prettier': {
|
||||||
\ 'function': 'ale#fixers#prettier#Fix',
|
\ 'function': 'ale#fixers#prettier#Fix',
|
||||||
\ 'suggested_filetypes': ['javascript', 'typescript', 'css', 'less', 'scss', 'json', 'json5', 'graphql', 'markdown', 'vue', 'html', 'yaml', 'openapi', 'ruby'],
|
\ 'suggested_filetypes': ['javascript', 'typescript', 'css', 'less', 'scss', 'json', 'json5', 'graphql', 'markdown', 'vue', 'svelte', 'html', 'yaml', 'openapi', 'ruby'],
|
||||||
\ 'description': 'Apply prettier to a file.',
|
\ 'description': 'Apply prettier to a file.',
|
||||||
\ },
|
\ },
|
||||||
\ 'prettier_eslint': {
|
\ 'prettier_eslint': {
|
||||||
|
@ -74,6 +74,7 @@ function! ale#fixers#prettier#ApplyFixForVersion(buffer, version) abort
|
|||||||
\ 'graphql': 'graphql',
|
\ 'graphql': 'graphql',
|
||||||
\ 'markdown': 'markdown',
|
\ 'markdown': 'markdown',
|
||||||
\ 'vue': 'vue',
|
\ 'vue': 'vue',
|
||||||
|
\ 'svelte': 'svelte',
|
||||||
\ 'yaml': 'yaml',
|
\ 'yaml': 'yaml',
|
||||||
\ 'openapi': 'yaml',
|
\ 'openapi': 'yaml',
|
||||||
\ 'html': 'html',
|
\ 'html': 'html',
|
||||||
|
@ -489,6 +489,9 @@ Notes:
|
|||||||
* `stylelint`
|
* `stylelint`
|
||||||
* SugarSS
|
* SugarSS
|
||||||
* `stylelint`
|
* `stylelint`
|
||||||
|
* Svelte
|
||||||
|
* `prettier`
|
||||||
|
* `svelteserver`
|
||||||
* Swift
|
* Swift
|
||||||
* Apple `swift-format`
|
* Apple `swift-format`
|
||||||
* `sourcekit-lsp`
|
* `sourcekit-lsp`
|
||||||
|
31
doc/ale-svelte.txt
Normal file
31
doc/ale-svelte.txt
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
===============================================================================
|
||||||
|
ALE Svelte Integration *ale-svelte-options*
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
prettier *ale-svelte-prettier*
|
||||||
|
|
||||||
|
See |ale-javascript-prettier| for information about the available options.
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
svelteserver *ale-svelte-svelteserver*
|
||||||
|
|
||||||
|
g:ale_svelte_svelteserver_executable *g:ale_svelte_svelteserver_executable*
|
||||||
|
*b:ale_svelte_svelteserver_executable*
|
||||||
|
Type: |String|
|
||||||
|
Default: `'svelteserver'`
|
||||||
|
|
||||||
|
See |ale-integrations-local-executables|
|
||||||
|
|
||||||
|
|
||||||
|
g:ale_svelte_svelteserver_use_global *g:ale_svelte_svelteserver_use_global*
|
||||||
|
*b:ale_svelte_svelteserver_use_global*
|
||||||
|
Type: |Number|
|
||||||
|
Default: `get(g:, 'ale_use_global_executables', 0)`
|
||||||
|
|
||||||
|
See |ale-integrations-local-executables|
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
vim:tw=78:ts=2:sts=2:sw=2:ft=help:norl:
|
@ -1438,6 +1438,7 @@ g:ale_linter_aliases *g:ale_linter_aliases*
|
|||||||
\ 'ps1': 'powershell',
|
\ 'ps1': 'powershell',
|
||||||
\ 'rmarkdown': 'r',
|
\ 'rmarkdown': 'r',
|
||||||
\ 'rmd': 'r',
|
\ 'rmd': 'r',
|
||||||
|
\ 'svelte': ['svelte', 'javascript'],
|
||||||
\ 'systemverilog': 'verilog',
|
\ 'systemverilog': 'verilog',
|
||||||
\ 'typescriptreact': ['typescript', 'tsx'],
|
\ 'typescriptreact': ['typescript', 'tsx'],
|
||||||
\ 'verilog_systemverilog': ['verilog_systemverilog', 'verilog'],
|
\ 'verilog_systemverilog': ['verilog_systemverilog', 'verilog'],
|
||||||
@ -1588,6 +1589,7 @@ g:ale_linters *g:ale_linters*
|
|||||||
\ 'python': ['flake8', 'mypy', 'pylint', 'pyright'],
|
\ 'python': ['flake8', 'mypy', 'pylint', 'pyright'],
|
||||||
\ 'rust': ['cargo', 'rls'],
|
\ 'rust': ['cargo', 'rls'],
|
||||||
\ 'spec': [],
|
\ 'spec': [],
|
||||||
|
\ 'svelte': ['eslint', 'svelteserver'],
|
||||||
\ 'text': [],
|
\ 'text': [],
|
||||||
\ 'vue': ['eslint', 'vls'],
|
\ 'vue': ['eslint', 'vls'],
|
||||||
\ 'zsh': ['shell'],
|
\ 'zsh': ['shell'],
|
||||||
@ -3010,6 +3012,9 @@ documented in additional help files.
|
|||||||
stylelint.............................|ale-stylus-stylelint|
|
stylelint.............................|ale-stylus-stylelint|
|
||||||
sugarss.................................|ale-sugarss-options|
|
sugarss.................................|ale-sugarss-options|
|
||||||
stylelint.............................|ale-sugarss-stylelint|
|
stylelint.............................|ale-sugarss-stylelint|
|
||||||
|
svelte..................................|ale-svelte-options|
|
||||||
|
prettier..............................|ale-svelte-prettier|
|
||||||
|
svelteserver..........................|ale-svelte-svelteserver|
|
||||||
swift...................................|ale-swift-options|
|
swift...................................|ale-swift-options|
|
||||||
sourcekitlsp..........................|ale-swift-sourcekitlsp|
|
sourcekitlsp..........................|ale-swift-sourcekitlsp|
|
||||||
systemd.................................|ale-systemd-options|
|
systemd.................................|ale-systemd-options|
|
||||||
|
@ -498,6 +498,9 @@ formatting.
|
|||||||
* [stylelint](https://github.com/stylelint/stylelint)
|
* [stylelint](https://github.com/stylelint/stylelint)
|
||||||
* SugarSS
|
* SugarSS
|
||||||
* [stylelint](https://github.com/stylelint/stylelint)
|
* [stylelint](https://github.com/stylelint/stylelint)
|
||||||
|
* Svelte
|
||||||
|
* [prettier](https://github.com/prettier/prettier)
|
||||||
|
* [svelteserver](https://github.com/sveltejs/language-tools/tree/master/packages/language-server)
|
||||||
* Swift
|
* Swift
|
||||||
* [Apple swift-format](https://github.com/apple/swift-format)
|
* [Apple swift-format](https://github.com/apple/swift-format)
|
||||||
* [sourcekit-lsp](https://github.com/apple/sourcekit-lsp)
|
* [sourcekit-lsp](https://github.com/apple/sourcekit-lsp)
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
Before:
|
||||||
|
call ale#assert#SetUpLinterTest('svelte', 'svelteserver')
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#assert#TearDownLinterTest()
|
||||||
|
|
||||||
|
Execute(The default command should be correct):
|
||||||
|
AssertLinter 'svelteserver', ale#Escape('svelteserver') . ' --stdio'
|
Loading…
Reference in New Issue
Block a user