diff options
| author | anott03 <amitav_nott@ryecountryday.org> | 2021-07-14 13:25:00 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-07-14 19:25:00 +0200 |
| commit | df579bac425e4b6b69a0c8e694b154610cd5420b (patch) | |
| tree | fc4eb1bcbeeabe199bd997757bd72892fb4c07a0 /lua/telescope/builtin/files.lua | |
| parent | a4896e5ef39a8006a8251d48d4cf24aac81a4f94 (diff) | |
refactor: move from telescope.path to plenary.path (#473)
This will deprecate telescope.path, we will remove it soon. Please move over to plenary.path
Co-authored-by: Simon Hauser <Simon-Hauser@outlook.de>
Diffstat (limited to 'lua/telescope/builtin/files.lua')
| -rw-r--r-- | lua/telescope/builtin/files.lua | 68 |
1 files changed, 53 insertions, 15 deletions
diff --git a/lua/telescope/builtin/files.lua b/lua/telescope/builtin/files.lua index 9aee76a..d1e80f7 100644 --- a/lua/telescope/builtin/files.lua +++ b/lua/telescope/builtin/files.lua @@ -47,10 +47,9 @@ files.live_grep = function(opts) end, vim.api.nvim_list_bufs()) if not next(bufnrs) then return end - local tele_path = require'telescope.path' for _, bufnr in ipairs(bufnrs) do local file = vim.api.nvim_buf_get_name(bufnr) - table.insert(filelist, tele_path.make_relative(file, opts.cwd)) + table.insert(filelist, Path:new(file):make_relative(opts.cwd)) end elseif search_dirs then for i, path in ipairs(search_dirs) do @@ -242,6 +241,10 @@ end files.file_browser = function(opts) opts = opts or {} + local is_dir = function(value) + return value:sub(-1, -1) == os_sep + end + opts.depth = opts.depth or 1 opts.cwd = opts.cwd and vim.fn.expand(opts.cwd) or vim.loop.cwd() opts.new_finder = opts.new_finder or function(path) @@ -258,18 +261,53 @@ files.file_browser = function(opts) }) table.insert(data, 1, '..' .. os_sep) - return finders.new_table { - results = data, - entry_maker = (function() - local tele_path = require'telescope.path' - local gen = make_entry.gen_from_file(opts) - return function(entry) - local tmp = gen(entry) - tmp.ordinal = tele_path.make_relative(entry, opts.cwd) - return tmp + local maker = function() + local mt = {} + mt.cwd = opts.cwd + mt.display = function(entry) + local hl_group + local display = utils.transform_path(opts, entry.value) + if is_dir(entry.value) then + display = display .. os_sep + if not opts.disable_devicons then + display = (opts.dir_icon or "") .. " " .. display + hl_group = "Default" + end + else + display, hl_group = utils.transform_devicons(entry.value, display, opts.disable_devicons) end - end)() - } + + if hl_group then + return display, { { {1, 3}, hl_group } } + else + return display + end + end + + mt.__index = function(t, k) + local raw = rawget(mt, k) + if raw then return raw end + + if k == "path" then + local retpath = Path:new({t.cwd, t.value}):absolute() + if not vim.loop.fs_access(retpath, "R", nil) then + retpath = t.value + end + if is_dir(t.value) then retpath = retpath .. os_sep end + return retpath + end + + return rawget(t, rawget({ value = 1 }, k)) + end + + return function(line) + local tbl = {line} + tbl.ordinal = Path:new(line):make_relative(opts.cwd) + return setmetatable(tbl, mt) + end + end + + return finders.new_table { results = data, entry_maker = maker() } end pickers.new(opts, { @@ -279,7 +317,7 @@ files.file_browser = function(opts) sorter = conf.file_sorter(opts), attach_mappings = function(prompt_bufnr, map) action_set.select:replace_if(function() - return action_state.get_selected_entry().path:sub(-1) == os_sep + return is_dir(action_state.get_selected_entry().path) end, function() local new_cwd = vim.fn.expand(action_state.get_selected_entry().path:sub(1, -2)) local current_picker = action_state.get_current_picker(prompt_bufnr) @@ -299,7 +337,7 @@ files.file_browser = function(opts) end local fpath = current_picker.cwd .. os_sep .. file - if string.sub(fpath, -1) ~= os_sep then + if not is_dir(fpath) then actions.close(prompt_bufnr) Path:new(fpath):touch({ parents = true }) vim.cmd(string.format(':e %s', fpath)) |
