mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 04:17:01 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
| local F = {}
 | |
| 
 | |
| --- Returns the first argument which is not nil.
 | |
| ---
 | |
| --- If all arguments are nil, returns nil.
 | |
| ---
 | |
| --- Examples:
 | |
| ---
 | |
| --- ```lua
 | |
| --- local a = nil
 | |
| --- local b = nil
 | |
| --- local c = 42
 | |
| --- local d = true
 | |
| --- assert(vim.F.if_nil(a, b, c, d) == 42)
 | |
| --- ```
 | |
| ---
 | |
| ---@generic T
 | |
| ---@param ... T
 | |
| ---@return T
 | |
| function F.if_nil(...)
 | |
|   local nargs = select('#', ...)
 | |
|   for i = 1, nargs do
 | |
|     local v = select(i, ...)
 | |
|     if v ~= nil then
 | |
|       return v
 | |
|     end
 | |
|   end
 | |
|   return nil
 | |
| end
 | |
| 
 | |
| -- Use in combination with pcall
 | |
| function F.ok_or_nil(status, ...)
 | |
|   if not status then
 | |
|     return
 | |
|   end
 | |
|   return ...
 | |
| end
 | |
| 
 | |
| -- Nil pcall.
 | |
| function F.npcall(fn, ...)
 | |
|   return F.ok_or_nil(pcall(fn, ...))
 | |
| end
 | |
| 
 | |
| --- Wrap a function to return nil if it fails, otherwise the value
 | |
| function F.nil_wrap(fn)
 | |
|   return function(...)
 | |
|     return F.npcall(fn, ...)
 | |
|   end
 | |
| end
 | |
| 
 | |
| --- like {...} except preserve the length explicitly
 | |
| function F.pack_len(...)
 | |
|   return { n = select('#', ...), ... }
 | |
| end
 | |
| 
 | |
| --- like unpack() but use the length set by F.pack_len if present
 | |
| function F.unpack_len(t)
 | |
|   return unpack(t, 1, t.n)
 | |
| end
 | |
| 
 | |
| return F
 | 
