From 9b91e9ac4403aef5d5c475b17574ee234682ecad Mon Sep 17 00:00:00 2001 From: Ben Block Date: Wed, 13 Dec 2023 11:56:58 -0500 Subject: [PATCH] Adding support for Odin language server (ols). --- ale_linters/odin/ols.vim | 19 +++++++++++++++ doc/ale-odin.txt | 29 +++++++++++++++++++++++ doc/ale-supported-languages-and-tools.txt | 2 ++ doc/ale.txt | 2 ++ supported-tools.md | 2 ++ test/linter/test_odin_ols.vader | 16 +++++++++++++ test/test-files/odin/main.odin | 0 7 files changed, 70 insertions(+) create mode 100644 ale_linters/odin/ols.vim create mode 100644 doc/ale-odin.txt create mode 100644 test/linter/test_odin_ols.vader create mode 100644 test/test-files/odin/main.odin diff --git a/ale_linters/odin/ols.vim b/ale_linters/odin/ols.vim new file mode 100644 index 0000000000..242dea0ee9 --- /dev/null +++ b/ale_linters/odin/ols.vim @@ -0,0 +1,19 @@ +" Author: Benjamin Block +" Description: A language server for Odin. + +function! ale_linters#odin#ols#GetProjectRoot(buffer) abort + return fnamemodify('', ':h') +endfunction + +call ale#Set('odin_ols_executable', 'ols') +call ale#Set('odin_ols_config', {}) + +call ale#linter#Define('odin', { +\ 'name': 'ols', +\ 'lsp': 'stdio', +\ 'language': 'odin', +\ 'lsp_config': {b -> ale#Var(b, 'odin_ols_config')}, +\ 'executable': {b -> ale#Var(b, 'odin_ols_executable')}, +\ 'command': '%e', +\ 'project_root': function('ale_linters#odin#ols#GetProjectRoot'), +\}) diff --git a/doc/ale-odin.txt b/doc/ale-odin.txt new file mode 100644 index 0000000000..826411de25 --- /dev/null +++ b/doc/ale-odin.txt @@ -0,0 +1,29 @@ +=============================================================================== +ALE Odin Integration *ale-odin-options* + *ale-integration-odin* + +=============================================================================== +Integration Information + + Currently, the only supported linter for Odin is ols. + +=============================================================================== +ols *ale-odin-ols* + +g:ale_odin_ols_executable *g:ale_odin_ols_executable* + *b:ale_odin_ols_executable* + Type: |String| + Default: `'ols'` + + This variable can be modified to change the executable path for `ols`. + + +g:ale_odin_ols_config *g:ale_odin_ols_config* + *b:ale_odin_ols_config* + Type: |Dictionary| + Default: `{}` + + Dictionary with configuration settings for ols. + +=============================================================================== + vim:tw=78:ts=2:sts=2:sw=2:ft=help:norl: diff --git a/doc/ale-supported-languages-and-tools.txt b/doc/ale-supported-languages-and-tools.txt index aa49a1b19e..3bae16b03a 100644 --- a/doc/ale-supported-languages-and-tools.txt +++ b/doc/ale-supported-languages-and-tools.txt @@ -418,6 +418,8 @@ Notes: * `ocamllsp` * `ocp-indent` * `ols` +* Odin + * `ols` * OpenApi * `ibm_validator` * `prettier` diff --git a/doc/ale.txt b/doc/ale.txt index 5f7999b865..4c3b855c25 100644 --- a/doc/ale.txt +++ b/doc/ale.txt @@ -3220,6 +3220,8 @@ documented in additional help files. ols...................................|ale-ocaml-ols| ocamlformat...........................|ale-ocaml-ocamlformat| ocp-indent............................|ale-ocaml-ocp-indent| + odin....................................|ale-odin-options| + ols...................................|ale-odin-ols| openapi.................................|ale-openapi-options| ibm_validator.........................|ale-openapi-ibm-validator| prettier..............................|ale-openapi-prettier| diff --git a/supported-tools.md b/supported-tools.md index 6431cfe630..8ca3e0d221 100644 --- a/supported-tools.md +++ b/supported-tools.md @@ -427,6 +427,8 @@ formatting. * [ocamllsp](https://github.com/ocaml/ocaml-lsp) * [ocp-indent](https://github.com/OCamlPro/ocp-indent) * [ols](https://github.com/freebroccolo/ocaml-language-server) +* Odin + * [ols](https://github.com/DanielGavin/ols) * OpenApi * [ibm_validator](https://github.com/IBM/openapi-validator) * [prettier](https://github.com/prettier/prettier) diff --git a/test/linter/test_odin_ols.vader b/test/linter/test_odin_ols.vader new file mode 100644 index 0000000000..ac7d2797e3 --- /dev/null +++ b/test/linter/test_odin_ols.vader @@ -0,0 +1,16 @@ +Before: + call ale#assert#SetUpLinterTest('odin', 'ols') + +After: + call ale#assert#TearDownLinterTest() + +Execute(The default executable path should be correct): + AssertLinter 'ols', ale#Escape('ols') + +Execute(The LSP values should be set correctly): + call ale#test#SetFilename('../test-files/odin/main.odin') + + AssertLSPLanguage 'odin' + AssertLSPOptions {} + AssertLSPConfig {} + AssertLSPProject '.' diff --git a/test/test-files/odin/main.odin b/test/test-files/odin/main.odin new file mode 100644 index 0000000000..e69de29bb2