mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-25 20:07:09 +00:00 
			
		
		
		
	fix(vim.system): clear_env=true gives an invalid env to uv.spawn #33955
Problem:
In setup_env, some needed logic is bypassed when clear_env=true.
Solution:
Drop the early return in setup_env().
Co-authored-by: BirdeeHub <birdee@localhost>
(cherry picked from commit 731e616a79)
			
			
This commit is contained in:
		 Birdee
					Birdee
				
			
				
					committed by
					
						![github-actions[bot]](/assets/img/avatar_default.png) github-actions[bot]
						github-actions[bot]
					
				
			
			
				
	
			
			
			![github-actions[bot]](/assets/img/avatar_default.png) github-actions[bot]
						github-actions[bot]
					
				
			
						parent
						
							68d204462c
						
					
				
				
					commit
					203d4f916d
				
			| @@ -210,15 +210,13 @@ end | ||||
| --- @param clear_env? boolean | ||||
| --- @return string[]? | ||||
| local function setup_env(env, clear_env) | ||||
|   if clear_env then | ||||
|     return env | ||||
|   end | ||||
|  | ||||
|   if not clear_env then | ||||
|     --- @type table<string,string|number> | ||||
|     env = vim.tbl_extend('force', base_env(), env or {}) | ||||
|   end | ||||
|  | ||||
|   local renv = {} --- @type string[] | ||||
|   for k, v in pairs(env) do | ||||
|   for k, v in pairs(env or {}) do | ||||
|     renv[#renv + 1] = string.format('%s=%s', k, tostring(v)) | ||||
|   end | ||||
|  | ||||
|   | ||||
| @@ -73,6 +73,26 @@ describe('vim.system', function() | ||||
|         eq('hellocat', system({ 'cat' }, { stdin = 'hellocat', text = true }).stdout) | ||||
|       end) | ||||
|  | ||||
|       it('can set environment', function() | ||||
|         eq( | ||||
|           'TESTVAL', | ||||
|           system( | ||||
|             { n.testprg('printenv-test'), 'TEST' }, | ||||
|             { env = { TEST = 'TESTVAL' }, text = true } | ||||
|           ).stdout | ||||
|         ) | ||||
|       end) | ||||
|  | ||||
|       it('can set environment with clear_env = true', function() | ||||
|         eq( | ||||
|           'TESTVAL', | ||||
|           system( | ||||
|             { n.testprg('printenv-test'), 'TEST' }, | ||||
|             { clear_env = true, env = { TEST = 'TESTVAL' }, text = true } | ||||
|           ).stdout | ||||
|         ) | ||||
|       end) | ||||
|  | ||||
|       it('supports timeout', function() | ||||
|         eq({ | ||||
|           code = 124, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user