diff options
| author | Daniil Rozanov <daniilrozzanov@gmail.com> | 2024-04-24 03:34:52 +0300 | 
|---|---|---|
| committer | Daniil Rozanov <daniilrozzanov@gmail.com> | 2024-04-24 03:34:52 +0300 | 
| commit | f9b36bf730fda5488be87b91fd03a6f7cbf64e73 (patch) | |
| tree | d8a7da573111d40c0e51c9e9954a3bb1977dd39c /lua/cmake/telescope/pickers.lua | |
| parent | 672f0d32e322b79661b5d7959887adaa9e41ad98 (diff) | |
refactor: full rewrite
Diffstat (limited to 'lua/cmake/telescope/pickers.lua')
| -rw-r--r-- | lua/cmake/telescope/pickers.lua | 102 | 
1 files changed, 102 insertions, 0 deletions
diff --git a/lua/cmake/telescope/pickers.lua b/lua/cmake/telescope/pickers.lua new file mode 100644 index 0000000..c543df8 --- /dev/null +++ b/lua/cmake/telescope/pickers.lua @@ -0,0 +1,102 @@ +local pickers = require("telescope.pickers") +local finders = require("telescope.finders") +local conf = require("telescope.config").values +local actions = require("telescope.actions") +local action_state = require("telescope.actions.state") +local cmake_make_entry = require("cmake.telescope.make_entry") +local previewers = require("cmake.telescope.previewers") + +local M = {} + +M.build_dirs = function(opts) +	local cmake = require("cmake") +	pickers +		.new(opts, { +			prompt_title = "CMake Builds", +			finder = finders.new_table({ +				results = cmake.project.fileapis, +				-- entry_maker = cmake_make_entry.gen_from_fileapi(opts), +				entry_maker = function(entry) +					return { +						value = entry, +						display = entry.path, +						ordinal = entry.path, +					} +				end, +				sorter = conf.generic_sorter(opts), +				-- attach_mappings = function(prompt_bufnr, map) +				-- 	actions.select_default:replace(function() end) +				-- 	return true +				-- end, +			}), +		}) +		:find() +end + +M.configure = function(opts) +	local cmake = require("cmake") +	local runner = require("cmake.runner") +	opts.layout_strategy = "vertical" +	opts.layout_config = { +		prompt_position = "top", +		preview_cutoff = 0, +		preview_height = 5, +		mirror = true, +	} +	pickers +		.new(opts, { +			default_selection_index = cmake.project:current_configure_index(), +			prompt_title = "CMake Configure Options", +			finder = finders.new_table({ +				results = cmake.project:list_configs(), +				entry_maker = cmake_make_entry.gen_from_configure(opts), +			}), +			sorter = conf.generic_sorter(opts), +			previewer = previewers.configure_previewer(), +			attach_mappings = function(prompt_bufnr, map) +				actions.select_default:replace(function() +					actions.close(prompt_bufnr) +					local selection = action_state.get_selected_entry() +					cmake.project.current_config = selection.value +					runner.start(selection.value.generate_command) +				end) +				return true +			end, +		}) +		:find() +end + +M.build = function(opts) +	local cmake = require("cmake") +	local runner = require("cmake.runner") +	opts.layout_strategy = "vertical" +	opts.layout_config = { +		prompt_position = "top", +		preview_cutoff = 0, +		preview_height = 5, +		mirror = true, +	} +	pickers +		.new(opts, { +			default_selection_index = cmake.project:current_build_index(), +			prompt_title = "CMake Build Options", +			finder = finders.new_table({ +				results = cmake.project:list_builds(), +				entry_maker = cmake_make_entry.gen_from_configure(opts), +			}), +			sorter = conf.generic_sorter(opts), +			previewer = previewers.build_previewer(), +			attach_mappings = function(prompt_bufnr, map) +				actions.select_default:replace(function() +					actions.close(prompt_bufnr) +					local selection = action_state.get_selected_entry() +					cmake.project.current_config = selection.value +					runner.start(selection.value.build_command) +				end) +				return true +			end, +		}) +		:find() +end + +return M  | 
