780 lines
24 KiB
VimL
780 lines
24 KiB
VimL
|
if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'vim') == -1
|
||
|
|
||
|
" vimball.vim : construct a file containing both paths and files
|
||
|
" Author: Charles E. Campbell
|
||
|
" Date: Apr 11, 2016
|
||
|
" Version: 37
|
||
|
" GetLatestVimScripts: 1502 1 :AutoInstall: vimball.vim
|
||
|
" Copyright: (c) 2004-2011 by Charles E. Campbell
|
||
|
" The VIM LICENSE applies to Vimball.vim, and Vimball.txt
|
||
|
" (see |copyright|) except use "Vimball" instead of "Vim".
|
||
|
" No warranty, express or implied.
|
||
|
" *** *** Use At-Your-Own-Risk! *** ***
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" Load Once: {{{1
|
||
|
if &cp || exists("g:loaded_vimball")
|
||
|
finish
|
||
|
endif
|
||
|
let g:loaded_vimball = "v37"
|
||
|
if v:version < 702
|
||
|
echohl WarningMsg
|
||
|
echo "***warning*** this version of vimball needs vim 7.2"
|
||
|
echohl Normal
|
||
|
finish
|
||
|
endif
|
||
|
let s:keepcpo= &cpo
|
||
|
set cpo&vim
|
||
|
"DechoTabOn
|
||
|
|
||
|
" =====================================================================
|
||
|
" Constants: {{{1
|
||
|
if !exists("s:USAGE")
|
||
|
let s:USAGE = 0
|
||
|
let s:WARNING = 1
|
||
|
let s:ERROR = 2
|
||
|
|
||
|
" determine if cygwin is in use or not
|
||
|
if !exists("g:netrw_cygwin")
|
||
|
if has("win32") || has("win95") || has("win64") || has("win16")
|
||
|
if &shell =~ '\%(\<bash\>\|\<zsh\>\)\%(\.exe\)\=$'
|
||
|
let g:netrw_cygwin= 1
|
||
|
else
|
||
|
let g:netrw_cygwin= 0
|
||
|
endif
|
||
|
else
|
||
|
let g:netrw_cygwin= 0
|
||
|
endif
|
||
|
endif
|
||
|
|
||
|
" set up g:vimball_mkdir if the mkdir() call isn't defined
|
||
|
if !exists("*mkdir")
|
||
|
if exists("g:netrw_local_mkdir")
|
||
|
let g:vimball_mkdir= g:netrw_local_mkdir
|
||
|
elseif executable("mkdir")
|
||
|
let g:vimball_mkdir= "mkdir"
|
||
|
elseif executable("makedir")
|
||
|
let g:vimball_mkdir= "makedir"
|
||
|
endif
|
||
|
if !exists(g:vimball_mkdir)
|
||
|
call vimball#ShowMesg(s:WARNING,"(vimball) g:vimball_mkdir undefined")
|
||
|
endif
|
||
|
endif
|
||
|
endif
|
||
|
|
||
|
" =====================================================================
|
||
|
" Functions: {{{1
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#MkVimball: creates a vimball given a list of paths to files {{{2
|
||
|
" Input:
|
||
|
" line1,line2: a range of lines containing paths to files to be included in the vimball
|
||
|
" writelevel : if true, force a write to filename.vmb, even if it exists
|
||
|
" (usually accomplished with :MkVimball! ...
|
||
|
" filename : base name of file to be created (ie. filename.vmb)
|
||
|
" Output: a filename.vmb using vimball format:
|
||
|
" path
|
||
|
" filesize
|
||
|
" [file]
|
||
|
" path
|
||
|
" filesize
|
||
|
" [file]
|
||
|
fun! vimball#MkVimball(line1,line2,writelevel,...) range
|
||
|
" call Dfunc("MkVimball(line1=".a:line1." line2=".a:line2." writelevel=".a:writelevel." vimballname<".a:1.">) a:0=".a:0)
|
||
|
if a:1 =~ '\.vim$' || a:1 =~ '\.txt$'
|
||
|
let vbname= substitute(a:1,'\.\a\{3}$','.vmb','')
|
||
|
else
|
||
|
let vbname= a:1
|
||
|
endif
|
||
|
if vbname !~ '\.vmb$'
|
||
|
let vbname= vbname.'.vmb'
|
||
|
endif
|
||
|
" call Decho("vbname<".vbname.">")
|
||
|
if !a:writelevel && a:1 =~ '[\/]'
|
||
|
call vimball#ShowMesg(s:ERROR,"(MkVimball) vimball name<".a:1."> should not include slashes; use ! to insist")
|
||
|
" call Dret("MkVimball : vimball name<".a:1."> should not include slashes")
|
||
|
return
|
||
|
endif
|
||
|
if !a:writelevel && filereadable(vbname)
|
||
|
call vimball#ShowMesg(s:ERROR,"(MkVimball) file<".vbname."> exists; use ! to insist")
|
||
|
" call Dret("MkVimball : file<".vbname."> already exists; use ! to insist")
|
||
|
return
|
||
|
endif
|
||
|
|
||
|
" user option bypass
|
||
|
call vimball#SaveSettings()
|
||
|
|
||
|
if a:0 >= 2
|
||
|
" allow user to specify where to get the files
|
||
|
let home= expand(a:2)
|
||
|
else
|
||
|
" use first existing directory from rtp
|
||
|
let home= vimball#VimballHome()
|
||
|
endif
|
||
|
|
||
|
" save current directory
|
||
|
let curdir = getcwd()
|
||
|
call s:ChgDir(home)
|
||
|
|
||
|
" record current tab, initialize while loop index
|
||
|
let curtabnr = tabpagenr()
|
||
|
let linenr = a:line1
|
||
|
" call Decho("curtabnr=".curtabnr)
|
||
|
|
||
|
while linenr <= a:line2
|
||
|
let svfile = getline(linenr)
|
||
|
" call Decho("svfile<".svfile.">")
|
||
|
|
||
|
if !filereadable(svfile)
|
||
|
call vimball#ShowMesg(s:ERROR,"unable to read file<".svfile.">")
|
||
|
call s:ChgDir(curdir)
|
||
|
call vimball#RestoreSettings()
|
||
|
" call Dret("MkVimball")
|
||
|
return
|
||
|
endif
|
||
|
|
||
|
" create/switch to mkvimball tab
|
||
|
if !exists("vbtabnr")
|
||
|
tabnew
|
||
|
sil! file Vimball
|
||
|
let vbtabnr= tabpagenr()
|
||
|
else
|
||
|
exe "tabn ".vbtabnr
|
||
|
endif
|
||
|
|
||
|
let lastline= line("$") + 1
|
||
|
if lastline == 2 && getline("$") == ""
|
||
|
call setline(1,'" Vimball Archiver by Charles E. Campbell')
|
||
|
call setline(2,'UseVimball')
|
||
|
call setline(3,'finish')
|
||
|
let lastline= line("$") + 1
|
||
|
endif
|
||
|
call setline(lastline ,substitute(svfile,'$',' [[[1',''))
|
||
|
call setline(lastline+1,0)
|
||
|
|
||
|
" write the file from the tab
|
||
|
" call Decho("exe $r ".fnameescape(svfile))
|
||
|
exe "$r ".fnameescape(svfile)
|
||
|
|
||
|
call setline(lastline+1,line("$") - lastline - 1)
|
||
|
" call Decho("lastline=".lastline." line$=".line("$"))
|
||
|
|
||
|
" restore to normal tab
|
||
|
exe "tabn ".curtabnr
|
||
|
let linenr= linenr + 1
|
||
|
endwhile
|
||
|
|
||
|
" write the vimball
|
||
|
exe "tabn ".vbtabnr
|
||
|
call s:ChgDir(curdir)
|
||
|
setlocal ff=unix
|
||
|
if a:writelevel
|
||
|
" call Decho("exe w! ".fnameescape(vbname))
|
||
|
exe "w! ".fnameescape(vbname)
|
||
|
else
|
||
|
" call Decho("exe w ".fnameescape(vbname))
|
||
|
exe "w ".fnameescape(vbname)
|
||
|
endif
|
||
|
" call Decho("Vimball<".vbname."> created")
|
||
|
echo "Vimball<".vbname."> created"
|
||
|
|
||
|
" remove the evidence
|
||
|
setlocal nomod bh=wipe
|
||
|
exe "tabn ".curtabnr
|
||
|
exe "tabc! ".vbtabnr
|
||
|
|
||
|
" restore options
|
||
|
call vimball#RestoreSettings()
|
||
|
|
||
|
" call Dret("MkVimball")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#Vimball: extract and distribute contents from a vimball {{{2
|
||
|
" (invoked the the UseVimball command embedded in
|
||
|
" vimballs' prologue)
|
||
|
fun! vimball#Vimball(really,...)
|
||
|
" call Dfunc("vimball#Vimball(really=".a:really.") a:0=".a:0)
|
||
|
|
||
|
if v:version < 701 || (v:version == 701 && !exists('*fnameescape'))
|
||
|
echoerr "your vim is missing the fnameescape() function (pls upgrade to vim 7.2 or later)"
|
||
|
" call Dret("vimball#Vimball : needs 7.1 with patch 299 or later")
|
||
|
return
|
||
|
endif
|
||
|
|
||
|
if getline(1) !~ '^" Vimball Archiver'
|
||
|
echoerr "(Vimball) The current file does not appear to be a Vimball!"
|
||
|
" call Dret("vimball#Vimball")
|
||
|
return
|
||
|
endif
|
||
|
|
||
|
" set up standard settings
|
||
|
call vimball#SaveSettings()
|
||
|
let curtabnr = tabpagenr()
|
||
|
let vimballfile = expand("%:tr")
|
||
|
|
||
|
" set up vimball tab
|
||
|
" call Decho("setting up vimball tab")
|
||
|
tabnew
|
||
|
sil! file Vimball
|
||
|
let vbtabnr= tabpagenr()
|
||
|
let didhelp= ""
|
||
|
|
||
|
" go to vim plugin home
|
||
|
if a:0 > 0
|
||
|
" let user specify the directory where the vimball is to be unpacked.
|
||
|
" If, however, the user did not specify a full path, set the home to be below the current directory
|
||
|
let home= expand(a:1)
|
||
|
if has("win32") || has("win95") || has("win64") || has("win16")
|
||
|
if home !~ '^\a:[/\\]'
|
||
|
let home= getcwd().'/'.a:1
|
||
|
endif
|
||
|
elseif home !~ '^/'
|
||
|
let home= getcwd().'/'.a:1
|
||
|
endif
|
||
|
else
|
||
|
let home= vimball#VimballHome()
|
||
|
endif
|
||
|
" call Decho("home<".home.">")
|
||
|
|
||
|
" save current directory and remove older same-named vimball, if any
|
||
|
let curdir = getcwd()
|
||
|
" call Decho("home<".home.">")
|
||
|
" call Decho("curdir<".curdir.">")
|
||
|
|
||
|
call s:ChgDir(home)
|
||
|
let s:ok_unablefind= 1
|
||
|
call vimball#RmVimball(vimballfile)
|
||
|
unlet s:ok_unablefind
|
||
|
|
||
|
let linenr = 4
|
||
|
let filecnt = 0
|
||
|
|
||
|
" give title to listing of (extracted) files from Vimball Archive
|
||
|
if a:really
|
||
|
echohl Title | echomsg "Vimball Archive" | echohl None
|
||
|
else
|
||
|
echohl Title | echomsg "Vimball Archive Listing" | echohl None
|
||
|
echohl Statement | echomsg "files would be placed under: ".home | echohl None
|
||
|
endif
|
||
|
|
||
|
" apportion vimball contents to various files
|
||
|
" call Decho("exe tabn ".curtabnr)
|
||
|
exe "tabn ".curtabnr
|
||
|
" call Decho("linenr=".linenr." line$=".line("$"))
|
||
|
while 1 < linenr && linenr < line("$")
|
||
|
let fname = substitute(getline(linenr),'\t\[\[\[1$','','')
|
||
|
let fname = substitute(fname,'\\','/','g')
|
||
|
let fsize = substitute(getline(linenr+1),'^\(\d\+\).\{-}$','\1','')+0
|
||
|
let fenc = substitute(getline(linenr+1),'^\d\+\s*\(\S\{-}\)$','\1','')
|
||
|
let filecnt = filecnt + 1
|
||
|
" call Decho("fname<".fname."> fsize=".fsize." filecnt=".filecnt. " fenc=".fenc)
|
||
|
|
||
|
if a:really
|
||
|
echomsg "extracted <".fname.">: ".fsize." lines"
|
||
|
else
|
||
|
echomsg "would extract <".fname.">: ".fsize." lines"
|
||
|
endif
|
||
|
" call Decho("using L#".linenr.": will extract file<".fname.">")
|
||
|
" call Decho("using L#".(linenr+1).": fsize=".fsize)
|
||
|
|
||
|
" Allow AsNeeded/ directory to take place of plugin/ directory
|
||
|
" when AsNeeded/filename is filereadable or was present in VimballRecord
|
||
|
if fname =~ '\<plugin/'
|
||
|
let anfname= substitute(fname,'\<plugin/','AsNeeded/','')
|
||
|
if filereadable(anfname) || (exists("s:VBRstring") && s:VBRstring =~# anfname)
|
||
|
" call Decho("using anfname<".anfname."> instead of <".fname.">")
|
||
|
let fname= anfname
|
||
|
endif
|
||
|
endif
|
||
|
|
||
|
" make directories if they don't exist yet
|
||
|
if a:really
|
||
|
" call Decho("making directories if they don't exist yet (fname<".fname.">)")
|
||
|
let fnamebuf= substitute(fname,'\\','/','g')
|
||
|
let dirpath = substitute(home,'\\','/','g')
|
||
|
" call Decho("init: fnamebuf<".fnamebuf.">")
|
||
|
" call Decho("init: dirpath <".dirpath.">")
|
||
|
while fnamebuf =~ '/'
|
||
|
let dirname = dirpath."/".substitute(fnamebuf,'/.*$','','')
|
||
|
let dirpath = dirname
|
||
|
let fnamebuf = substitute(fnamebuf,'^.\{-}/\(.*\)$','\1','')
|
||
|
" call Decho("dirname<".dirname.">")
|
||
|
" call Decho("dirpath<".dirpath.">")
|
||
|
if !isdirectory(dirname)
|
||
|
" call Decho("making <".dirname.">")
|
||
|
if exists("g:vimball_mkdir")
|
||
|
call system(g:vimball_mkdir." ".shellescape(dirname))
|
||
|
else
|
||
|
call mkdir(dirname)
|
||
|
endif
|
||
|
call s:RecordInVar(home,"rmdir('".dirname."')")
|
||
|
endif
|
||
|
endwhile
|
||
|
endif
|
||
|
call s:ChgDir(home)
|
||
|
|
||
|
" grab specified qty of lines and place into "a" buffer
|
||
|
" (skip over path/filename and qty-lines)
|
||
|
let linenr = linenr + 2
|
||
|
let lastline = linenr + fsize - 1
|
||
|
" call Decho("exe ".linenr.",".lastline."yank a")
|
||
|
" no point in handling a zero-length file
|
||
|
if lastline >= linenr
|
||
|
exe "silent ".linenr.",".lastline."yank a"
|
||
|
|
||
|
" copy "a" buffer into tab
|
||
|
" call Decho('copy "a buffer into tab#'.vbtabnr)
|
||
|
exe "tabn ".vbtabnr
|
||
|
setlocal ma
|
||
|
sil! %d
|
||
|
silent put a
|
||
|
1
|
||
|
sil! d
|
||
|
|
||
|
" write tab to file
|
||
|
if a:really
|
||
|
let fnamepath= home."/".fname
|
||
|
" call Decho("exe w! ".fnameescape(fnamepath))
|
||
|
if fenc != ""
|
||
|
exe "silent w! ++enc=".fnameescape(fenc)." ".fnameescape(fnamepath)
|
||
|
else
|
||
|
exe "silent w! ".fnameescape(fnamepath)
|
||
|
endif
|
||
|
echo "wrote ".fnameescape(fnamepath)
|
||
|
call s:RecordInVar(home,"call delete('".fnamepath."')")
|
||
|
endif
|
||
|
|
||
|
" return to tab with vimball
|
||
|
" call Decho("exe tabn ".curtabnr)
|
||
|
exe "tabn ".curtabnr
|
||
|
|
||
|
" set up help if it's a doc/*.txt file
|
||
|
" call Decho("didhelp<".didhelp."> fname<".fname.">")
|
||
|
if a:really && didhelp == "" && fname =~ 'doc/[^/]\+\.\(txt\|..x\)$'
|
||
|
let didhelp= substitute(fname,'^\(.*\<doc\)[/\\][^.]*\.\(txt\|..x\)$','\1','')
|
||
|
" call Decho("didhelp<".didhelp.">")
|
||
|
endif
|
||
|
endif
|
||
|
|
||
|
" update for next file
|
||
|
" call Decho("update linenr= [linenr=".linenr."] + [fsize=".fsize."] = ".(linenr+fsize))
|
||
|
let linenr= linenr + fsize
|
||
|
endwhile
|
||
|
|
||
|
" set up help
|
||
|
" call Decho("about to set up help: didhelp<".didhelp.">")
|
||
|
if didhelp != ""
|
||
|
let htpath= home."/".didhelp
|
||
|
" call Decho("exe helptags ".htpath)
|
||
|
exe "helptags ".fnameescape(htpath)
|
||
|
echo "did helptags"
|
||
|
endif
|
||
|
|
||
|
" make sure a "Press ENTER..." prompt appears to keep the messages showing!
|
||
|
while filecnt <= &ch
|
||
|
echomsg " "
|
||
|
let filecnt= filecnt + 1
|
||
|
endwhile
|
||
|
|
||
|
" record actions in <.VimballRecord>
|
||
|
call s:RecordInFile(home)
|
||
|
|
||
|
" restore events, delete tab and buffer
|
||
|
exe "sil! tabn ".vbtabnr
|
||
|
setlocal nomod bh=wipe
|
||
|
exe "sil! tabn ".curtabnr
|
||
|
exe "sil! tabc! ".vbtabnr
|
||
|
call vimball#RestoreSettings()
|
||
|
call s:ChgDir(curdir)
|
||
|
|
||
|
" call Dret("vimball#Vimball")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#RmVimball: remove any files, remove any directories made by any {{{2
|
||
|
" previous vimball extraction based on a file of the current
|
||
|
" name.
|
||
|
" Usage: RmVimball (assume current file is a vimball; remove)
|
||
|
" RmVimball vimballname
|
||
|
fun! vimball#RmVimball(...)
|
||
|
" call Dfunc("vimball#RmVimball() a:0=".a:0)
|
||
|
if exists("g:vimball_norecord")
|
||
|
" call Dret("vimball#RmVimball : (g:vimball_norecord)")
|
||
|
return
|
||
|
endif
|
||
|
|
||
|
if a:0 == 0
|
||
|
let curfile= expand("%:tr")
|
||
|
" call Decho("case a:0=0: curfile<".curfile."> (used expand(%:tr))")
|
||
|
else
|
||
|
if a:1 =~ '[\/]'
|
||
|
call vimball#ShowMesg(s:USAGE,"RmVimball vimballname [path]")
|
||
|
" call Dret("vimball#RmVimball : suspect a:1<".a:1.">")
|
||
|
return
|
||
|
endif
|
||
|
let curfile= a:1
|
||
|
" call Decho("case a:0=".a:0.": curfile<".curfile.">")
|
||
|
endif
|
||
|
if curfile =~ '\.vmb$'
|
||
|
let curfile= substitute(curfile,'\.vmb','','')
|
||
|
elseif curfile =~ '\.vba$'
|
||
|
let curfile= substitute(curfile,'\.vba','','')
|
||
|
endif
|
||
|
if a:0 >= 2
|
||
|
let home= expand(a:2)
|
||
|
else
|
||
|
let home= vimball#VimballHome()
|
||
|
endif
|
||
|
let curdir = getcwd()
|
||
|
" call Decho("home <".home.">")
|
||
|
" call Decho("curfile<".curfile.">")
|
||
|
" call Decho("curdir <".curdir.">")
|
||
|
|
||
|
call s:ChgDir(home)
|
||
|
if filereadable(".VimballRecord")
|
||
|
" call Decho(".VimballRecord is readable")
|
||
|
" call Decho("curfile<".curfile.">")
|
||
|
keepalt keepjumps 1split
|
||
|
sil! keepalt keepjumps e .VimballRecord
|
||
|
let keepsrch= @/
|
||
|
" call Decho('search for ^\M'.curfile.'.\m: ')
|
||
|
" call Decho('search for ^\M'.curfile.'.\m{vba|vmb}: ')
|
||
|
" call Decho('search for ^\M'.curfile.'\m[-0-9.]*\.{vba|vmb}: ')
|
||
|
if search('^\M'.curfile."\m: ".'cw')
|
||
|
let foundit= 1
|
||
|
elseif search('^\M'.curfile.".\mvmb: ",'cw')
|
||
|
let foundit= 2
|
||
|
elseif search('^\M'.curfile.'\m[-0-9.]*\.vmb: ','cw')
|
||
|
let foundit= 2
|
||
|
elseif search('^\M'.curfile.".\mvba: ",'cw')
|
||
|
let foundit= 1
|
||
|
elseif search('^\M'.curfile.'\m[-0-9.]*\.vba: ','cw')
|
||
|
let foundit= 1
|
||
|
else
|
||
|
let foundit = 0
|
||
|
endif
|
||
|
if foundit
|
||
|
if foundit == 1
|
||
|
let exestring = substitute(getline("."),'^\M'.curfile.'\m\S\{-}\.vba: ','','')
|
||
|
else
|
||
|
let exestring = substitute(getline("."),'^\M'.curfile.'\m\S\{-}\.vmb: ','','')
|
||
|
endif
|
||
|
let s:VBRstring= substitute(exestring,'call delete(','','g')
|
||
|
let s:VBRstring= substitute(s:VBRstring,"[')]",'','g')
|
||
|
" call Decho("exe ".exestring)
|
||
|
sil! keepalt keepjumps exe exestring
|
||
|
sil! keepalt keepjumps d
|
||
|
let exestring= strlen(substitute(exestring,'call delete(.\{-})|\=',"D","g"))
|
||
|
" call Decho("exestring<".exestring.">")
|
||
|
echomsg "removed ".exestring." files"
|
||
|
else
|
||
|
let s:VBRstring= ''
|
||
|
let curfile = substitute(curfile,'\.vmb','','')
|
||
|
" call Decho("unable to find <".curfile."> in .VimballRecord")
|
||
|
if !exists("s:ok_unablefind")
|
||
|
call vimball#ShowMesg(s:WARNING,"(RmVimball) unable to find <".curfile."> in .VimballRecord")
|
||
|
endif
|
||
|
endif
|
||
|
sil! keepalt keepjumps g/^\s*$/d
|
||
|
sil! keepalt keepjumps wq!
|
||
|
let @/= keepsrch
|
||
|
endif
|
||
|
call s:ChgDir(curdir)
|
||
|
|
||
|
" call Dret("vimball#RmVimball")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#Decompress: attempts to automatically decompress vimballs {{{2
|
||
|
fun! vimball#Decompress(fname,...)
|
||
|
" call Dfunc("Decompress(fname<".a:fname.">) a:0=".a:0)
|
||
|
|
||
|
" decompression:
|
||
|
if expand("%") =~ '.*\.gz' && executable("gunzip")
|
||
|
" handle *.gz with gunzip
|
||
|
silent exe "!gunzip ".shellescape(a:fname)
|
||
|
if v:shell_error != 0
|
||
|
call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) gunzip may have failed with <".a:fname.">")
|
||
|
endif
|
||
|
let fname= substitute(a:fname,'\.gz$','','')
|
||
|
exe "e ".escape(fname,' \')
|
||
|
if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
|
||
|
|
||
|
elseif expand("%") =~ '.*\.gz' && executable("gzip")
|
||
|
" handle *.gz with gzip -d
|
||
|
silent exe "!gzip -d ".shellescape(a:fname)
|
||
|
if v:shell_error != 0
|
||
|
call vimball#ShowMesg(s:WARNING,'(vimball#Decompress) "gzip -d" may have failed with <'.a:fname.">")
|
||
|
endif
|
||
|
let fname= substitute(a:fname,'\.gz$','','')
|
||
|
exe "e ".escape(fname,' \')
|
||
|
if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
|
||
|
|
||
|
elseif expand("%") =~ '.*\.bz2' && executable("bunzip2")
|
||
|
" handle *.bz2 with bunzip2
|
||
|
silent exe "!bunzip2 ".shellescape(a:fname)
|
||
|
if v:shell_error != 0
|
||
|
call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) bunzip2 may have failed with <".a:fname.">")
|
||
|
endif
|
||
|
let fname= substitute(a:fname,'\.bz2$','','')
|
||
|
exe "e ".escape(fname,' \')
|
||
|
if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
|
||
|
|
||
|
elseif expand("%") =~ '.*\.bz2' && executable("bzip2")
|
||
|
" handle *.bz2 with bzip2 -d
|
||
|
silent exe "!bzip2 -d ".shellescape(a:fname)
|
||
|
if v:shell_error != 0
|
||
|
call vimball#ShowMesg(s:WARNING,'(vimball#Decompress) "bzip2 -d" may have failed with <'.a:fname.">")
|
||
|
endif
|
||
|
let fname= substitute(a:fname,'\.bz2$','','')
|
||
|
exe "e ".escape(fname,' \')
|
||
|
if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
|
||
|
|
||
|
elseif expand("%") =~ '.*\.zip' && executable("unzip")
|
||
|
" handle *.zip with unzip
|
||
|
silent exe "!unzip ".shellescape(a:fname)
|
||
|
if v:shell_error != 0
|
||
|
call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) unzip may have failed with <".a:fname.">")
|
||
|
endif
|
||
|
let fname= substitute(a:fname,'\.zip$','','')
|
||
|
exe "e ".escape(fname,' \')
|
||
|
if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
|
||
|
endif
|
||
|
|
||
|
if a:0 == 0| setlocal noma bt=nofile fmr=[[[,]]] fdm=marker | endif
|
||
|
|
||
|
" call Dret("Decompress")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#ShowMesg: {{{2
|
||
|
fun! vimball#ShowMesg(level,msg)
|
||
|
" call Dfunc("vimball#ShowMesg(level=".a:level." msg<".a:msg.">)")
|
||
|
|
||
|
let rulerkeep = &ruler
|
||
|
let showcmdkeep = &showcmd
|
||
|
set noruler noshowcmd
|
||
|
redraw!
|
||
|
|
||
|
if &fo =~# '[ta]'
|
||
|
echomsg "***vimball*** ".a:msg
|
||
|
else
|
||
|
if a:level == s:WARNING || a:level == s:USAGE
|
||
|
echohl WarningMsg
|
||
|
elseif a:level == s:ERROR
|
||
|
echohl Error
|
||
|
endif
|
||
|
echomsg "***vimball*** ".a:msg
|
||
|
echohl None
|
||
|
endif
|
||
|
|
||
|
if a:level != s:USAGE
|
||
|
call inputsave()|let ok= input("Press <cr> to continue")|call inputrestore()
|
||
|
endif
|
||
|
|
||
|
let &ruler = rulerkeep
|
||
|
let &showcmd = showcmdkeep
|
||
|
|
||
|
" call Dret("vimball#ShowMesg")
|
||
|
endfun
|
||
|
" =====================================================================
|
||
|
" s:ChgDir: change directory (in spite of Windoze) {{{2
|
||
|
fun! s:ChgDir(newdir)
|
||
|
" call Dfunc("ChgDir(newdir<".a:newdir.">)")
|
||
|
if (has("win32") || has("win95") || has("win64") || has("win16"))
|
||
|
try
|
||
|
exe 'silent cd '.fnameescape(substitute(a:newdir,'/','\\','g'))
|
||
|
catch /^Vim\%((\a\+)\)\=:E/
|
||
|
call mkdir(fnameescape(substitute(a:newdir,'/','\\','g')))
|
||
|
exe 'silent cd '.fnameescape(substitute(a:newdir,'/','\\','g'))
|
||
|
endtry
|
||
|
else
|
||
|
try
|
||
|
exe 'silent cd '.fnameescape(a:newdir)
|
||
|
catch /^Vim\%((\a\+)\)\=:E/
|
||
|
call mkdir(fnameescape(a:newdir))
|
||
|
exe 'silent cd '.fnameescape(a:newdir)
|
||
|
endtry
|
||
|
endif
|
||
|
" call Dret("ChgDir : curdir<".getcwd().">")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" s:RecordInVar: record a un-vimball command in the .VimballRecord file {{{2
|
||
|
fun! s:RecordInVar(home,cmd)
|
||
|
" call Dfunc("RecordInVar(home<".a:home."> cmd<".a:cmd.">)")
|
||
|
if a:cmd =~ '^rmdir'
|
||
|
" if !exists("s:recorddir")
|
||
|
" let s:recorddir= substitute(a:cmd,'^rmdir',"call s:Rmdir",'')
|
||
|
" else
|
||
|
" let s:recorddir= s:recorddir."|".substitute(a:cmd,'^rmdir',"call s:Rmdir",'')
|
||
|
" endif
|
||
|
elseif !exists("s:recordfile")
|
||
|
let s:recordfile= a:cmd
|
||
|
else
|
||
|
let s:recordfile= s:recordfile."|".a:cmd
|
||
|
endif
|
||
|
" call Dret("RecordInVar : s:recordfile<".(exists("s:recordfile")? s:recordfile : "")."> s:recorddir<".(exists("s:recorddir")? s:recorddir : "").">")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" s:RecordInFile: {{{2
|
||
|
fun! s:RecordInFile(home)
|
||
|
" call Dfunc("s:RecordInFile()")
|
||
|
if exists("g:vimball_norecord")
|
||
|
" call Dret("s:RecordInFile : g:vimball_norecord")
|
||
|
return
|
||
|
endif
|
||
|
|
||
|
if exists("s:recordfile") || exists("s:recorddir")
|
||
|
let curdir= getcwd()
|
||
|
call s:ChgDir(a:home)
|
||
|
keepalt keepjumps 1split
|
||
|
|
||
|
let cmd= expand("%:tr").": "
|
||
|
" call Decho("cmd<".cmd.">")
|
||
|
|
||
|
sil! keepalt keepjumps e .VimballRecord
|
||
|
setlocal ma
|
||
|
$
|
||
|
if exists("s:recordfile") && exists("s:recorddir")
|
||
|
let cmd= cmd.s:recordfile."|".s:recorddir
|
||
|
elseif exists("s:recorddir")
|
||
|
let cmd= cmd.s:recorddir
|
||
|
elseif exists("s:recordfile")
|
||
|
let cmd= cmd.s:recordfile
|
||
|
else
|
||
|
" call Dret("s:RecordInFile : neither recordfile nor recorddir exist")
|
||
|
return
|
||
|
endif
|
||
|
" call Decho("cmd<".cmd.">")
|
||
|
|
||
|
" put command into buffer, write .VimballRecord `file
|
||
|
keepalt keepjumps put=cmd
|
||
|
sil! keepalt keepjumps g/^\s*$/d
|
||
|
sil! keepalt keepjumps wq!
|
||
|
call s:ChgDir(curdir)
|
||
|
|
||
|
if exists("s:recorddir")
|
||
|
" call Decho("unlet s:recorddir<".s:recorddir.">")
|
||
|
unlet s:recorddir
|
||
|
endif
|
||
|
if exists("s:recordfile")
|
||
|
" call Decho("unlet s:recordfile<".s:recordfile.">")
|
||
|
unlet s:recordfile
|
||
|
endif
|
||
|
else
|
||
|
" call Decho("s:record[file|dir] doesn't exist")
|
||
|
endif
|
||
|
|
||
|
" call Dret("s:RecordInFile")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#VimballHome: determine/get home directory path (usually from rtp) {{{2
|
||
|
fun! vimball#VimballHome()
|
||
|
" call Dfunc("vimball#VimballHome()")
|
||
|
if exists("g:vimball_home")
|
||
|
let home= g:vimball_home
|
||
|
else
|
||
|
" go to vim plugin home
|
||
|
for home in split(&rtp,',') + ['']
|
||
|
if isdirectory(home) && filewritable(home) | break | endif
|
||
|
let basehome= substitute(home,'[/\\]\.vim$','','')
|
||
|
if isdirectory(basehome) && filewritable(basehome)
|
||
|
let home= basehome."/.vim"
|
||
|
break
|
||
|
endif
|
||
|
endfor
|
||
|
if home == ""
|
||
|
" just pick the first directory
|
||
|
let home= substitute(&rtp,',.*$','','')
|
||
|
endif
|
||
|
if (has("win32") || has("win95") || has("win64") || has("win16"))
|
||
|
let home= substitute(home,'/','\\','g')
|
||
|
endif
|
||
|
endif
|
||
|
" insure that the home directory exists
|
||
|
" call Decho("picked home<".home.">")
|
||
|
if !isdirectory(home)
|
||
|
if exists("g:vimball_mkdir")
|
||
|
" call Decho("home<".home."> isn't a directory -- making it now with g:vimball_mkdir<".g:vimball_mkdir.">")
|
||
|
" call Decho("system(".g:vimball_mkdir." ".shellescape(home).")")
|
||
|
call system(g:vimball_mkdir." ".shellescape(home))
|
||
|
else
|
||
|
" call Decho("home<".home."> isn't a directory -- making it now with mkdir()")
|
||
|
call mkdir(home)
|
||
|
endif
|
||
|
endif
|
||
|
" call Dret("vimball#VimballHome <".home.">")
|
||
|
return home
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#SaveSettings: {{{2
|
||
|
fun! vimball#SaveSettings()
|
||
|
" call Dfunc("SaveSettings()")
|
||
|
let s:makeep = getpos("'a")
|
||
|
let s:regakeep= @a
|
||
|
if exists("+acd")
|
||
|
let s:acdkeep = &acd
|
||
|
endif
|
||
|
let s:eikeep = &ei
|
||
|
let s:fenkeep = &l:fen
|
||
|
let s:hidkeep = &hidden
|
||
|
let s:ickeep = &ic
|
||
|
let s:lzkeep = &lz
|
||
|
let s:pmkeep = &pm
|
||
|
let s:repkeep = &report
|
||
|
let s:vekeep = &ve
|
||
|
let s:ffkeep = &l:ff
|
||
|
let s:swfkeep = &l:swf
|
||
|
if exists("+acd")
|
||
|
setlocal ei=all ve=all noacd nofen noic report=999 nohid bt= ma lz pm= ff=unix noswf
|
||
|
else
|
||
|
setlocal ei=all ve=all nofen noic report=999 nohid bt= ma lz pm= ff=unix noswf
|
||
|
endif
|
||
|
" vimballs should be in unix format
|
||
|
setlocal ff=unix
|
||
|
" call Dret("SaveSettings")
|
||
|
endfun
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" vimball#RestoreSettings: {{{2
|
||
|
fun! vimball#RestoreSettings()
|
||
|
" call Dfunc("RestoreSettings()")
|
||
|
let @a = s:regakeep
|
||
|
if exists("+acd")
|
||
|
let &acd = s:acdkeep
|
||
|
endif
|
||
|
let &l:fen = s:fenkeep
|
||
|
let &hidden = s:hidkeep
|
||
|
let &ic = s:ickeep
|
||
|
let &lz = s:lzkeep
|
||
|
let &pm = s:pmkeep
|
||
|
let &report = s:repkeep
|
||
|
let &ve = s:vekeep
|
||
|
let &ei = s:eikeep
|
||
|
let &l:ff = s:ffkeep
|
||
|
if s:makeep[0] != 0
|
||
|
" restore mark a
|
||
|
" call Decho("restore mark-a: makeep=".string(makeep))
|
||
|
call setpos("'a",s:makeep)
|
||
|
endif
|
||
|
if exists("+acd")
|
||
|
unlet s:acdkeep
|
||
|
endif
|
||
|
unlet s:regakeep s:eikeep s:fenkeep s:hidkeep s:ickeep s:repkeep s:vekeep s:makeep s:lzkeep s:pmkeep s:ffkeep
|
||
|
" call Dret("RestoreSettings")
|
||
|
endfun
|
||
|
|
||
|
let &cpo = s:keepcpo
|
||
|
unlet s:keepcpo
|
||
|
|
||
|
" ---------------------------------------------------------------------
|
||
|
" Modelines: {{{1
|
||
|
" vim: fdm=marker
|
||
|
|
||
|
endif
|