mirror of
https://github.com/dense-analysis/ale
synced 2025-01-24 16:56:02 +00:00
Merge pull request #3424 from maxice8/atools
Add support for Alpine Linux APKBUILD
This commit is contained in:
commit
a6dfc611f6
12
ale_linters/apkbuild/apkbuild_lint.vim
Normal file
12
ale_linters/apkbuild/apkbuild_lint.vim
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
" Author: Leo <thinkabit.ukim@gmail.com>
|
||||||
|
" Description: apkbuild-lint from atools linter for APKBUILDs
|
||||||
|
|
||||||
|
call ale#Set('apkbuild_apkbuild_lint_executable', 'apkbuild-lint')
|
||||||
|
|
||||||
|
call ale#linter#Define('apkbuild', {
|
||||||
|
\ 'name': 'apkbuild_lint',
|
||||||
|
\ 'output_stream': 'stdout',
|
||||||
|
\ 'executable': {b -> ale#Var(b, 'apkbuild_apkbuild_lint_executable')},
|
||||||
|
\ 'command': '%e %t',
|
||||||
|
\ 'callback': 'ale#handlers#atools#Handle',
|
||||||
|
\})
|
12
ale_linters/apkbuild/secfixes_check.vim
Normal file
12
ale_linters/apkbuild/secfixes_check.vim
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
" Author: Leo <thinkabit.ukim@gmail.com>
|
||||||
|
" Description: secfixes-check from atools linter for APKBUILDs
|
||||||
|
|
||||||
|
call ale#Set('apkbuild_secfixes_check_executable', 'secfixes-check')
|
||||||
|
|
||||||
|
call ale#linter#Define('apkbuild', {
|
||||||
|
\ 'name': 'secfixes_check',
|
||||||
|
\ 'output_stream': 'stdout',
|
||||||
|
\ 'executable': {b -> ale#Var(b, 'apkbuild_secfixes_check_executable')},
|
||||||
|
\ 'command': '%e %t',
|
||||||
|
\ 'callback': 'ale#handlers#atools#Handle',
|
||||||
|
\})
|
41
autoload/ale/handlers/atools.vim
Normal file
41
autoload/ale/handlers/atools.vim
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
" Author: Leo <thinkabit.ukim@gmail.com>
|
||||||
|
" Description: Handlers for output expected from atools
|
||||||
|
|
||||||
|
function! ale#handlers#atools#Handle(buffer, lines) abort
|
||||||
|
" Format: SEVERITY:[TAG]:PATH:LINENUM:MSG
|
||||||
|
" Example: MC:[AL5]:./APKBUILD:12:variable set to empty string: install=
|
||||||
|
let l:pattern = '\([^:]\+\):\([^:]\+\):\([^:]\+\):\(\d\+\):\(.\+\)$'
|
||||||
|
let l:output = []
|
||||||
|
|
||||||
|
for l:match in ale#util#GetMatches(a:lines, l:pattern)
|
||||||
|
" We are expected to receive 2 characters, the first character
|
||||||
|
" can be 'S', 'I', 'M' 'T', which are respectively:
|
||||||
|
" Serious (Error)
|
||||||
|
" Important (Error)
|
||||||
|
" Minor (Warning)
|
||||||
|
" Style (Warning)
|
||||||
|
"
|
||||||
|
" The second character can be either 'C' or 'P', which are respectively:
|
||||||
|
" Certain (Error)
|
||||||
|
" Possible (Warning)
|
||||||
|
let l:severity = matchstr(l:match[1], '^.')
|
||||||
|
let l:certainty = matchstr(l:match[1], '.$')
|
||||||
|
|
||||||
|
let l:type = 'E'
|
||||||
|
" If the tag returns 'Minor' or 'Style' or is 'Possible'
|
||||||
|
" then return a warning
|
||||||
|
|
||||||
|
if l:severity is# 'M' || l:severity is# 'T' || l:certainty is# 'P'
|
||||||
|
let l:type = 'W'
|
||||||
|
endif
|
||||||
|
|
||||||
|
call add(l:output, {
|
||||||
|
\ 'lnum': l:match[4] + 0,
|
||||||
|
\ 'text': l:match[5],
|
||||||
|
\ 'type': l:type,
|
||||||
|
\ 'code': matchstr(l:match[2], 'AL[0-9]*'),
|
||||||
|
\})
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return l:output
|
||||||
|
endfunction
|
@ -38,6 +38,7 @@ let s:default_ale_linter_aliases = {
|
|||||||
"
|
"
|
||||||
" NOTE: Update the g:ale_linters documentation when modifying this.
|
" NOTE: Update the g:ale_linters documentation when modifying this.
|
||||||
let s:default_ale_linters = {
|
let s:default_ale_linters = {
|
||||||
|
\ 'apkbuild': ['apkbuild_lint', 'secfixes_check'],
|
||||||
\ 'csh': ['shell'],
|
\ 'csh': ['shell'],
|
||||||
\ 'elixir': ['credo', 'dialyxir', 'dogma'],
|
\ 'elixir': ['credo', 'dialyxir', 'dogma'],
|
||||||
\ 'go': ['gofmt', 'golint', 'go vet'],
|
\ 'go': ['gofmt', 'golint', 'go vet'],
|
||||||
|
30
doc/ale-apkbuild.txt
Normal file
30
doc/ale-apkbuild.txt
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
===============================================================================
|
||||||
|
ALE APKBUILD Integration *ale-apkbuild-options*
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
apkbuild-lint *ale-apkbuild-apkbuild-lint*
|
||||||
|
|
||||||
|
g:ale_apkbuild_apkbuild_lint_executable
|
||||||
|
*g:ale_apkbuild_apkbuild_lint_executable*
|
||||||
|
*b:ale_apkbuild_apkbuild_lint_executable*
|
||||||
|
|
||||||
|
Type: |String|
|
||||||
|
Default: `'apkbuild-lint'`
|
||||||
|
|
||||||
|
This variable can be set to change the path to apkbuild-lint
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
secfixes-check *ale-apkbuild-secfixes-check*
|
||||||
|
|
||||||
|
g:ale_apkbuild_secfixes_check_executable
|
||||||
|
*g:ale_apkbuild_secfixes_check_executable*
|
||||||
|
*b:ale_apkbuild_secfixes_check_executable*
|
||||||
|
|
||||||
|
Type: |String|
|
||||||
|
Default: `'secfixes-check'`
|
||||||
|
|
||||||
|
This variable can be set to change the path to secfixes-check
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
vim:tw=78:ts=2:sts=2:sw=2:ft=help:norl:
|
@ -20,6 +20,9 @@ Notes:
|
|||||||
* `ansible-lint`
|
* `ansible-lint`
|
||||||
* API Blueprint
|
* API Blueprint
|
||||||
* `drafter`
|
* `drafter`
|
||||||
|
* APKBUILD
|
||||||
|
* `apkbuild-lint`
|
||||||
|
* `secfixes-check`
|
||||||
* AsciiDoc
|
* AsciiDoc
|
||||||
* `alex`!!
|
* `alex`!!
|
||||||
* `languagetool`!!
|
* `languagetool`!!
|
||||||
|
@ -1556,6 +1556,7 @@ g:ale_linters *g:ale_linters*
|
|||||||
following values: >
|
following values: >
|
||||||
|
|
||||||
{
|
{
|
||||||
|
\ 'apkbuild': ['apkbuild_lint', 'secfixes_check'],
|
||||||
\ 'csh': ['shell'],
|
\ 'csh': ['shell'],
|
||||||
\ 'elixir': ['credo', 'dialyxir', 'dogma'],
|
\ 'elixir': ['credo', 'dialyxir', 'dogma'],
|
||||||
\ 'go': ['gofmt', 'golint', 'go vet'],
|
\ 'go': ['gofmt', 'golint', 'go vet'],
|
||||||
@ -2599,6 +2600,9 @@ documented in additional help files.
|
|||||||
ada-language-server...................|ale-ada-language-server|
|
ada-language-server...................|ale-ada-language-server|
|
||||||
ansible.................................|ale-ansible-options|
|
ansible.................................|ale-ansible-options|
|
||||||
ansible-lint..........................|ale-ansible-ansible-lint|
|
ansible-lint..........................|ale-ansible-ansible-lint|
|
||||||
|
apkbuild................................|ale-apkbuild-options|
|
||||||
|
apkbuild-lint.........................|ale-apkbuild-apkbuild-lint|
|
||||||
|
secfixes-check........................|ale-apkbuild-secfixes-check|
|
||||||
asciidoc................................|ale-asciidoc-options|
|
asciidoc................................|ale-asciidoc-options|
|
||||||
write-good............................|ale-asciidoc-write-good|
|
write-good............................|ale-asciidoc-write-good|
|
||||||
textlint..............................|ale-asciidoc-textlint|
|
textlint..............................|ale-asciidoc-textlint|
|
||||||
|
@ -29,6 +29,9 @@ formatting.
|
|||||||
* [ansible-lint](https://github.com/willthames/ansible-lint)
|
* [ansible-lint](https://github.com/willthames/ansible-lint)
|
||||||
* API Blueprint
|
* API Blueprint
|
||||||
* [drafter](https://github.com/apiaryio/drafter)
|
* [drafter](https://github.com/apiaryio/drafter)
|
||||||
|
* APKBUILD
|
||||||
|
* [apkbuild-lint](https://gitlab.alpinelinux.org/Leo/atools)
|
||||||
|
* [secfixes-check](https://gitlab.alpinelinux.org/Leo/atools)
|
||||||
* AsciiDoc
|
* AsciiDoc
|
||||||
* [alex](https://github.com/wooorm/alex) :floppy_disk:
|
* [alex](https://github.com/wooorm/alex) :floppy_disk:
|
||||||
* [languagetool](https://languagetool.org/) :floppy_disk:
|
* [languagetool](https://languagetool.org/) :floppy_disk:
|
||||||
|
85
test/handler/test_atools_handler.vader
Normal file
85
test/handler/test_atools_handler.vader
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
Before:
|
||||||
|
runtime autoload/ale/handlers/atools.vim
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#linter#Reset()
|
||||||
|
|
||||||
|
Execute(The atools handler should handle basic errors or warings):
|
||||||
|
AssertEqual
|
||||||
|
\ [
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 2,
|
||||||
|
\ 'text': 'trailing whitespace',
|
||||||
|
\ 'type': 'E',
|
||||||
|
\ 'code': 'AL8',
|
||||||
|
\ },
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 15,
|
||||||
|
\ 'text': '$pkgname should not be used in the source url',
|
||||||
|
\ 'type': 'W',
|
||||||
|
\ 'code': 'AL29',
|
||||||
|
\ },
|
||||||
|
\ ],
|
||||||
|
\ ale#handlers#atools#Handle(bufnr(''), [
|
||||||
|
\ 'IC:[AL8]:APKBUILD:2:trailing whitespace',
|
||||||
|
\ 'MC:[AL29]:APKBUILD:15:$pkgname should not be used in the source url',
|
||||||
|
\ ])
|
||||||
|
|
||||||
|
" Regardless of the severity, if the certainty is [P]ossible and not [C]ertain
|
||||||
|
" or if regardless of the Certainity the Severity is not [I]mportant or [S]erious
|
||||||
|
" then it must be a [W]arning
|
||||||
|
Execute(If we are not Certain or Importantly Serious, be a Warning):
|
||||||
|
AssertEqual
|
||||||
|
\ [
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 3,
|
||||||
|
\ 'text': 'This violation is Serious but Possible false positive, I am a Warning!',
|
||||||
|
\ 'type': 'W',
|
||||||
|
\ 'code': 'AL',
|
||||||
|
\ },
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 4,
|
||||||
|
\ 'text': 'This violation is Important but Possible false positive, I am a Warning!',
|
||||||
|
\ 'type': 'W',
|
||||||
|
\ 'code': 'AL',
|
||||||
|
\ },
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 5,
|
||||||
|
\ 'text': 'This violation is Minor, I am a Warning!',
|
||||||
|
\ 'type': 'W',
|
||||||
|
\ 'code': 'AL',
|
||||||
|
\ },
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 6,
|
||||||
|
\ 'text': 'This violation is Style, I am a Warning!',
|
||||||
|
\ 'type': 'W',
|
||||||
|
\ 'code': 'AL',
|
||||||
|
\ },
|
||||||
|
\ ],
|
||||||
|
\ ale#handlers#atools#Handle(bufnr(''), [
|
||||||
|
\ 'SP:[AL]:APKBUILD:3:This violation is Serious but Possible false positive, I am a Warning!',
|
||||||
|
\ 'IP:[AL]:APKBUILD:4:This violation is Important but Possible false positive, I am a Warning!',
|
||||||
|
\ 'MC:[AL]:APKBUILD:5:This violation is Minor, I am a Warning!',
|
||||||
|
\ 'TC:[AL]:APKBUILD:6:This violation is Style, I am a Warning!',
|
||||||
|
\ ])
|
||||||
|
|
||||||
|
Execute(We should be error if we are Certain it is Serious or Important):
|
||||||
|
AssertEqual
|
||||||
|
\ [
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 7,
|
||||||
|
\ 'text': 'This is Certainly Serious, I am an Error!',
|
||||||
|
\ 'type': 'E',
|
||||||
|
\ 'code': 'AL',
|
||||||
|
\ },
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 8,
|
||||||
|
\ 'text': 'This is Certainly Important, I am an Error!',
|
||||||
|
\ 'type': 'E',
|
||||||
|
\ 'code': 'AL',
|
||||||
|
\ },
|
||||||
|
\ ],
|
||||||
|
\ ale#handlers#atools#Handle(bufnr(''), [
|
||||||
|
\ 'SC:[AL]:APKBUILD:7:This is Certainly Serious, I am an Error!',
|
||||||
|
\ 'IC:[AL]:APKBUILD:8:This is Certainly Important, I am an Error!',
|
||||||
|
\ ])
|
@ -70,3 +70,10 @@ Execute(The defaults for the verilog filetype should be correct):
|
|||||||
Execute(Default aliases for React should be defined):
|
Execute(Default aliases for React should be defined):
|
||||||
AssertEqual ['javascript', 'jsx'], ale#linter#ResolveFiletype('javascriptreact')
|
AssertEqual ['javascript', 'jsx'], ale#linter#ResolveFiletype('javascriptreact')
|
||||||
AssertEqual ['typescript', 'tsx'], ale#linter#ResolveFiletype('typescriptreact')
|
AssertEqual ['typescript', 'tsx'], ale#linter#ResolveFiletype('typescriptreact')
|
||||||
|
|
||||||
|
Execute(The defaults for the apkbuild filetype should be correct):
|
||||||
|
AssertEqual ['apkbuild_lint', 'secfixes_check'], GetLinterNames('apkbuild')
|
||||||
|
|
||||||
|
let g:ale_linters_explicit = 1
|
||||||
|
|
||||||
|
AssertEqual [], GetLinterNames('apkbuild')
|
||||||
|
Loading…
Reference in New Issue
Block a user