Some checks failed
		
		
	
	Detach Plugins / check (FlyGrep.vim) (push) Has been cancelled
				
			Detach Plugins / check (GitHub.vim) (push) Has been cancelled
				
			Detach Plugins / check (JavaUnit.vim) (push) Has been cancelled
				
			Detach Plugins / check (SourceCounter.vim) (push) Has been cancelled
				
			Detach Plugins / check (cpicker.nvim) (push) Has been cancelled
				
			Detach Plugins / check (dein-ui.vim) (push) Has been cancelled
				
			Detach Plugins / check (git.vim) (push) Has been cancelled
				
			Detach Plugins / check (iedit.vim) (push) Has been cancelled
				
			Detach Plugins / check (scrollbar.vim) (push) Has been cancelled
				
			Detach Plugins / check (vim-chat) (push) Has been cancelled
				
			Detach Plugins / check (vim-cheat) (push) Has been cancelled
				
			Detach Plugins / check (vim-todo) (push) Has been cancelled
				
			Detach Plugins / check (xmake.vim) (push) Has been cancelled
				
			test / Linux (nvim, nightly) (push) Has been cancelled
				
			test / Linux (nvim, v0.3.8) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.2) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.3) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.4) (push) Has been cancelled
				
			test / Linux (nvim, v0.5.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.5.1) (push) Has been cancelled
				
			test / Linux (nvim, v0.6.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.6.1) (push) Has been cancelled
				
			test / Linux (nvim, v0.7.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.7.2) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.1) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.2) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.3) (push) Has been cancelled
				
			test / Linux (nvim, v0.9.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.9.1) (push) Has been cancelled
				
			test / Linux (true, vim, v7.4.052) (push) Has been cancelled
				
			test / Linux (true, vim, v7.4.1689) (push) Has been cancelled
				
			test / Linux (true, vim, v7.4.629) (push) Has been cancelled
				
			test / Linux (true, vim, v8.0.0027) (push) Has been cancelled
				
			test / Linux (true, vim, v8.0.0183) (push) Has been cancelled
				
			test / Linux (vim, nightly) (push) Has been cancelled
				
			test / Linux (vim, v8.0.0184) (push) Has been cancelled
				
			test / Linux (vim, v8.0.1453) (push) Has been cancelled
				
			test / Linux (vim, v8.1.2269) (push) Has been cancelled
				
			test / Linux (vim, v8.2.2434) (push) Has been cancelled
				
			test / Linux (vim, v8.2.3995) (push) Has been cancelled
				
			test / Windows (nvim, nightly) (push) Has been cancelled
				
			test / Windows (nvim, v0.3.8) (push) Has been cancelled
				
			test / Windows (nvim, v0.4.2) (push) Has been cancelled
				
			test / Windows (nvim, v0.4.3) (push) Has been cancelled
				
			test / Windows (nvim, v0.4.4) (push) Has been cancelled
				
			test / Windows (nvim, v0.5.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.5.1) (push) Has been cancelled
				
			test / Windows (nvim, v0.6.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.6.1) (push) Has been cancelled
				
			test / Windows (nvim, v0.7.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.7.2) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.1) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.2) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.3) (push) Has been cancelled
				
			test / Windows (nvim, v0.9.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.9.1) (push) Has been cancelled
				
			test / Windows (vim, nightly) (push) Has been cancelled
				
			test / Windows (vim, v7.4.1185) (push) Has been cancelled
				
			test / Windows (vim, v7.4.1689) (push) Has been cancelled
				
			test / Windows (vim, v8.0.0027) (push) Has been cancelled
				
			test / Windows (vim, v8.0.1453) (push) Has been cancelled
				
			test / Windows (vim, v8.1.2269) (push) Has been cancelled
				
			test / Windows (vim, v8.2.2434) (push) Has been cancelled
				
			test / Windows (vim, v8.2.3995) (push) Has been cancelled
				
			docker / docker (push) Has been cancelled
				
			mirror / check (coding) (push) Has been cancelled
				
			mirror / check (gitee) (push) Has been cancelled
				
			mirror / check (gitlab) (push) Has been cancelled
				
			
		
			
				
	
	
		
			123 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
local parser = require("neo-tree.command.parser")
 | 
						|
local utils = require("neo-tree.utils")
 | 
						|
 | 
						|
local M = {
 | 
						|
  show_key_value_completions = true,
 | 
						|
}
 | 
						|
 | 
						|
local get_path_completions = function(key_prefix, base_path)
 | 
						|
  key_prefix = key_prefix or ""
 | 
						|
  local completions = {}
 | 
						|
  local expanded = parser.resolve_path(base_path)
 | 
						|
  local path_completions = vim.fn.glob(expanded .. "*", false, true)
 | 
						|
  for _, completion in ipairs(path_completions) do
 | 
						|
    if expanded ~= base_path then
 | 
						|
      -- we need to recreate the relative path from the aboluste path
 | 
						|
      -- first strip trailing slashes to normalize
 | 
						|
      if expanded:sub(-1) == utils.path_separator then
 | 
						|
        expanded = expanded:sub(1, -2)
 | 
						|
      end
 | 
						|
      if base_path:sub(-1) == utils.path_separator then
 | 
						|
        base_path = base_path:sub(1, -2)
 | 
						|
      end
 | 
						|
      -- now put just the current completion onto the base_path being used
 | 
						|
      completion = base_path .. string.sub(completion, #expanded + 1)
 | 
						|
    end
 | 
						|
    table.insert(completions, key_prefix .. completion)
 | 
						|
  end
 | 
						|
 | 
						|
  return table.concat(completions, "\n")
 | 
						|
end
 | 
						|
 | 
						|
local get_ref_completions = function(key_prefix)
 | 
						|
  key_prefix = key_prefix or ""
 | 
						|
  local completions = { key_prefix .. "HEAD" }
 | 
						|
  local ok, refs = utils.execute_command("git show-ref")
 | 
						|
  if not ok then
 | 
						|
    return ""
 | 
						|
  end
 | 
						|
  for _, ref in ipairs(refs) do
 | 
						|
    local _, i = ref:find("refs%/%a+%/")
 | 
						|
    if i then
 | 
						|
      table.insert(completions, key_prefix .. ref:sub(i + 1))
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  return table.concat(completions, "\n")
 | 
						|
end
 | 
						|
 | 
						|
M.complete_args = function(argLead, cmdLine)
 | 
						|
  local candidates = {}
 | 
						|
  local existing = utils.split(cmdLine, " ")
 | 
						|
  local parsed = parser.parse(existing, false)
 | 
						|
 | 
						|
  local eq = string.find(argLead, "=")
 | 
						|
  if eq == nil then
 | 
						|
    if M.show_key_value_completions then
 | 
						|
      -- may be the start of a new key=value pair
 | 
						|
      for _, key in ipairs(parser.list_args) do
 | 
						|
        key = tostring(key)
 | 
						|
        if key:find(argLead, 1, true) and not parsed[key] then
 | 
						|
          table.insert(candidates, key .. "=")
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      for _, key in ipairs(parser.path_args) do
 | 
						|
        key = tostring(key)
 | 
						|
        if key:find(argLead, 1, true) and not parsed[key] then
 | 
						|
          table.insert(candidates, key .. "=./")
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      for _, key in ipairs(parser.ref_args) do
 | 
						|
        key = tostring(key)
 | 
						|
        if key:find(argLead, 1, true) and not parsed[key] then
 | 
						|
          table.insert(candidates, key .. "=")
 | 
						|
        end
 | 
						|
      end
 | 
						|
    end
 | 
						|
  else
 | 
						|
    -- continuation of a key=value pair
 | 
						|
    local key = string.sub(argLead, 1, eq - 1)
 | 
						|
    local value = string.sub(argLead, eq + 1)
 | 
						|
    local arg_type = parser.arg_type_lookup[key]
 | 
						|
    if arg_type == parser.PATH then
 | 
						|
      return get_path_completions(key .. "=", value)
 | 
						|
    elseif arg_type == parser.REF then
 | 
						|
      return get_ref_completions(key .. "=")
 | 
						|
    elseif arg_type == parser.LIST then
 | 
						|
      local valid_values = parser.arguments[key].values
 | 
						|
      if valid_values and not parsed[key] then
 | 
						|
        for _, vv in ipairs(valid_values) do
 | 
						|
          if vv:find(value) then
 | 
						|
            table.insert(candidates, key .. "=" .. vv)
 | 
						|
          end
 | 
						|
        end
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  -- may be a value without a key
 | 
						|
  for value, key in pairs(parser.reverse_lookup) do
 | 
						|
    value = tostring(value)
 | 
						|
    local key_already_used = false
 | 
						|
    if parser.arg_type_lookup[key] == parser.LIST then
 | 
						|
      key_already_used = type(parsed[key]) ~= "nil"
 | 
						|
    else
 | 
						|
      key_already_used = type(parsed[value]) ~= "nil"
 | 
						|
    end
 | 
						|
 | 
						|
    if not key_already_used and value:find(argLead, 1, true) then
 | 
						|
      table.insert(candidates, value)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  if #candidates == 0 then
 | 
						|
    -- default to path completion
 | 
						|
    return get_path_completions(nil, argLead) .. "\n" .. get_ref_completions(nil)
 | 
						|
  end
 | 
						|
  return table.concat(candidates, "\n")
 | 
						|
end
 | 
						|
 | 
						|
return M
 |