mirror of
https://github.com/dense-analysis/ale
synced 2025-01-15 11:31:29 +00:00
Merge pull request #1415 from fohte/fixer-rufo
Add rufo fixer for Ruby files
This commit is contained in:
commit
434f22e44a
@ -143,7 +143,7 @@ formatting.
|
|||||||
| reStructuredText | [alex](https://github.com/wooorm/alex) !!, [proselint](http://proselint.com/), [redpen](http://redpen.cc/), [rstcheck](https://github.com/myint/rstcheck), [vale](https://github.com/ValeLint/vale), [write-good](https://github.com/btford/write-good) |
|
| reStructuredText | [alex](https://github.com/wooorm/alex) !!, [proselint](http://proselint.com/), [redpen](http://redpen.cc/), [rstcheck](https://github.com/myint/rstcheck), [vale](https://github.com/ValeLint/vale), [write-good](https://github.com/btford/write-good) |
|
||||||
| Re:VIEW | [redpen](http://redpen.cc/) |
|
| Re:VIEW | [redpen](http://redpen.cc/) |
|
||||||
| RPM spec | [rpmlint](https://github.com/rpm-software-management/rpmlint) (disabled by default; see `:help ale-integration-spec`) |
|
| RPM spec | [rpmlint](https://github.com/rpm-software-management/rpmlint) (disabled by default; see `:help ale-integration-spec`) |
|
||||||
| Ruby | [brakeman](http://brakemanscanner.org/) !!, [rails_best_practices](https://github.com/flyerhzm/rails_best_practices) !!, [reek](https://github.com/troessner/reek), [rubocop](https://github.com/bbatsov/rubocop), [ruby](https://www.ruby-lang.org) |
|
| Ruby | [brakeman](http://brakemanscanner.org/) !!, [rails_best_practices](https://github.com/flyerhzm/rails_best_practices) !!, [reek](https://github.com/troessner/reek), [rubocop](https://github.com/bbatsov/rubocop), [ruby](https://www.ruby-lang.org), [rufo](https://github.com/ruby-formatter/rufo) |
|
||||||
| Rust | cargo !! (see `:help ale-integration-rust` for configuration instructions), [rls](https://github.com/rust-lang-nursery/rls), [rustc](https://www.rust-lang.org/), [rustfmt](https://github.com/rust-lang-nursery/rustfmt) |
|
| Rust | cargo !! (see `:help ale-integration-rust` for configuration instructions), [rls](https://github.com/rust-lang-nursery/rls), [rustc](https://www.rust-lang.org/), [rustfmt](https://github.com/rust-lang-nursery/rustfmt) |
|
||||||
| SASS | [sass-lint](https://www.npmjs.com/package/sass-lint), [stylelint](https://github.com/stylelint/stylelint) |
|
| SASS | [sass-lint](https://www.npmjs.com/package/sass-lint), [stylelint](https://github.com/stylelint/stylelint) |
|
||||||
| SCSS | [prettier](https://github.com/prettier/prettier), [sass-lint](https://www.npmjs.com/package/sass-lint), [scss-lint](https://github.com/brigade/scss-lint), [stylelint](https://github.com/stylelint/stylelint) |
|
| SCSS | [prettier](https://github.com/prettier/prettier), [sass-lint](https://www.npmjs.com/package/sass-lint), [scss-lint](https://github.com/brigade/scss-lint), [stylelint](https://github.com/stylelint/stylelint) |
|
||||||
|
@ -85,6 +85,11 @@ let s:default_registry = {
|
|||||||
\ 'suggested_filetypes': ['ruby'],
|
\ 'suggested_filetypes': ['ruby'],
|
||||||
\ 'description': 'Fix ruby files with rubocop --auto-correct.',
|
\ 'description': 'Fix ruby files with rubocop --auto-correct.',
|
||||||
\ },
|
\ },
|
||||||
|
\ 'rufo': {
|
||||||
|
\ 'function': 'ale#fixers#rufo#Fix',
|
||||||
|
\ 'suggested_filetypes': ['ruby'],
|
||||||
|
\ 'description': 'Fix ruby files with rufo',
|
||||||
|
\ },
|
||||||
\ 'standard': {
|
\ 'standard': {
|
||||||
\ 'function': 'ale#fixers#standard#Fix',
|
\ 'function': 'ale#fixers#standard#Fix',
|
||||||
\ 'suggested_filetypes': ['javascript'],
|
\ 'suggested_filetypes': ['javascript'],
|
||||||
|
20
autoload/ale/fixers/rufo.vim
Normal file
20
autoload/ale/fixers/rufo.vim
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
" Author: Fohte (Hayato Kawai) https://github.com/fohte
|
||||||
|
" Description: Integration of Rufo with ALE.
|
||||||
|
|
||||||
|
call ale#Set('ruby_rufo_executable', 'rufo')
|
||||||
|
|
||||||
|
function! ale#fixers#rufo#GetCommand(buffer) abort
|
||||||
|
let l:executable = ale#Var(a:buffer, 'ruby_rufo_executable')
|
||||||
|
let l:exec_args = l:executable =~? 'bundle$'
|
||||||
|
\ ? ' exec rufo'
|
||||||
|
\ : ''
|
||||||
|
|
||||||
|
return ale#Escape(l:executable) . l:exec_args . ' %t'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale#fixers#rufo#Fix(buffer) abort
|
||||||
|
return {
|
||||||
|
\ 'command': ale#fixers#rufo#GetCommand(a:buffer),
|
||||||
|
\ 'read_temporary_file': 1,
|
||||||
|
\}
|
||||||
|
endfunction
|
@ -86,5 +86,17 @@ g:ale_ruby_ruby_executable *g:ale_ruby_ruby_executable*
|
|||||||
This variable can be changed to use a different executable for ruby.
|
This variable can be changed to use a different executable for ruby.
|
||||||
|
|
||||||
|
|
||||||
|
===============================================================================
|
||||||
|
rufo *ale-ruby-rufo*
|
||||||
|
|
||||||
|
g:ale_ruby_rufo_executable *g:ale_ruby_rufo_executable*
|
||||||
|
*b:ale_ruby_rufo_executable*
|
||||||
|
Type: String
|
||||||
|
Default: `'rufo'`
|
||||||
|
|
||||||
|
Override the invoked rufo binary. This is useful for running rufo from
|
||||||
|
binstubs or a bundle.
|
||||||
|
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
vim:tw=78:ts=2:sts=2:sw=2:ft=help:norl:
|
vim:tw=78:ts=2:sts=2:sw=2:ft=help:norl:
|
||||||
|
@ -198,6 +198,7 @@ CONTENTS *ale-contents*
|
|||||||
reek................................|ale-ruby-reek|
|
reek................................|ale-ruby-reek|
|
||||||
rubocop.............................|ale-ruby-rubocop|
|
rubocop.............................|ale-ruby-rubocop|
|
||||||
ruby................................|ale-ruby-ruby|
|
ruby................................|ale-ruby-ruby|
|
||||||
|
rufo................................|ale-ruby-rufo|
|
||||||
rust..................................|ale-rust-options|
|
rust..................................|ale-rust-options|
|
||||||
cargo...............................|ale-rust-cargo|
|
cargo...............................|ale-rust-cargo|
|
||||||
rls.................................|ale-rust-rls|
|
rls.................................|ale-rust-rls|
|
||||||
@ -367,7 +368,7 @@ Notes:
|
|||||||
* reStructuredText: `alex`!!, `proselint`, `redpen`, `rstcheck`, `vale`, `write-good`
|
* reStructuredText: `alex`!!, `proselint`, `redpen`, `rstcheck`, `vale`, `write-good`
|
||||||
* Re:VIEW: `redpen`
|
* Re:VIEW: `redpen`
|
||||||
* RPM spec: `rpmlint`
|
* RPM spec: `rpmlint`
|
||||||
* Ruby: `brakeman`, `rails_best_practices`!!, `reek`, `rubocop`, `ruby`
|
* Ruby: `brakeman`, `rails_best_practices`!!, `reek`, `rubocop`, `ruby`, `rufo`
|
||||||
* Rust: `cargo`!!, `rls`, `rustc` (see |ale-integration-rust|), `rustfmt`
|
* Rust: `cargo`!!, `rls`, `rustc` (see |ale-integration-rust|), `rustfmt`
|
||||||
* SASS: `sass-lint`, `stylelint`
|
* SASS: `sass-lint`, `stylelint`
|
||||||
* SCSS: `prettier`, `sass-lint`, `scss-lint`, `stylelint`
|
* SCSS: `prettier`, `sass-lint`, `scss-lint`, `stylelint`
|
||||||
|
33
test/fixers/test_rufo_fixer_callback.vader
Normal file
33
test/fixers/test_rufo_fixer_callback.vader
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
Before:
|
||||||
|
Save g:ale_ruby_rufo_executable
|
||||||
|
|
||||||
|
" Use an invalid global executable, so we don't match it.
|
||||||
|
let g:ale_ruby_rufo_executable = 'xxxinvalid'
|
||||||
|
|
||||||
|
call ale#test#SetDirectory('/testplugin/test/fixers')
|
||||||
|
silent cd ..
|
||||||
|
silent cd command_callback
|
||||||
|
let g:dir = getcwd()
|
||||||
|
|
||||||
|
After:
|
||||||
|
Restore
|
||||||
|
|
||||||
|
call ale#test#RestoreDirectory()
|
||||||
|
|
||||||
|
Execute(The rufo command should contain `bundle exec` when executable is `bundle`):
|
||||||
|
let g:ale_ruby_rufo_executable = 'bundle'
|
||||||
|
call ale#test#SetFilename('ruby_paths/dummy.rb')
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ ale#Escape('bundle') . ' exec rufo %t',
|
||||||
|
\ ale#fixers#rufo#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
Execute(The rufo callback should return the correct default values):
|
||||||
|
call ale#test#SetFilename('ruby_paths/dummy.rb')
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ {
|
||||||
|
\ 'read_temporary_file': 1,
|
||||||
|
\ 'command': ale#Escape('xxxinvalid') . ' %t'
|
||||||
|
\ },
|
||||||
|
\ ale#fixers#rufo#Fix(bufnr(''))
|
Loading…
Reference in New Issue
Block a user