runtime(getscript): CI: failure on powershell
Problem:  The CheckVimScriptURL() function does not work properly on
          pwershell. Most likely this is because curl is aliased to
          Invoke-WebRequest on Powershell and redirection seems to work
          slightly different
Solution: Disable CheckVimScriptURL() on Powershell and then simplify
          the curl download logic
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		| @ -606,40 +606,24 @@ endfun | |||||||
| " Check status code of scriptaddr and downloadaddr | " Check status code of scriptaddr and downloadaddr | ||||||
| " return v:true if the script is downloadable or v:false in case of errors | " return v:true if the script is downloadable or v:false in case of errors | ||||||
| fun CheckVimScriptURL(script_id, src_id) | fun CheckVimScriptURL(script_id, src_id) | ||||||
|   if !executable('curl') |   " doesn't work with powershell | ||||||
|  |   if !executable('curl') || &shell =~? 'pwsh\|powershell' | ||||||
|     return v:true |     return v:true | ||||||
|   endif |   endif | ||||||
|   let output = has("win32") ? ' -o NUL ' : ' -o /dev/null ' |   let output = has("win32") ? ' -o NUL ' : ' -o /dev/null ' | ||||||
|  |  | ||||||
|   " Handle PowerShell differently |   let temp = tempname() | ||||||
|   if &shell =~? '\<pwsh\>\|\<powershell\>' |   defer delete(temp) | ||||||
|     " For PowerShell, use direct command output |   let script_url = g:GetLatestVimScripts_scriptaddr . a:script_id | ||||||
|     let script_url = g:GetLatestVimScripts_scriptaddr . a:script_id |   let download_url = g:GetLatestVimScripts_downloadaddr . a:src_id | ||||||
|     let script_cmd = 'curl -s -I -w "%{http_code}"' . output . shellescape(script_url) |  | ||||||
|     let script_status = system(script_cmd) |  | ||||||
|     let script_status = substitute(script_status, '\n$', '', '') |  | ||||||
|  |  | ||||||
|     let download_url = g:GetLatestVimScripts_downloadaddr . a:src_id |   let script_cmd = 'curl -s -I -w "%{http_code}"' . output . shellescape(script_url) . ' >' . shellescape(temp) | ||||||
|     let download_cmd = 'curl -s -I -w "%{http_code}"' . output . shellescape(download_url) |   call system(script_cmd) | ||||||
|     let download_status = system(download_cmd) |   let script_status = readfile(temp, 'b')[0] | ||||||
|     let download_status = substitute(download_status, '\n$', '', '') |  | ||||||
|   else |  | ||||||
|     " For other shells, use temporary files |  | ||||||
|     let temp_script = tempname() |  | ||||||
|     let temp_download = tempname() |  | ||||||
|  |  | ||||||
|     let script_url = g:GetLatestVimScripts_scriptaddr . a:script_id |   let download_cmd = 'curl -s -I -w "%{http_code}"' . output . shellescape(download_url) . ' >' . shellescape(temp) | ||||||
|     let script_cmd = 'curl -s -I -w "%{http_code}"' . output . shellescape(script_url) . ' >' . shellescape(temp_script) |   call system(download_cmd) | ||||||
|     call system(script_cmd) |   let download_status = readfile(temp, 'b')[0] | ||||||
|     let script_status = readfile(temp_script, 'b')[0] |  | ||||||
|     call delete(temp_script) |  | ||||||
|  |  | ||||||
|     let download_url = g:GetLatestVimScripts_downloadaddr . a:src_id |  | ||||||
|     let download_cmd = 'curl -s -I -w "%{http_code}"' . output . shellescape(download_url) . ' >' . shellescape(temp_download) |  | ||||||
|     call system(download_cmd) |  | ||||||
|     let download_status = readfile(temp_download, 'b')[0] |  | ||||||
|     call delete(temp_download) |  | ||||||
|   endif |  | ||||||
|  |  | ||||||
|   if script_status !=# '200' |   if script_status !=# '200' | ||||||
|     let s:message += [ printf('Error: Failed to reach script: %s', a:script_id) ] |     let s:message += [ printf('Error: Failed to reach script: %s', a:script_id) ] | ||||||
| @ -651,7 +635,7 @@ fun CheckVimScriptURL(script_id, src_id) | |||||||
|     return v:false |     return v:false | ||||||
|   endif |   endif | ||||||
|   return v:true |   return v:true | ||||||
| endfunction | endfun | ||||||
|  |  | ||||||
| " --------------------------------------------------------------------- | " --------------------------------------------------------------------- | ||||||
| " Restore Options: {{{1 | " Restore Options: {{{1 | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user