Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Browse files

Merge branch 'master' of https://github.com/xolox/vim-misc

  • Loading branch information...
commit 1529fff1a5e9d83bc4a6a24de6bdcf86dca546c9 2 parents 2bb7009 + d7b3e0c
@xolox authored
Showing with 24 additions and 4 deletions.
  1. +21 −1 autoload/xolox/misc/escape.vim
  2. +3 −3 autoload/xolox/misc/open.vim
View
22 autoload/xolox/misc/escape.vim
@@ -1,6 +1,6 @@
" Vim auto-load script
" Author: Peter Odding <peter@peterodding.com>
-" Last Change: March 15, 2011
+" Last Change: November 21, 2011
" URL: http://peterodding.com/code/vim/misc/
" Convert a string into a :substitute pattern that matches the string literally.
@@ -23,4 +23,24 @@ function! xolox#misc#escape#substitute(string)
return ''
endfunction
+" Convert a string into a quoted command line argument. I was going to add a
+" long rant here about &shellslash, but really, it won't make any difference.
+" Let's just suffice to say that I have yet to encounter a single person out
+" there who uses this option for its intended purpose (running a UNIX-style
+" shell on Windows).
+
+function! xolox#misc#escape#shell(string)
+ if xolox#misc#os#is_win()
+ try
+ let ssl_save = &shellslash
+ set noshellslash
+ return shellescape(a:string)
+ finally
+ let &shellslash = ssl_save
+ endtry
+ else
+ return shellescape(a:string)
+ endif
+endfunction
+
" vim: ts=2 sw=2 et
View
6 autoload/xolox/misc/open.vim
@@ -1,10 +1,10 @@
" Vim auto-load script
" Author: Peter Odding <peter@peterodding.com>
-" Last Change: June 18, 2011
+" Last Change: November 21, 2011
" URL: http://peterodding.com/code/vim/misc/
if !exists('s:version')
- let s:version = '1.0'
+ let s:version = '1.1'
let s:enoimpl = "open.vim %s: %s() hasn't been implemented for your platform! If you have suggestions, please contact peter@peterodding.com."
let s:handlers = ['gnome-open', 'kde-open', 'exo-open', 'xdg-open']
endif
@@ -15,7 +15,7 @@ function! xolox#misc#open#file(path, ...)
call xolox#shell#open_with_windows_shell(a:path)
catch /^Vim\%((\a\+)\)\=:E117/
let command = '!start CMD /C START "" %s'
- silent execute printf(command, shellescape(a:path))
+ silent execute printf(command, xolox#misc#escape#shell(a:path))
endtry
return
elseif has('macunix')
Please sign in to comment.
Something went wrong with that request. Please try again.