forked from aniani/vim
		
	runtime(netrw): upstream snapshot of v177
relevant commits: - defaults!: use 'suffixes' for 'g:netrw_sort_sequence' - refactor: remove associated buffer when deliting a file - refactor: s:NetrwLocalRm - refactor: s:NetrwDelete - refactor: s:NetrwLocalRmFile - feat: use vim.notify on neovim - fix: prefer v:lua instead of luaeval for vim.deprecate - chore: remove old batteries closes: #16638 Signed-off-by: Luca Saccarola <github.e41mv@aleeas.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							bf7c88d852
						
					
				
				
					commit
					73d8222b31
				
			
							
								
								
									
										164
									
								
								runtime/pack/dist/opt/netrw/autoload/netrw.vim
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										164
									
								
								runtime/pack/dist/opt/netrw/autoload/netrw.vim
									
									
									
									
										vendored
									
									
								
							| @@ -19,7 +19,7 @@ if &cp || exists("g:loaded_netrw") | ||||
|   finish | ||||
| endif | ||||
|  | ||||
| let g:loaded_netrw = "v176" | ||||
| let g:loaded_netrw = "v177" | ||||
|  | ||||
| if !has("patch-9.1.1054") && !has('nvim') | ||||
|   echoerr 'netrw needs Vim v9.1.1054' | ||||
| @@ -45,11 +45,8 @@ setl cpo&vim | ||||
| "          netrw#ErrorMsg(s:NOTE | s:WARNING | s:ERROR,["message1","message2",...],error-number) | ||||
| "          (this function can optionally take a list of messages) | ||||
| "  Dec 2, 2019 : max errnum currently is 106 | ||||
| fun! netrw#ErrorMsg(level,msg,errnum) | ||||
|   "  call Dfunc("netrw#ErrorMsg(level=".a:level." msg<".a:msg."> errnum=".a:errnum.") g:netrw_use_errorwindow=".g:netrw_use_errorwindow) | ||||
|  | ||||
| function! netrw#ErrorMsg(level, msg, errnum) | ||||
|     if a:level < g:netrw_errorlvl | ||||
|     "   call Dret("netrw#ErrorMsg : suppressing level=".a:level." since g:netrw_errorlvl=".g:netrw_errorlvl) | ||||
|         return | ||||
|     endif | ||||
|  | ||||
| @@ -60,7 +57,6 @@ fun! netrw#ErrorMsg(level,msg,errnum) | ||||
|     else | ||||
|         let level = "**note** (netrw) " | ||||
|     endif | ||||
|   "  call Decho("level=".level,'~'.expand("<slnum>")) | ||||
|  | ||||
|     if g:netrw_use_errorwindow == 2 && exists("*popup_atcursor") | ||||
|         " use popup window | ||||
| @@ -71,6 +67,8 @@ fun! netrw#ErrorMsg(level,msg,errnum) | ||||
|         endif | ||||
|         let s:popuperr_id = popup_atcursor(msg, {}) | ||||
|         let s:popuperr_text = "" | ||||
|     elseif has('nvim') | ||||
|         call v:lua.vim.notify(level . a:msg, a:level + 2) | ||||
|     elseif g:netrw_use_errorwindow | ||||
|         " (default) netrw creates a one-line window to show error/warning | ||||
|         " messages (reliably displayed) | ||||
| @@ -142,12 +140,9 @@ fun! netrw#ErrorMsg(level,msg,errnum) | ||||
|             unsilent echomsg level.a:msg | ||||
|         endif | ||||
|  | ||||
|     "   call Decho("echomsg ***netrw*** ".a:msg,'~'.expand("<slnum>")) | ||||
|         echohl None | ||||
|     endif | ||||
|  | ||||
|   "  call Dret("netrw#ErrorMsg") | ||||
| endfun | ||||
| endfunction | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " s:NetrwInit: initializes variables if they haven't been defined {{{2 | ||||
| @@ -523,11 +518,9 @@ call s:NetrwInit("g:netrw_sort_by"       , "name") " alternatives: date | ||||
| call s:NetrwInit("g:netrw_sort_options"  , "") | ||||
| call s:NetrwInit("g:netrw_sort_direction", "normal") " alternative: reverse  (z y x ...) | ||||
| if !exists("g:netrw_sort_sequence") | ||||
|   if has("unix") | ||||
|     let g:netrw_sort_sequence= '[\/]$,\<core\%(\.\d\+\)\=\>,\.h$,\.c$,\.cpp$,\~\=\*$,*,\.o$,\.obj$,\.info$,\.swp$,\.bak$,\~$' | ||||
|   else | ||||
|     let g:netrw_sort_sequence= '[\/]$,\.h$,\.c$,\.cpp$,*,\.o$,\.obj$,\.info$,\.swp$,\.bak$,\~$' | ||||
|   endif | ||||
|     let g:netrw_sort_sequence = !empty(&suffixes) | ||||
|                 \ ? printf('[\/]$,*,\%(%s\)[*@]\=$', &suffixes->split(',')->map('escape(v:val, ".*$~")')->join('\|')) | ||||
|                 \ : '[\/]$,*' | ||||
| endif | ||||
| call s:NetrwInit("g:netrw_special_syntax"   , 0) | ||||
| call s:NetrwInit("g:netrw_ssh_browse_reject", '^total\s\+\d\+$') | ||||
| @@ -4893,7 +4886,7 @@ fun! s:NetrwBrowseUpDir(islocal) | ||||
| endfun | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " netrw#BrowseX:  (implements "x" and "gx") executes a special "viewer" script or program for the {{{2 | ||||
| " netrw#BrowseX:  (implements "x") executes a special "viewer" script or program for the {{{2 | ||||
| "              given filename; typically this means given their extension. | ||||
| "              0=local, 1=remote | ||||
| fun! netrw#BrowseX(fname,remote) | ||||
| @@ -4995,17 +4988,6 @@ fun! netrw#BrowseX(fname,remote) | ||||
|   let &aw= awkeep | ||||
| endfun | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " netrw#BrowseXVis: used by gx in visual mode to select a file for browsing {{{2 | ||||
| fun! netrw#BrowseXVis() | ||||
|   let dict={} | ||||
|   let dict.a=[getreg('a'), getregtype('a')] | ||||
|   norm! gv"ay | ||||
|   let gxfile= @a | ||||
|   call s:RestoreRegister(dict) | ||||
|   call netrw#BrowseX(gxfile,netrw#CheckIfRemote(gxfile)) | ||||
| endfun | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " s:NetrwBufRename: renames a buffer without the side effect of retaining an unlisted buffer having the old name {{{2 | ||||
| "                   Using the file command on a "[No Name]" buffer does not seem to cause the old "[No Name]" buffer | ||||
| @@ -5316,7 +5298,7 @@ endfun | ||||
| "  s:NetrwHome: this function determines a "home" for saving bookmarks and history {{{2 | ||||
| function! s:NetrwHome() | ||||
|   if has('nvim') | ||||
|     let home = netrw#own#JoinPath(stdpath('state'), 'netrw') | ||||
|     let home = netrw#own#PathJoin(stdpath('state'), 'netrw') | ||||
|   elseif exists("g:netrw_home") | ||||
|     let home = expand(g:netrw_home) | ||||
|   else | ||||
| @@ -6350,7 +6332,7 @@ fun! s:NetrwMarkFileCopy(islocal,...) | ||||
|     endif | ||||
|  | ||||
|     " copy marked files while within the same directory (ie. allow renaming) | ||||
|     if s:StripTrailingSlash(simplify(s:netrwmftgt)) == s:StripTrailingSlash(simplify(b:netrw_curdir)) | ||||
|     if simplify(s:netrwmftgt) ==# simplify(b:netrw_curdir) | ||||
|       if len(s:netrwmarkfilelist_{bufnr('%')}) == 1 | ||||
|         " only one marked file | ||||
|         "     call Decho("case: only one marked file",'~'.expand("<slnum>")) | ||||
| @@ -10237,7 +10219,7 @@ endfun | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " s:NetrwLocalRm: {{{2 | ||||
| fun! s:NetrwLocalRm(path) range | ||||
| function! s:NetrwLocalRm(path) range | ||||
|     if !exists("w:netrw_bannercnt") | ||||
|         let w:netrw_bannercnt = b:netrw_bannercnt | ||||
|     endif | ||||
| @@ -10252,10 +10234,10 @@ fun! s:NetrwLocalRm(path) range | ||||
|         " remove all marked files | ||||
|         for fname in s:netrwmarkfilelist_{bufnr("%")} | ||||
|             let ok = s:NetrwLocalRmFile(a:path, fname, all) | ||||
|       if ok =~# 'q\%[uit]' || ok == "no" | ||||
|         break | ||||
|       elseif ok =~# '^a\%[ll]$' | ||||
|             if ok =~# '^a\%[ll]$' | ||||
|                 let all = 1 | ||||
|             elseif ok =~# "n\%[o]" | ||||
|                 break | ||||
|             endif | ||||
|         endfor | ||||
|         call s:NetrwUnMarkFile(1) | ||||
| @@ -10274,19 +10256,23 @@ fun! s:NetrwLocalRm(path) range | ||||
|                 let ctr = ctr + 1 | ||||
|                 continue | ||||
|             endif | ||||
|  | ||||
|             let curword = s:NetrwGetWord() | ||||
|             if curword == "./" || curword == "../" | ||||
|                 let ctr = ctr + 1 | ||||
|                 continue | ||||
|             endif | ||||
|  | ||||
|             let ok = s:NetrwLocalRmFile(a:path, curword, all) | ||||
|       if ok =~# 'q\%[uit]' || ok == "no" | ||||
|         break | ||||
|       elseif ok =~# '^a\%[ll]$' | ||||
|             if ok =~# '^a\%[ll]$' | ||||
|                 let all = 1 | ||||
|             elseif ok =~# "n\%[o]" | ||||
|                 break | ||||
|             endif | ||||
|  | ||||
|             let ctr = ctr + 1 | ||||
|         endwhile | ||||
|  | ||||
|         let &l:sol = keepsol | ||||
|     endif | ||||
|  | ||||
| @@ -10295,73 +10281,62 @@ fun! s:NetrwLocalRm(path) range | ||||
|         NetrwKeepj call s:NetrwRefresh(1, s:NetrwBrowseChgDir(1, './', 0)) | ||||
|         NetrwKeepj call winrestview(svpos) | ||||
|     endif | ||||
|  | ||||
|     let @@= ykeep | ||||
| endfun | ||||
| endfunction | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " s:NetrwLocalRmFile: remove file fname given the path {{{2 | ||||
| "                     Give confirmation prompt unless all==1 | ||||
| fun! s:NetrwLocalRmFile(path,fname,all) | ||||
|   "  call Dfunc("s:NetrwLocalRmFile(path<".a:path."> fname<".a:fname."> all=".a:all) | ||||
|  | ||||
| function! s:NetrwLocalRmFile(path, fname, all) | ||||
|     let all = a:all | ||||
|     let ok = "" | ||||
|     let dir = 0 | ||||
|     NetrwKeepj norm! 0 | ||||
|   let rmfile= s:NetrwFile(s:ComposePath(a:path,escape(a:fname, '\\'))) | ||||
|   "  call Decho("rmfile<".rmfile.">",'~'.expand("<slnum>")) | ||||
|     let rmfile = s:NetrwFile(s:ComposePath(a:path, escape(a:fname, '\\')))->fnamemodify(':.') | ||||
|  | ||||
|     " if not a directory | ||||
|     if rmfile !~ '^"' && (rmfile =~ '@$' || rmfile !~ '[\/]$') | ||||
|     " attempt to remove file | ||||
|     "   call Decho("attempt to remove file<".rmfile.">",'~'.expand("<slnum>")) | ||||
|         let msg = "Confirm deletion of file <%s> [{y(es)},n(o),a(ll)]: " | ||||
|     else | ||||
|         let msg = "Confirm *recursive* deletion of directory <%s> [{y(es)},n(o),a(ll)]: " | ||||
|         let dir = 1 | ||||
|     endif | ||||
|  | ||||
|     " Ask confirmation | ||||
|     if !all | ||||
|         echohl Statement | ||||
|         call inputsave() | ||||
|       let ok= input("Confirm deletion of file <".rmfile."> ","[{y(es)},n(o),a(ll),q(uit)] ") | ||||
|         let ok = input(printf(msg, rmfile)) | ||||
|         call inputrestore() | ||||
|         echohl NONE | ||||
|       if ok == "" | ||||
|         let ok="no" | ||||
|       endif | ||||
|       "    call Decho("response: ok<".ok.">",'~'.expand("<slnum>")) | ||||
|       let ok= substitute(ok,'\[{y(es)},n(o),a(ll),q(uit)]\s*','','e') | ||||
|       "    call Decho("response: ok<".ok."> (after sub)",'~'.expand("<slnum>")) | ||||
|       if ok =~# '^a\%[ll]$' | ||||
|         if ok =~# '^a\%[ll]$' || ok =~# '^y\%[es]$' | ||||
|             let all = 1 | ||||
|       endif | ||||
|     endif | ||||
|  | ||||
|     if all || ok =~# '^y\%[es]$' || ok == "" | ||||
|       let ret= s:NetrwDelete(rmfile) | ||||
|       "    call Decho("errcode=".v:shell_error." ret=".ret,'~'.expand("<slnum>")) | ||||
|     endif | ||||
|  | ||||
|         else | ||||
|     " attempt to remove directory | ||||
|     if !all | ||||
|       echohl Statement | ||||
|       call inputsave() | ||||
|       let ok= input("Confirm *recursive* deletion of directory <".rmfile."> ","[{y(es)},n(o),a(ll),q(uit)] ") | ||||
|       call inputrestore() | ||||
|       let ok= substitute(ok,'\[{y(es)},n(o),a(ll),q(uit)]\s*','','e') | ||||
|       if ok == "" | ||||
|         let ok="no" | ||||
|       endif | ||||
|       if ok =~# '^a\%[ll]$' | ||||
|         let all= 1 | ||||
|             let ok = 'no' | ||||
|         endif | ||||
|     endif | ||||
|  | ||||
|     if !dir && (all || empty(ok)) | ||||
|         " This works because delete return 0 if successful | ||||
|         if s:NetrwDelete(rmfile) | ||||
|             call netrw#ErrorMsg(s:ERROR, printf("unable to delete <%s>!", rmfile), 103) | ||||
|         else | ||||
|             " Remove file only if there are no pending changes | ||||
|             execute printf('silent! bwipeout %s', rmfile) | ||||
|         endif | ||||
|  | ||||
|     elseif dir && (all || empty(ok)) | ||||
|         " Remove trailing / | ||||
|         let rmfile = substitute(rmfile, '[\/]$', '', 'e') | ||||
|  | ||||
|     if all || ok =~# '^y\%[es]$' || ok == "" | ||||
|         if delete(rmfile, "rf") | ||||
|         call netrw#ErrorMsg(s:ERROR,"unable to delete directory <".rmfile.">!",103) | ||||
|       endif | ||||
|     endif | ||||
|             call netrw#ErrorMsg(s:ERROR, printf("unable to delete directory <%s>!", rmfile), 103) | ||||
|         endif | ||||
|  | ||||
|     endif | ||||
|  | ||||
|   "  call Dret("s:NetrwLocalRmFile ".ok) | ||||
|     return ok | ||||
| endfun | ||||
| endfunction | ||||
|  | ||||
| " ===================================================================== | ||||
| " Support Functions: {{{1 | ||||
| @@ -10483,13 +10458,6 @@ fun! netrw#WinPath(path) | ||||
|   return path | ||||
| endfun | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " s:StripTrailingSlash: removes trailing slashes from a path {{{2 | ||||
| fun! s:StripTrailingSlash(path) | ||||
|   " remove trailing slash | ||||
|   return substitute(a:path, '[/\\]$', '', 'g') | ||||
| endfun | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " s:NetrwBadd: adds marked files to buffer list or vice versa {{{2 | ||||
| "              cb : bl2mf=0  add marked files to buffer list | ||||
| @@ -10872,31 +10840,24 @@ endfun | ||||
| "           Uses Steve Hall's idea to insure that Windows paths stay | ||||
| "           acceptable.  No effect on Unix paths. | ||||
| "  Examples of use:  let result= s:NetrwDelete(path) | ||||
| fun! s:NetrwDelete(path) | ||||
|   "  call Dfunc("s:NetrwDelete(path<".a:path.">)") | ||||
|  | ||||
| function! s:NetrwDelete(path) | ||||
|     let path = netrw#WinPath(a:path) | ||||
|   if !g:netrw_cygwin && has("win32") | ||||
|     if exists("+shellslash") | ||||
|  | ||||
|     if !g:netrw_cygwin && has("win32") && exists("+shellslash") | ||||
|         let sskeep = &shellslash | ||||
|         setl noshellslash | ||||
|         let result = delete(path) | ||||
|         let &shellslash = sskeep | ||||
|     else | ||||
|       "    call Decho("exe let result= ".a:cmd."('".path."')",'~'.expand("<slnum>")) | ||||
|       let result= delete(path) | ||||
|     endif | ||||
|   else | ||||
|     "   call Decho("let result= delete(".path.")",'~'.expand("<slnum>")) | ||||
|         let result = delete(path) | ||||
|     endif | ||||
|  | ||||
|     if result < 0 | ||||
|         NetrwKeepj call netrw#ErrorMsg(s:WARNING, "delete(".path.") failed!", 71) | ||||
|     endif | ||||
|  | ||||
|   "  call Dret("s:NetrwDelete ".result) | ||||
|     return result | ||||
| endfun | ||||
| endfunction | ||||
|  | ||||
| " --------------------------------------------------------------------- | ||||
| " s:NetrwBufRemover: removes a buffer that: {{{2s | ||||
| @@ -11650,7 +11611,7 @@ fun! s:UserMaps(islocal,funcname) | ||||
|   endif | ||||
| endfun | ||||
|  | ||||
| " Deprecated: {{{ | ||||
| " Deprecated: {{{1 | ||||
|  | ||||
| function! netrw#Launch(args) | ||||
|     call netrw#own#Deprecate('netrw#Launch', 'v180', {'vim': 'dist#vim9#Launch', 'nvim': 'vim.system'}) | ||||
| @@ -11665,14 +11626,11 @@ function! netrw#Open(file) | ||||
| endfunction | ||||
|  | ||||
| " }}} | ||||
| " ========================== | ||||
| " Settings Restoration: {{{1 | ||||
| " ========================== | ||||
| let &cpo= s:keepcpo | ||||
| unlet s:keepcpo | ||||
|  | ||||
| " =============== | ||||
| " Modelines: {{{1 | ||||
| " =============== | ||||
| " }}} | ||||
|  | ||||
| " vim:ts=8 sts=4 sw=4 et fdm=marker | ||||
|   | ||||
| @@ -2,12 +2,14 @@ | ||||
| " THIS FUNCTIONS DON'T COMMIT TO ANY BACKWARDS COMPATABILITY. SO CHANGES AND | ||||
| " BREAKAGES IF USED OUTSIDE OF NETRW.VIM ARE EXPECTED. | ||||
|  | ||||
| " General: {{{ | ||||
|  | ||||
| let s:deprecation_msgs = [] | ||||
| function! netrw#own#Deprecate(name, version, alternatives) | ||||
|     " If running on neovim use vim.deprecate | ||||
|     if has('nvim') | ||||
|         let s:alternative = a:alternatives->get('nvim', v:null) | ||||
|         call luaeval('vim.deprecate(unpack(_A)) and nil', [a:name, s:alternative, a:version, "netrw", v:false]) | ||||
|         call v:lua.vim.deprecate(a:name, s:alternative, a:version, "netrw", v:false) | ||||
|         return | ||||
|     endif | ||||
|  | ||||
| @@ -27,8 +29,20 @@ function! netrw#own#Deprecate(name, version, alternatives) | ||||
|     call add(s:deprecation_msgs, a:name) | ||||
| endfunction | ||||
|  | ||||
| function! netrw#own#Open(file) abort | ||||
|     if has('nvim') | ||||
|         call luaeval('vim.ui.open(_A[1]) and nil', [a:file]) | ||||
|     else | ||||
|         call dist#vim9#Open(a:file) | ||||
|     endif | ||||
| endfunction | ||||
|  | ||||
| " }}} | ||||
| " Path Utilities: {{{ | ||||
|  | ||||
| let s:slash = &shellslash ? '/' : '\' | ||||
| function! netrw#own#JoinPath(...) | ||||
|  | ||||
| function! netrw#own#PathJoin(...) | ||||
|     let path = "" | ||||
|  | ||||
|     for arg in a:000 | ||||
| @@ -42,12 +56,6 @@ function! netrw#own#JoinPath(...) | ||||
|     return path | ||||
| endfunction | ||||
|  | ||||
| function! netrw#own#Open(file) abort | ||||
|     if has('nvim') | ||||
|         call luaeval('vim.ui.open(_A[1]) and nil', [a:file]) | ||||
|     else | ||||
|         call dist#vim9#Open(a:file) | ||||
|     endif | ||||
| endfunction | ||||
| " }}} | ||||
|  | ||||
| " vim:ts=8 sts=4 sw=4 et fdm=marker | ||||
|   | ||||
| @@ -15,7 +15,7 @@ if &cp || exists("g:loaded_netrwSettings") | ||||
|     finish | ||||
| endif | ||||
|  | ||||
| let g:loaded_netrwSettings = "v176" | ||||
| let g:loaded_netrwSettings = "v177" | ||||
|  | ||||
| " NetrwSettings: {{{ | ||||
|  | ||||
|   | ||||
| @@ -15,7 +15,7 @@ if &cp || exists("g:loaded_netrwPlugin") | ||||
|     finish | ||||
| endif | ||||
|  | ||||
| let g:loaded_netrwPlugin = "v176" | ||||
| let g:loaded_netrwPlugin = "v177" | ||||
|  | ||||
| let s:keepcpo = &cpo | ||||
| set cpo&vim | ||||
|   | ||||
		Reference in New Issue
	
	Block a user