]> git.phdru.name Git - dotfiles.git/commitdiff
.vimrc: Check chmod just once
authorOleg Broytman <phd@phdru.name>
Mon, 26 Mar 2018 03:59:48 +0000 (06:59 +0300)
committerOleg Broytman <phd@phdru.name>
Mon, 26 Mar 2018 03:59:48 +0000 (06:59 +0300)
.vimrc

diff --git a/.vimrc b/.vimrc
index f59293420e8c60039afd64bc21176a647a3920aa..bb97edbbe8e9e16a6bea41408283798516eede09 100644 (file)
--- a/.vimrc
+++ b/.vimrc
@@ -586,26 +586,25 @@ endif
 " From Tip 212:
 " http://vim.wikia.com/wiki/Setting_file_attributes_without_reloading_a_buffer
 
-function! SetExecutableBit(x)
-   if !executable('chmod')
-      return
-   endif
-   checktime
-   let fname = expand("%:p")
-   let fx = executable(fname)
-   execute "au FileChangedShell " . fname . " :echo"
-   if a:x && !fx
-      !chmod a+x %
-   elseif !a:x && fx
-      !chmod a-x %
-   endif
-   if v:shell_error
-      echoerr 'Error running chmod: ' . v:shell_error
-   endif
-   checktime
-   execute "au! FileChangedShell " . fname
-endfunction
-command! Xbit if executable(expand("%:p")) | call SetExecutableBit(0) | else | call SetExecutableBit(1) | endif
+if executable('chmod')
+   function! SetExecutableBit(x)
+      checktime
+      let fname = expand("%:p")
+      let fx = executable(fname)
+      execute "au FileChangedShell " . fname . " :echo"
+      if a:x && !fx
+         !chmod a+x %
+      elseif !a:x && fx
+         !chmod a-x %
+      endif
+      if v:shell_error
+         echoerr 'Error running chmod: ' . v:shell_error
+      endif
+      checktime
+      execute "au! FileChangedShell " . fname
+   endfunction
+   command! Xbit if executable(expand("%:p")) | call SetExecutableBit(0) | else | call SetExecutableBit(1) | endif
+endif
 
 
 " ----------