Merge pull request #842 from gfontenot/gf-swiftformat
Add support for SwiftFormat as a fixer
This commit is contained in:
commit
dcf7cbe366
@ -117,7 +117,7 @@ name. That seems to be the fairest way to arrange this table.
|
|||||||
| SML | [smlnj](http://www.smlnj.org/) |
|
| SML | [smlnj](http://www.smlnj.org/) |
|
||||||
| Stylus | [stylelint](https://github.com/stylelint/stylelint) |
|
| Stylus | [stylelint](https://github.com/stylelint/stylelint) |
|
||||||
| SQL | [sqlint](https://github.com/purcell/sqlint) |
|
| SQL | [sqlint](https://github.com/purcell/sqlint) |
|
||||||
| Swift | [swiftlint](https://swift.org/) |
|
| Swift | [swiftlint](https://github.com/realm/SwiftLint), [swiftformat](https://github.com/nicklockwood/SwiftFormat) |
|
||||||
| Tcl | [nagelfar](http://nagelfar.sourceforge.net)|
|
| Tcl | [nagelfar](http://nagelfar.sourceforge.net)|
|
||||||
| Texinfo | [proselint](http://proselint.com/)|
|
| Texinfo | [proselint](http://proselint.com/)|
|
||||||
| Text^ | [proselint](http://proselint.com/), [vale](https://github.com/ValeLint/vale) |
|
| Text^ | [proselint](http://proselint.com/), [vale](https://github.com/ValeLint/vale) |
|
||||||
|
@ -72,6 +72,11 @@ let s:default_registry = {
|
|||||||
\ 'suggested_filetypes': ['css', 'sass', 'scss', 'stylus'],
|
\ 'suggested_filetypes': ['css', 'sass', 'scss', 'stylus'],
|
||||||
\ 'description': 'Fix stylesheet files using stylelint --fix.',
|
\ 'description': 'Fix stylesheet files using stylelint --fix.',
|
||||||
\ },
|
\ },
|
||||||
|
\ 'swiftformat': {
|
||||||
|
\ 'function': 'ale#fixers#swiftformat#Fix',
|
||||||
|
\ 'suggested_filetypes': ['swift'],
|
||||||
|
\ 'description': 'Apply SwiftFormat to a file.',
|
||||||
|
\ },
|
||||||
\}
|
\}
|
||||||
|
|
||||||
" Reset the function registry to the default entries.
|
" Reset the function registry to the default entries.
|
||||||
|
25
autoload/ale/fixers/swiftformat.vim
Normal file
25
autoload/ale/fixers/swiftformat.vim
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
" Author: gfontenot (Gordon Fontenot) <gordon@fonten.io>
|
||||||
|
" Description: Integration of SwiftFormat with ALE.
|
||||||
|
|
||||||
|
call ale#Set('swift_swiftformat_executable', 'swiftformat')
|
||||||
|
call ale#Set('swift_swiftformat_use_global', 0)
|
||||||
|
call ale#Set('swift_swiftformat_options', '')
|
||||||
|
|
||||||
|
function! ale#fixers#swiftformat#GetExecutable(buffer) abort
|
||||||
|
return ale#node#FindExecutable(a:buffer, 'swift_swiftformat', [
|
||||||
|
\ 'Pods/SwiftFormat/CommandLineTool/swiftformat',
|
||||||
|
\ 'ios/Pods/SwiftFormat/CommandLineTool/swiftformat',
|
||||||
|
\ 'swiftformat',
|
||||||
|
\])
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale#fixers#swiftformat#Fix(buffer) abort
|
||||||
|
let l:options = ale#Var(a:buffer, 'swift_swiftformat_options')
|
||||||
|
|
||||||
|
return {
|
||||||
|
\ 'read_temporary_file': 1,
|
||||||
|
\ 'command': ale#Escape(ale#fixers#swiftformat#GetExecutable(a:buffer))
|
||||||
|
\ . ' %t'
|
||||||
|
\ . ' ' . l:options,
|
||||||
|
\}
|
||||||
|
endfunction
|
@ -224,7 +224,7 @@ The following languages and tools are supported.
|
|||||||
* SML: 'smlnj'
|
* SML: 'smlnj'
|
||||||
* Stylus: 'stylelint'
|
* Stylus: 'stylelint'
|
||||||
* SQL: 'sqlint'
|
* SQL: 'sqlint'
|
||||||
* Swift: 'swiftlint'
|
* Swift: 'swiftlint', 'swiftformat'
|
||||||
* Texinfo: 'proselint'
|
* Texinfo: 'proselint'
|
||||||
* Text: 'proselint', 'vale'
|
* Text: 'proselint', 'vale'
|
||||||
* TypeScript: 'eslint', 'tslint', 'tsserver', 'typecheck'
|
* TypeScript: 'eslint', 'tslint', 'tsserver', 'typecheck'
|
||||||
|
0
test/command_callback/swift_paths/dummy.swift
Normal file
0
test/command_callback/swift_paths/dummy.swift
Normal file
38
test/fixers/test_swiftformat_fixer_callback.vader
Normal file
38
test/fixers/test_swiftformat_fixer_callback.vader
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
Before:
|
||||||
|
Save g:ale_swift_swiftformat_executable
|
||||||
|
|
||||||
|
" Use an invalid global executable, so we don't match it.
|
||||||
|
let g:ale_swift_swiftformat_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 swiftformat callback should return the correct default values):
|
||||||
|
call ale#test#SetFilename('swift_paths/dummy.swift')
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ {
|
||||||
|
\ 'read_temporary_file': 1,
|
||||||
|
\ 'command': ale#Escape(g:ale_swift_swiftformat_executable)
|
||||||
|
\ . ' %t ',
|
||||||
|
\ },
|
||||||
|
\ ale#fixers#swiftformat#Fix(bufnr(''))
|
||||||
|
|
||||||
|
Execute(The swiftformat callback should include any additional options):
|
||||||
|
call ale#test#SetFilename('swift_paths/dummy.swift')
|
||||||
|
let g:ale_swift_swiftformat_options = '--some-option'
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ {
|
||||||
|
\ 'read_temporary_file': 1,
|
||||||
|
\ 'command': ale#Escape(g:ale_swift_swiftformat_executable)
|
||||||
|
\ . ' %t --some-option',
|
||||||
|
\ },
|
||||||
|
\ ale#fixers#swiftformat#Fix(bufnr(''))
|
Loading…
Reference in New Issue
Block a user