aboutsummaryrefslogtreecommitdiff
path: root/dotfiles/.vim/autoload/neomake/makers/ft/swift.vim
diff options
context:
space:
mode:
Diffstat (limited to 'dotfiles/.vim/autoload/neomake/makers/ft/swift.vim')
-rw-r--r--dotfiles/.vim/autoload/neomake/makers/ft/swift.vim54
1 files changed, 54 insertions, 0 deletions
diff --git a/dotfiles/.vim/autoload/neomake/makers/ft/swift.vim b/dotfiles/.vim/autoload/neomake/makers/ft/swift.vim
new file mode 100644
index 0000000..76bb440
--- /dev/null
+++ b/dotfiles/.vim/autoload/neomake/makers/ft/swift.vim
@@ -0,0 +1,54 @@
+" vim: ts=4 sw=4 et
+
+function! neomake#makers#ft#swift#EnabledMakers() abort
+ if !empty(s:get_swiftpm_config())
+ return ['swiftpm']
+ endif
+ return ['swiftc']
+endfunction
+
+function! s:get_swiftpm_config() abort
+ return neomake#utils#FindGlobFile('Package.swift')
+endfunction
+
+function! s:get_swiftpm_base_maker() abort
+ let maker = {
+ \ 'exe': 'swift',
+ \ 'append_file': 0,
+ \ 'errorformat':
+ \ '%E%f:%l:%c: error: %m,' .
+ \ '%E%f:%l: error: %m,' .
+ \ '%W%f:%l:%c: warning: %m,' .
+ \ '%Z%\s%#^~%#,' .
+ \ '%-G%.%#',
+ \ }
+ let config = s:get_swiftpm_config()
+ if !empty(config)
+ let maker.cwd = fnamemodify(config, ':h')
+ endif
+ return maker
+endfunction
+
+function! neomake#makers#ft#swift#swiftpm() abort
+ let maker = s:get_swiftpm_base_maker()
+ let maker.args = ['build', '--build-tests']
+ return maker
+endfunction
+
+function! neomake#makers#ft#swift#swiftpmtest() abort
+ let maker = s:get_swiftpm_base_maker()
+ let maker.args = ['test']
+ return maker
+endfunction
+
+function! neomake#makers#ft#swift#swiftc() abort
+ " `export SDKROOT="$(xcodebuild -version -sdk macosx Path)"`
+ return {
+ \ 'args': ['-parse'],
+ \ 'errorformat':
+ \ '%E%f:%l:%c: error: %m,' .
+ \ '%W%f:%l:%c: warning: %m,' .
+ \ '%Z%\s%#^~%#,' .
+ \ '%-G%.%#',
+ \ }
+endfunction