summaryrefslogtreecommitdiff
path: root/ale_linters/ruby
diff options
context:
space:
mode:
authorymap <ymap.dev@gmail.com>2023-09-13 23:53:24 +0900
committerGitHub <noreply@github.com>2023-09-13 15:53:24 +0100
commit9092af9ad6a5c93a759be571323ea1d0cafa8d6e (patch)
tree6c58290794d91819fb2d80d2da8752997627537b /ale_linters/ruby
parentac615e7f656fb379cfe7cd205842b0f089a060d6 (diff)
downloadale-9092af9ad6a5c93a759be571323ea1d0cafa8d6e.zip
Add support for Packwerk (#4594)
Packwerk (https://github.com/Shopify/packwerk) is a Ruby gem used to enforce boundaries and modularize Rails applications.
Diffstat (limited to 'ale_linters/ruby')
-rw-r--r--ale_linters/ruby/packwerk.vim55
1 files changed, 55 insertions, 0 deletions
diff --git a/ale_linters/ruby/packwerk.vim b/ale_linters/ruby/packwerk.vim
new file mode 100644
index 00000000..4014b2da
--- /dev/null
+++ b/ale_linters/ruby/packwerk.vim
@@ -0,0 +1,55 @@
+" Author: ymap - https://github.com/ymap
+" Description: Packwerk, a static analyzer used to enforce boundaries and modularize Rails applications.
+
+call ale#Set('ruby_packwerk_executable', 'packwerk')
+call ale#Set('ruby_packwerk_options', '')
+
+function! ale_linters#ruby#packwerk#Handle(buffer, lines) abort
+ let l:pattern = '\v^[^:]+:(\d+):(\d+)$'
+ let l:index = 0
+ let l:output = []
+
+ while l:index < len(a:lines) - 1
+ let l:cleaned_line = substitute(a:lines[l:index], '\v\e\[[0-9;]*m', '', 'g')
+ let l:match = matchlist(l:cleaned_line, l:pattern)
+
+ if len(l:match) > 0
+ call add(l:output, {
+ \ 'lnum': l:match[1] + 0,
+ \ 'col': l:match[2] + 0,
+ \ 'text': a:lines[l:index + 1],
+ \})
+ endif
+
+ let l:index += 1
+ endwhile
+
+ return l:output
+endfunction
+
+function! ale_linters#ruby#packwerk#GetCommand(buffer) abort
+ let l:rails_root = ale#ruby#FindRailsRoot(a:buffer)
+
+ if l:rails_root is? ''
+ return ''
+ endif
+
+ let l:executable = ale#Var(a:buffer, 'ruby_packwerk_executable')
+ let l:sep = has('win32') ? '\' : '/'
+ let l:abs_path = expand('#' . a:buffer . ':p')
+ let l:rel_path = substitute(l:abs_path, escape(l:rails_root . l:sep, '\'), '', '')
+
+ return ale#ruby#EscapeExecutable(l:executable, 'packwerk')
+ \ . ' check'
+ \ . ale#Pad(ale#Var(a:buffer, 'ruby_packwerk_options'))
+ \ . ' '
+ \ . ale#Escape(rel_path)
+endfunction
+
+call ale#linter#Define('ruby', {
+\ 'name': 'packwerk',
+\ 'executable': {b -> ale#Var(b, 'ruby_packwerk_executable')},
+\ 'command': function('ale_linters#ruby#packwerk#GetCommand'),
+\ 'callback': 'ale_linters#ruby#packwerk#Handle',
+\ 'lint_file': 1,
+\})