-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ocaml: prepare for filetype separation (#3732)
The ocaml filetype is currently used for several, different file formats. This causes problems as not all tools support all formats. New filetypes are introduced to support this separation, this needs some changes in ale that are fortunately backwards-compatible. These change add ocamlinterface file support for ocp-indent, merlin, ocamlformat and ocaml-lsp. For ocaml-lsp I took the liberty to add all recognised language ids, even if they are not supported. ols has not been changed as the project has been abandoned since 2019.
- Loading branch information
Showing
5 changed files
with
69 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
" Author: Andrey Popp -- @andreypopp | ||
" Description: Report errors in OCaml code with Merlin | ||
|
||
if !exists('g:merlin') | ||
finish | ||
endif | ||
|
||
function! ale_linters#ocamlinterface#merlin#Handle(buffer, lines) abort | ||
return merlin#ErrorLocList() | ||
endfunction | ||
|
||
call ale#linter#Define('ocamlinterface', { | ||
\ 'name': 'merlin', | ||
\ 'executable': 'ocamlmerlin', | ||
\ 'command': 'true', | ||
\ 'callback': 'ale_linters#ocamlinterface#merlin#Handle', | ||
\}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
" Author: Risto Stevcev <[email protected]> | ||
" Description: The official language server for OCaml | ||
|
||
call ale#Set('ocaml_ocamllsp_use_opam', 1) | ||
|
||
call ale#linter#Define('ocamlinterface', { | ||
\ 'name': 'ocamllsp', | ||
\ 'lsp': 'stdio', | ||
\ 'executable': function('ale#handlers#ocamllsp#GetExecutable'), | ||
\ 'command': function('ale#handlers#ocamllsp#GetCommand'), | ||
\ 'language': function('ale#handlers#ocamllsp#GetLanguage'), | ||
\ 'project_root': function('ale#handlers#ocamllsp#GetProjectRoot'), | ||
\}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,13 @@ | ||
" Author: Risto Stevcev <[email protected]> | ||
" Description: Handlers for the official OCaml language server | ||
|
||
let s:language_id_of_filetype = { | ||
\ 'menhir': 'ocaml.menhir', | ||
\ 'ocaml': 'ocaml', | ||
\ 'ocamlinterface': 'ocaml.interface', | ||
\ 'ocamllex': 'ocaml.lex' | ||
\} | ||
|
||
function! ale#handlers#ocamllsp#GetExecutable(buffer) abort | ||
return 'ocamllsp' | ||
endfunction | ||
|
@@ -13,7 +20,7 @@ function! ale#handlers#ocamllsp#GetCommand(buffer) abort | |
endfunction | ||
|
||
function! ale#handlers#ocamllsp#GetLanguage(buffer) abort | ||
return getbufvar(a:buffer, '&filetype') | ||
return s:language_id_of_filetype[getbufvar(a:buffer, '&filetype')] | ||
endfunction | ||
|
||
function! ale#handlers#ocamllsp#GetProjectRoot(buffer) abort | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
Before: | ||
call ale#assert#SetUpLinterTest('ocamlinterface', 'ocamllsp') | ||
|
||
Save &filetype | ||
let &filetype = 'ocamlinterface' | ||
|
||
After: | ||
call ale#assert#TearDownLinterTest() | ||
|
||
Execute(The language string should be correct): | ||
AssertLSPLanguage 'ocaml.interface' | ||
|
||
Execute(The project root should be detected correctly): | ||
AssertLSPProject '' | ||
|
||
call ale#test#SetFilename('../test-files/ocamllsp/file.ml') | ||
|
||
AssertLSPProject ale#path#Simplify(g:dir . '/../test-files/ocamllsp') | ||
|
||
Execute(The executable should be run using opam exec by default): | ||
call ale#test#SetFilename('../test-files/ocamllsp/file.ml') | ||
|
||
AssertLinter 'ocamllsp', 'opam config exec -- ocamllsp' | ||
|
||
Execute(The executable should be run directly if use_opam flag is disabled): | ||
let g:ale_ocaml_ocamllsp_use_opam = 0 | ||
call ale#test#SetFilename('../test-files/ocamllsp/file.ml') | ||
|
||
AssertLinter 'ocamllsp', 'ocamllsp' |