Compare commits
No commits in common. 'master' and 'v0.2.2' have entirely different histories.
@ -1,3 +0,0 @@
|
||||
# These are supported funding model platforms
|
||||
|
||||
github: ray-x
|
@ -1,6 +1,3 @@
|
||||
selene.toml
|
||||
|
||||
lua/navigator.lua.bak
|
||||
tests/fixtures/tests
|
||||
.vim/
|
||||
*cache*/
|
||||
*target*/
|
||||
tests/fixtures/tests
|
@ -1,6 +0,0 @@
|
||||
{
|
||||
"$schema": "https://raw.githubusercontent.com/sumneko/vscode-lua/master/setting/schema.json",
|
||||
"Lua.workspace.library": [
|
||||
"${3rd}/luassert/library"
|
||||
]
|
||||
}
|
@ -1,332 +0,0 @@
|
||||
!_TAG_FILE_FORMAT 2 /extended format; --format=1 will not append ;" to lines/
|
||||
!_TAG_FILE_SORTED 1 /0=unsorted, 1=sorted, 2=foldcase/
|
||||
!_TAG_OUTPUT_EXCMD number /number, pattern, mixed, or combineV2/
|
||||
!_TAG_OUTPUT_FILESEP slash /slash or backslash/
|
||||
!_TAG_OUTPUT_MODE u-ctags /u-ctags or e-ctags/
|
||||
!_TAG_PATTERN_LENGTH_LIMIT 96 /0 for no limit/
|
||||
!_TAG_PROC_CWD /home/ray/github/ray-x/navigator.lua/ //
|
||||
!_TAG_PROGRAM_AUTHOR Universal Ctags Team //
|
||||
!_TAG_PROGRAM_NAME Universal Ctags /Derived from Exuberant Ctags/
|
||||
!_TAG_PROGRAM_URL https://ctags.io/ /official site/
|
||||
!_TAG_PROGRAM_VERSION 5.9.0 /227c65e76/
|
||||
Custom_fold_text lua/navigator/foldts.lua 20;" f
|
||||
Fix lua/navigator/protocal.txt 374;" f
|
||||
["sumneko_lua"] issue130/init.lua 62;" f
|
||||
["tsserver"] issue130/init.lua 71;" f
|
||||
['<Tab>'] playground/init.lua 72;" f
|
||||
['sumneko_lua'] playground/init_130.lua 34;" f
|
||||
['sumneko_lua'] playground/init_131.lua 22;" f
|
||||
['sumneko_lua'] playground/init_lsp_installer.lua 22;" f
|
||||
['tsserver'] playground/init_130.lua 43;" f
|
||||
['tsserver'] playground/init_131.lua 31;" f
|
||||
['tsserver'] playground/init_lsp_installer.lua 31;" f
|
||||
\x21 tests/fixtures/tests 133;" f
|
||||
_ lua/navigator/util.lua 300;" f
|
||||
_update_sign lua/navigator/codeAction.lua 44;" f
|
||||
_update_sign lua/navigator/codelens.lua 26;" f
|
||||
_update_virtual_text lua/navigator/codeAction.lua 27;" f
|
||||
action_virtual_call_back lua/navigator/codeAction.lua 141;" f
|
||||
add lua/navigator/lspclient/clients.lua 54;" f
|
||||
add_highlight lua/navigator/lspclient/highlight.lua 34;" f unknown:M
|
||||
add_locs lua/navigator/dochighlight.lua 15;" f
|
||||
add_servers lua/navigator/lspclient/clients.lua 680;" f
|
||||
add_workspace_folder lua/navigator/workspace.lua 9;" f unknown:M
|
||||
adjust_foldend lua/navigator/foldlsp.lua 120;" f unknown:M
|
||||
adjust_foldstart lua/navigator/foldlsp.lua 116;" f unknown:M
|
||||
async thread.lua 4;" f
|
||||
async_hdlr lua/navigator/reference.lua 139;" f unknown:M
|
||||
async_ref lua/navigator/reference.lua 148;" f
|
||||
autocmd lua/navigator/lspclient/mapping.lua 216;" f
|
||||
before lua/navigator/dochighlight.lua 125;" f
|
||||
buf_func lua/navigator/treesitter.lua 442;" f unknown:M
|
||||
buf_ts lua/navigator/treesitter.lua 489;" f unknown:M
|
||||
bufs_ts lua/navigator/treesitter.lua 511;" f unknown:M
|
||||
call_async lua/navigator/lspwrapper.lua 153;" f unknown:M
|
||||
call_hierarchy_handler lua/navigator/cclshierarchy.lua 12;" f
|
||||
call_hierarchy_handler lua/navigator/hierarchy.lua 12;" f
|
||||
call_sync lua/navigator/lspwrapper.lua 145;" f unknown:M
|
||||
callback lua/navigator/lspwrapper.lua 155;" f
|
||||
check_cap lua/navigator/lspclient/mapping.lua 84;" f
|
||||
check_capabilities lua/navigator/lspwrapper.lua 121;" f unknown:M
|
||||
check_lhs lua/navigator/lspwrapper.lua 31;" f
|
||||
clear_all_buf lua/navigator/util.lua 380;" f unknown:M
|
||||
clear_buf lua/navigator/util.lua 366;" f unknown:M
|
||||
clear_diag_VT lua/navigator/diagnostics.lua 325;" f
|
||||
clear_usage_highlights lua/navigator/treesitter.lua 612;" f unknown:M
|
||||
cmd_nohl lua/navigator/dochighlight.lua 201;" f
|
||||
cmp_kind lua/navigator/lspclient/lspkind.lua 128;" f unknown:lspkind
|
||||
code_action lua/navigator/codeAction.lua 161;" f unknown:code_action
|
||||
code_action_prompt lua/navigator/codeAction.lua 188;" f unknown:code_action
|
||||
code_action_req lua/navigator/codeAction.lua 145;" f
|
||||
codelens_hdlr lua/navigator/codelens.lua 49;" f
|
||||
comp_kind lua/navigator/lspclient/lspkind.lua 120;" f unknown:lspkind
|
||||
config lua/navigator/diagnostics.lua 474;" f unknown:M
|
||||
config playground/init.lua 32;" f
|
||||
config playground/init.lua 47;" f
|
||||
config playground/init.lua 60;" f
|
||||
config playground/init_131.lua 17;" f
|
||||
config playground/init_131.lua 51;" f
|
||||
config playground/init_lsp_installer.lua 17;" f
|
||||
config playground/init_lsp_installer.lua 51;" f
|
||||
config playground/init_ts_only.lua 35;" f
|
||||
config playground/init_ts_only.lua 52;" f
|
||||
config_values lua/navigator.lua 212;" f unknown:M
|
||||
config_values lua/navigator.lua.bak 47;" f unknown:M
|
||||
ctags lua/navigator/ctags.lua 133;" f
|
||||
ctags_gen lua/navigator/ctags.lua 54;" f
|
||||
ctags_symbols lua/navigator/ctags.lua 85;" f
|
||||
curriedDot playground/js/curry.js 1;" f
|
||||
cut lua/navigator/lru.lua 60;" f
|
||||
debounce_trailing lua/navigator/debounce.lua 3;" f unknown:M
|
||||
debug_folds lua/navigator/foldlsp.lua 82;" f unknown:M
|
||||
def lua/navigator/definition.lua 145;" f
|
||||
def_preview lua/navigator/definition.lua 41;" f
|
||||
definition_hdlr README.md 759;" f
|
||||
definition_hdlr doc/navigator.txt 662;" f
|
||||
definition_hdlr lua/navigator/definition.lua 8;" f
|
||||
del lua/navigator/lru.lua 95;" f
|
||||
del_keymap lua/navigator/lspclient/mapping.lua 131;" f
|
||||
delete lua/navigator/lru.lua 145;" f
|
||||
deprecated lua/navigator.lua 117;" f unknown:M
|
||||
diag_hdlr lua/navigator/diagnostics.lua 196;" f
|
||||
diagnositc_config_sign lua/navigator/lspclient/highlight.lua 7;" f unknown:M
|
||||
dirname lua/navigator/lspclient/clients.lua 85;" f
|
||||
disable lua/navigator/codelens.lua 99;" f unknown:M
|
||||
displayName playground/js/closure.js 3;" f
|
||||
documentHighlight lua/navigator/dochighlight.lua 218;" f
|
||||
document_symbol_handler lua/navigator/symbols.lua 43;" f unknown:M
|
||||
document_symbols lua/navigator/symbols.lua 21;" f unknown:M
|
||||
empty lua/navigator/util.lua 425;" f unknown:M
|
||||
encoding lua/navigator/util.lua 436;" f unknown:M
|
||||
entry_to_item lua/navigator/ctags.lua 9;" f
|
||||
error lua/navigator/util.lua 203;" f unknown:M
|
||||
error lua/navigator/util.lua 460;" f unknown:M
|
||||
error_marker lua/navigator/diagnostics.lua 57;" f
|
||||
exclude lua/navigator/util.lua 341;" f unknown:M
|
||||
expand playground/init.lua 65;" f
|
||||
extend_config lua/navigator.lua 138;" f
|
||||
extend_config lua/navigator.lua.bak 27;" f
|
||||
extension lua/navigator/render.lua 12;" f
|
||||
extract_result lua/navigator/lspwrapper.lua 109;" f
|
||||
file_exists lua/navigator/util.lua 75;" f unknown:M
|
||||
filename lua/navigator/render.lua 5;" f
|
||||
find_definition lua/navigator/treesitter.lua 75;" f unknown:M
|
||||
find_ts_func_by_range lua/navigator/lspwrapper.lua 246;" f
|
||||
fmt lua/navigator/util.lua 208;" f unknown:M
|
||||
fnamemodify lua/navigator/lspwrapper.lua 56;" f
|
||||
fold_handler lua/navigator/foldlsp.lua 90;" f unknown:M
|
||||
folds_levels lua/navigator/foldts.lua 53;" f
|
||||
format_hdl lua/navigator/formatting.lua 4;" f
|
||||
func thread.lua 1;" f
|
||||
get lua/navigator/lru.lua 112;" f
|
||||
getArgs lua/navigator/util.lua 245;" f unknown:M
|
||||
getDir lua/navigator/util.lua 119;" f
|
||||
get_all_nodes lua/navigator/treesitter.lua 267;" f
|
||||
get_base lua/navigator/util.lua 109;" f unknown:M
|
||||
get_cfg lua/navigator/lspclient/clients.lua 685;" f
|
||||
get_count lua/navigator/diagnostics.lua 49;" f
|
||||
get_current_winid lua/navigator/codeAction.lua 23;" f
|
||||
get_current_winid lua/navigator/util.lua 387;" f unknown:M
|
||||
get_data_from_file lua/navigator/util.lua 36;" f unknown:M
|
||||
get_definitions lua/navigator/treesitter.lua 111;" f
|
||||
get_fold_indic lua/navigator/foldlsp.lua 130;" f unknown:M
|
||||
get_fold_indic lua/navigator/foldts.lua 162;" f unknown:M
|
||||
get_icon lua/navigator/treesitter.lua 27;" f
|
||||
get_keymaps_help lua/navigator/lspclient/mapping.lua 333;" f unknown:M
|
||||
get_line_diagnostic lua/navigator/diagnostics.lua 452;" f unknown:M
|
||||
get_namespace lua/navigator/codeAction.lua 19;" f
|
||||
get_node_at_line lua/navigator/treesitter.lua 561;" f unknown:M
|
||||
get_node_at_pos lua/navigator/treesitter.lua 616;" f unknown:M
|
||||
get_node_scope lua/navigator/treesitter.lua 632;" f unknown:M
|
||||
get_pads lua/navigator/render.lua 17;" f
|
||||
get_relative_path lua/navigator/util.lua 137;" f unknown:M
|
||||
get_scope lua/navigator/treesitter.lua 151;" f
|
||||
get_smallest_context lua/navigator/treesitter.lua 213;" f
|
||||
get_symbol lua/navigator/definition.lua 36;" f
|
||||
get_symbol lua/navigator/dochighlight.lua 11;" f
|
||||
get_symbol lua/navigator/lspwrapper.lua 24;" f unknown:M
|
||||
goto_adjacent_usage lua/navigator/treesitter.lua 230;" f unknown:M
|
||||
goto_adjent_reference lua/navigator/dochighlight.lua 161;" f
|
||||
goto_definition lua/navigator/treesitter.lua 35;" f unknown:M
|
||||
goto_next_usage lua/navigator/treesitter.lua 256;" f unknown:M
|
||||
goto_previous_usage lua/navigator/treesitter.lua 259;" f unknown:M
|
||||
handle_document_highlight lua/navigator/dochighlight.lua 141;" f
|
||||
handlers['textDocument/codeLens'] lua/navigator/codelens.lua 75;" f unknown:vim.lsp
|
||||
handlers['textDocument/documentHighlight'] lua/navigator/dochighlight.lua 229;" f unknown:vim.lsp
|
||||
hi_symbol lua/navigator/dochighlight.lua 46;" f
|
||||
hide_diagnostic lua/navigator/diagnostics.lua 336;" f unknown:M
|
||||
highlight_usages lua/navigator/treesitter.lua 588;" f unknown:M
|
||||
i tests/fixtures/tests 122;" f
|
||||
implementation lua/navigator/implementation.lua 24;" f unknown:M
|
||||
implementation_handler lua/navigator/implementation.lua 18;" f
|
||||
incoming_calls lua/navigator/cclshierarchy.lua 72;" f unknown:M
|
||||
incoming_calls lua/navigator/hierarchy.lua 80;" f unknown:M
|
||||
incoming_calls_handler lua/navigator/cclshierarchy.lua 54;" f
|
||||
incoming_calls_handler lua/navigator/hierarchy.lua 63;" f
|
||||
info lua/navigator.lua 7;" f
|
||||
info lua/navigator/util.lua 197;" f unknown:M
|
||||
info lua/navigator/util.lua 464;" f unknown:M
|
||||
init lua/navigator/lazyloader.lua 2;" f
|
||||
init lua/navigator/lspclient/lspkind.lua 132;" f unknown:lspkind
|
||||
inline lua/navigator/codelens.lua 117;" f unknown:M
|
||||
io_read lua/navigator/util.lua 64;" f unknown:M
|
||||
key lua/navigator/treesitter.lua 263;" f
|
||||
lines_from_locations lua/navigator/lspwrapper.lua 55;" f unknown:M
|
||||
list_workspace_folders lua/navigator/workspace.lua 92;" f unknown:M
|
||||
load lua/navigator/lazyloader.lua 46;" f
|
||||
load_cfg lua/navigator/lspclient/clients.lua 372;" f
|
||||
load_plugins playground/init.lua 26;" f
|
||||
load_plugins playground/init_130.lua 13;" f
|
||||
load_plugins playground/init_131.lua 10;" f
|
||||
load_plugins playground/init_lsp_installer.lua 10;" f
|
||||
load_plugins playground/init_ts_only.lua 26;" f
|
||||
location_handler lua/navigator/implementation.lua 10;" f
|
||||
locations_to_items lua/navigator/lspwrapper.lua 315;" f unknown:M
|
||||
log lua/navigator/util.lua 194;" f unknown:M
|
||||
lru_pairs lua/navigator/lru.lua 164;" f
|
||||
lsp_startup lua/navigator/lspclient/clients.lua 462;" f
|
||||
main README.md 36;" f
|
||||
main doc/navigator.txt 86;" f
|
||||
makeFreeSpace lua/navigator/lru.lua 105;" f
|
||||
makeFunc playground/js/closure.js 1;" f
|
||||
map lua/navigator/util.lua 91;" f unknown:M
|
||||
match_parameter lua/navigator/signature.lua 5;" f
|
||||
matches lua/navigator/foldts.lua 69;" f
|
||||
merge lua/navigator/util.lua 84;" f unknown:M
|
||||
mk_handler lua/navigator/util.lua 413;" f unknown:M
|
||||
mynext lua/navigator/lru.lua 149;" f
|
||||
nav_doc_hl lua/navigator/dochighlight.lua 208;" f
|
||||
new lua/navigator/lru.lua 32;" f unknown:lru
|
||||
new_list_view lua/navigator/gui.lua 10;" f unknown:M
|
||||
node_in_range lua/navigator/treesitter.lua 547;" f
|
||||
node_is_definination lua/navigator/treesitter.lua 51;" f
|
||||
nohl lua/navigator/dochighlight.lua 34;" f
|
||||
nv_ref_async lua/navigator/reference.lua 109;" f
|
||||
nvim_0_6_1 lua/navigator/util.lua 391;" f unknown:M
|
||||
nvim_0_8 lua/navigator/util.lua 402;" f unknown:M
|
||||
oldval tests/fixtures/tests 124;" f
|
||||
on_attach README.md 243;" f
|
||||
on_attach README.md 303;" f
|
||||
on_attach README.md 583;" f
|
||||
on_attach doc/navigator.txt 247;" f
|
||||
on_attach doc/navigator.txt 289;" f
|
||||
on_attach doc/navigator.txt 505;" f
|
||||
on_attach issue130/init.lua 72;" f unknown:options
|
||||
on_attach lua/navigator.lua 26;" f
|
||||
on_attach lua/navigator/foldlsp.lua 25;" f unknown:M
|
||||
on_attach lua/navigator/foldts.lua 15;" f unknown:M
|
||||
on_attach lua/navigator/lspclient/attach.lua 10;" f unknown:M
|
||||
on_attach lua/navigator/lspclient/clients.lua 180;" f
|
||||
on_attach lua/navigator/lspclient/clients.lua 204;" f
|
||||
on_attach lua/navigator/lspclient/clients.lua 552;" f unknown:cfg
|
||||
on_attach lua/navigator/lspclient/clients.lua 564;" f unknown:cfg
|
||||
on_attach lua/navigator/lspclient/clients.lua 576;" f unknown:cfg
|
||||
on_attach lua/navigator/lspclient/clients.lua 604;" f unknown:cfg
|
||||
on_attach lua/navigator/lspclient/clients.lua 660;" f unknown:cfg
|
||||
on_attach playground/init_130.lua 44;" f unknown:options
|
||||
on_attach playground/init_131.lua 32;" f unknown:options
|
||||
on_attach playground/init_lsp_installer.lua 32;" f unknown:options
|
||||
on_confirm lua/navigator/workspace.lua 58;" f
|
||||
on_exit lua/navigator/ctags.lua 73;" f
|
||||
on_filetype lua/navigator/lspclient/clients.lua 806;" f
|
||||
on_init lua/navigator/lspclient/clients.lua 594;" f unknown:cfg
|
||||
on_input_filter lua/navigator/workspace.lua 65;" f
|
||||
on_move lua/navigator/workspace.lua 99;" f
|
||||
on_new_config lua/navigator/lspclient/clients.lua 247;" f
|
||||
on_stdout lua/navigator/ctags.lua 69;" f
|
||||
open_file lua/navigator/util.lua 326;" f unknown:M
|
||||
open_log lua/navigator/util.lua 274;" f unknown:M
|
||||
open_lsp_log lua/navigator/lspclient/config.lua 22;" f unknown:M
|
||||
order_locations lua/navigator/lspwrapper.lua 262;" f
|
||||
outgoing_calls lua/navigator/cclshierarchy.lua 89;" f unknown:M
|
||||
outgoing_calls lua/navigator/hierarchy.lua 91;" f unknown:M
|
||||
outgoing_calls_handler lua/navigator/cclshierarchy.lua 64;" f
|
||||
outgoing_calls_handler lua/navigator/hierarchy.lua 72;" f
|
||||
p lua/navigator/util.lua 259;" f unknown:M
|
||||
pack lua/navigator/util.lua 279;" f unknown:table
|
||||
partial lua/navigator/util.lua 419;" f unknown:M
|
||||
path_cur lua/navigator/util.lua 23;" f unknown:M
|
||||
path_sep lua/navigator/util.lua 12;" f unknown:M
|
||||
prepare_for_render lua/navigator/render.lua 51;" f unknown:M
|
||||
prepare_node lua/navigator/treesitter.lua 138;" f
|
||||
printError lua/navigator/util.lua 263;" f unknown:M
|
||||
prompt lua/navigator/workspace.lua 12;" f
|
||||
prompt lua/navigator/workspace.lua 22;" f
|
||||
prompt lua/navigator/workspace.lua 30;" f
|
||||
quickfix_extract lua/navigator/util.lua 223;" f unknown:M
|
||||
range_code_action lua/navigator/codeAction.lua 173;" f unknown:code_action
|
||||
ref lua/navigator/reference.lua 202;" f
|
||||
ref_hdlr lua/navigator/reference.lua 136;" f
|
||||
ref_req lua/navigator/reference.lua 185;" f
|
||||
ref_view lua/navigator/reference.lua 13;" f
|
||||
refresh lua/navigator/codelens.lua 86;" f unknown:M
|
||||
reload lua/navigator/util.lua 269;" f unknown:M
|
||||
reload_lsp lua/navigator/lspclient/config.lua 7;" f unknown:M
|
||||
remove_workspace_folder lua/navigator/workspace.lua 17;" f unknown:M
|
||||
rename lua/navigator/rename.lua 6;" f unknown:M
|
||||
render_action_virtual_text lua/navigator/codeAction.lua 79;" f unknown:code_action
|
||||
request lua/navigator/lspwrapper.lua 464;" f unknown:M
|
||||
root_dir lua/navigator/lspclient/clients.lua 120;" f
|
||||
root_dir lua/navigator/lspclient/clients.lua 164;" f
|
||||
root_dir lua/navigator/lspclient/clients.lua 187;" f
|
||||
root_dir lua/navigator/lspclient/clients.lua 99;" f
|
||||
round lua/navigator/util.lua 32;" f unknown:M
|
||||
run_action lua/navigator/codelens.lua 105;" f unknown:M
|
||||
select lua/navigator/gui.lua 59;" f unknown:M
|
||||
set lua/navigator/lru.lua 122;" f
|
||||
setNewest lua/navigator/lru.lua 84;" f
|
||||
set_cmds lua/navigator/lspclient/mapping.lua 118;" f
|
||||
set_diag_loclist lua/navigator/diagnostics.lua 383;" f unknown:M
|
||||
set_event_handler lua/navigator/lspclient/mapping.lua 228;" f
|
||||
set_keymap lua/navigator/lspclient/mapping.lua 135;" f
|
||||
set_mapping lua/navigator/lspclient/mapping.lua 124;" f
|
||||
set_virt_eol lua/navigator/util.lua 356;" f unknown:M
|
||||
setup lua/navigator.lua 216;" f unknown:M
|
||||
setup lua/navigator.lua.bak 51;" f unknown:M
|
||||
setup lua/navigator/codelens.lua 64;" f unknown:M
|
||||
setup lua/navigator/lspclient/clients.lua 19;" f
|
||||
setup lua/navigator/lspclient/clients.lua 696;" f
|
||||
setup lua/navigator/lspclient/mapping.lua 273;" f unknown:M
|
||||
setup_fmt lua/navigator/lspclient/clients.lua 425;" f
|
||||
setup_fold lua/navigator/foldts.lua 33;" f unknown:M
|
||||
setup_plugin lua/navigator/foldlsp.lua 30;" f unknown:M
|
||||
show lua/navigator/util.lua 283;" f unknown:M
|
||||
show_buf_diagnostics lua/navigator/diagnostics.lua 351;" f unknown:M
|
||||
show_diagnostics lua/navigator/diagnostics.lua 457;" f unknown:M
|
||||
signature_handler lua/navigator/signature.lua 44;" f
|
||||
slice_locations lua/navigator/lspwrapper.lua 280;" f
|
||||
sort_select lua/navigator/codeAction.lua 154;" f
|
||||
split lua/navigator/util.lua 212;" f unknown:M
|
||||
split2 lua/navigator/util.lua 295;" f unknown:M
|
||||
start_client lua/navigator.lua 243;" f unknown:vim.lsp
|
||||
symbol_kind lua/navigator/lspclient/lspkind.lua 124;" f unknown:lspkind
|
||||
symbol_to_items lua/navigator/lspwrapper.lua 425;" f unknown:M
|
||||
symbols_to_items lua/navigator/lspwrapper.lua 75;" f unknown:M
|
||||
testitem lua/navigator/ctags.lua 144;" f
|
||||
throttle_leading lua/navigator/debounce.lua 14;" f unknown:M
|
||||
title lua/navigator/protocal.txt 388;" f
|
||||
title lua/navigator/protocal.txt 392;" f
|
||||
toggle_diagnostics lua/navigator/diagnostics.lua 342;" f unknown:M
|
||||
toggle_lspformat lua/navigator/lspclient/mapping.lua 254;" f unknown:M
|
||||
trace lua/navigator/util.lua 200;" f unknown:M
|
||||
trim_and_pad lua/navigator/util.lua 307;" f unknown:M
|
||||
trim_level lua/navigator/foldts.lua 55;" f
|
||||
ts_definition lua/navigator/lspwrapper.lua 207;" f
|
||||
ts_functions lua/navigator/lspwrapper.lua 163;" f
|
||||
type vim.toml 21;" f
|
||||
type vim.toml 26;" f
|
||||
type vim.toml 29;" f
|
||||
type vim.toml 31;" f
|
||||
unload lua/navigator/lspwrapper.lua 354;" f
|
||||
update_capabilities lua/navigator/lspclient/clients.lua 442;" f
|
||||
update_err_marker lua/navigator/diagnostics.lua 414;" f unknown:M
|
||||
update_err_marker_async lua/navigator/diagnostics.lua 191;" f
|
||||
update_folds lua/navigator/foldlsp.lua 62;" f unknown:M
|
||||
warn lua/navigator.lua 3;" f
|
||||
warn lua/navigator/util.lua 456;" f unknown:M
|
||||
workspace_symbol lua/navigator/workspace.lua 28;" f unknown:M
|
||||
workspace_symbol_handler lua/navigator/symbols.lua 103;" f unknown:M
|
||||
workspace_symbol_live lua/navigator/workspace.lua 36;" f unknown:M
|
||||
workspace_symbols lua/navigator/symbols.lua 9;" f unknown:M
|
||||
~ lua/navigator/treesitter.lua 202;" f
|
||||
~ lua/navigator/treesitter.lua 371;" f
|
@ -1,4 +1,4 @@
|
||||
function! folding#ngfoldexpr()
|
||||
function! folding#foldexpr()
|
||||
" return luaeval(printf('require"navigator.foldinglsp".get_fold_indic(%d)', v:lnum))
|
||||
return luaeval(printf('require"navigator.foldts".get_fold_indic(%d)', v:lnum))
|
||||
endfunction
|
||||
|
@ -1,11 +0,0 @@
|
||||
# Change Logs
|
||||
## 2023-12-07
|
||||
- [x] Changed key maps
|
||||
- Add fallback to key maps e.g. if `gD` does not find a type declaraion, it will fallback to `gD`
|
||||
which is default key map go to global declaration
|
||||
- `gt`: removed `gt` mapping and prefer `<space>D`
|
||||
|
||||
- [ ] Changed key maps
|
||||
I plan to change the mapping for following key maps as it conflicts with other vim default key maps
|
||||
- `gp`: changed to `<Leader>gp`
|
||||
- `gP`: changed to `<Leader>gP`
|
@ -1,897 +0,0 @@
|
||||
navigator.txt
|
||||
|
||||
================================================================================
|
||||
CONTENTS *navigator-contents*
|
||||
|
||||
1. Navigator.................................................|navigator-navigator|
|
||||
1.1. Example: Javascript closure.|navigator-example:_javascript_closure|
|
||||
1.2. Example: C++ definition.......|navigator-example:_c++_definition|
|
||||
1.3. Golang struct type.................|navigator-golang_struct_type|
|
||||
2. Features:.................................................|navigator-features:|
|
||||
3. Why a new plugin...................................|navigator-why_a_new_plugin|
|
||||
4. Similar projects / special mentions:.|navigator-similar_projects_/_special_mentions:|
|
||||
5. Install.....................................................|navigator-install|
|
||||
5.1. Setup...................................................|navigator-setup|
|
||||
5.2. Sample vimrc turning your neovim into a full-featured IDE.|navigator-sample_vimrc_turning_your_neovim_into_a_full-featured_ide|
|
||||
5.3. Work with nvim-cmp and nvim-autopairs.|navigator-work_with_nvim-cmp_and_nvim-autopairs|
|
||||
5.4. All configure options...................|navigator-all_configure_options|
|
||||
5.4.1. LSP clients.................................|navigator-lsp_clients|
|
||||
5.4.1.1. Add your own servers.........|navigator-add_your_own_servers|
|
||||
5.4.2. Disable a lsp client loading from navigator.|navigator-disable_a_lsp_client_loading_from_navigator|
|
||||
5.4.3. Try it your self.......................|navigator-try_it_your_self|
|
||||
5.4.4. Default keymaps.........................|navigator-default_keymaps|
|
||||
5.4.5. Colors/Highlight:.....................|navigator-colors/highlight:|
|
||||
5.5. Dependency.........................................|navigator-dependency|
|
||||
5.6. Integrat with lsp_installer (williamboman/nvim-lsp-installer).|navigator-integrat_with_lsp_installer_(williamboman/nvim-lsp-installer)|
|
||||
5.6.1. Integration with other lsp plugins (e.g. rust-tools, go.nvim, clangd extension).|navigator-integration_with_other_lsp_plugins_(e.g._rust-tools,_go.nvim,_clangd_extension)|
|
||||
5.7. Usage...................................................|navigator-usage|
|
||||
5.8. Configuration...................................|navigator-configuration|
|
||||
5.9. Highlight...........................................|navigator-highlight|
|
||||
5.10. commands............................................|navigator-commands|
|
||||
5.11. Screenshots......................................|navigator-screenshots|
|
||||
5.11.1. Reference....................................|navigator-reference|
|
||||
5.11.2. Definition preview..................|navigator-definition_preview|
|
||||
5.11.3. Sidebar, folding, outline....|navigator-sidebar,_folding,_outline|
|
||||
5.11.4. GUI and multigrid support....|navigator-gui_and_multigrid_support|
|
||||
5.11.5. Document Symbol and navigate through the list.|navigator-document_symbol_and_navigate_through_the_list|
|
||||
5.11.6. Workspace Symbol......................|navigator-workspace_symbol|
|
||||
5.11.7. highlight document symbol and jump between reference.|navigator-highlight_document_symbol_and_jump_between_reference|
|
||||
6. Current symbol highlight and jump backward/forward between symbols.|navigator-current_symbol_highlight_and_jump_backward/forward_between_symbols|
|
||||
6.1. Diagnostic.....................................|navigator-diagnostic|
|
||||
6.2. Edit in preview window.............|navigator-edit_in_preview_window|
|
||||
6.3. Implementation.............................|navigator-implementation|
|
||||
6.4. Fzy search in reference...........|navigator-fzy_search_in_reference|
|
||||
6.5. Code actions.................................|navigator-code_actions|
|
||||
6.6. Symbol rename...............................|navigator-symbol_rename|
|
||||
6.6.1. Fill struct with gopls.......|navigator-fill_struct_with_gopls|
|
||||
6.7. Code preview with highlight...|navigator-code_preview_with_highlight|
|
||||
6.8. Treesitter symbol.......................|navigator-treesitter_symbol|
|
||||
6.9. Signature help.............................|navigator-signature_help|
|
||||
6.10. Call hierarchy (incomming/outgoing calls).|navigator-call_hierarchy_(incomming/outgoing_calls)|
|
||||
6.11. Light bulb if codeAction available.|navigator-light_bulb_if_codeaction_available|
|
||||
6.12. Codelens........................................|navigator-codelens|
|
||||
6.13. Predefined LSP symbol nerdfont/emoji.|navigator-predefined_lsp_symbol_nerdfont/emoji|
|
||||
6.14. VS-code style folding with treesitter.|navigator-vs-code_style_folding_with_treesitter|
|
||||
6.14.1. folding function..................|navigator-folding_function|
|
||||
6.14.2. folding comments..................|navigator-folding_comments|
|
||||
7. Debug the plugin...................................|navigator-debug_the_plugin|
|
||||
8. Break changes and known issues.......|navigator-break_changes_and_known_issues|
|
||||
9. Todo...........................................................|navigator-todo|
|
||||
10. Errors and Bug Reporting..................|navigator-errors_and_bug_reporting|
|
||||
|
||||
================================================================================
|
||||
NAVIGATOR *navigator-navigator*
|
||||
|
||||
* Source code analysis and navigate tool
|
||||
* Easy code navigation, view diagnostic errors, see relationships of functions, variables
|
||||
* A plugin combines the power of LSP and 🌲🏡 Treesitter together. Not only provids a better highlight but also help you analyse symbol context effectively.
|
||||
* ctags fuzzy search & build ctags symbols
|
||||
|
||||
-
|
||||
|
||||
* [](https://youtu.be/P1kd7Y8AatE)
|
||||
|
||||
Here are some examples
|
||||
|
||||
EXAMPLE: JAVASCRIPT CLOSURE *navigator-example:_javascript_closure*
|
||||
|
||||
The following screenshot shows javascript call tree 🌲 of variable `browser` insides a closure. This feature is similar to incoming & outgoing calls from LSP. It is designed for the symbol analysis.
|
||||
|
||||
|
||||
|
||||
Explanation:
|
||||
|
||||
* The first line of floating windows shows there are 3 references for the symbol browser in closure.js
|
||||
* The first reference of browser is an assignment, an emoji 📝 indicates the value is changed in this line. In many
|
||||
cases, we search for references to find out when the value changed.
|
||||
* The second reference of `browser` is inside function `displayName` and `displayName` sit inside `makeFunc`, So you
|
||||
will see `displayName{} <- makeFunc{}`
|
||||
* The third similar to the second, as var browser is on the right side of '=', the value not changed in this line
|
||||
and emoji is not shown.
|
||||
|
||||
EXAMPLE: C++ DEFINITION *navigator-example:_c++_definition*
|
||||
|
||||
C++ example: search reference and definition
|
||||
|
||||
You may find a 🦕 dinosaur(d) on the line of `Rectangle rect,` which means there is a definition (d for def) of rect in this line.
|
||||
|
||||
`<- f main()` means the definition is inside function main().
|
||||
|
||||
GOLANG STRUCT TYPE *navigator-golang_struct_type*
|
||||
|
||||
Struct type references in multiple Go ﳑ files
|
||||
|
||||
|
||||
|
||||
This feature can provide you info in which function/class/method the variable was referenced. It is handy for a large
|
||||
project where class/function definition is too long to fit into the preview window. Also provides a bird's eye view of where the
|
||||
variable is:
|
||||
|
||||
* Referenced
|
||||
* Modified
|
||||
* Defined
|
||||
* Called
|
||||
|
||||
================================================================================
|
||||
FEATURES: *navigator-features:*
|
||||
|
||||
* LSP easy setup. Support the most commonly used lsp clients setup. Dynamic lsp activation based on buffer type. This
|
||||
also enables you to handle workspace with mixed types of codes (e.g. Go + javascript + yml). A better default setup is
|
||||
included for LSP clients.
|
||||
* Out of box experience. 10 lines of minimum vimrc can turn your neovim into a full-featured LSP & Treesitter powered IDE
|
||||
* UI with floating windows, navigator provides a visual way to manage and navigate through symbols, diagnostic errors, reference etc. It covers
|
||||
all features(handler) provided by LSP from commonly used search reference, to less commonly used search for interface
|
||||
implementation.
|
||||
* Code Action GUI
|
||||
* Luv async thread and tasks
|
||||
* Edit your code in preview window
|
||||
* Async request with lsp.buf_request for reference search
|
||||
* Treesitter symbol search. It is handy for large files (Some of LSP e.g. lua_ls, there is a 100kb file size limitation?)
|
||||
* FZY search with either native C (if gcc installed) or Lua-JIT
|
||||
* LSP multiple symbol highlight/marker and hop between document references
|
||||
* Preview definination/references
|
||||
* Better navigation for diagnostic errors, Navigate through all files/buffers that contain errors/warnings
|
||||
* Grouping references/implementation/incoming/outgoing based on file names.
|
||||
* Treesitter based variable/function context analysis. It is 10x times faster compared to purely rely on LSP. In most
|
||||
of the case, it takes treesitter less than 4 ms to read and render all nodes for a file of 1,000 LOC.
|
||||
* The first plugin, IMO, allows you to search in all treesitter symbols in the workspace.
|
||||
* Nerdfont, emoji for LSP and treesitter kind
|
||||
* Optimize display (remove trailing bracket/space), display the caller of reference, de-duplicate lsp results (e.g reference
|
||||
in the same line). Using treesitter for file preview highlighter etc
|
||||
* ccls call hierarchy (Non-standard `ccls/call` API) supports
|
||||
* Syntax folding based on treesitter or LSP_fold folding algorithm. (It behaves similar to vs-code); comment folding
|
||||
* Treesitter symbols sidebar, LSP document symbole sidebar. Both with preview and folding
|
||||
* Fully support LSP CodeAction, CodeLens, CodeLens action. Help you improve code quality.
|
||||
* LRU cache for treesitter nodes
|
||||
* Lazy loader friendly
|
||||
* Multigrid support (different font and detachable)
|
||||
|
||||
================================================================================
|
||||
WHY A NEW PLUGIN *navigator-why_a_new_plugin*
|
||||
|
||||
I'd like to go beyond what the system is offering.
|
||||
|
||||
================================================================================
|
||||
SIMILAR PROJECTS / SPECIAL MENTIONS: *navigator-similar_projects_/_special_mentions:*
|
||||
|
||||
* nvim-lsputils (https://github.com/RishabhRD/nvim-lsputils)
|
||||
* nvim-fzy (https://github.com/mfussenegger/nvim-fzy.git)
|
||||
* fuzzy (https://github.com/amirrezaask/fuzzy.nvim)
|
||||
* lspsaga (https://github.com/glepnir/lspsaga.nvim)
|
||||
* fzf-lsp lsp with fzf as gui backend (https://github.com/gfanto/fzf-lsp.nvim)
|
||||
* nvim-treesitter-textobjects (https://github.com/nvim-treesitter/nvim-treesitter-textobjects)
|
||||
|
||||
================================================================================
|
||||
INSTALL *navigator-install*
|
||||
|
||||
Require nvim-0.6.1 or above, nightly (0.8) prefered
|
||||
|
||||
You can remove your lspconfig setup and use this plugin.
|
||||
The plugin depends on lspconfig and guihua.lua (https://github.com/ray-x/guihua.lua), which provides GUI and fzy support(migrate from romgrk's project (romgrk/fzy-lua-native)).
|
||||
>
|
||||
Plug 'neovim/nvim-lspconfig'
|
||||
Plug 'ray-x/guihua.lua', {'do': 'cd lua/fzy && make' }
|
||||
Plug 'ray-x/navigator.lua'
|
||||
<
|
||||
|
||||
Note: Highly recommend: 'nvim-treesitter/nvim-treesitter'
|
||||
|
||||
Packer
|
||||
>
|
||||
use({
|
||||
'ray-x/navigator.lua',
|
||||
requires = {
|
||||
{ 'ray-x/guihua.lua', run = 'cd lua/fzy && make' },
|
||||
{ 'neovim/nvim-lspconfig' },
|
||||
},
|
||||
})
|
||||
<
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
SETUP *navigator-setup*
|
||||
|
||||
Easy setup BOTH lspconfig and navigator with one liner. Navigator covers around 20 most used LSP setup.
|
||||
>
|
||||
lua require'navigator'.setup()
|
||||
<
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
SAMPLE VIMRC TURNING YOUR NEOVIM INTO A FULL-FEATURED IDE *navigator-sample_vimrc_turning_your_neovim_into_a_full-featured_ide*
|
||||
>
|
||||
call plug#begin('~/.vim/plugged')
|
||||
Plug 'neovim/nvim-lspconfig'
|
||||
Plug 'ray-x/guihua.lua', {'do': 'cd lua/fzy && make' }
|
||||
Plug 'ray-x/navigator.lua'
|
||||
" Plug 'hrsh7th/nvim-cmp' and other plugins you commenly use...
|
||||
" optional, if you need treesitter symbol support
|
||||
Plug 'nvim-treesitter/nvim-treesitter', {'do': ':TSUpdate'}
|
||||
call plug#end()
|
||||
" No need for require('lspconfig'), navigator will configure it for you
|
||||
lua <<EOF
|
||||
require'navigator'.setup()
|
||||
EOF
|
||||
<
|
||||
|
||||
You can remove your lspconfig.lua and use the hooks of navigator.lua. As the
|
||||
navigator will bind keys and handler for you. The LSP will be loaded lazily based on filetype.
|
||||
|
||||
A treesitter only mode. In some cases LSP is buggy or not available, you can also use treesitter
|
||||
standalone
|
||||
>
|
||||
call plug#begin('~/.vim/plugged')
|
||||
Plug 'ray-x/guihua.lua', {'do': 'cd lua/fzy && make' }
|
||||
Plug 'ray-x/navigator.lua'
|
||||
" Plug 'hrsh7th/nvim-compe' and other plugins you commenly use...
|
||||
" optional, if you need treesitter symbol support
|
||||
Plug 'nvim-treesitter/nvim-treesitter', {'do': ':TSUpdate'}
|
||||
" optional:
|
||||
Plug 'nvim-treesitter/nvim-treesitter-refactor' " this provides "go to def" etc
|
||||
call plug#end()
|
||||
lua <<EOF
|
||||
require'navigator'.setup()
|
||||
EOF
|
||||
<
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
WORK WITH NVIM-CMP AND NVIM-AUTOPAIRS *navigator-work_with_nvim-cmp_and_nvim-autopairs*
|
||||
|
||||
The buffer type of navigator floating windows is `guihua`
|
||||
I would suggest disable `guihua` for autocomplete.
|
||||
e.g.
|
||||
>
|
||||
require('nvim-autopairs').setup{
|
||||
disable_filetype = { "TelescopePrompt" , "guihua", "guihua_rust", "clap_input" },
|
||||
if vim.o.ft == 'clap_input' and vim.o.ft == 'guihua' and vim.o.ft == 'guihua_rust' then
|
||||
require'cmp'.setup.buffer { completion = {enable = false} }
|
||||
end
|
||||
-- or with autocmd
|
||||
vim.cmd("autocmd FileType guihua lua require('cmp').setup.buffer { enabled = false }")
|
||||
vim.cmd("autocmd FileType guihua_rust lua require('cmp').setup.buffer { enabled = false }")
|
||||
...
|
||||
}
|
||||
<
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
ALL CONFIGURE OPTIONS *navigator-all_configure_options*
|
||||
|
||||
Nondefault configuration example:
|
||||
>
|
||||
require'navigator'.setup({
|
||||
debug = false, -- log output, set to true and log path: ~/.cache/nvim/gh.log
|
||||
width = 0.75, -- max width ratio (number of cols for the floating window) / (window width)
|
||||
height = 0.3, -- max list window height, 0.3 by default
|
||||
preview_height = 0.35, -- max height of preview windows
|
||||
border = {"╭", "─", "╮", "│", "╯", "─", "╰", "│"}, -- border style, can be one of 'none', 'single', 'double',
|
||||
-- 'shadow', or a list of chars which defines the border
|
||||
on_attach = function(client, bufnr)
|
||||
-- your hook
|
||||
end,
|
||||
-- put a on_attach of your own here, e.g
|
||||
-- function(client, bufnr)
|
||||
-- -- the on_attach will be called at end of navigator on_attach
|
||||
-- end,
|
||||
-- The attach code will apply to all LSP clients
|
||||
default_mapping = true, -- set to false if you will remap every key
|
||||
keymaps = {{key = "gK", func = "declaration()"}}, -- a list of key maps
|
||||
-- this kepmap gK will override "gD" mapping function declaration() in default kepmap
|
||||
-- please check mapping.lua for all keymaps
|
||||
treesitter_analysis = true, -- treesitter variable context
|
||||
transparency = 50, -- 0 ~ 100 blur the main window, 100: fully transparent, 0: opaque, set to nil or 100 to disable it
|
||||
lsp_signature_help = true, -- if you would like to hook ray-x/lsp_signature plugin in navigator
|
||||
-- setup here. if it is nil, navigator will not init signature help
|
||||
signature_help_cfg = nil, -- if you would like to init ray-x/lsp_signature plugin in navigator, and pass in your own config to signature help
|
||||
icons = {
|
||||
-- Code action
|
||||
code_action_icon = "🏏",
|
||||
-- Diagnostics
|
||||
diagnostic_head = '🐛',
|
||||
diagnostic_head_severity_1 = "🈲",
|
||||
-- refer to lua/navigator.lua for more icons setups
|
||||
},
|
||||
lsp_installer = false, -- set to true if you would like use the lsp installed by williamboman/nvim-lsp-installer
|
||||
lsp = {
|
||||
enable = true, -- skip lsp setup if disabled make sure add require('navigator.lspclient.mapping').setup() in you
|
||||
-- own on_attach
|
||||
code_action = {enable = true, sign = true, sign_priority = 40, virtual_text = true},
|
||||
code_lens_action = {enable = true, sign = true, sign_priority = 40, virtual_text = true},
|
||||
|
||||
format_on_save = true, -- {true|false} set to false to disasble lsp code format on save (if you are using prettier/efm/formater etc)
|
||||
-- table: {enable = {'lua', 'go'}, disable = {'javascript', 'typescript'}} to enable/disable specific language
|
||||
-- enable: a whitelist of language that will be formatted on save
|
||||
-- disable: a blacklist of language that will not be formatted on save
|
||||
-- function: function(bufnr) return true end to enable/disable lsp format on save
|
||||
|
||||
disable_format_cap = {"sqlls", "lua_ls", "gopls"}, -- a list of lsp disable format capacity (e.g. if you using efm or vim-codeformat etc), empty {} by default
|
||||
disable_lsp = {'pylsd', 'sqlls'}, -- a list of lsp server disabled for your project, e.g. denols and tsserver you may
|
||||
-- only want to enable one lsp server
|
||||
-- to disable all default config and use your own lsp setup set
|
||||
-- disable_lsp = 'all'
|
||||
-- Default {}
|
||||
diagnostic = {
|
||||
underline = true,
|
||||
virtual_text = true, -- show virtual for diagnostic message
|
||||
update_in_insert = false, -- update diagnostic message in insert mode
|
||||
float = {
|
||||
focusable = false,
|
||||
style = 'minimal',
|
||||
border = 'rounded',
|
||||
source = 'always',
|
||||
header = '',
|
||||
prefix = '',
|
||||
}
|
||||
},
|
||||
diagnostic_scrollbar_sign = {'▃', '▆', '█'}, -- experimental: diagnostic status in scroll bar area; set to false to disable the diagnostic sign,
|
||||
-- for other style, set to {'╍', 'ﮆ'} or {'-', '='}
|
||||
diagnostic_virtual_text = true, -- show virtual for diagnostic message
|
||||
diagnostic_update_in_insert = false, -- update diagnostic message in insert mode
|
||||
display_diagnostic_qf = true, -- always show quickfix if there are diagnostic errors, set to false if you want to
|
||||
ignore it
|
||||
tsserver = {
|
||||
filetypes = {'typescript'} -- disable javascript etc,
|
||||
-- set to {} to disable the lspclient for all filetypes
|
||||
},
|
||||
ctags ={
|
||||
cmd = 'ctags',
|
||||
tagfile = 'tags'
|
||||
options = '-R --exclude=.git --exclude=node_modules --exclude=test --exclude=vendor --excmd=number'
|
||||
}
|
||||
gopls = { -- gopls setting
|
||||
on_attach = function(client, bufnr) -- on_attach for gopls
|
||||
-- your special on attach here
|
||||
-- e.g. disable gopls format because a known issue https://github.com/golang/go/issues/45732
|
||||
print("i am a hook, I will disable document format")
|
||||
client.resolved_capabilities.document_formatting = false
|
||||
end,
|
||||
settings = {
|
||||
gopls = {gofumpt = false} -- disable gofumpt etc,
|
||||
}
|
||||
},
|
||||
lua_ls = {
|
||||
sumneko_root_path = vim.fn.expand("$HOME") .. "/github/sumneko/lua-language-server",
|
||||
sumneko_binary = vim.fn.expand("$HOME") .. "/github/sumneko/lua-language-server/bin/macOS/lua-language-server",
|
||||
},
|
||||
servers = {'cmake', 'ltex'}, -- by default empty, and it should load all LSP clients avalible based on filetype
|
||||
-- but if you whant navigator load e.g. `cmake` and `ltex` for you , you
|
||||
-- can put them in the `servers` list and navigator will auto load them.
|
||||
-- you could still specify the custom config like this
|
||||
-- cmake = {filetypes = {'cmake', 'makefile'}, single_file_support = false},
|
||||
}
|
||||
})
|
||||
<
|
||||
|
||||
LSP CLIENTS *navigator-lsp_clients*
|
||||
|
||||
Built clients:
|
||||
>
|
||||
local servers = {
|
||||
"angularls", "gopls", "tsserver", "flow", "bashls", "dockerls", "julials", "pylsp", "pyright",
|
||||
"jedi_language_server", "jdtls", "lua_ls", "vimls", "html", "jsonls", "solargraph", "cssls",
|
||||
"yamlls", "clangd", "ccls", "sqlls", "denols", "graphql", "dartls", "dotls",
|
||||
"kotlin_language_server", "nimls", "intelephense", "vuels", "phpactor", "omnisharp",
|
||||
"r_language_server", "rust_analyzer", "terraformls", "svelte", "texlab", "clojure_lsp", "elixirls",
|
||||
"sourcekit", "fsautocomplete", "vls", "hls"
|
||||
}
|
||||
<
|
||||
|
||||
Navigator will try to load avalible lsp server/client based on filetype. The clients has none default on_attach.
|
||||
incremental sync and debounce is enabled by navigator. And the lsp
|
||||
snippet will be enabled. So you could use COQ and nvim-cmp snippet expand.
|
||||
|
||||
Other than above setup, additional none default setup are used for following lsp:
|
||||
|
||||
* gopls
|
||||
* clangd
|
||||
* rust_analyzer
|
||||
* sqlls
|
||||
* lua_ls
|
||||
* pyright
|
||||
* ccls
|
||||
|
||||
Please check client setup (https://github.com/ray-x/navigator.lua/blob/26012cf9c172aa788a2e53018d94b32c5c75af75/lua/navigator/lspclient/clients.lua#L98-L234)
|
||||
|
||||
The plugin can work with multiple LSP, e.g sqlls+gopls+efm. But there are cases you may need to disable some of the
|
||||
servers. (Prevent loading multiple LSP for same source code.) e.g. I saw strange behaviours when I use
|
||||
pylsp+pyright+jedi
|
||||
together. If you have multiple similar LSP installed and have trouble with the plugin, please enable only one at a time.
|
||||
|
||||
ADD YOUR OWN SERVERS *navigator-add_your_own_servers*
|
||||
|
||||
Above servers covered a small part neovim lspconfig support, You can still use lspconfig to add and config servers not
|
||||
in the list. If you would like to add a server not in the list, you can check this PR https://github.com/ray-x/navigator.lua/pull/107
|
||||
|
||||
Alternatively, update following option in setup(if you do not want a PR):
|
||||
>
|
||||
require'navigator'setup{lsp={servers={'cmake', 'lexls'}}}
|
||||
<
|
||||
|
||||
Above option add cmake and lexls to the default server list
|
||||
|
||||
DISABLE A LSP CLIENT LOADING FROM NAVIGATOR *navigator-disable_a_lsp_client_loading_from_navigator*
|
||||
|
||||
Note: If you have multiple lsp installed for same language, please only enable one at a time by disable others with e.g. `disable_lsp={'denols', 'clangd'}`
|
||||
To disable a specific LSP, set `filetypes` to {} e.g.
|
||||
>
|
||||
require'navigator'.setup({
|
||||
lsp={
|
||||
pylsd={filetype={}}
|
||||
}
|
||||
})
|
||||
<
|
||||
|
||||
Or:
|
||||
>
|
||||
require'navigator'.setup({
|
||||
lsp={
|
||||
disable_lsp = {'pylsd', 'sqlls'},
|
||||
}
|
||||
})
|
||||
<
|
||||
|
||||
TRY IT YOUR SELF *navigator-try_it_your_self*
|
||||
|
||||
In `playground` folder, there is a `init.lua` and source code for you to play with. Check playground/README.md (https://github.com/ray-x/navigator.lua/blob/master/playground/README.md) for more details
|
||||
|
||||
DEFAULT KEYMAPS *navigator-default_keymaps*
|
||||
|
||||
| mode | key | function |
|
||||
| ---- | --------------- | ---------------------------------------------------------- |
|
||||
| n | gr | async references, definitions and context |
|
||||
| n | <Leader>gr | show reference and context |
|
||||
| i | <m-k> | signature help |
|
||||
| n | <c-k> | signature help |
|
||||
| n | gW | workspace symbol |
|
||||
| n | gD | declaration |
|
||||
| n | gd | definition |
|
||||
| n | g0 | document symbol |
|
||||
| n | <C-]> | go to definition (if multiple show listview) |
|
||||
| n | gp | definition preview (Go to Preview) |
|
||||
| n | <C-LeftMouse> | definition |
|
||||
| n | g<LeftMouse> | implementation |
|
||||
| n | <Leader>gt | treesitter document symbol |
|
||||
| n | <Leader>gT | treesitter symbol for all open buffers |
|
||||
| n | <Leader> ct | ctags symbol search |
|
||||
| n | <Leader> cg | ctags symbol generate |
|
||||
| n | K | hover doc |
|
||||
| n | <Space>ca | code action (when you see 🏏 ) |
|
||||
| n | <Space>la | code lens action (when you see a codelens indicator) |
|
||||
| v | <Space>ca | range code action (when you see 🏏 ) |
|
||||
| n | <Space>rn | rename with floating window |
|
||||
| n | <Leader>re | rename (lsp default) |
|
||||
| n | <Leader>gi | hierarchy incoming calls |
|
||||
| n | <Leader>go | hierarchy outgoing calls |
|
||||
| n | gi | implementation |
|
||||
| n | <Space> D | type definition |
|
||||
| n | gL | show line diagnostic |
|
||||
| n | gG | show diagnostic for all buffers |
|
||||
| n | ]d | next diagnostic |
|
||||
| n | [d | previous diagnostic |
|
||||
| n | <Leader> dt | diagnostic toggle(enable/disable) |
|
||||
| n | ]r | next treesitter reference/usage |
|
||||
| n | [r | previous treesitter reference/usage |
|
||||
| n | <Space> wa | add workspace folder |
|
||||
| n | <Space> wr | remove workspace folder |
|
||||
| n | <Space> wl | print workspace folder |
|
||||
| n | <Leader>k | toggle reference highlight |
|
||||
| i/n | <C-p> | previous item in list |
|
||||
| i/n | <C-n> | next item in list |
|
||||
| i/n | number 1~9 | move to ith row/item in the list |
|
||||
| i/n | <Up> | previous item in list |
|
||||
| i/n | <Down> | next item in list |
|
||||
| n | <Ctrl-w>j | move cursor to preview (windows move to bottom view point) |
|
||||
| n | <Ctrl-w>k | move cursor to list (windows move to up view point) |
|
||||
| i/n | <C-o> | open preview file in nvim/Apply action |
|
||||
| n | <C-v> | open preview file in nvim with vsplit |
|
||||
| n | <C-s> | open preview file in nvim with split |
|
||||
| n | <Enter> | open preview file in nvim/Apply action |
|
||||
| n | <ESC> | close listview of floating window |
|
||||
| i/n | <C-e> | close listview of floating window |
|
||||
| i/n | <C-b> | previous page in listview |
|
||||
| i/n | <C-f> | next page in listview |
|
||||
| i/n | <C-s> | save the modification to preview window to file |
|
||||
|
||||
COLORS/HIGHLIGHT: *navigator-colors/highlight:*
|
||||
|
||||
You can override default highlight GuihuaListDark (listview) and GuihuaTextViewDark (code view) and GuihuaListHl (select item)
|
||||
|
||||
e.g.
|
||||
>
|
||||
hi default GuihuaTextViewDark guifg=#e0d8f4 guibg=#332e55
|
||||
hi default GuihuaListDark guifg=#e0d8f4 guibg=#103234
|
||||
hi default GuihuaListHl guifg=#e0d8f4 guibg=#404254
|
||||
<
|
||||
|
||||
There are other Lsp highlight been used in this plugin, e.g LspReferenceRead/Text/Write are used for document highlight,
|
||||
LspDiagnosticsXXX are used for diagnostic. Please check highlight.lua and dochighlight.lua for more info.
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
DEPENDENCY *navigator-dependency*
|
||||
|
||||
* lspconfig
|
||||
* guihua.lua (provides floating window, FZY)
|
||||
* Optional:
|
||||
* treesitter (list treesitter symbols, object analysis)
|
||||
* lsp-signature (better signature help)
|
||||
|
||||
The plugin can be loaded lazily (packer `opt = true` ), And it will check if optional plugins existance and load those plugins only if they existed.
|
||||
|
||||
The terminal will need to be able to output nerdfont and emoji correctly. I am using Kitty with nerdfont (Victor Mono).
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
INTEGRAT WITH LSP_INSTALLER (WILLIAMBOMAN/NVIM-LSP-INSTALLER) *navigator-integrat_with_lsp_installer_(williamboman/nvim-lsp-installer)*
|
||||
|
||||
If you are using lsp_installer and would like to use the lsp servers installed by lsp_installer. Please set
|
||||
>
|
||||
lsp_installer = true
|
||||
<
|
||||
|
||||
In the config. Also please setup the lsp server from installer setup with `server:setup{opts}`
|
||||
|
||||
example:
|
||||
>
|
||||
use({
|
||||
'williamboman/nvim-lsp-installer',
|
||||
config = function()
|
||||
local lsp_installer = require('nvim-lsp-installer')
|
||||
lsp_installer.setup{}
|
||||
end,
|
||||
})
|
||||
use({
|
||||
'ray-x/navigator.lua',
|
||||
config = function()
|
||||
require('navigator').setup({
|
||||
debug = true,
|
||||
lsp_installer = true,
|
||||
keymaps = { { key = 'gR', func = "require('navigator.reference').async_ref()" } },
|
||||
})
|
||||
end,
|
||||
})
|
||||
<
|
||||
|
||||
Please refer to lsp_installer_config (https://github.com/ray-x/navigator.lua/blob/master/playground/init_lsp_installer.lua)
|
||||
for more info
|
||||
|
||||
Alternatively, Navigator can be used to startup the server installed by lsp-installer.
|
||||
as it will override the navigator setup
|
||||
|
||||
To start LSP installed by lsp_installer, please use following setups
|
||||
>
|
||||
require'navigator'.setup({
|
||||
-- lsp_installer = false -- default value is false
|
||||
lsp = {
|
||||
tsserver = { cmd = {'your tsserver installed by lsp_installer'} }
|
||||
}
|
||||
})
|
||||
<
|
||||
|
||||
example cmd setup (mac) for pyright :
|
||||
>
|
||||
require'navigator'.setup({
|
||||
-- lsp_installer = false -- default value is false
|
||||
lsp = {
|
||||
tsserver = {
|
||||
cmd = { "/Users/username/.local/share/nvim/lsp_servers/python/node_modules/.bin/pyright-langserver", "--stdio" }
|
||||
}
|
||||
}
|
||||
}
|
||||
<
|
||||
|
||||
The lsp servers installed by nvim-lsp-installer is in following dir
|
||||
>
|
||||
local path = require 'nvim-lsp-installer.path'
|
||||
local install_root_dir = path.concat {vim.fn.stdpath 'data', 'lsp_servers'}
|
||||
<
|
||||
|
||||
And you can setup binary full path to this: (e.g. with gopls)
|
||||
`install_root_dir .. '/go/gopls'` So the config is
|
||||
>
|
||||
local path = require 'nvim-lsp-installer.path'
|
||||
local install_root_dir = path.concat {vim.fn.stdpath 'data', 'lsp_servers'}
|
||||
require'navigator'.setup({
|
||||
-- lsp_installer = false -- default value is false
|
||||
lsp = {
|
||||
gopls = {
|
||||
cmd = { install_root_dir .. '/go/gopls' }
|
||||
}
|
||||
}
|
||||
}
|
||||
<
|
||||
|
||||
Use lsp_installer configs
|
||||
You can delegate the lsp server setup to lsp_installer with `server:setup{opts}`
|
||||
Here is an example init_lsp_installer.lua (https://github.com/ray-x/navigator.lua/blob/master/playground/init_lsp_installer.lua)
|
||||
|
||||
INTEGRATION WITH OTHER LSP PLUGINS (E.G. RUST-TOOLS, GO.NVIM, CLANGD EXTENSION) *navigator-integration_with_other_lsp_plugins_(e.g._rust-tools,_go.nvim,_clangd_extension)*
|
||||
|
||||
There are lots of plugins provides lsp support
|
||||
go.nvim allow you either hook gopls from go.nvim or from navigator and it can export the lsp setup from go.nvim.
|
||||
|
||||
rust-tools and clangd allow you to setup on_attach from config server
|
||||
Here is an example to setup rust with rust-tools
|
||||
>
|
||||
require'navigator'.setup({
|
||||
lsp = {
|
||||
disable_lsp = { "rust_analyzer", "clangd" }, -- will not run rust_analyzer setup from navigator
|
||||
}
|
||||
})
|
||||
require('rust-tools').setup({
|
||||
server = {
|
||||
on_attach = function(_, _)
|
||||
require('navigator.lspclient.mapping').setup() -- setup navigator keymaps here,
|
||||
-- otherwise, you can define your own commands to call navigator functions
|
||||
end,
|
||||
}
|
||||
})
|
||||
require("clangd_extensions").setup {
|
||||
server = {
|
||||
on_attach = function(_, _)
|
||||
require('navigator.lspclient.mapping').setup() -- setup navigator keymaps here,
|
||||
-- otherwise, you can define your own commands to call navigator functions
|
||||
end,
|
||||
}
|
||||
}
|
||||
<
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
USAGE *navigator-usage*
|
||||
|
||||
Please refer to lua/navigator/lspclient/mapping.lua on key mappings. Should be able to work out-of-box.
|
||||
|
||||
* Use <c-e> or `:q!` to kill the floating window
|
||||
* (or <c-n>, <c-p>) to move
|
||||
* <c-o> or <CR> to open location or apply code actions. Note: <CR> might be bound in insert mode by other plugins
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
CONFIGURATION *navigator-configuration*
|
||||
|
||||
In `navigator.lua` there is a default configuration. You can override the values by passing your own values
|
||||
|
||||
e.g
|
||||
>
|
||||
-- The attach will be call at end of navigator on_attach()
|
||||
require'navigator'.setup({on_attach = function(client, bufnr) require 'illuminate'.on_attach(client)})
|
||||
<
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
HIGHLIGHT *navigator-highlight*
|
||||
|
||||
Highlight I am using:
|
||||
|
||||
* LspReferenceRead, LspReferenceText and LspReferenceWrite are used for `autocmd CursorHold <buffer> lua vim.lsp.buf.document_highlight()`
|
||||
That is where you saw the current symbol been highlighted.
|
||||
* GuihuaListDark and GuihuaTextViewDark is used for floating listvew and TextView. They are be based on current background
|
||||
(Normal) and PmenuSel
|
||||
* In future, I will use NormalFloat for floating view. But ATM, most of colorscheme does not define NormalFloat
|
||||
|
||||
You can override the above highlight to fit your current colorscheme
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
COMMANDS *navigator-commands*
|
||||
|
||||
| command | function |
|
||||
| ------------ | ------------------------- |
|
||||
| LspToggleFmt | toggle lsp auto format |
|
||||
| LspKeymaps | show LSP releated keymaps |
|
||||
| Nctags {args} | show ctags symbols, args: -g regen ctags |
|
||||
| LspRestart | reload lsp |
|
||||
| LspSymbols | document symbol in side panel |
|
||||
| NRefPanel |symbol reference in side panel |
|
||||
| TSymobls | treesitter symbol in side panel |
|
||||
| Calltree {args} | lsp call hierarchy call tree, args: -i (incomming default), -o (outgoing) |
|
||||
|
||||
:LspToggleFmt *:LspToggleFmt*
|
||||
Toggle lsp auto format.
|
||||
|
||||
:LspKeymaps *:LspKeymaps*
|
||||
Show Lsp keymaps.
|
||||
|
||||
:Nctags [flags] *:Nctags*
|
||||
Show ctags symbols.
|
||||
[flags]:
|
||||
-g regen ctags
|
||||
|
||||
:LspRestart *:LspRestart*
|
||||
Restart Lsp.
|
||||
|
||||
:LspSymbols *:LspSymbols*
|
||||
Lsp document symbol in side panel.
|
||||
|
||||
:TSSymbols *:TSSymbols*
|
||||
Treesitter symbol in side panel.
|
||||
|
||||
:NRefPanel *:NRefPanel*
|
||||
Symbol reference in side panel.
|
||||
|
||||
:Calltree [flags] *:Calltree*
|
||||
Lsp call hierarchy call tree.
|
||||
[flags]:
|
||||
-i: incomming default
|
||||
-o: outgoing
|
||||
--------------------------------------------------------------------------------
|
||||
SCREENSHOTS *navigator-screenshots*
|
||||
|
||||
colorscheme: aurora (https://github.com/ray-x/aurora)
|
||||
|
||||
REFERENCE *navigator-reference*
|
||||
|
||||
Pls check the first part of README
|
||||
|
||||
DEFINITION PREVIEW *navigator-definition_preview*
|
||||
|
||||
Using treesitter and LSP to view the symbol definition
|
||||
|
||||
|
||||
|
||||
SIDEBAR, FOLDING, OUTLINE *navigator-sidebar,_folding,_outline*
|
||||
|
||||
Treesitter outline and Diagnostics
|
||||
|
||||
|
||||
|
||||
GUI AND MULTIGRID SUPPORT *navigator-gui_and_multigrid_support*
|
||||
|
||||
You can load a different font size for floating win
|
||||
|
||||
|
||||
|
||||
DOCUMENT SYMBOL AND NAVIGATE THROUGH THE LIST *navigator-document_symbol_and_navigate_through_the_list*
|
||||
|
||||
|
||||
The key binding to navigate in the list.
|
||||
|
||||
* up and down key
|
||||
* `<Ctrl-f/b>` for page up and down
|
||||
* number key 1~9 go to the ith item.
|
||||
* If there are loads of results, would be good to use fzy search prompt to filter out the result you are interested.
|
||||
|
||||
WORKSPACE SYMBOL *navigator-workspace_symbol*
|
||||
|
||||
|
||||
|
||||
HIGHLIGHT DOCUMENT SYMBOL AND JUMP BETWEEN REFERENCE *navigator-highlight_document_symbol_and_jump_between_reference*
|
||||
|
||||
|
||||
|
||||
================================================================================
|
||||
CURRENT SYMBOL HIGHLIGHT AND JUMP BACKWARD/FORWARD BETWEEN SYMBOLS *navigator-current_symbol_highlight_and_jump_backward/forward_between_symbols*
|
||||
|
||||
Document highlight provided by LSP.
|
||||
Jump between symbols with treesitter (with `]r` and `[r`)
|
||||
|
||||
|
||||
DIAGNOSTIC *navigator-diagnostic*
|
||||
|
||||
Visual studio code style show errors minimap in scroll bar area
|
||||
(Check setup for `diagnostic_scrollbar_sign`)
|
||||
|
||||
|
||||
|
||||
Diagnostic in single bufer
|
||||
|
||||
|
||||
|
||||
Show diagnostic in all buffers
|
||||
|
||||
|
||||
|
||||
EDIT IN PREVIEW WINDOW *navigator-edit_in_preview_window*
|
||||
|
||||
You can in place edit your code in floating window
|
||||
|
||||
https://user-images.githubusercontent.com/1681295/121832919-89cbc080-cd0e-11eb-9778-11d0f356b38d.mov
|
||||
|
||||
(Note: This feature only avalible in `find reference` and `find diagnostic`, You can not add/remove lines in floating window)
|
||||
|
||||
IMPLEMENTATION *navigator-implementation*
|
||||
|
||||
|
||||
|
||||
FZY SEARCH IN REFERENCE *navigator-fzy_search_in_reference*
|
||||
|
||||
|
||||
|
||||
CODE ACTIONS *navigator-code_actions*
|
||||
|
||||
|
||||
|
||||
SYMBOL RENAME *navigator-symbol_rename*
|
||||
|
||||
|
||||
|
||||
FILL STRUCT WITH GOPLS *navigator-fill_struct_with_gopls*
|
||||
|
||||
|
||||
|
||||
CODE PREVIEW WITH HIGHLIGHT *navigator-code_preview_with_highlight*
|
||||
|
||||
|
||||
|
||||
TREESITTER SYMBOL *navigator-treesitter_symbol*
|
||||
|
||||
Treetsitter symbols in all buffers
|
||||
|
||||
|
||||
SIGNATURE HELP *navigator-signature_help*
|
||||
|
||||
Improved signature help with current parameter highlighted
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
CALL HIERARCHY (INCOMMING/OUTGOING CALLS) *navigator-call_hierarchy_(incomming/outgoing_calls)*
|
||||
|
||||
|
||||
|
||||
LIGHT BULB IF CODEACTION AVAILABLE *navigator-light_bulb_if_codeaction_available*
|
||||
|
||||
|
||||
|
||||
CODELENS *navigator-codelens*
|
||||
|
||||
Codelens for gopls/golang. Garbage collection analyse:
|
||||
|
||||
|
||||
|
||||
Codelens for C++/ccls. Symbol reference
|
||||
|
||||
|
||||
|
||||
PREDEFINED LSP SYMBOL NERDFONT/EMOJI *navigator-predefined_lsp_symbol_nerdfont/emoji*
|
||||
|
||||
|
||||
|
||||
VS-CODE STYLE FOLDING WITH TREESITTER *navigator-vs-code_style_folding_with_treesitter*
|
||||
|
||||
FOLDING FUNCTION *navigator-folding_function*
|
||||
|
||||
|
||||
|
||||
FOLDING COMMENTS *navigator-folding_comments*
|
||||
|
||||
|
||||
|
||||
================================================================================
|
||||
DEBUG THE PLUGIN *navigator-debug_the_plugin*
|
||||
|
||||
One simple way to gether debug info and understand what is wrong is output the debug logs
|
||||
>
|
||||
require'navigator'.setup({
|
||||
debug = false, -- log output, set to true and log path: ~/.local/share/nvim/gh.log
|
||||
})
|
||||
<
|
||||
>
|
||||
-- a example of adding logs in the plugin
|
||||
local log = require"navigator.util".log
|
||||
local definition_hdlr = util.mk_handler(function(err, locations, ctx, _)
|
||||
-- output your log
|
||||
log('[definition] log for locations', locations, "and ctx", ctx)
|
||||
if err ~= nil then
|
||||
return
|
||||
end
|
||||
end
|
||||
<
|
||||
|
||||
================================================================================
|
||||
BREAK CHANGES AND KNOWN ISSUES *navigator-break_changes_and_known_issues*
|
||||
|
||||
known issues I am working on (https://github.com/ray-x/navigator.lua/issues/1)
|
||||
|
||||
================================================================================
|
||||
TODO *navigator-todo*
|
||||
|
||||
* The project is in the early phase, bugs expected, PRs and suggestions are welcome
|
||||
* Async (some of the requests is slow on large codebases and might be good to use co-rountine)
|
||||
* More clients. I use go, python, js/ts, java, c/cpp, lua most of the time. Did not test other languages (e.g dart, swift etc)
|
||||
* Configuration options
|
||||
|
||||
================================================================================
|
||||
ERRORS AND BUG REPORTING *navigator-errors_and_bug_reporting*
|
||||
|
||||
* Please double check your setup and check if minium setup works or not
|
||||
* It should works for 0.6.1, neovim 0.7.x prefered.
|
||||
* Check console output
|
||||
* Check `LspInfo` and treesitter status with `checkhealth`
|
||||
* Turn on log and attach the log to your issue if possible you can remove any personal/company info in the log
|
||||
* Submit Issue with minium vimrc. Please check playground/init.lua as a vimrc template. !!!Please DONOT use a packer vimrc
|
||||
|
||||
that installs everything to default folder!!! Also check this repo navigator bug report (https://github.com/fky2015/navigator.nvim-bug-report)
|
@ -1,4 +0,0 @@
|
||||
autocmd BufRead,BufNewFile *.tf,*.tfvars set filetype=terraform
|
||||
autocmd BufRead,BufNewFile *.tfstate,*.tfstate.backup set filetype=json
|
||||
autocmd BufRead,BufNewFile *.hcl set filetype=hcl
|
||||
autocmd BufRead,BufNewFile .terraformrc,terraform.rc set filetype=hcl
|
@ -1,12 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<title></title>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<link href="css/style.css" rel="stylesheet">
|
||||
</head>
|
||||
<body>
|
||||
|
||||
</body>
|
||||
</html>
|
@ -1,191 +0,0 @@
|
||||
local type_to_lspkind = { c = 5, m = 7, f = 6, s = 5 }
|
||||
local util = require('navigator.util')
|
||||
local log = util.log
|
||||
local sep = util.path_sep()
|
||||
local vfn = vim.fn
|
||||
local cur_dir = vfn.getcwd()
|
||||
|
||||
-- convert ctags line to lsp entry
|
||||
local function entry_to_item(entry)
|
||||
local item = {}
|
||||
item.name, item.filename, item.line, item.remain = string.match(entry, '(.*)\t(.*)\t(%d+);(.*)')
|
||||
local type = 'combine'
|
||||
item.remain = item.remain or ''
|
||||
if item.remain:sub(1, 1) == [["]] then
|
||||
type = 'number'
|
||||
end
|
||||
if item.name == nil or item.filename == nil then
|
||||
return
|
||||
end
|
||||
|
||||
if type == 'combine' then
|
||||
-- '/^type ServerResponse struct {$/;"\ts\tpackage:client'
|
||||
item.inline, item.type, item.containerName, item.ref =
|
||||
string.match(item.remain, '/^(.*)$/;"\t(%a)\t(.+)')
|
||||
else
|
||||
-- '"\tm\tstruct:store.Customer\ttyperef:typename:string'
|
||||
item.type, item.containerName, item.ref = string.match(item.remain, '"\t(%a)\t(.+)')
|
||||
end
|
||||
item.kind = type_to_lspkind[item.type] or 13
|
||||
item.lnum = tonumber(item.line) - 1
|
||||
item.location = {
|
||||
uri = 'file://' .. cur_dir .. sep .. item.filename,
|
||||
range = {
|
||||
start = { line = item.lnum, character = 0 },
|
||||
['end'] = { line = item.lnum, character = 0 },
|
||||
},
|
||||
}
|
||||
|
||||
item.uri = 'file://' .. cur_dir .. sep .. item.filename
|
||||
item.range = {
|
||||
start = { line = item.lnum, character = 0 },
|
||||
['end'] = { line = item.lnum, character = 0 },
|
||||
}
|
||||
|
||||
-- item.detail = (item.containerName or '') .. (item.ref or '')
|
||||
-- item.text = '[' .. kind .. ']' .. item.name .. ' ' .. item.detail
|
||||
|
||||
if item.lnum == nil then
|
||||
vim.notify('incorrect ctags format, need run ctag with "-excmd=number|combine" option')
|
||||
end
|
||||
item.remain = nil
|
||||
return item
|
||||
end
|
||||
|
||||
local function ctags_gen()
|
||||
local cmd = 'ctags' -- -x -n -u -f - ' .. vfn.expand('%:p')
|
||||
local output = _NgConfigValues.ctags.tagfile
|
||||
-- rm file first
|
||||
util.rm_file(output)
|
||||
local options =
|
||||
'-R --exclude=.git --exclude=node_modules --exclude=test --exclude=vendor --excmd=number '
|
||||
if _NgConfigValues.ctags then
|
||||
cmd = _NgConfigValues.ctags.cmd
|
||||
options = _NgConfigValues.ctags.options or options
|
||||
end
|
||||
|
||||
local lang = vim.o.ft
|
||||
options = options .. '--language-force=' .. lang
|
||||
cmd = cmd .. ' ' .. options
|
||||
cmd = string.format('%s -f %s %s --language-force=%s', cmd, output, options, lang)
|
||||
cmd = vim.split(cmd, ' ')
|
||||
log(cmd)
|
||||
vfn.jobstart(cmd, {
|
||||
on_stdout = function(_, _, _)
|
||||
vim.notify('ctags completed')
|
||||
end,
|
||||
|
||||
on_exit = function(_, data, _) -- id, data, event
|
||||
-- log(vim.inspect(data) .. "exit")
|
||||
if data and data ~= 0 then
|
||||
return vim.notify(cmd .. ' failed ' .. tostring(data), vim.log.levels.ERROR)
|
||||
else
|
||||
vim.notify('ctags generated')
|
||||
end
|
||||
end,
|
||||
})
|
||||
end
|
||||
|
||||
local symbols_to_items = require('navigator.lspwrapper').symbols_to_items
|
||||
local function ctags_symbols()
|
||||
local height = _NgConfigValues.height or 0.4
|
||||
local width = _NgConfigValues.width or 0.7
|
||||
height = math.floor(height * vfn.winheight('%'))
|
||||
width = math.floor(vim.api.nvim_get_option('columns') * width)
|
||||
local items = {}
|
||||
local ctags_file = _NgConfigValues.ctags.tagfile
|
||||
-- the tagfile name can be either .tags or tags
|
||||
if vim.fn.filereadable(ctags_file) == 0 then
|
||||
if vim.fn.filereadable('tags') == 1 then -- for some config the default tagfile is tags
|
||||
ctags_file = 'tags'
|
||||
_NgConfigValues.ctags.tagfile = 'tags'
|
||||
end
|
||||
end
|
||||
if not util.file_exists(ctags_file) then
|
||||
ctags_gen()
|
||||
vim.cmd('sleep 400m')
|
||||
end
|
||||
local cnts = util.io_read(ctags_file)
|
||||
if cnts == nil then
|
||||
return vim.notify('ctags file ' .. ctags_file .. ' not found')
|
||||
end
|
||||
cnts = vfn.split(cnts, '\n')
|
||||
for _, value in pairs(cnts) do
|
||||
local it = entry_to_item(value)
|
||||
if it then
|
||||
table.insert(items, it)
|
||||
end
|
||||
end
|
||||
cnts = nil
|
||||
|
||||
local ft = vim.o.ft
|
||||
local result = symbols_to_items(items)
|
||||
if next(result) == nil then
|
||||
return vim.notify('no symbols found')
|
||||
end
|
||||
log(result[1])
|
||||
local opt = {
|
||||
api = ' ',
|
||||
ft = ft,
|
||||
bg = 'GuihuaListDark',
|
||||
data = result,
|
||||
items = result,
|
||||
enter = true,
|
||||
loc = 'top_center',
|
||||
transparency = 50,
|
||||
prompt = true,
|
||||
rawdata = true,
|
||||
title = 'ctags',
|
||||
rect = { height = height, pos_x = 0, pos_y = 0, width = width },
|
||||
}
|
||||
|
||||
require('navigator.gui').new_list_view(opt)
|
||||
end
|
||||
|
||||
-- gen_ctags()
|
||||
|
||||
local function ctags(...)
|
||||
local gen = select(1, ...)
|
||||
log(gen)
|
||||
if gen == '-g' then
|
||||
ctags_gen()
|
||||
vim.cmd('sleep 200m')
|
||||
ctags_symbols()
|
||||
else
|
||||
ctags_symbols()
|
||||
end
|
||||
end
|
||||
|
||||
local function testitem()
|
||||
local e =
|
||||
[[ServerResponse internal/clients/server.go /^type ServerResponse struct {$/;" s package:client]]
|
||||
local ecombine =
|
||||
[[ServerResponse internal/clients/server.go 5;/^type ServerResponse struct {$/;" s package:client]]
|
||||
local enumber =
|
||||
[[CustomerID internal/store/models.go 17;" m struct:store.Customer typeref:typename:string]]
|
||||
local enumber2 =
|
||||
[[CustomerDescription internal/controllers/customer.go 27;" c package:controllers]]
|
||||
local enumber3 = [[add_servers lua/navigator/lspclient/clients.lua 680;" f]]
|
||||
local i = entry_to_item(ecombine)
|
||||
print(vim.inspect(i))
|
||||
|
||||
i = entry_to_item(enumber)
|
||||
print(vim.inspect(i))
|
||||
|
||||
i = entry_to_item(enumber2)
|
||||
print(vim.inspect(i))
|
||||
|
||||
i = entry_to_item(enumber3)
|
||||
print(vim.inspect(i))
|
||||
i = entry_to_item(e)
|
||||
print(vim.inspect(i))
|
||||
end
|
||||
-- testitem()
|
||||
-- gen_ctags()
|
||||
-- ctags_symbols()
|
||||
|
||||
return {
|
||||
ctags_gen = ctags_gen,
|
||||
ctags = ctags,
|
||||
ctags_symbols = ctags_symbols,
|
||||
}
|
@ -1,56 +0,0 @@
|
||||
local M = {}
|
||||
|
||||
local util = require('navigator.util')
|
||||
local log = util.log
|
||||
local health = vim.health
|
||||
if not vim.health then
|
||||
health = require('health')
|
||||
end
|
||||
|
||||
local nvim_09 = vim.fn.has('nvim-0.9') == 1
|
||||
|
||||
local start = nvim_09 and health.start or health.report_start
|
||||
local ok = nvim_09 and health.ok or health.report_ok
|
||||
local error = nvim_09 and health.error or health.report_error
|
||||
local warn = nvim_09 and health.warn or health.report_warn
|
||||
local info = nvim_09 and health.info or health.report_info
|
||||
|
||||
local vfn = vim.fn
|
||||
|
||||
local function plugin_check()
|
||||
start('navigator Plugin Check')
|
||||
|
||||
local plugins = {
|
||||
'lspconfig',
|
||||
'nvim-treesitter',
|
||||
'guihua',
|
||||
}
|
||||
local any_warn = false
|
||||
local ts_installed = false
|
||||
for _, plugin in ipairs(plugins) do
|
||||
if pcall(require, plugin) then
|
||||
ok(string.format('%s: plugin is installed', plugin))
|
||||
if plugin == 'nvim-treesitter' then
|
||||
ts_installed = true
|
||||
end
|
||||
else
|
||||
any_warn = true
|
||||
warn(string.format('%s: not installed/loaded', plugin))
|
||||
end
|
||||
end
|
||||
if any_warn then
|
||||
warn('Not all plugin installed')
|
||||
else
|
||||
ok('All plugin installed')
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
function M.check()
|
||||
if vim.fn.has('nvim-0.9') == 0 then
|
||||
warn('Suggested neovim version 0.9 or higher')
|
||||
end
|
||||
plugin_check()
|
||||
end
|
||||
|
||||
return M
|
@ -1,314 +1,102 @@
|
||||
local gui = require('navigator.gui')
|
||||
local util = require('navigator.util')
|
||||
local gui = require "navigator.gui"
|
||||
local util = require "navigator.util"
|
||||
local log = util.log
|
||||
local trace = util.trace
|
||||
local partial = util.partial
|
||||
local lsphelper = require('navigator.lspwrapper')
|
||||
|
||||
local path_sep = require('navigator.util').path_sep()
|
||||
local path_cur = require('navigator.util').path_cur()
|
||||
local uv = vim.uv or vim.loop
|
||||
local cwd = uv.cwd()
|
||||
local in_method = 'callHierarchy/incomingCalls'
|
||||
local out_method = 'callHierarchy/outgoingCalls'
|
||||
|
||||
local lsp_method = { to = out_method, from = in_method }
|
||||
local panel_method = { to = out_method, from = in_method }
|
||||
local lsphelper = require "navigator.lspwrapper"
|
||||
|
||||
local path_sep = require"navigator.util".path_sep()
|
||||
local path_cur = require"navigator.util".path_cur()
|
||||
local cwd = vim.loop.cwd()
|
||||
local M = {}
|
||||
local outgoing_calls_handler
|
||||
local incoming_calls_handler
|
||||
local hierarchy_handler
|
||||
|
||||
local call_hierarchy
|
||||
|
||||
local function pick_call_hierarchy_item(call_hierarchy_items)
|
||||
if not call_hierarchy_items then
|
||||
return
|
||||
end
|
||||
if #call_hierarchy_items == 1 then
|
||||
return call_hierarchy_items[1]
|
||||
end
|
||||
local items = {}
|
||||
for i, item in pairs(call_hierarchy_items) do
|
||||
local entry = item.detail or item.name
|
||||
table.insert(items, string.format('%d. %s', i, entry))
|
||||
end
|
||||
local choice = vim.fn.inputlist(items)
|
||||
if choice < 1 or choice > #items then
|
||||
return
|
||||
end
|
||||
return choice
|
||||
end
|
||||
|
||||
-- convert lsp result to navigator items
|
||||
local function call_hierarchy_result_procesor(direction, err, result, ctx, config)
|
||||
math.randomseed(os.clock() * 100000000000)
|
||||
trace(direction, err, ctx, config)
|
||||
trace(result)
|
||||
local function call_hierarchy_handler(direction, err, result, ctx, cfg, error_message)
|
||||
if not result then
|
||||
vim.notify('No call hierarchy items found', vim.log.levels.WARN)
|
||||
print("No call hierarchy items found")
|
||||
return
|
||||
end
|
||||
-- trace('call_hierarchy', result)
|
||||
|
||||
local bufnr = ctx.bufnr or vim.api.nvim_get_current_buf()
|
||||
assert(next(vim.lsp.get_clients({buffer = bufnr})), 'Must have a client running to use call hierarchy')
|
||||
trace('call_hierarchy', result)
|
||||
assert(#vim.lsp.buf_get_clients() > 0, "Must have a client running to use lsp_tags")
|
||||
if err ~= nil then
|
||||
log('dir', direction, 'result', result, 'err', err, ctx)
|
||||
vim.notify('ERROR: ' .. err, vim.log.levels.WARN)
|
||||
log("dir", direction, "result", result, "err", err, ctx)
|
||||
print("ERROR: " .. error_message)
|
||||
return
|
||||
end
|
||||
|
||||
local items = ctx.items or {}
|
||||
local items = {}
|
||||
|
||||
local kind = ' '
|
||||
for _, call_hierarchy_result in pairs(result) do
|
||||
local call_hierarchy_item = call_hierarchy_result[direction]
|
||||
for _, call_hierarchy_call in pairs(result) do
|
||||
local call_hierarchy_item = call_hierarchy_call[direction]
|
||||
local kind = ' '
|
||||
if call_hierarchy_item.kind then
|
||||
kind = require('navigator.lspclient.lspkind').symbol_kind(call_hierarchy_item.kind) .. ' '
|
||||
kind = require'navigator.lspclient.lspkind'.symbol_kind(call_hierarchy_item.kind) .. ' '
|
||||
end
|
||||
-- for _, range in pairs(call_hierarchy_call.fromRanges) do
|
||||
range = call_hierarchy_item.range or call_hierarchy_item.selectionRange
|
||||
local filename = assert(vim.uri_to_fname(call_hierarchy_item.uri))
|
||||
local display_filename = filename:gsub(cwd .. path_sep, path_cur, 1)
|
||||
call_hierarchy_item.detail = call_hierarchy_item.detail or ''
|
||||
call_hierarchy_item.detail = string.gsub(call_hierarchy_item.detail, '\n', ' ↳ ')
|
||||
trace(call_hierarchy_item)
|
||||
call_hierarchy_item.detail = call_hierarchy_item.detail or ""
|
||||
call_hierarchy_item.detail = call_hierarchy_item.detail:gsub("\n", " ↳ ")
|
||||
trace(range, call_hierarchy_item)
|
||||
|
||||
local disp_item = vim.tbl_deep_extend('force', {}, call_hierarchy_item)
|
||||
disp_item = vim.tbl_deep_extend('force', disp_item, {
|
||||
local disp_item = {
|
||||
uri = call_hierarchy_item.uri,
|
||||
filename = filename,
|
||||
display_filename = display_filename,
|
||||
indent_level = ctx.depth or 1,
|
||||
method = lsp_method[direction],
|
||||
node_text = call_hierarchy_item.name,
|
||||
type = kind,
|
||||
id = math.random(1, 100000),
|
||||
text = kind .. call_hierarchy_item.name .. ' ﰲ ' .. call_hierarchy_item.detail,
|
||||
lnum = call_hierarchy_item.selectionRange.start.line + 1,
|
||||
col = call_hierarchy_item.selectionRange.start.character,
|
||||
})
|
||||
range = range,
|
||||
lnum = range.start.line + 1,
|
||||
col = range.start.character
|
||||
}
|
||||
|
||||
table.insert(items, disp_item)
|
||||
-- end
|
||||
end
|
||||
trace(items)
|
||||
return items
|
||||
end
|
||||
|
||||
local call_hierarchy_handler_from = partial(call_hierarchy_result_procesor, 'from')
|
||||
local call_hierarchy_handler_to = partial(call_hierarchy_result_procesor, 'to')
|
||||
local call_hierarchy_handler_from = partial(call_hierarchy_handler, "from")
|
||||
local call_hierarchy_handler_to = partial(call_hierarchy_handler, "to")
|
||||
|
||||
-- the handler that deal all lsp request
|
||||
hierarchy_handler = function(dir, handler, show, api, err, result, ctx, cfg)
|
||||
trace(dir, handler, api, show, err, result, ctx, cfg)
|
||||
ctx = ctx or {} -- can be nil if it is async call
|
||||
cfg = cfg or {}
|
||||
local opts = ctx.opts or {}
|
||||
vim.validate({ handler = { handler, 'function' }, show = { show, 'function' }, api = { api, 'string' } })
|
||||
local bufnr = ctx.bufnr or vim.api.nvim_get_current_buf()
|
||||
assert(next(vim.lsp.get_clients({buffer = bufnr})), 'Must have a client running to use lsp hierarchy')
|
||||
local function incoming_calls_handler(bang, err, result, ctx, cfg)
|
||||
assert(#vim.lsp.buf_get_clients() > 0, "Must have a client running to use lsp hierarchy")
|
||||
local results = call_hierarchy_handler_from(err, result, ctx, cfg, "Incoming calls not found")
|
||||
|
||||
local results = handler(err, result, ctx, cfg, 'Incoming calls not found')
|
||||
|
||||
local ft = vim.api.nvim_buf_get_option(ctx.bufnr or vim.api.nvim_get_current_buf(), 'ft')
|
||||
if ctx.no_show then
|
||||
return results
|
||||
end
|
||||
-- local panel = args.panel
|
||||
-- local items = args.items
|
||||
-- local parent_node = args.node
|
||||
-- local section_id = args.section_id or 1
|
||||
local show_args = {
|
||||
items = results,
|
||||
ft = ft,
|
||||
api = api,
|
||||
bufnr = bufnr,
|
||||
panel = opts.panel,
|
||||
parent_node = opts.parent_node,
|
||||
title = 'Call Hierarchy',
|
||||
}
|
||||
local win = show(show_args)
|
||||
return results, win
|
||||
local ft = vim.api.nvim_buf_get_option(ctx.bufnr, "ft")
|
||||
gui.new_list_view({items = results, ft = ft, api = ' '})
|
||||
end
|
||||
|
||||
local make_params = function(uri, pos)
|
||||
return {
|
||||
textDocument = {
|
||||
uri = uri,
|
||||
},
|
||||
position = pos,
|
||||
}
|
||||
end
|
||||
local function outgoing_calls_handler(bang, err, result, ctx, cfg)
|
||||
local results = call_hierarchy_handler_to(err, result, ctx, cfg, "Outgoing calls not found")
|
||||
|
||||
local function display_panel(args)
|
||||
-- args = {items=results, ft=ft, api=api}
|
||||
log(args)
|
||||
|
||||
local Panel = require('guihua.panel')
|
||||
local bufnr = args.bufnr or vim.api.nvim_get_current_buf()
|
||||
-- local ft = args.ft or vim.api.nvim_buf_get_option(bufnr, 'buftype')
|
||||
local items = args.items
|
||||
local p = Panel:new({
|
||||
header = args.header or 'Call Hierarchy',
|
||||
render = function(buf)
|
||||
log(buf)
|
||||
return items
|
||||
end,
|
||||
fold = function(panel, node)
|
||||
if node.expanded ~= nil then
|
||||
node.expanded = not node.expanded
|
||||
vim.cmd('normal! za')
|
||||
else
|
||||
expand(panel, node)
|
||||
node.expanded = true
|
||||
end
|
||||
log('fold')
|
||||
return node
|
||||
end,
|
||||
})
|
||||
p:open(true)
|
||||
local ft = vim.api.nvim_buf_get_option(ctx.bufnr, "ft")
|
||||
gui.new_list_view({items = results, ft = ft, api = ' '})
|
||||
-- fzf_locations(bang, "", "Outgoing Calls", results, false)
|
||||
end
|
||||
|
||||
local function expand_item(args)
|
||||
-- args = {items=results, ft=ft, api=api}
|
||||
print('dispaly panel')
|
||||
trace(args, args.parent_node)
|
||||
local panel = args.panel
|
||||
local items = args.items
|
||||
local parent_node = args.parent_node
|
||||
local section_id = args.section_id or 1
|
||||
|
||||
local sect
|
||||
local sectid = 1
|
||||
for i, s in pairs(panel.sections) do
|
||||
if s.id == section_id then
|
||||
sectid = i
|
||||
break
|
||||
end
|
||||
end
|
||||
sect = panel.sections[sectid]
|
||||
for i, node in pairs(sect.nodes) do
|
||||
if node.id == parent_node.id then
|
||||
for j in ipairs(items) do
|
||||
items[j].indent_level = parent_node.indent_level + 1
|
||||
table.insert(sect.nodes, i + j, args.items[j])
|
||||
end
|
||||
sect.nodes[i].expanded = true
|
||||
sect.nodes[i].expandable = false
|
||||
break
|
||||
end
|
||||
end
|
||||
trace(panel.sections[sectid])
|
||||
-- render the panel again
|
||||
panel:redraw(false)
|
||||
end
|
||||
|
||||
incoming_calls_handler = util.partial4(
|
||||
hierarchy_handler,
|
||||
'from',
|
||||
call_hierarchy_handler_from,
|
||||
gui.new_list_view,
|
||||
' '
|
||||
)
|
||||
outgoing_calls_handler = util.partial4(hierarchy_handler, 'to', call_hierarchy_handler_to, gui.new_list_view, ' ')
|
||||
|
||||
local incoming_calls_panel = util.partial4(
|
||||
hierarchy_handler,
|
||||
'from',
|
||||
call_hierarchy_handler_from,
|
||||
display_panel,
|
||||
' '
|
||||
)
|
||||
local outgoing_calls_panel = util.partial4(hierarchy_handler, 'to', call_hierarchy_handler_to, display_panel, ' ')
|
||||
|
||||
local incoming_calls_expand = util.partial4(hierarchy_handler, 'from', call_hierarchy_handler_from, expand_item, ' ')
|
||||
local outgoing_calls_expand = util.partial4(hierarchy_handler, 'to', call_hierarchy_handler_to, expand_item, ' ')
|
||||
|
||||
function expand(panel, node)
|
||||
trace(panel, node)
|
||||
local params = make_params(node.uri, {
|
||||
line = node.range.start.line,
|
||||
character = node.range.start.character,
|
||||
})
|
||||
local handler = incoming_calls_expand
|
||||
if node.api == out_method then
|
||||
handler = outgoing_calls_expand
|
||||
function M.incoming_calls(bang, opts)
|
||||
assert(#vim.lsp.buf_get_clients() > 0, "Must have a client running to use lsp hierarchy")
|
||||
if not lsphelper.check_capabilities("call_hierarchy") then
|
||||
return
|
||||
end
|
||||
|
||||
local bufnr = vim.uri_to_bufnr(node.uri)
|
||||
call_hierarchy(node.method, {
|
||||
params = params,
|
||||
panel = panel,
|
||||
parent_node = node,
|
||||
handler = handler,
|
||||
bufnr = bufnr,
|
||||
})
|
||||
local params = vim.lsp.util.make_position_params()
|
||||
lsphelper.call_sync("callHierarchy/incomingCalls", params, opts, partial(incoming_calls_handler, bang))
|
||||
end
|
||||
|
||||
local request = vim.lsp.buf_request
|
||||
|
||||
-- call_hierarchy with floating window
|
||||
call_hierarchy = function(method, opts)
|
||||
trace(method, opts)
|
||||
opts = opts or {}
|
||||
local params = opts.params or vim.lsp.util.make_position_params()
|
||||
local bufnr = opts.bufnr
|
||||
local handler = function(err, result, ctx, cfg)
|
||||
ctx.opts = opts
|
||||
return opts.handler(err, result, ctx, cfg)
|
||||
function M.outgoing_calls(bang, opts)
|
||||
assert(#vim.lsp.buf_get_clients() > 0, "Must have a client running to use lsp_tags")
|
||||
if not lsphelper.check_capabilities("call_hierarchy") then
|
||||
return
|
||||
end
|
||||
-- log(opts, params)
|
||||
return request(
|
||||
bufnr,
|
||||
'textDocument/prepareCallHierarchy',
|
||||
params,
|
||||
vim.lsp.with(function(err, result, ctx)
|
||||
if err then
|
||||
vim.notify(err.message, vim.log.levels.WARN)
|
||||
return
|
||||
end
|
||||
local call_hierarchy_item = pick_call_hierarchy_item(result)
|
||||
local client = vim.lsp.get_client_by_id(ctx.client_id)
|
||||
if client then
|
||||
trace('result', result, 'items', call_hierarchy_item, method, ctx, client.name)
|
||||
client.request(method, {
|
||||
item = call_hierarchy_item,
|
||||
args = {
|
||||
method = method,
|
||||
},
|
||||
}, handler, ctx.bufnr)
|
||||
else
|
||||
vim.notify(string.format('Client with id=%d stopped', ctx.client_id), vim.log.levels.WARN)
|
||||
end
|
||||
end, { direction = method, depth = opts.depth })
|
||||
)
|
||||
end
|
||||
|
||||
function M.incoming_calls(opts)
|
||||
call_hierarchy(in_method, opts)
|
||||
end
|
||||
|
||||
function M.outgoing_calls(opts)
|
||||
call_hierarchy(out_method, opts)
|
||||
local params = vim.lsp.util.make_position_params()
|
||||
lsphelper.call_sync("callHierarchy/outgoingCalls", params, opts, partial(outgoing_calls_handler, bang))
|
||||
end
|
||||
|
||||
function M.incoming_calls_panel(opts)
|
||||
opts = vim.tbl_extend('force', { handler = incoming_calls_panel }, opts or {})
|
||||
call_hierarchy(in_method, opts)
|
||||
end
|
||||
|
||||
function M.outgoing_calls_panel(opts)
|
||||
opts = vim.tbl_extend('force', { handler = outgoing_calls_panel }, opts or {})
|
||||
call_hierarchy(out_method, opts)
|
||||
end
|
||||
M.incoming_calls_call = partial(M.incoming_calls, 0)
|
||||
M.outgoing_calls_call = partial(M.outgoing_calls, 0)
|
||||
|
||||
M.incoming_calls_handler = incoming_calls_handler
|
||||
M.outgoing_calls_handler = outgoing_calls_handler
|
||||
-- for testing
|
||||
M._call_hierarchy = call_hierarchy
|
||||
M.incoming_calls_handler = partial(incoming_calls_handler, 0)
|
||||
M.outgoing_calls_handler = partial(outgoing_calls_handler, 0)
|
||||
|
||||
function M.calltree(args)
|
||||
if args == '-o' then
|
||||
return M.outgoing_calls_panel()
|
||||
end
|
||||
M.incoming_calls_panel()
|
||||
end
|
||||
return M
|
||||
|
@ -1,55 +0,0 @@
|
||||
local lsp = vim.lsp
|
||||
local util = lsp.util
|
||||
local nutils = require('navigator.util')
|
||||
local api = vim.api
|
||||
local log = nutils.log
|
||||
local M = {}
|
||||
|
||||
function M.handler(err, result, ctx, config)
|
||||
config = config or {}
|
||||
config.focus_id = ctx.method
|
||||
if api.nvim_get_current_buf() ~= ctx.bufnr then
|
||||
-- Ignore result since buffer changed. This happens for slow language servers.
|
||||
return
|
||||
end
|
||||
local failed = false
|
||||
if err then
|
||||
vim.notify('no hover info ' .. err)
|
||||
failed = true
|
||||
end
|
||||
if not result or not result.contents then
|
||||
if config.silent ~= true then
|
||||
vim.notify('No hover information available')
|
||||
end
|
||||
failed = true
|
||||
end
|
||||
local bufnr = ctx.bufnr
|
||||
-- get filetype for bufnr
|
||||
local ft = api.nvim_buf_get_option(bufnr, 'filetype')
|
||||
if failed then
|
||||
if _NgConfigValues.lsp.hover.ft then
|
||||
local fallback_fn = _NgConfigValues.hover.ft or ''
|
||||
if type(fallback_fn) == 'function' then
|
||||
fallback_fn(ctx, config)
|
||||
end
|
||||
end
|
||||
return -- return early as no valid hover info lets fallback to other sources
|
||||
end
|
||||
local format = 'markdown'
|
||||
local contents ---@type string[]
|
||||
if type(result.contents) == 'table' and result.contents.kind == 'plaintext' then
|
||||
format = 'plaintext'
|
||||
contents = vim.split(result.contents.value or '', '\n', { trimempty = true })
|
||||
else
|
||||
contents = util.convert_input_to_markdown_lines(result.contents)
|
||||
end
|
||||
if vim.tbl_isempty(contents) then
|
||||
if config.silent ~= true then
|
||||
vim.notify('No information available')
|
||||
end
|
||||
return
|
||||
end
|
||||
return util.open_floating_preview(contents, format, config)
|
||||
end
|
||||
|
||||
return M
|
@ -1,48 +1,64 @@
|
||||
return {
|
||||
init = function()
|
||||
local loader = nil
|
||||
local log = require('navigator.util').log
|
||||
local packer_plugins = packer_plugins or nil -- suppress warnings
|
||||
local log = require'navigator.util'.log
|
||||
-- packer only
|
||||
local lazy_plugins = {
|
||||
['nvim-lspconfig'] = 'neovim/nvim-lspconfig',
|
||||
['guihua.lua'] = 'ray-x/guihua.lua',
|
||||
}
|
||||
if pcall(require, 'lazy') then
|
||||
require('lazy').load({ plugins = { 'nvim-lspconfig', 'guihua.lua' } })
|
||||
elseif vim.fn.empty(packer_plugins) == 0 then -- packer install
|
||||
if packer_plugins ~= nil then -- packer install
|
||||
local lazy_plugins = {
|
||||
["nvim-lspconfig"] = "neovim/nvim-lspconfig",
|
||||
["guihua.lua"] = "ray-x/guihua.lua"
|
||||
}
|
||||
|
||||
if _NgConfigValues.lsp_installer == true then
|
||||
lazy_plugins["nvim-lsp-installer"] = "williamboman/nvim-lsp-installer"
|
||||
end
|
||||
|
||||
-- packer installed
|
||||
loader = require('packer').loader
|
||||
loader = require"packer".loader
|
||||
for plugin, url in pairs(lazy_plugins) do
|
||||
if not packer_plugins[url] or not packer_plugins[url].loaded then
|
||||
-- log("loading ", plugin)
|
||||
loader(plugin)
|
||||
end
|
||||
end
|
||||
else
|
||||
loader = function(plugin)
|
||||
local cmd = 'packadd ' .. plugin
|
||||
vim.cmd(cmd)
|
||||
|
||||
end
|
||||
|
||||
if _NgConfigValues.lsp_installer == true then
|
||||
local has_lspinst, lspinst = pcall(require, "lsp_installer")
|
||||
log('lsp_installer installed', has_lspinst)
|
||||
if has_lspinst then
|
||||
lspinst.setup()
|
||||
local configs = require "lspconfig/configs"
|
||||
local servers = require'nvim-lsp-installer'.get_installed_servers()
|
||||
for _, server in pairs(servers) do
|
||||
local cfg = require'navigator.lspclient.clients'.get_cfg(server)
|
||||
local lsp_inst_cfg = configs[server]
|
||||
if lsp_inst_cfg and lsp_inst_cfg.document_config.default_config then
|
||||
lsp_inst_cfg = lsp_inst_cfg.document_config.default_config
|
||||
lsp_inst_cfg = vim.tbl_deep_extend('keep', lsp_inst_cfg, cfg)
|
||||
require'lspconfig'[server].setup(lsp_inst_cfg)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end,
|
||||
load = function(plugin_name, path)
|
||||
local loader = nil
|
||||
|
||||
if pcall(require, 'lazy') then
|
||||
require('lazy').load({ plugins = { plugin_name } })
|
||||
else
|
||||
packer_plugins = packer_plugins or nil -- suppress warnings
|
||||
-- packer only
|
||||
if packer_plugins ~= nil then -- packer install
|
||||
local lazy_plugins = {}
|
||||
lazy_plugins[plugin_name] = path
|
||||
loader = require('packer').loader
|
||||
for plugin, _ in pairs(lazy_plugins) do
|
||||
if packer_plugins[plugin] and packer_plugins[plugin].loaded == false then
|
||||
pcall(loader, plugin)
|
||||
end
|
||||
local packer_plugins = packer_plugins or nil -- suppress warnings
|
||||
-- packer only
|
||||
if packer_plugins ~= nil then -- packer install
|
||||
local lazy_plugins = {}
|
||||
lazy_plugins[plugin_name] = path
|
||||
loader = require"packer".loader
|
||||
for plugin, url in pairs(lazy_plugins) do
|
||||
if packer_plugins[plugin] and packer_plugins[plugin].loaded == false then
|
||||
-- log("loading ", plugin)
|
||||
pcall(loader, plugin)
|
||||
end
|
||||
end
|
||||
end
|
||||
end,
|
||||
|
||||
end
|
||||
}
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,215 +0,0 @@
|
||||
local M = {}
|
||||
local vfn = vim.fn
|
||||
M.defaults = function()
|
||||
local has_lsp, lspconfig = pcall(require, 'lspconfig')
|
||||
local highlight = require('navigator.lspclient.highlight')
|
||||
if not has_lsp then
|
||||
return {
|
||||
setup = function()
|
||||
vim.notify('loading lsp config failed LSP may not working correctly', vim.log.levels.WARN)
|
||||
end,
|
||||
}
|
||||
end
|
||||
local util = lspconfig.util
|
||||
local on_attach = require('navigator.lspclient.attach').on_attach
|
||||
|
||||
local setups = {
|
||||
clojure_lsp = {
|
||||
root_dir = function(fname)
|
||||
return util.root_pattern(
|
||||
'deps.edn',
|
||||
'build.boot',
|
||||
'project.clj',
|
||||
'shadow-cljs.edn',
|
||||
'bb.edn',
|
||||
'.git'
|
||||
)(fname) or util.path.dirname(fname)
|
||||
end,
|
||||
on_attach = on_attach,
|
||||
filetypes = { 'clojure', 'edn' },
|
||||
message_level = vim.lsp.protocol.MessageType.error,
|
||||
cmd = { 'clojure-lsp' },
|
||||
},
|
||||
|
||||
elixirls = {
|
||||
on_attach = on_attach,
|
||||
filetypes = { 'elixir', 'eelixir' },
|
||||
cmd = { 'elixir-ls' },
|
||||
message_level = vim.lsp.protocol.MessageType.error,
|
||||
settings = {
|
||||
elixirLS = {
|
||||
dialyzerEnabled = true,
|
||||
fetchDeps = false,
|
||||
},
|
||||
},
|
||||
root_dir = function(fname)
|
||||
return util.root_pattern('mix.exs', '.git')(fname) or util.path.dirname(fname)
|
||||
end,
|
||||
},
|
||||
|
||||
gopls = {
|
||||
-- capabilities = cap,
|
||||
filetypes = { 'go', 'gomod', 'gohtmltmpl', 'gotexttmpl' },
|
||||
message_level = vim.lsp.protocol.MessageType.Error,
|
||||
cmd = {
|
||||
'gopls', -- share the gopls instance if there is one already
|
||||
'-remote=auto', --[[ debug options ]] --
|
||||
-- "-logfile=auto",
|
||||
-- "-debug=:0",
|
||||
'-remote.debug=:0',
|
||||
-- "-rpc.trace",
|
||||
},
|
||||
|
||||
flags = { allow_incremental_sync = true, debounce_text_changes = 1000 },
|
||||
settings = {
|
||||
gopls = {
|
||||
-- more settings: https://github.com/golang/tools/blob/master/gopls/doc/settings.md
|
||||
-- flags = {allow_incremental_sync = true, debounce_text_changes = 500},
|
||||
-- not supported
|
||||
analyses = { unusedparams = true, unreachable = false },
|
||||
codelenses = {
|
||||
generate = true, -- show the `go generate` lens.
|
||||
gc_details = true, -- // Show a code lens toggling the display of gc's choices.
|
||||
test = true,
|
||||
tidy = true,
|
||||
},
|
||||
usePlaceholders = true,
|
||||
completeUnimported = true,
|
||||
staticcheck = true,
|
||||
matcher = 'fuzzy',
|
||||
diagnosticsDelay = '500ms',
|
||||
symbolMatcher = 'fuzzy',
|
||||
gofumpt = false, -- true, -- turn on for new repos, gofmpt is good but also create code turmoils
|
||||
buildFlags = { '-tags', 'integration' },
|
||||
-- buildFlags = {"-tags", "functional"}
|
||||
semanticTokens = true,
|
||||
},
|
||||
},
|
||||
on_attach = function(client, bufnr)
|
||||
on_attach(client, bufnr)
|
||||
if
|
||||
vim.fn.has('nvim-0.8.3') == 1
|
||||
and not client.server_capabilities.semanticTokensProvider
|
||||
then
|
||||
local semantic = client.config.capabilities.textDocument.semanticTokens
|
||||
if semantic then
|
||||
client.server_capabilities.semanticTokensProvider = {
|
||||
full = true,
|
||||
legend = {
|
||||
tokenModifiers = semantic.tokenModifiers,
|
||||
tokenTypes = semantic.tokenTypes,
|
||||
},
|
||||
range = true,
|
||||
}
|
||||
end
|
||||
end
|
||||
end,
|
||||
root_dir = function(fname)
|
||||
return util.root_pattern('go.mod', '.git')(fname) or util.path.dirname(fname)
|
||||
end,
|
||||
},
|
||||
clangd = {
|
||||
flags = { allow_incremental_sync = true, debounce_text_changes = 500 },
|
||||
cmd = {
|
||||
'clangd',
|
||||
'--background-index',
|
||||
'--suggest-missing-includes',
|
||||
'--clang-tidy',
|
||||
'--header-insertion=iwyu',
|
||||
'--enable-config',
|
||||
'--offset-encoding=utf-16',
|
||||
'--clang-tidy-checks=-*,llvm-*,clang-analyzer-*',
|
||||
'--cross-file-rename',
|
||||
},
|
||||
filetypes = { 'c', 'cpp', 'objc', 'objcpp' },
|
||||
on_attach = function(client, bufnr)
|
||||
client.server_capabilities.documentFormattingProvider = client.server_capabilities.documentFormattingProvider
|
||||
or true
|
||||
on_attach(client, bufnr)
|
||||
end,
|
||||
},
|
||||
rust_analyzer = {
|
||||
root_dir = function(fname)
|
||||
return util.root_pattern('Cargo.toml', 'rust-project.json', '.git')(fname)
|
||||
or util.path.dirname(fname)
|
||||
end,
|
||||
filetypes = { 'rust' },
|
||||
message_level = vim.lsp.protocol.MessageType.error,
|
||||
on_attach = on_attach,
|
||||
settings = {
|
||||
['rust-analyzer'] = {
|
||||
cargo = { loadOutDirsFromCheck = true },
|
||||
procMacro = { enable = true },
|
||||
},
|
||||
},
|
||||
flags = { allow_incremental_sync = true, debounce_text_changes = 500 },
|
||||
},
|
||||
sqlls = {
|
||||
cmd = { 'sql-language-server', 'up', '--method', 'stdio' },
|
||||
filetypes = { 'sql', 'mysql' },
|
||||
root_dir = util.root_pattern('.sqllsrc.json'),
|
||||
on_attach = on_attach,
|
||||
flags = { allow_incremental_sync = true, debounce_text_changes = 500 },
|
||||
},
|
||||
|
||||
pyright = {
|
||||
on_attach = on_attach,
|
||||
-- on_init = require('navigator.lspclient.python').on_init,
|
||||
on_init = function(client)
|
||||
require('navigator.lspclient.python').on_init(client)
|
||||
end,
|
||||
on_new_config = function(new_config, new_root_dir)
|
||||
local python_path = require('navigator.lspclient.python').pyenv_path(new_root_dir)
|
||||
new_config.settings.python.pythonPath = python_path
|
||||
end,
|
||||
cmd = { 'pyright-langserver', '--stdio' },
|
||||
filetypes = { 'python' },
|
||||
flags = { allow_incremental_sync = true, debounce_text_changes = 500 },
|
||||
settings = {
|
||||
python = {
|
||||
venvPath = '.',
|
||||
formatting = { provider = 'black' },
|
||||
analysis = {
|
||||
autoSearchPaths = true,
|
||||
useLibraryCodeForTypes = true,
|
||||
diagnosticMode = 'workspace',
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
ccls = {
|
||||
on_attach = on_attach,
|
||||
init_options = {
|
||||
compilationDatabaseDirectory = 'build',
|
||||
root_dir = [[ util.root_pattern("compile_commands.json", "compile_flags.txt", "CMakeLists.txt", "Makefile", ".git") or util.path.dirname ]],
|
||||
index = { threads = 2 },
|
||||
clang = { excludeArgs = { '-frounding-math' } },
|
||||
},
|
||||
flags = { allow_incremental_sync = true },
|
||||
},
|
||||
jdtls = {
|
||||
settings = {
|
||||
java = {
|
||||
signatureHelp = { enabled = true },
|
||||
contentProvider = { preferred = 'fernflower' },
|
||||
},
|
||||
},
|
||||
},
|
||||
omnisharp = {
|
||||
cmd = { 'omnisharp', '--languageserver', '--hostPID', tostring(vfn.getpid()) },
|
||||
},
|
||||
terraformls = {
|
||||
filetypes = { 'terraform', 'tf' },
|
||||
},
|
||||
|
||||
sourcekit = {
|
||||
cmd = { 'sourcekit-lsp' },
|
||||
filetypes = { 'swift' }, -- This is recommended if you have separate settings for clangd.
|
||||
},
|
||||
}
|
||||
|
||||
setups.lua_ls = require('navigator.lspclient.lua_ls').lua_ls()
|
||||
return setups
|
||||
end
|
||||
|
||||
return M
|
@ -1,67 +1,89 @@
|
||||
local M = {}
|
||||
|
||||
-- local log = require('navigator.util').log
|
||||
local log = require"navigator.util".log
|
||||
local api = vim.api
|
||||
|
||||
local cmd_group = api.nvim_create_augroup('NGHiGroup', {})
|
||||
-- lsp sign ﮻ ﯭ ﳀ
|
||||
function M.config_signs()
|
||||
function M.diagnositc_config_sign()
|
||||
if M.configed then
|
||||
return
|
||||
end
|
||||
local icons = _NgConfigValues.icons
|
||||
|
||||
local sign_name = 'NavigatorLightBulb'
|
||||
local sign_name = "NavigatorLightBulb"
|
||||
if vim.fn.sign_getdefined(sign_name).text == nil then
|
||||
vim.fn.sign_define(
|
||||
sign_name,
|
||||
{ text = icons.code_action_icon, texthl = 'LspDiagnosticsSignHint' }
|
||||
)
|
||||
|
||||
sign_name = 'NavigatorCodeLensLightBulb'
|
||||
vim.fn.sign_define(
|
||||
sign_name,
|
||||
{ text = icons.code_lens_action_icon, texthl = 'LspDiagnosticsSignHint' }
|
||||
)
|
||||
vim.fn
|
||||
.sign_define(sign_name, {text = icons.code_action_icon, texthl = "LspDiagnosticsSignHint"})
|
||||
|
||||
sign_name = "NavigatorCodeLensLightBulb"
|
||||
vim.fn.sign_define(sign_name,
|
||||
{text = icons.code_lens_action_icon, texthl = "LspDiagnosticsSignHint"})
|
||||
end
|
||||
|
||||
local e, w, i, h = icons.diagnostic_err, icons.diagnostic_warn, icons.diagnostic_info,
|
||||
icons.diagnostic_hint
|
||||
if vim.diagnostic ~= nil then
|
||||
local t = vim.fn.sign_getdefined('DiagnosticSignWarn')
|
||||
if vim.tbl_isempty(t) or t[1].text == "W " and icons.icons == true then
|
||||
|
||||
vim.fn.sign_define('DiagnosticSignError',
|
||||
{text = e, texthl = 'DiagnosticError', linehl = '', numhl = ''})
|
||||
vim.fn.sign_define('DiagnosticSignWarn',
|
||||
{text = w, texthl = 'DiagnosticWarn', linehl = '', numhl = ''})
|
||||
vim.fn.sign_define('DiagnosticSignInfo',
|
||||
{text = i, texthl = 'DiagnosticInfo', linehl = '', numhl = ''})
|
||||
vim.fn.sign_define('DiagnosticSignHint',
|
||||
{text = h, texthl = 'DiagnosticHint', linehl = '', numhl = ''})
|
||||
|
||||
t = vim.fn.sign_getdefined('DiagnosticSignWarn')
|
||||
end
|
||||
else
|
||||
local t = vim.fn.sign_getdefined('LspDiagnosticSignWarn')
|
||||
if vim.tbl_isempty(t) or t[1].text == "W " and icons.icons == true then
|
||||
vim.fn.sign_define('LspDiagnosticsSignError',
|
||||
{text = e, texthl = 'LspDiagnosticsSignError', linehl = '', numhl = ''})
|
||||
vim.fn.sign_define('LspDiagnosticsSignWarning',
|
||||
{text = w, texthl = 'LspDiagnosticsSignWarning', linehl = '', numhl = ''})
|
||||
vim.fn.sign_define('LspDiagnosticsSignInformation', {
|
||||
text = i,
|
||||
texthl = 'LspDiagnosticsSignInformation',
|
||||
linehl = '',
|
||||
numhl = ''
|
||||
})
|
||||
vim.fn.sign_define('LspDiagnosticsSignHint',
|
||||
{text = h, texthl = 'LspDiagnosticsSignHint', linehl = '', numhl = ''})
|
||||
end
|
||||
end
|
||||
M.configed = true
|
||||
end
|
||||
|
||||
local colors = {
|
||||
{ '#aefe00', '#aede00', '#aebe00', '#4e7efe' },
|
||||
{ '#ff00e0', '#df00e0', '#af00e0', '#fedefe' },
|
||||
{ '#1000ef', '#2000df', '#2000cf', '#f0f040' },
|
||||
{ '#d8a8a3', '#c8a8a3', '#b8a8a3', '#4e2c33' },
|
||||
{ '#ffa724', '#efa024', '#dfa724', '#0040ff' },
|
||||
{ '#afdc2b', '#09dc4b', '#08d04b', '#ef4f8f' },
|
||||
}
|
||||
|
||||
function M.add_highlight()
|
||||
|
||||
-- lsp system default
|
||||
api.nvim_command("hi! link LspDiagnosticsUnderlineError SpellBad")
|
||||
api.nvim_command("hi! link LspDiagnosticsUnderlineWarning SpellRare")
|
||||
api.nvim_command("hi! link LspDiagnosticsUnderlineInformation SpellRare")
|
||||
api.nvim_command("hi! link LspDiagnosticsUnderlineHint SpellRare")
|
||||
|
||||
api.nvim_set_hl(0, 'DiagnosticUnderlineError', { link = 'SpellBad', default = true })
|
||||
api.nvim_set_hl(0, 'DiagnosticUnderlineWarn', { link = 'SpellRare', default = true })
|
||||
api.nvim_set_hl(0, 'DiagnosticUnderlineInfo', { link = 'SpellRare', default = true })
|
||||
api.nvim_set_hl(0, 'DiagnosticUnderlineHint', { link = 'SpellRare', default = true })
|
||||
api.nvim_set_hl(0, 'NGPreviewTitle', { link = 'Title', default = true })
|
||||
api.nvim_set_hl(0, 'LspReferenceRead', { default = true, link = 'IncSearch' })
|
||||
api.nvim_set_hl(0, 'LspReferenceText', { default = true, link = 'Visual' })
|
||||
api.nvim_set_hl(0, 'LspReferenceWrite', { default = true, link = 'Search' })
|
||||
api.nvim_command("hi! link DiagnosticUnderlineError SpellBad")
|
||||
api.nvim_command("hi! link DiagnosticUnderlineWarning SpellRare")
|
||||
api.nvim_command("hi! link DiagnosticUnderlineInformation SpellRare")
|
||||
api.nvim_command("hi! link DiagnosticUnderlineHint SpellRare")
|
||||
api.nvim_command("hi def link NGPreviewTitle Title")
|
||||
local colors = {
|
||||
{'#aefe00', '#aede00', '#aebe00', '#4e7efe'}, {'#ff00e0', '#df00e0', '#af00e0', '#fedefe'},
|
||||
{'#1000ef', '#2000df', '#2000cf', '#f0f040'}, {'#d8a8a3', '#c8a8a3', '#b8a8a3', '#4e2c33'},
|
||||
{'#ffa724', '#efa024', '#dfa724', '#0040ff'}, {'#afdc2b', '#09dc4b', '#08d04b', '#ef4f8f'}
|
||||
}
|
||||
|
||||
for i = 1, #colors do
|
||||
for j = 1, 3 do
|
||||
local hlg = string.format('NGHiReference_%i_%i', i, j) -- , colors[i][j], colors[i][4]
|
||||
api.nvim_set_hl(0, hlg, { fg = colors[i][j], bg = colors[i][4], default = true })
|
||||
local cmd = string.format("hi! default NGHiReference_%i_%i guibg=%s guifg=%s ", i, j,
|
||||
colors[i][j], colors[i][4])
|
||||
vim.cmd(cmd)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
api.nvim_create_autocmd('ColorScheme', {
|
||||
group = cmd_group,
|
||||
pattern = '*',
|
||||
callback = function()
|
||||
M.add_highlight()
|
||||
end,
|
||||
})
|
||||
|
||||
return M
|
||||
|
@ -1,68 +0,0 @@
|
||||
local log = require('vim.lsp.log')
|
||||
local util = require('vim.lsp.util')
|
||||
local api = vim.api
|
||||
local bufstates = {}
|
||||
return {
|
||||
on_inlayhint = function(err, result, ctx, _)
|
||||
if err then
|
||||
if log.error() then
|
||||
log.error('inlayhint', err)
|
||||
end
|
||||
return
|
||||
end
|
||||
local bufnr = assert(ctx.bufnr)
|
||||
if util.buf_versions[bufnr] ~= ctx.version then
|
||||
return
|
||||
end
|
||||
local client_id = ctx.client_id
|
||||
if not result then
|
||||
return
|
||||
end
|
||||
local bufstate = bufstates[bufnr]
|
||||
if not bufstate or not bufstate.enabled then
|
||||
return
|
||||
end
|
||||
if not (bufstate.client_hint and bufstate.version) then
|
||||
bufstate.client_hint = vim.defaulttable()
|
||||
bufstate.version = ctx.version
|
||||
end
|
||||
local hints_by_client = bufstate.client_hint
|
||||
local client = assert(vim.lsp.get_client_by_id(client_id))
|
||||
|
||||
local new_hints_by_lnum = vim.defaulttable()
|
||||
local num_unprocessed = #result
|
||||
if num_unprocessed == 0 then
|
||||
hints_by_client[client_id] = {}
|
||||
bufstate.version = ctx.version
|
||||
api.nvim__buf_redraw_range(bufnr, 0, -1)
|
||||
return
|
||||
end
|
||||
|
||||
local lines = api.nvim_buf_get_lines(bufnr, 0, -1, false)
|
||||
---@param position lsp.Position
|
||||
---@return integer
|
||||
local function pos_to_byte(position)
|
||||
local col = position.character
|
||||
if col > 0 then
|
||||
local line = lines[position.line + 1] or ''
|
||||
local ok, convert_result
|
||||
ok, convert_result = pcall(util._str_byteindex_enc, line, col, client.offset_encoding)
|
||||
if ok then
|
||||
return convert_result
|
||||
end
|
||||
return math.min(#line, col)
|
||||
end
|
||||
return col
|
||||
end
|
||||
|
||||
for _, hint in ipairs(result) do
|
||||
local lnum = hint.position.line
|
||||
hint.position.character = pos_to_byte(hint.position)
|
||||
table.insert(new_hints_by_lnum[lnum], hint)
|
||||
end
|
||||
|
||||
hints_by_client[client_id] = new_hints_by_lnum
|
||||
bufstate.version = ctx.version
|
||||
api.nvim__buf_redraw_range(bufnr, 0, -1)
|
||||
end,
|
||||
}
|
@ -1,68 +0,0 @@
|
||||
local vfn = vim.fn
|
||||
|
||||
local on_attach = require('navigator.lspclient.attach').on_attach
|
||||
|
||||
local library = {}
|
||||
local function add(lib)
|
||||
for _, p in pairs(vfn.expand(lib, false, true)) do
|
||||
local uv = vim.uv or vim.loop
|
||||
p = uv.fs_realpath(p)
|
||||
if p then
|
||||
library[p] = true
|
||||
end
|
||||
end
|
||||
end
|
||||
local function lua_ls()
|
||||
-- add runtime
|
||||
-- add plugins it may be very slow to add all in path
|
||||
add('$VIMRUNTIME')
|
||||
-- add your config
|
||||
-- local home = vfn.expand("$HOME")
|
||||
add(vfn.stdpath('config'))
|
||||
|
||||
library[vfn.expand('$VIMRUNTIME/lua')] = true
|
||||
library[vfn.expand('$VIMRUNTIME/lua/vim')] = true
|
||||
library[vfn.expand('$VIMRUNTIME/lua/vim/lsp')] = true
|
||||
|
||||
return {
|
||||
cmd = { 'lua-language-server' },
|
||||
filetypes = { 'lua' },
|
||||
on_attach = on_attach,
|
||||
flags = { allow_incremental_sync = true, debounce_text_changes = 500 },
|
||||
settings = {
|
||||
Lua = {
|
||||
runtime = {
|
||||
-- Tell the language server which version of Lua you're using (most likely LuaJIT in the case of Neovim)
|
||||
version = 'LuaJIT',
|
||||
},
|
||||
hint = { enable = true, typeCoverage = true },
|
||||
diagnostics = {
|
||||
enable = true,
|
||||
-- Get the language server to recognize the `vim` global
|
||||
globals = { 'vim', 'describe', 'it', 'before_each', 'after_each', 'teardown', 'pending' },
|
||||
},
|
||||
completion = { callSnippet = 'Both' },
|
||||
workspace = {
|
||||
-- Make the server aware of Neovim runtime files
|
||||
library = library,
|
||||
checkThirdParty = false,
|
||||
maxPreload = 1000,
|
||||
preloadFileSize = 40000,
|
||||
},
|
||||
telemetry = { enable = false },
|
||||
},
|
||||
},
|
||||
on_new_config = function(cfg, root)
|
||||
local libs = vim.schedule(function()
|
||||
vim.tbl_deep_extend('force', {}, library)
|
||||
end)
|
||||
libs[root] = nil
|
||||
cfg.settings.Lua.workspace.library = libs
|
||||
return cfg
|
||||
end,
|
||||
}
|
||||
end
|
||||
|
||||
return {
|
||||
lua_ls = lua_ls,
|
||||
}
|
@ -1,39 +0,0 @@
|
||||
local util = require('lspconfig/util')
|
||||
local path = util.path
|
||||
local M = {}
|
||||
local shell = vim.o.shell
|
||||
local exepath = vim.fn.exepath
|
||||
-- https://github.com/ray-x/navigator.lua/issues/247#issue-1465308677
|
||||
M.pyenv_path = function(workspace)
|
||||
-- Use activated virtualenv.
|
||||
if vim.env.VIRTUAL_ENV then
|
||||
return path.join(vim.env.VIRTUAL_ENV, 'bin', 'python'), 'virtual env'
|
||||
end
|
||||
|
||||
-- Find and use virtualenv in workspace directory.
|
||||
for _, pattern in ipairs({ '*', '.*' }) do
|
||||
local match = vim.fn.glob(path.join(workspace, pattern, 'pyvenv.cfg'))
|
||||
local sep = require('navigator.util').path_sep()
|
||||
local py = 'bin' .. sep .. 'python'
|
||||
if match ~= '' then
|
||||
print('found', match)
|
||||
print(vim.fn.glob(path.join(workspace, pattern)))
|
||||
match = string.gsub(match, 'pyvenv.cfg', py)
|
||||
return match, string.format('venv base folder: %s', match)
|
||||
end
|
||||
match = vim.fn.glob(path.join(workspace, pattern, 'poetry.lock'))
|
||||
if match ~= '' then
|
||||
local venv_base_folder = vim.fn.trim(vim.fn.system('poetry env info -p'))
|
||||
return path.join(venv_base_folder, 'bin', 'python'), string.format('venv base folder: %s', venv_base_folder)
|
||||
end
|
||||
end
|
||||
|
||||
-- Fallback to system Python.
|
||||
return exepath('python3') or exepath('python') or 'python', 'fallback to system python path'
|
||||
end
|
||||
M.on_init = function(client)
|
||||
local python_path, msg = M.pyenv_path(client.config.root_dir)
|
||||
vim.notify(string.format('%s \ncurrent python path: %s', msg, python_path))
|
||||
client.config.settings.python.pythonPath = python_path
|
||||
end
|
||||
return M
|
@ -1,50 +0,0 @@
|
||||
return {
|
||||
'angularls',
|
||||
'gopls',
|
||||
'tsserver',
|
||||
'flow',
|
||||
'bashls',
|
||||
'dockerls',
|
||||
'julials',
|
||||
'pylsp',
|
||||
'pyright',
|
||||
'jedi_language_server',
|
||||
'jdtls',
|
||||
'lua_ls',
|
||||
'vimls',
|
||||
'html',
|
||||
'jsonls',
|
||||
'solargraph',
|
||||
'cssls',
|
||||
'tailwindcss',
|
||||
'yamlls',
|
||||
'clangd',
|
||||
'ccls',
|
||||
'sqlls',
|
||||
'denols',
|
||||
'graphql',
|
||||
'dartls',
|
||||
'dotls',
|
||||
'kotlin_language_server',
|
||||
'nimls',
|
||||
'intelephense',
|
||||
'vuels',
|
||||
'volar',
|
||||
'phpactor',
|
||||
'omnisharp',
|
||||
'r_language_server',
|
||||
'rust_analyzer',
|
||||
'terraformls',
|
||||
'svelte',
|
||||
'texlab',
|
||||
'clojure_lsp',
|
||||
'elixirls',
|
||||
'ruff_lsp',
|
||||
'sourcekit',
|
||||
'fsautocomplete',
|
||||
'vls',
|
||||
'hls',
|
||||
'tflint',
|
||||
'terraform_lsp',
|
||||
'zls',
|
||||
}
|
@ -1,557 +1,44 @@
|
||||
-- the preview and cache are copy from
|
||||
-- smjonas/inc-renamer.nvim
|
||||
-- https://github.com/smjonas/inc-rename.nvim/blob/main/lua/inc_rename/init.lua
|
||||
-- inplace rename are from neovim vim.lsp.buf.rename
|
||||
|
||||
local util = require('navigator.util')
|
||||
local log = util.log
|
||||
local api = vim.api
|
||||
local vfn = vim.fn
|
||||
|
||||
local M = {
|
||||
hl_group = 'Substitute',
|
||||
}
|
||||
local make_position_params = vim.lsp.util.make_position_params
|
||||
local rename_group = api.nvim_create_augroup('nav-rename', {})
|
||||
|
||||
local state = {
|
||||
should_fetch_references = true,
|
||||
cached_lines = nil,
|
||||
input_win_id = nil,
|
||||
input_bufnr = nil,
|
||||
confirm = nil,
|
||||
oldname = nil,
|
||||
newname = nil,
|
||||
err = nil,
|
||||
}
|
||||
local backspace = api.nvim_replace_termcodes('<bs>', true, false, true)
|
||||
|
||||
local ns = api.nvim_create_namespace('nav-rename')
|
||||
|
||||
local function set_error(msg, level)
|
||||
state.err = { msg = msg, level = level }
|
||||
state.cached_lines = nil
|
||||
end
|
||||
|
||||
local function ts_symbol()
|
||||
local ok, _ = pcall(require, 'nvim-treesitter')
|
||||
if not ok then
|
||||
vim.notify('treesitter not installed')
|
||||
-- try best
|
||||
return {}
|
||||
end
|
||||
|
||||
local bufnr = api.nvim_get_current_buf()
|
||||
local queries = require('nvim-treesitter.query')
|
||||
local ft_to_lang = require('nvim-treesitter.parsers').ft_to_lang
|
||||
|
||||
local lang = ft_to_lang(vim.bo[bufnr].filetype)
|
||||
local query = (vim.fn.has('nvim-0.9') == 1) and vim.treesitter.query.get(lang, 'highlights')
|
||||
or vim.treesitter.get_query(lang, 'highlights')
|
||||
|
||||
local ts_utils = require('nvim-treesitter.ts_utils')
|
||||
local current_node = ts_utils.get_node_at_cursor()
|
||||
if not current_node then
|
||||
return
|
||||
end
|
||||
local start_row, _, end_row, _ = current_node:range()
|
||||
for id, _, _ in query:iter_captures(current_node, 0, start_row, end_row) do
|
||||
local name = query.captures[id]
|
||||
if name:find('builtin') or name:find('keyword') then
|
||||
return
|
||||
end
|
||||
end
|
||||
return current_node
|
||||
end
|
||||
|
||||
local function visible(bufnr)
|
||||
if api.nvim_buf_is_loaded(bufnr) then
|
||||
for _, win in ipairs(api.nvim_tabpage_list_wins(0)) do
|
||||
if api.nvim_win_get_buf(win) == bufnr then
|
||||
return true
|
||||
end
|
||||
end
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function hash(a, b, c)
|
||||
local cantor = function(x, y)
|
||||
return (x + y + 1) * (x + y) / 2 + y
|
||||
end
|
||||
return cantor(a, cantor(b, c))
|
||||
end
|
||||
|
||||
-- a function from smjonas/inc-rename.nvim
|
||||
local function cache_lines(result)
|
||||
local cached_lines = {}
|
||||
local exists = {}
|
||||
for _, res in ipairs(result) do
|
||||
local range = res.range
|
||||
if range.start.line == range['end'].line then
|
||||
local bufnr
|
||||
if res.uri then
|
||||
bufnr = vim.uri_to_bufnr(res.uri)
|
||||
else
|
||||
bufnr = vim.api.nvim_get_current_buf()
|
||||
end
|
||||
if visible(bufnr) then
|
||||
if not cached_lines[bufnr] then
|
||||
cached_lines[bufnr] = {}
|
||||
end
|
||||
if not exists[bufnr] then
|
||||
exists[bufnr] = {}
|
||||
end
|
||||
|
||||
local line_nr = range.start.line
|
||||
local line = api.nvim_buf_get_lines(bufnr, line_nr, line_nr + 1, false)[1]
|
||||
local start_col, end_col = range.start.character, range['end'].character
|
||||
local line_info = { text = line, start_col = start_col, end_col = end_col }
|
||||
local h = hash(line_nr, start_col, end_col)
|
||||
if not exists[bufnr][h] then
|
||||
if cached_lines[bufnr][line_nr] then
|
||||
table.insert(cached_lines[bufnr][line_nr], line_info)
|
||||
else
|
||||
cached_lines[bufnr][line_nr] = { line_info }
|
||||
end
|
||||
exists[bufnr][h] = true
|
||||
end
|
||||
|
||||
-- log(cached_lines[bufnr])
|
||||
end
|
||||
end
|
||||
end
|
||||
return cached_lines
|
||||
end
|
||||
|
||||
local function fetch_lsp_references(bufnr, lsp_params, callback)
|
||||
require('navigator.reference').fetch_lsp_references(
|
||||
bufnr,
|
||||
lsp_params,
|
||||
function(err, result, ctx, cfg)
|
||||
if err then
|
||||
log('[nav-rename] Error while finding references: ' .. err.message, ctx, cfg)
|
||||
return
|
||||
end
|
||||
if not result or vim.tbl_isempty(result) then
|
||||
log('[nav-rename] Nothing to rename', result)
|
||||
return
|
||||
end
|
||||
state.total = #result
|
||||
state.cached_lines = cache_lines(result)
|
||||
state.should_fetch_references = false
|
||||
if callback then
|
||||
callback()
|
||||
end
|
||||
end
|
||||
)
|
||||
end
|
||||
|
||||
-- inspired by smjonas/inc-rename.nvim
|
||||
local function teardown(switch_buffer)
|
||||
state.should_fetch_references = true
|
||||
state.cached_lines = nil
|
||||
state.oldname = nil
|
||||
state.newname = nil
|
||||
if state.input_win_id and api.nvim_win_is_valid(state.input_win_id) then
|
||||
state.input_win_id = nil
|
||||
if switch_buffer then
|
||||
api.nvim_set_current_win(state.win_id)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local function restore_buffer()
|
||||
for bufnr, line_info_per_bufnr in pairs(state.cached_lines or {}) do
|
||||
for line_nr, line_info in pairs(line_info_per_bufnr) do
|
||||
log(line_nr, line_info[1].text)
|
||||
api.nvim_buf_set_lines(bufnr, line_nr, line_nr + 1, false, { line_info[1].text })
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
-- Called when the user is still typing the command or the command arguments
|
||||
-- inspired by smjonas/inc-rename.nvim
|
||||
local function incremental_rename_preview(opts, preview_ns, preview_buf)
|
||||
log(opts, preview_ns, preview_buf)
|
||||
local new_name = opts.args
|
||||
|
||||
state.new_name = new_name
|
||||
vim.v.errmsg = ''
|
||||
|
||||
if state.should_fetch_references then
|
||||
fetch_lsp_references(preview_buf, state.lsp_params, function()
|
||||
incremental_rename_preview(opts, preview_ns, preview_buf)
|
||||
end)
|
||||
end
|
||||
|
||||
if not state.cached_lines then
|
||||
log('lsp references not fetched yet')
|
||||
return
|
||||
end
|
||||
|
||||
local function apply_highlights_fn(bufnr, line_nr, line_info)
|
||||
local offset = 0
|
||||
local updated_line = line_info[1].text
|
||||
local highlight_positions = {}
|
||||
|
||||
for _, info in ipairs(line_info) do
|
||||
updated_line = updated_line:sub(1, info.start_col + offset)
|
||||
.. new_name
|
||||
.. updated_line:sub(info.end_col + 1 + offset)
|
||||
|
||||
table.insert(highlight_positions, {
|
||||
start_col = info.start_col + offset,
|
||||
end_col = info.start_col + #new_name + offset,
|
||||
})
|
||||
-- Offset by the length difference between the new and old names
|
||||
offset = offset + #new_name - (info.end_col - info.start_col)
|
||||
end
|
||||
|
||||
api.nvim_buf_set_lines(bufnr or opts.bufnr, line_nr, line_nr + 1, false, { updated_line })
|
||||
|
||||
for _, hl_pos in ipairs(highlight_positions) do
|
||||
api.nvim_buf_add_highlight(
|
||||
bufnr or opts.bufnr,
|
||||
preview_ns,
|
||||
M.hl_group,
|
||||
line_nr,
|
||||
hl_pos.start_col,
|
||||
hl_pos.end_col
|
||||
)
|
||||
end
|
||||
end
|
||||
|
||||
for bufnr, line_info_per_bufnr in pairs(state.cached_lines) do
|
||||
for line_nr, line_info in pairs(line_info_per_bufnr) do
|
||||
apply_highlights_fn(bufnr, line_nr, line_info)
|
||||
end
|
||||
end
|
||||
|
||||
state.preview_ns = preview_ns
|
||||
end
|
||||
|
||||
-- function rewrite from smjonas/inc-rename.nvim
|
||||
local function perform_lsp_rename(new_name, params)
|
||||
params = params or make_position_params()
|
||||
params.newName = new_name
|
||||
|
||||
vim.lsp.buf_request(0, 'textDocument/rename', params, function(err, result, ctx, _)
|
||||
if err and err.message then
|
||||
vim.notify('[nav-rename] Error while renaming: ' .. err.message, vim.log.levels.ERROR)
|
||||
return
|
||||
end
|
||||
|
||||
if not result or vim.tbl_isempty(result) then
|
||||
set_error('[nav-rename] Nothing renamed', vim.log.levels.INFO)
|
||||
return
|
||||
end
|
||||
|
||||
local client = vim.lsp.get_client_by_id(ctx.client_id)
|
||||
vim.lsp.util.apply_workspace_edit(result, client.offset_encoding)
|
||||
|
||||
if _NgConfigValues.lsp.rename.show_result then
|
||||
local changed_instances = 0
|
||||
local changed_files = 0
|
||||
|
||||
local with_edits = result.documentChanges ~= nil
|
||||
for _, change in pairs(result.documentChanges or result.changes) do
|
||||
changed_instances = changed_instances + (with_edits and #change.edits or #change)
|
||||
changed_files = changed_files + 1
|
||||
end
|
||||
|
||||
local message = string.format(
|
||||
'Renamed %s instance%s %s in %s file%s \n to %s:',
|
||||
changed_instances,
|
||||
changed_instances == 1 and '' or 's',
|
||||
state.oldname,
|
||||
changed_files,
|
||||
changed_files == 1 and '' or 's',
|
||||
new_name
|
||||
)
|
||||
vim.notify(message)
|
||||
end
|
||||
if M.config and M.config.post_hook then
|
||||
M.config.post_hook(result)
|
||||
end
|
||||
end)
|
||||
end
|
||||
|
||||
local function inc_rename_execute(opts)
|
||||
if vim.v.errmsg ~= '' then
|
||||
log(
|
||||
'[nav-rename] An error occurred in the preview function.' .. vim.v.errmsg,
|
||||
vim.log.levels.ERROR
|
||||
)
|
||||
elseif state.err then
|
||||
log(state.err.msg, state.err.level)
|
||||
end
|
||||
restore_buffer()
|
||||
teardown(true)
|
||||
perform_lsp_rename(opts.args, opts.params)
|
||||
end
|
||||
-- https://github.com/lukas-reineke/dotfiles/blob/master/vim/lua/lsp/rename.lua
|
||||
local M = {}
|
||||
local util = require "navigator.util"
|
||||
local rename_prompt = "Rename -> "
|
||||
|
||||
M.rename = function()
|
||||
if _NgConfigValues.lsp.rename.style == 'floating-preview' then
|
||||
return M.rename_preview()
|
||||
end
|
||||
if _NgConfigValues.lsp.rename.style == 'inplace-preview' then
|
||||
return M.rename_inplace()
|
||||
end
|
||||
|
||||
local input = vim.ui.input
|
||||
|
||||
local ghinput = require('guihua.input')
|
||||
-- make sure everything was restored
|
||||
ghinput.setup({
|
||||
on_change = function(new_name) end,
|
||||
on_concel = function(new_name) end,
|
||||
title = 'lsp rename',
|
||||
on_cancel = function() end,
|
||||
})
|
||||
vim.ui.input = ghinput.input
|
||||
vim.lsp.buf.rename()
|
||||
vim.defer_fn(function()
|
||||
vim.ui.input = input
|
||||
end, 1000)
|
||||
end
|
||||
|
||||
M.rename_preview = function()
|
||||
local input = vim.ui.input
|
||||
state.cached_lines = {}
|
||||
state.confrim = nil
|
||||
state.should_fetch_references = true
|
||||
state.lsp_params = make_position_params()
|
||||
|
||||
if not ts_symbol() then
|
||||
return
|
||||
end
|
||||
|
||||
rename_group = api.nvim_create_augroup('nav-rename', {})
|
||||
if vim.fn.has('nvim-0.8.0') ~= 1 then
|
||||
vim.ui.input = require('guihua.floating').input
|
||||
vim.lsp.buf.rename()
|
||||
return vim.defer_fn(function()
|
||||
vim.ui.input = input
|
||||
end, 1000)
|
||||
end
|
||||
|
||||
local ghinput = require('guihua.input')
|
||||
state.win_id = vim.fn.win_getid(0)
|
||||
state.lsp_params = make_position_params()
|
||||
state.preview_buf = vim.api.nvim_get_current_buf()
|
||||
|
||||
local inputopts = {
|
||||
on_change = function(new_name)
|
||||
incremental_rename_preview({ args = new_name }, ns, state.preview_buf)
|
||||
end,
|
||||
preview_buf = state.preview_buf,
|
||||
on_confirm = function(new_name)
|
||||
-- put back everything
|
||||
log('on_confirm', new_name)
|
||||
restore_buffer()
|
||||
end,
|
||||
on_cancel = function(new_name)
|
||||
restore_buffer()
|
||||
teardown(true)
|
||||
log('cancel', new_name)
|
||||
end,
|
||||
}
|
||||
if vim.fn.has('nvim-0.9.0') == 1 then
|
||||
inputopts.title = 'symbol rename'
|
||||
end
|
||||
ghinput.setup(inputopts)
|
||||
vim.ui.input = ghinput.input
|
||||
|
||||
vim.lsp.buf.rename()
|
||||
end
|
||||
|
||||
-- rename without floating window
|
||||
-- a moodify version of neovim vim.lsp.buf.rename
|
||||
function M.rename_inplace(new_name, options)
|
||||
options = options or {}
|
||||
state.confrim = nil
|
||||
state.should_fetch_references = true
|
||||
state.cached_lines = {}
|
||||
state.lsp_params = make_position_params()
|
||||
rename_group = api.nvim_create_augroup('nav-rename', {})
|
||||
local bufnr = options.bufnr or api.nvim_get_current_buf()
|
||||
local clients = vim.lsp.get_clients({
|
||||
bufnr = bufnr,
|
||||
name = options.name,
|
||||
local current_name = vim.fn.expand("<cword>")
|
||||
local bufnr = vim.api.nvim_create_buf(false, true)
|
||||
vim.api.nvim_buf_set_option(bufnr, "buftype", "prompt")
|
||||
vim.api.nvim_buf_set_option(bufnr, "bufhidden", "wipe")
|
||||
vim.api.nvim_buf_add_highlight(bufnr, -1, "NGPreviewTitle", 0, 0, #rename_prompt)
|
||||
vim.fn.prompt_setprompt(bufnr, rename_prompt)
|
||||
local width = #current_name + #rename_prompt + 10
|
||||
local winnr = vim.api.nvim_open_win(bufnr, true, {
|
||||
relative = "cursor",
|
||||
width = width,
|
||||
height = 1,
|
||||
row = -3,
|
||||
col = 1,
|
||||
style = "minimal",
|
||||
border = "single"
|
||||
})
|
||||
if options.filter then
|
||||
clients = vim.tbl_filter(options.filter, clients)
|
||||
end
|
||||
|
||||
if not ts_symbol() then
|
||||
vim.api.nvim_win_set_option(winnr, "winhl", "Normal:Floating")
|
||||
vim.api.nvim_buf_set_option(bufnr, "filetype", "guihua")
|
||||
util.map("n", "<ESC>", "<cmd>bd!<CR>", {silent = true, buffer = true})
|
||||
util.map({"n", "i"}, "<CR>", "<cmd>lua require('navigator.rename').callback()<CR>",
|
||||
{silent = true, buffer = true})
|
||||
util.map({"n", "i"}, "<BS>", [[<ESC>"_cl]], {silent = true, buffer = true})
|
||||
vim.cmd(string.format("normal i%s", current_name))
|
||||
end
|
||||
|
||||
M.callback = function()
|
||||
local new_name = vim.trim(vim.fn.getline("."):sub(#rename_prompt + 1, -1))
|
||||
vim.cmd [[stopinsert]]
|
||||
vim.cmd [[bd!]]
|
||||
if #new_name == 0 or new_name == vim.fn.expand("<cword>") then
|
||||
return
|
||||
end
|
||||
|
||||
-- Clients must at least support rename, prepareRename is optional
|
||||
clients = vim.tbl_filter(function(client)
|
||||
return client.supports_method('textDocument/rename')
|
||||
end, clients)
|
||||
|
||||
if #clients == 0 then
|
||||
vim.notify('[LSP] Rename, no matching language servers with rename capability.')
|
||||
end
|
||||
|
||||
local confirm_key = _NgConfigValues.lsp.rename.confirm
|
||||
local cancel_key = _NgConfigValues.lsp.rename.concel
|
||||
local win = api.nvim_get_current_win()
|
||||
|
||||
-- Compute early to account for cursor movements after going async
|
||||
local cword = vim.fn.expand('<cword>')
|
||||
state.oldname = cword
|
||||
|
||||
---@private
|
||||
local function get_text_at_range(range, offset_encoding)
|
||||
return api.nvim_buf_get_text(
|
||||
bufnr,
|
||||
range.start.line,
|
||||
util._get_line_byte_from_position(bufnr, range.start, offset_encoding),
|
||||
range['end'].line,
|
||||
util._get_line_byte_from_position(bufnr, range['end'], offset_encoding),
|
||||
{}
|
||||
)[1]
|
||||
end
|
||||
|
||||
local on_finish_cb = function()
|
||||
log('leave insert')
|
||||
|
||||
api.nvim_buf_clear_namespace(bufnr, ns, 0, -1)
|
||||
api.nvim_del_augroup_by_name('nav-rename')
|
||||
vim.keymap.del({ 'i', 'n' }, confirm_key, { buffer = bufnr })
|
||||
vim.keymap.del({ 'i', 'n' }, cancel_key, { buffer = bufnr })
|
||||
restore_buffer()
|
||||
if state.confirm then
|
||||
-- lets put back
|
||||
log('execute rename')
|
||||
inc_rename_execute({ args = state.new_name or vim.fn.expand('<cword>'), params = {} })
|
||||
end
|
||||
end
|
||||
local try_use_client
|
||||
try_use_client = function(idx, client)
|
||||
if not client then
|
||||
return
|
||||
end
|
||||
|
||||
local params = make_position_params(win, client.offset_encoding)
|
||||
---@private
|
||||
local function rename(name)
|
||||
params.newName = name
|
||||
local handler = client.handlers['textDocument/rename']
|
||||
or vim.lsp.handlers['textDocument/rename']
|
||||
client.request('textDocument/rename', params, function(...)
|
||||
handler(...)
|
||||
try_use_client(next(clients, idx))
|
||||
end, bufnr)
|
||||
end
|
||||
|
||||
if client.supports_method('textDocument/prepareRename') then
|
||||
-- log(params)
|
||||
client.request('textDocument/prepareRename', params, function(err, result)
|
||||
if err or result == nil then
|
||||
if next(clients, idx) then
|
||||
try_use_client(next(clients, idx))
|
||||
else
|
||||
local msg = err and ('Error on prepareRename: ' .. (err.message or ''))
|
||||
or 'Nothing to rename'
|
||||
vim.notify(msg, vim.log.levels.INFO)
|
||||
end
|
||||
return
|
||||
end
|
||||
|
||||
incremental_rename_preview({ args = cword, floating = false }, 0, bufnr)
|
||||
if new_name then
|
||||
return rename(new_name)
|
||||
end
|
||||
|
||||
vim.api.nvim_create_autocmd({ 'TextChangedI', 'TextChanged' }, {
|
||||
group = rename_group,
|
||||
callback = function()
|
||||
local w = vim.fn.expand('<cword>')
|
||||
local curl = vfn.getline('.')
|
||||
local curc = curl:sub(vfn.col('.'), vfn.col('.'))
|
||||
local node = ts_symbol()
|
||||
if node and node:type():find('identifier') then
|
||||
w = vim.treesitter.get_node_text(node, bufnr)
|
||||
log(node:range(), node:type())
|
||||
else
|
||||
-- log(curc, node:type(), vim.treesitter.get_node_text(node, bufnr))
|
||||
-- cursor at end of symbol
|
||||
if curc:match('%W') and curc ~= '_' then
|
||||
local cur_pos = vim.fn.getpos('.')
|
||||
cur_pos[3] = cur_pos[3] - 1
|
||||
vfn.setpos('.', cur_pos)
|
||||
log('move back')
|
||||
|
||||
node = ts_symbol()
|
||||
if node and node:type():find('identifier') then
|
||||
w = vim.treesitter.get_node_text(node, bufnr)
|
||||
else
|
||||
w = vim.fn.expand('<cword>')
|
||||
end
|
||||
cur_pos[3] = cur_pos[3] + 1
|
||||
vfn.setpos('.', cur_pos)
|
||||
end
|
||||
end
|
||||
log(curc, w)
|
||||
incremental_rename_preview({ args = w, floating = false }, ns, bufnr)
|
||||
end,
|
||||
})
|
||||
vim.keymap.set({ 'i', 'n' }, confirm_key, function()
|
||||
print('done rename')
|
||||
local input = vim.fn.expand('<cword>')
|
||||
log('newname', input)
|
||||
state.confirm = true
|
||||
vim.cmd('stopinsert')
|
||||
on_finish_cb()
|
||||
end, { buffer = bufnr })
|
||||
|
||||
if cancel_key == nil or cancel_key == '' then
|
||||
vim.api.nvim_create_autocmd({ 'InsertLeave' }, {
|
||||
group = rename_group,
|
||||
callback = function()
|
||||
state.confirm = nil
|
||||
on_finish_cb()
|
||||
end,
|
||||
})
|
||||
else
|
||||
vim.keymap.set({ 'i', 'n' }, cancel_key, function()
|
||||
print('cancel rename')
|
||||
state.confirm = nil
|
||||
on_finish_cb()
|
||||
end, { buffer = bufnr })
|
||||
end
|
||||
|
||||
vim.cmd('noautocmd startinsert')
|
||||
end, bufnr)
|
||||
else
|
||||
assert(
|
||||
client.supports_method('textDocument/rename'),
|
||||
'Client must support textDocument/rename'
|
||||
)
|
||||
if new_name then
|
||||
rename(new_name)
|
||||
return
|
||||
end
|
||||
|
||||
local prompt_opts = {
|
||||
prompt = 'New Name: ',
|
||||
default = cword,
|
||||
}
|
||||
vim.ui.input(prompt_opts, function(input)
|
||||
if not input or #input == 0 then
|
||||
return
|
||||
end
|
||||
rename(input)
|
||||
end)
|
||||
end
|
||||
end
|
||||
|
||||
try_use_client(next(clients))
|
||||
local params = vim.lsp.util.make_position_params()
|
||||
params.newName = new_name
|
||||
vim.lsp.buf_request(0, "textDocument/rename", params)
|
||||
end
|
||||
|
||||
-- M.callback()
|
||||
return M
|
||||
|
@ -1,110 +0,0 @@
|
||||
local diagnostic = vim.diagnostic or vim.lsp.diagnostic
|
||||
local util = require('navigator.util')
|
||||
local log = util.log
|
||||
local api = vim.api
|
||||
|
||||
local M = {}
|
||||
function M.treesitter_and_diag_panel()
|
||||
local Panel = require('guihua.panel')
|
||||
|
||||
local diag = require('navigator.diagnostics')
|
||||
local ft = vim.bo.filetype
|
||||
local results = diag.diagnostic_list[ft]
|
||||
log(diag.diagnostic_list, ft)
|
||||
|
||||
local bufnr = api.nvim_get_current_buf()
|
||||
local p = Panel:new({
|
||||
header = 'treesitter',
|
||||
render = function(b)
|
||||
log('render for ', bufnr, b)
|
||||
return require('navigator.treesitter').all_ts_nodes(b)
|
||||
end,
|
||||
})
|
||||
p:add_section({
|
||||
header = 'diagnostic',
|
||||
render = function(buf)
|
||||
log(buf, diagnostic)
|
||||
if diag.diagnostic_list[ft] ~= nil then
|
||||
local display_items = {}
|
||||
for _, client_items in pairs(results) do
|
||||
for _, items in pairs(client_items) do
|
||||
for _, it in pairs(items) do
|
||||
log(it)
|
||||
table.insert(display_items, it)
|
||||
end
|
||||
end
|
||||
end
|
||||
return display_items
|
||||
else
|
||||
return {}
|
||||
end
|
||||
end,
|
||||
})
|
||||
p:open(true)
|
||||
end
|
||||
|
||||
function M.lsp_and_diag_panel()
|
||||
local Panel = require('guihua.panel')
|
||||
|
||||
local ft = vim.bo.filetype
|
||||
local diag = require('navigator.diagnostics')
|
||||
local results = diag.diagnostic_list[ft]
|
||||
log(diag.diagnostic_list, ft)
|
||||
|
||||
local bf = api.nvim_get_current_buf()
|
||||
ft = vim.api.nvim_buf_get_option(bf, 'buftype') or vim.bo.filetype
|
||||
if ft == 'nofile' or ft == 'guihua' or ft == 'prompt' then
|
||||
return
|
||||
end
|
||||
local lsp
|
||||
local p = Panel:new({
|
||||
header = 'symbols',
|
||||
render = function(bufnr)
|
||||
bufnr = bufnr or api.nvim_get_current_buf()
|
||||
local params = vim.lsp.util.make_range_params()
|
||||
local lsp_call = require('navigator.lspwrapper').call_sync
|
||||
if not Panel:is_open() or vim.fn.empty(lsp) == 1 then
|
||||
lsp = lsp_call(
|
||||
'textDocument/documentSymbol',
|
||||
params,
|
||||
{ timeout = 2000, bufnr = bufnr, no_show = true },
|
||||
vim.lsp.with(require('navigator.symbols').document_symbol_handler, { no_show = true })
|
||||
)
|
||||
else
|
||||
lsp_call = require('navigator.lspwrapper').call_async
|
||||
local f = function(err, result, ctx)
|
||||
-- log(result, ctx)
|
||||
ctx = ctx or {}
|
||||
ctx.no_show = true
|
||||
lsp = require('navigator.symbols').document_symbol_handler(err, result, ctx)
|
||||
return lsp
|
||||
end
|
||||
lsp_call('textDocument/documentSymbol', params, f, bufnr)
|
||||
end
|
||||
return lsp
|
||||
end,
|
||||
})
|
||||
p:add_section({
|
||||
header = 'diagnostic',
|
||||
render = function(buf)
|
||||
log(buf, diagnostic)
|
||||
if results ~= nil then
|
||||
local display_items = {}
|
||||
for _, client_items in pairs(results) do
|
||||
for _, items in pairs(client_items) do
|
||||
for _, it in pairs(items) do
|
||||
log(it)
|
||||
table.insert(display_items, it)
|
||||
end
|
||||
end
|
||||
end
|
||||
return display_items
|
||||
else
|
||||
return {}
|
||||
end
|
||||
end,
|
||||
})
|
||||
p:open(true)
|
||||
end
|
||||
|
||||
return M
|
@ -0,0 +1,76 @@
|
||||
local gui = require "navigator.gui"
|
||||
local util = require "navigator.util"
|
||||
local mk_handler = util.mk_handler
|
||||
local log = util.log
|
||||
local partial = util.partial
|
||||
local lsphelper = require "navigator.lspwrapper"
|
||||
local cwd = vim.loop.cwd()
|
||||
local M = {}
|
||||
|
||||
--- navigator signature
|
||||
local match_parameter = function(result)
|
||||
local signatures = result.signatures
|
||||
if #signatures < 1 then
|
||||
return result
|
||||
end
|
||||
|
||||
local signature = signatures[1]
|
||||
local activeParameter = result.activeParameter or signature.activeParameter
|
||||
if activeParameter == nil then
|
||||
return result
|
||||
end
|
||||
|
||||
if signature.parameters == nil then
|
||||
return
|
||||
end
|
||||
|
||||
if #signature.parameters < 2 or activeParameter + 1 > #signature.parameters then
|
||||
return result
|
||||
end
|
||||
|
||||
local nextParameter = signature.parameters[activeParameter + 1]
|
||||
|
||||
local label = signature.label
|
||||
if type(nextParameter.label) == "table" then -- label = {2, 4} c style
|
||||
local range = nextParameter.label
|
||||
label = label:sub(1, range[1]) .. [[`]] .. label:sub(range[1] + 1, range[2]) .. [[`]]
|
||||
.. label:sub(range[2] + 1, #label + 1)
|
||||
signature.label = label
|
||||
else
|
||||
if type(nextParameter.label) == "string" then -- label = 'par1 int'
|
||||
local i, j = label:find(nextParameter.label, 1, true)
|
||||
if i ~= nil then
|
||||
label = label:sub(1, i - 1) .. [[`]] .. label:sub(i, j) .. [[`]]
|
||||
.. label:sub(j + 1, #label + 1)
|
||||
signature.label = label
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local signature_handler = mk_handler(function(err, result, ctx, config)
|
||||
if config == nil then
|
||||
log("config nil")
|
||||
end
|
||||
if err then
|
||||
print("signature help error: ", err, vim.inspect(result), ctx, config)
|
||||
end
|
||||
config = config or {}
|
||||
if config.border == nil then
|
||||
config.border = _NgConfigValues.border
|
||||
end
|
||||
|
||||
if not (result and result.signatures and result.signatures[1]) then
|
||||
return
|
||||
end
|
||||
match_parameter(result)
|
||||
local lines = vim.lsp.util.convert_signature_help_to_markdown_lines(result)
|
||||
if vim.tbl_isempty(lines) then
|
||||
return
|
||||
end
|
||||
|
||||
local syntax = vim.lsp.util.try_trim_markdown_code_blocks(lines)
|
||||
config.focus_id = ctx.bufnr .. "lsp_signature"
|
||||
vim.lsp.util.open_floating_preview(lines, syntax, config)
|
||||
end)
|
||||
return {signature_handler = signature_handler}
|
@ -1,105 +0,0 @@
|
||||
-- https://github.com/lukas-reineke/dotfiles/blob/master/vim/lua/lsp/rename.lua
|
||||
local M = {}
|
||||
local util = require('navigator.util')
|
||||
local gutil = require('guihua.util')
|
||||
local lsphelper = require('navigator.lspwrapper')
|
||||
local symbols_to_items = lsphelper.symbols_to_items
|
||||
local vfn = vim.fn
|
||||
|
||||
M.add_workspace_folder = function()
|
||||
util.log(vim.ui.input)
|
||||
local input = require('guihua.floating').input
|
||||
input({ prompt = 'Workspace To Add: ', default = vfn.expand('%:p:h') }, function(inputs)
|
||||
vim.lsp.buf.add_workspace_folder(inputs)
|
||||
end)
|
||||
end
|
||||
|
||||
M.remove_workspace_folder = function()
|
||||
local select = require('guihua.gui').select
|
||||
local folders = vim.lsp.buf.list_workspace_folders()
|
||||
|
||||
if #folders > 1 then
|
||||
return select(folders, { prompt = 'select workspace to delete' }, function(workspace)
|
||||
vim.lsp.buf.remove_workspace_folder(workspace)
|
||||
end)
|
||||
end
|
||||
end
|
||||
|
||||
M.workspace_symbol = function()
|
||||
local input = require('guihua.floating').input
|
||||
input({ prompt = 'Search symbol: ', default = '' }, function(inputs)
|
||||
util.log(inputs)
|
||||
vim.lsp.buf.workspace_symbol(inputs)
|
||||
end)
|
||||
end
|
||||
|
||||
function M.workspace_symbol_live()
|
||||
local height = _NgConfigValues.height or 0.4
|
||||
height = math.floor(height * vfn.winheight('%'))
|
||||
local width = _NgConfigValues.width or 0.7
|
||||
width = math.floor(vim.api.nvim_get_option('columns') * width)
|
||||
local bufnr = vim.api.nvim_get_current_buf()
|
||||
local ft = vim.o.ft
|
||||
local data = { { text = 'input the symbol name to start fuzzy search' } }
|
||||
for _ = 1, height do
|
||||
table.insert(data, { text = '' })
|
||||
end
|
||||
local ListView = require('guihua.listview')
|
||||
local opt = {
|
||||
api = ' ',
|
||||
bg = 'GuihuaListDark',
|
||||
data = data,
|
||||
items = data,
|
||||
enter = true,
|
||||
ft = ft,
|
||||
loc = 'top_center',
|
||||
transparency = 50,
|
||||
prompt = true,
|
||||
on_confirm = function(item)
|
||||
vim.defer_fn(function()
|
||||
if item and item.name then
|
||||
require('navigator.symbols').workspace_symbols(item.name)
|
||||
end
|
||||
end, 10)
|
||||
end,
|
||||
on_input_filter = function(text)
|
||||
local params = { query = text or '#' }
|
||||
local results = vim.lsp.buf_request_sync(bufnr, 'workspace/symbol', params)
|
||||
local result
|
||||
for _, r in pairs(results) do
|
||||
-- util.log(r)
|
||||
if r.result then
|
||||
result = r.result
|
||||
break
|
||||
end
|
||||
end
|
||||
if not result then
|
||||
result = {}
|
||||
end
|
||||
|
||||
local items = symbols_to_items(result)
|
||||
items = gutil.dedup(items, 'name', 'kind')
|
||||
return items
|
||||
end,
|
||||
rect = { height = height, pos_x = 0, pos_y = 0, width = width },
|
||||
}
|
||||
|
||||
local win = ListView:new(opt)
|
||||
win:on_draw({})
|
||||
-- require('guihua.gui').new_list_view(opt)
|
||||
end
|
||||
|
||||
M.list_workspace_folders = function()
|
||||
local folders = vim.lsp.buf.list_workspace_folders()
|
||||
if #folders > 0 then
|
||||
return require('navigator.gui').new_list_view({
|
||||
title = 'workspace folders',
|
||||
items = folders,
|
||||
border = 'single',
|
||||
rawdata = true,
|
||||
on_move = function() end,
|
||||
})
|
||||
end
|
||||
end
|
||||
|
||||
return M
|
@ -1,38 +0,0 @@
|
||||
# Sandbox/Tutorial
|
||||
|
||||
## introduction
|
||||
|
||||
The folder contains `init.lua`, whitch is a minium vimrc to setup following plugins. Those plugin are some of the
|
||||
most used plugins for programmer.
|
||||
|
||||
- lspconfig
|
||||
- treesitter
|
||||
- navigator
|
||||
- nvim-cmp
|
||||
- luasnip
|
||||
- aurora (colorscheme used in the screenshot)
|
||||
|
||||
There are three folders `js`, `go`, `py`. Those folders have some basic source code you can play with.
|
||||
The init will install the plugins in `/tmp/nvim` folder. It will not affect your current setup.
|
||||
|
||||
## Install LSP
|
||||
|
||||
The playground has js, py, go folder, so you can install either one your self in your PATH.
|
||||
If you want to try lua, Please check sumneko setup in init.lua make sure it pointed to correct path. By default it
|
||||
potint to ~/github/sumneko if not existed in your PATH.
|
||||
|
||||
## run init.lua
|
||||
|
||||
```bash
|
||||
cd py
|
||||
neovim -u init.lua
|
||||
```
|
||||
|
||||
Move your cursor around and try to
|
||||
|
||||
- Edit the code
|
||||
- Check symbol reference with `<esc>gr`
|
||||
- Check document symbol with `<esc>g0`
|
||||
- treesitter symbole `<esc>gT`
|
||||
- peek definition `<esc>gp`
|
||||
- ...
|
@ -1,43 +0,0 @@
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
#include <unordered_map>
|
||||
|
||||
int main()
|
||||
{
|
||||
// Create an unordered_map of three strings (that map to strings)
|
||||
std::unordered_map<std::string, std::string> u =
|
||||
{
|
||||
{"RED", "#FF0000"},
|
||||
{"GREEN", "#00FF00"},
|
||||
{"BLUE", "#0000FF"}
|
||||
};
|
||||
|
||||
// Helper lambda function to print key-value pairs
|
||||
auto print_key_value = [](const auto& key, const auto& value)
|
||||
{
|
||||
std::cout << "Key:[" << key << "] Value:[" << value << "]\n";
|
||||
};
|
||||
std::cout << "Iterate and print key-value pairs of unordered_map, being\n"
|
||||
"explicit with their types:\n";
|
||||
for (const std::pair<const std::string, std::string>& n : u)
|
||||
print_key_value(n.first, n.second);
|
||||
std::cout << "\nIterate and print key-value pairs using C++17 structured binding:\n";
|
||||
for (const auto& [key, value] : u)
|
||||
print_key_value(key, value);
|
||||
|
||||
// Add two new entries to the unordered_map
|
||||
u["BLACK"] = "#000000";
|
||||
u["WHITE"] = "#FFFFFF";
|
||||
|
||||
std::cout << "\nOutput values by key:\n"
|
||||
"The HEX of color RED is:[" << u["RED"] << "]\n"
|
||||
"The HEX of color BLACK is:[" << u["BLACK"] << "]\n\n";
|
||||
|
||||
std::cout << "Use operator[] with non-existent key to insert a new key-value pair:\n";
|
||||
print_key_value("new_key", u["new_key"]);
|
||||
|
||||
std::cout << "\nIterate and print key-value pairs, using `auto`;\n"
|
||||
"new_key is now one of the keys in the map:\n";
|
||||
for (const auto& n : u)
|
||||
print_key_value(n.first, n.second);
|
||||
}
|
@ -1,8 +0,0 @@
|
||||
package main
|
||||
|
||||
func Fib(n int) int {
|
||||
if n < 2 {
|
||||
return n
|
||||
}
|
||||
return Fib(n-1) + Fib(n-2)
|
||||
}
|
@ -1,17 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestFib(t *testing.T) {
|
||||
require.NoError(t, nil)
|
||||
d := Fib(1)
|
||||
fmt.Println(d)
|
||||
if d != 1 {
|
||||
t.Errorf("NewDog failled %v", d)
|
||||
}
|
||||
}
|
@ -1,49 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
// "net/http"
|
||||
"net/http/httptest"
|
||||
"time"
|
||||
)
|
||||
|
||||
type Dog struct {
|
||||
name string
|
||||
age int
|
||||
owner string
|
||||
}
|
||||
|
||||
func NewDog(name string, age int) *Dog {
|
||||
return &Dog{name: name, age: age}
|
||||
}
|
||||
|
||||
// SetOwner
|
||||
func (d *Dog) SetOwner(owner string) {
|
||||
d.owner = owner
|
||||
}
|
||||
|
||||
// SetDogName
|
||||
func (d *Dog) SetDogName(name string) {
|
||||
if d == nil {
|
||||
d = NewDog(name, 0)
|
||||
d.name = name
|
||||
} else {
|
||||
d.name = name
|
||||
}
|
||||
}
|
||||
|
||||
func (d *Dog) SetOwnerUtf8(name []byte) {
|
||||
}
|
||||
|
||||
func fun1() {
|
||||
}
|
||||
|
||||
func fun1_test() {
|
||||
d := NewDog("", 1)
|
||||
NewDog("abc", 12)
|
||||
// fmt.Printf("abc", 1)
|
||||
time.Date(12, 12, 12, 33, 12, 55, 22, nil)
|
||||
|
||||
d.SetOwnerUtf8([]byte{1})
|
||||
w := httptest.NewRecorder()
|
||||
w.Write([]byte{})
|
||||
}
|
@ -1,25 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestDog(t *testing.T) {
|
||||
require.NoError(t, nil)
|
||||
d := NewDog("Fibi", 4)
|
||||
fmt.Println(d.name)
|
||||
if d.name != "Fibi" {
|
||||
t.Errorf("NewDog failled %v", d)
|
||||
}
|
||||
}
|
||||
|
||||
func TestCat(t *testing.T) {
|
||||
d := NewDog("Fibi cat", 4)
|
||||
fmt.Println(d.name)
|
||||
if d.name != "Fibi cat" {
|
||||
t.Errorf("NewDog failled %v", d)
|
||||
}
|
||||
}
|
@ -1,26 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestCow(t *testing.T) {
|
||||
require.NoError(t, nil)
|
||||
d := NewDog("Fibi", 4)
|
||||
fmt.Println(d.name)
|
||||
if d.name != "Fibi" {
|
||||
t.Errorf("NewDog failled %v", d)
|
||||
}
|
||||
}
|
||||
|
||||
func TestHorse(t *testing.T) {
|
||||
d := NewDog("Fibi cat", 4)
|
||||
fmt.Println(d.name)
|
||||
if d.name != "Fibi cat" {
|
||||
t.Errorf("NewDog failled %v", d)
|
||||
|
||||
}
|
||||
}
|
@ -1,67 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"math"
|
||||
//"math"
|
||||
)
|
||||
|
||||
type geometry interface {
|
||||
area() float64
|
||||
perim() float64
|
||||
}
|
||||
|
||||
type rect struct {
|
||||
width float64 `-line:"width"`
|
||||
height float64 `-line:"height"`
|
||||
}
|
||||
|
||||
type rect2 struct {
|
||||
width int `yml:"width"`
|
||||
height int `yml:"height"`
|
||||
}
|
||||
|
||||
func (r rect) area() float64 {
|
||||
return r.width * r.height
|
||||
}
|
||||
|
||||
func (r rect) perim() float64 {
|
||||
return 2*r.width + 2*r.height
|
||||
}
|
||||
|
||||
type circle struct {
|
||||
radius float64
|
||||
}
|
||||
|
||||
func (c circle) area() float64 {
|
||||
return math.Pi * c.radius * c.radius
|
||||
}
|
||||
|
||||
func (c circle) perim() float64 {
|
||||
return 2 * math.Pi * c.radius
|
||||
}
|
||||
|
||||
func measure(g geometry) int {
|
||||
fmt.Println(g)
|
||||
fmt.Println(g.area())
|
||||
fmt.Println(g.perim())
|
||||
return 1
|
||||
}
|
||||
|
||||
func m2() {
|
||||
measure(rect{width: 3})
|
||||
}
|
||||
|
||||
func M2() {
|
||||
measure(rect{width: 3})
|
||||
}
|
||||
|
||||
func interfaceTest() {
|
||||
r := rect{width: 3, height: 4}
|
||||
c := circle{radius: 5}
|
||||
measure(r)
|
||||
measure(c)
|
||||
d := circle{radius: 10}
|
||||
fmt.Println()
|
||||
fun2(d)
|
||||
}
|
@ -1,31 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"io/fs"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
// main
|
||||
// note: this is main func
|
||||
func main() {
|
||||
i := 32
|
||||
i = i + 1
|
||||
fmt.Println("hello, world", i)
|
||||
var uns1 unsafe.Pointer
|
||||
|
||||
var x struct {
|
||||
a int64
|
||||
b bool
|
||||
c string
|
||||
}
|
||||
const M, N = unsafe.Sizeof(x.c), unsafe.Sizeof(x)
|
||||
fmt.Println(M, N, uns1) // 16 32
|
||||
|
||||
var perr *fs.PathError
|
||||
if errors.As(nil, &perr) {
|
||||
fmt.Println(perr.Path)
|
||||
}
|
||||
myfunc3("a", "b")
|
||||
}
|
@ -1,39 +0,0 @@
|
||||
package main
|
||||
|
||||
import "fmt"
|
||||
|
||||
// import "fmt"
|
||||
|
||||
type person struct {
|
||||
name string
|
||||
age int
|
||||
}
|
||||
|
||||
type say interface {
|
||||
hello() string
|
||||
}
|
||||
|
||||
type strudent struct {
|
||||
person struct {
|
||||
name string
|
||||
age int
|
||||
}
|
||||
}
|
||||
|
||||
func newPerson(name string) *person {
|
||||
p := person{name: name}
|
||||
fmt.Println("")
|
||||
p.age = 42
|
||||
return &p
|
||||
}
|
||||
|
||||
func newPerson2(name, say string) {
|
||||
fmt.Println(name, say)
|
||||
}
|
||||
|
||||
func b() {
|
||||
newPerson2("a", "say")
|
||||
|
||||
ret := measure(rect{width: 3})
|
||||
fmt.Println(ret)
|
||||
}
|
@ -1,26 +0,0 @@
|
||||
package test
|
||||
|
||||
type Dog struct {
|
||||
name string
|
||||
age int
|
||||
owner string
|
||||
}
|
||||
|
||||
func NewDog(name string, age int) *Dog {
|
||||
return &Dog{name: name, age: age}
|
||||
}
|
||||
|
||||
// SetOwner
|
||||
func (d *Dog) SetOwner(owner string) {
|
||||
d.owner = owner
|
||||
}
|
||||
|
||||
// SetName
|
||||
func (d *Dog) SetName(name string) {
|
||||
if d == nil {
|
||||
d = NewDog(name, 0)
|
||||
d.name = name
|
||||
} else {
|
||||
d.name = name
|
||||
}
|
||||
}
|
@ -1,26 +0,0 @@
|
||||
package tekkkt
|
||||
|
||||
type Dog kkktruct {
|
||||
name kkktring
|
||||
age int
|
||||
owner kkktring
|
||||
}
|
||||
|
||||
func NewDog(name kkktring, age int) *Dog {
|
||||
return &Dog{name: name, age: age}
|
||||
}
|
||||
|
||||
// kkketOwner
|
||||
func (d *Dog) kkketOwner(owner kkktring) {
|
||||
d.owner = owner
|
||||
}
|
||||
|
||||
// kkketName
|
||||
func (d *Dog) kkketName(name kkktring) {
|
||||
if d == nil {
|
||||
d = NewDog(name, 0)
|
||||
d.name = name
|
||||
} elkkke {
|
||||
d.name = name
|
||||
}
|
||||
}
|
@ -1,22 +0,0 @@
|
||||
package test
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestDog(t *testing.T) {
|
||||
d := NewDog("Fibi", 4)
|
||||
fmt.Println(d.name)
|
||||
if d.name != "Fibi" {
|
||||
t.Errorf("NewDog failled %v", d)
|
||||
}
|
||||
}
|
||||
|
||||
func TestCat(t *testing.T) {
|
||||
d := NewDog("Fibi cat", 4)
|
||||
fmt.Println(d.name)
|
||||
if d.name != "Fibi cat" {
|
||||
t.Errorf("NewDog failled %v", d)
|
||||
}
|
||||
}
|
@ -1,70 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
// "strings"
|
||||
"time"
|
||||
|
||||
log "github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
// type Name2 struct {
|
||||
// f1 string
|
||||
// f2 int
|
||||
// }
|
||||
//
|
||||
// type name4 struct {
|
||||
// f1 string
|
||||
// f2 int
|
||||
// }
|
||||
//
|
||||
// type name5 struct {
|
||||
// f1 string
|
||||
// f2 int
|
||||
// }
|
||||
//
|
||||
// func test2() {
|
||||
// type some struct {
|
||||
// Success bool `-line:"success"`
|
||||
// Failure bool
|
||||
// }
|
||||
//
|
||||
// // myfunc("aaa", "bbb")
|
||||
// }
|
||||
|
||||
func myfunc3(v, v2 string) error {
|
||||
time.After(time.Hour)
|
||||
fmt.Println(v, v2)
|
||||
// fmt.Println(kk)
|
||||
//
|
||||
|
||||
time.Date(2020, 12, 11, 21, 11, 44, 12, nil)
|
||||
time.Date(2020, 1, 11, 11, 11, 2, 1, nil)
|
||||
time.Date(1111, 22, 11, 1, 1, 1, 1, nil)
|
||||
time.Date(12345, 2333, 444, 555, 66, 1, 22, nil)
|
||||
fmt.Println(`kkkkkk`)
|
||||
log.Info(`abc`)
|
||||
log.Infof(`log %s`, `def`)
|
||||
log.Infof(`log %d`, 33)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// func myfunc4() {
|
||||
// // myfunc("aaa", "bbb") // time.Date(12,11, )
|
||||
// // myfunc("abc", "def")
|
||||
// // myfunc("1", "2")
|
||||
// }
|
||||
//
|
||||
// func mytest2() {
|
||||
// i := 1
|
||||
// log.Infof("%d", i)
|
||||
// myfunc4()
|
||||
// }
|
||||
//
|
||||
// func myfunc5() {
|
||||
// hellostring := "hello"
|
||||
// if strings.Contains(hellostring, "hello") {
|
||||
// fmt.Println("it is there")
|
||||
// }
|
||||
// }
|
@ -1,157 +0,0 @@
|
||||
vim.cmd([[set runtimepath=$VIMRUNTIME]])
|
||||
local uv = vim.uv or vim.loop
|
||||
local os_name = uv.os_uname().sysname
|
||||
|
||||
local is_windows = os_name == 'Windows' or os_name == 'Windows_NT'
|
||||
|
||||
local package_root = '/tmp/nvim/lazy'
|
||||
local sep = '/'
|
||||
if is_windows then
|
||||
local tmp = os.getenv('TEMP')
|
||||
vim.cmd('set packpath=' .. tmp .. '\\nvim\\lazy')
|
||||
package_root = tmp .. '\\nvim\\lazy'
|
||||
sep = '\\'
|
||||
else
|
||||
vim.cmd([[set packpath=/tmp/nvim/lazy]])
|
||||
end
|
||||
|
||||
local plugin_folder = function()
|
||||
local host = os.getenv('HOST_NAME')
|
||||
if host and (host:find('Ray') or host:find('ray')) then
|
||||
return [[~/github/ray-x]] -- vim.fn.expand("$HOME") .. '/github/'
|
||||
else
|
||||
return ''
|
||||
end
|
||||
end
|
||||
|
||||
local lazypath = package_root .. sep .. 'lazy.nvim'
|
||||
if not uv.fs_stat(lazypath) then
|
||||
vim.fn.system({
|
||||
'git',
|
||||
'clone',
|
||||
'--filter=blob:none',
|
||||
'https://github.com/folke/lazy.nvim.git',
|
||||
'--branch=stable', -- latest stable release
|
||||
lazypath,
|
||||
})
|
||||
end
|
||||
vim.opt.rtp:prepend(lazypath)
|
||||
local function load_plugins()
|
||||
return {
|
||||
{
|
||||
'nvim-treesitter/nvim-treesitter',
|
||||
config = function()
|
||||
require('nvim-treesitter.configs').setup({
|
||||
ensure_installed = { 'go' },
|
||||
highlight = { enable = true },
|
||||
})
|
||||
end,
|
||||
build = ':TSUpdate',
|
||||
},
|
||||
{ 'neovim/nvim-lspconfig' },
|
||||
-- {
|
||||
-- 'simrat39/rust-tools.nvim',
|
||||
-- config = function()
|
||||
-- require('rust-tools').setup({
|
||||
-- server = {
|
||||
-- on_attach = function(client, bufnr)
|
||||
-- require('navigator.lspclient.mapping').setup({ client = client, bufnr = bufnr }) -- setup navigator keymaps here,
|
||||
-- -- otherwise, you can define your own commands to call navigator functions
|
||||
-- end,
|
||||
-- },
|
||||
-- })
|
||||
-- end,
|
||||
-- },
|
||||
{ 'ray-x/lsp_signature.nvim', dev = (plugin_folder() ~= '') },
|
||||
{
|
||||
'ray-x/navigator.lua',
|
||||
dev = (plugin_folder() ~= ''),
|
||||
-- '~/github/ray-x/navigator.lua',
|
||||
dependencies = { 'ray-x/guihua.lua', build = 'cd lua/fzy && make' },
|
||||
config = function()
|
||||
require('navigator').setup({
|
||||
keymaps = {
|
||||
{
|
||||
key = '<Leader>rn',
|
||||
func = require('navigator.rename').rename,
|
||||
desc = 'rename',
|
||||
},
|
||||
},
|
||||
lsp = {
|
||||
-- disable_lsp = { 'rust_analyzer', 'clangd' },
|
||||
},
|
||||
})
|
||||
end,
|
||||
},
|
||||
{
|
||||
'hrsh7th/nvim-cmp',
|
||||
dependencies = {
|
||||
'neovim/nvim-lspconfig',
|
||||
'hrsh7th/cmp-nvim-lsp',
|
||||
},
|
||||
config = function()
|
||||
-- Add additional capabilities supported by nvim-cmp
|
||||
local cmp = require('cmp')
|
||||
cmp.setup({
|
||||
snippet = {
|
||||
expand = function(args)
|
||||
luasnip.lsp_expand(args.body)
|
||||
end,
|
||||
},
|
||||
mapping = cmp.mapping.preset.insert({
|
||||
['<C-u>'] = cmp.mapping.scroll_docs(-4), -- Up
|
||||
['<C-d>'] = cmp.mapping.scroll_docs(4), -- Down
|
||||
-- C-b (back) C-f (forward) for snippet placeholder navigation.
|
||||
['<C-Space>'] = cmp.mapping.complete(),
|
||||
['<CR>'] = cmp.mapping.confirm({
|
||||
behavior = cmp.ConfirmBehavior.Replace,
|
||||
select = true,
|
||||
}),
|
||||
}),
|
||||
sources = {
|
||||
{ name = 'nvim_lsp' },
|
||||
},
|
||||
})
|
||||
end,
|
||||
},
|
||||
{
|
||||
'ray-x/go.nvim',
|
||||
dev = (plugin_folder() ~= ''),
|
||||
-- dev = true,
|
||||
ft = 'go',
|
||||
dependencies = {
|
||||
'mfussenegger/nvim-dap', -- Debug Adapter Protocol
|
||||
'rcarriga/nvim-dap-ui',
|
||||
'theHamsta/nvim-dap-virtual-text',
|
||||
'ray-x/guihua.lua',
|
||||
},
|
||||
config = function()
|
||||
require('go').setup({
|
||||
verbose = true,
|
||||
lsp_cfg = {
|
||||
handlers = {
|
||||
['textDocument/hover'] = vim.lsp.with(vim.lsp.handlers.hover, { border = 'double' }),
|
||||
['textDocument/signatureHelp'] = vim.lsp.with(
|
||||
vim.lsp.handlers.signature_help,
|
||||
{ border = 'round' }
|
||||
),
|
||||
},
|
||||
}, -- false: do nothing
|
||||
})
|
||||
end,
|
||||
},
|
||||
}
|
||||
end
|
||||
|
||||
local opts = {
|
||||
root = package_root, -- directory where plugins will be installed
|
||||
default = { lazy = true },
|
||||
dev = {
|
||||
-- directory where you store your local plugin projects
|
||||
path = plugin_folder(),
|
||||
},
|
||||
}
|
||||
|
||||
require('lazy').setup(load_plugins(), opts)
|
||||
|
||||
vim.cmd('colorscheme murphy')
|
@ -1,61 +0,0 @@
|
||||
vim.cmd([[set runtimepath=$VIMRUNTIME]])
|
||||
vim.cmd([[set packpath=/tmp/nvim/site]])
|
||||
|
||||
local package_root = '/tmp/nvim/site/pack'
|
||||
local install_path = package_root .. '/packer/start/packer.nvim'
|
||||
vim.g.coq_settings = {
|
||||
['auto_start'] = 'shut-up',
|
||||
}
|
||||
|
||||
local function load_plugins()
|
||||
require('packer').startup({
|
||||
function(use)
|
||||
use('wbthomason/packer.nvim')
|
||||
use('neovim/nvim-lspconfig')
|
||||
use({
|
||||
'williamboman/nvim-lsp-installer',
|
||||
config = function()
|
||||
local lsp_installer = require('nvim-lsp-installer')
|
||||
lsp_installer.setup{}
|
||||
end,
|
||||
})
|
||||
use({
|
||||
'ray-x/navigator.lua',
|
||||
config = function()
|
||||
require('navigator').setup({
|
||||
debug = true,
|
||||
lsp_installer = true,
|
||||
keymaps = { { key = 'gR', func = "require('navigator.reference').async_ref()" } },
|
||||
})
|
||||
end,
|
||||
})
|
||||
use('ray-x/guihua.lua')
|
||||
-- -- COQ (Autocompletion)
|
||||
use('ms-jpq/coq_nvim')
|
||||
use('ms-jpq/coq.artifacts')
|
||||
use('ms-jpq/coq.thirdparty')
|
||||
use('ray-x/aurora')
|
||||
end,
|
||||
config = {
|
||||
package_root = package_root,
|
||||
compile_path = install_path .. '/plugin/packer_compiled.lua',
|
||||
},
|
||||
})
|
||||
-- navigator/LSP setup
|
||||
end
|
||||
|
||||
if vim.fn.isdirectory(install_path) == 0 then
|
||||
print('install packer')
|
||||
vim.fn.system({
|
||||
'git',
|
||||
'clone',
|
||||
'https://github.com/wbthomason/packer.nvim',
|
||||
install_path,
|
||||
})
|
||||
load_plugins()
|
||||
require('packer').sync()
|
||||
vim.cmd('colorscheme aurora')
|
||||
else
|
||||
load_plugins()
|
||||
vim.cmd('colorscheme aurora')
|
||||
end
|
@ -1,79 +0,0 @@
|
||||
vim.cmd([[set runtimepath=$VIMRUNTIME]])
|
||||
vim.cmd([[set packpath=/tmp/nvim/site]])
|
||||
|
||||
local package_root = '/tmp/nvim/site/pack'
|
||||
local install_path = package_root .. '/packer/start/packer.nvim'
|
||||
|
||||
local function load_plugins()
|
||||
require('packer').startup({
|
||||
function(use)
|
||||
use('wbthomason/packer.nvim')
|
||||
use('neovim/nvim-lspconfig')
|
||||
use({
|
||||
'williamboman/nvim-lsp-installer',
|
||||
config = function()
|
||||
require('nvim-lsp-installer').setup({})
|
||||
end,
|
||||
})
|
||||
use({
|
||||
'ray-x/navigator.lua',
|
||||
-- '~/github/ray-x/navigator.lua',
|
||||
config = function()
|
||||
require('navigator').setup({
|
||||
debug = true,
|
||||
lsp_installer = true,
|
||||
keymaps = { { key = 'gR', func = "require('navigator.reference').async_ref()" } },
|
||||
})
|
||||
end,
|
||||
})
|
||||
use('ray-x/guihua.lua')
|
||||
|
||||
use({
|
||||
'hrsh7th/nvim-cmp',
|
||||
requires = {
|
||||
'hrsh7th/cmp-nvim-lsp',
|
||||
},
|
||||
config = function()
|
||||
local cmp = require('cmp')
|
||||
cmp.setup({
|
||||
mapping = {
|
||||
['<CR>'] = cmp.mapping.confirm({ select = true }),
|
||||
['<Tab>'] = cmp.mapping(function(fallback)
|
||||
if cmp.visible() then
|
||||
cmp.confirm({ select = true })
|
||||
else
|
||||
fallback()
|
||||
end
|
||||
end, { 'i', 's' }),
|
||||
},
|
||||
sources = {
|
||||
{ name = 'nvim_lsp' },
|
||||
},
|
||||
})
|
||||
end,
|
||||
})
|
||||
use('ray-x/aurora')
|
||||
end,
|
||||
config = {
|
||||
package_root = package_root,
|
||||
compile_path = install_path .. '/plugin/packer_compiled.lua',
|
||||
},
|
||||
})
|
||||
-- navigator/LSP setup
|
||||
end
|
||||
|
||||
if vim.fn.isdirectory(install_path) == 0 then
|
||||
print('install packer')
|
||||
vim.fn.system({
|
||||
'git',
|
||||
'clone',
|
||||
'https://github.com/wbthomason/packer.nvim',
|
||||
install_path,
|
||||
})
|
||||
load_plugins()
|
||||
require('packer').sync()
|
||||
vim.cmd('colorscheme aurora')
|
||||
else
|
||||
load_plugins()
|
||||
vim.cmd('colorscheme aurora')
|
||||
end
|
@ -1,7 +0,0 @@
|
||||
const sayHiToSomeone = (callback) => {
|
||||
return callbcak();
|
||||
};
|
||||
|
||||
sayHiToSomeone(()=> {
|
||||
console.log("aaa")
|
||||
})
|
@ -1,12 +0,0 @@
|
||||
function makeFunc() {
|
||||
var browser = 'Mozilla';
|
||||
function displayName() {
|
||||
alert(browser);
|
||||
var message = 'hello ' + browser;
|
||||
alert(message);
|
||||
}
|
||||
return displayName;
|
||||
}
|
||||
|
||||
var myFunc = makeFunc();
|
||||
myFunc();
|
@ -1,11 +0,0 @@
|
||||
function curriedDot(vector1) {
|
||||
return function(vector2) {
|
||||
return vector1.reduce(
|
||||
(sum, element, index) => (sum += element * vector2[index]),
|
||||
0
|
||||
);
|
||||
};
|
||||
}
|
||||
|
||||
const sumElements = curriedDot([1, 1, 1]);
|
||||
console.log()
|
@ -1 +0,0 @@
|
||||
const time = new Date(12, 33, )
|
@ -1,3 +0,0 @@
|
||||
console.log("abc");
|
||||
var kingsglove = "abcdefg";
|
||||
console.log()
|
@ -1,14 +0,0 @@
|
||||
from random import shuffle
|
||||
a = list(range(5))
|
||||
|
||||
def go(beg, c, b):
|
||||
if beg >= len(a):
|
||||
print(a )
|
||||
for i in range(beg, len(a)):
|
||||
a[beg], a[i] = a[i], a[beg]
|
||||
go(beg + 1)
|
||||
a[beg], a[i] = a[i], a[beg]
|
||||
print(a, b)
|
||||
|
||||
go(0, 1, 4)
|
||||
shuffle([1, 2,3 ])
|
@ -1,79 +0,0 @@
|
||||
import math
|
||||
import numpy as np
|
||||
import os
|
||||
|
||||
class Dog:
|
||||
def __init__(self, name):
|
||||
self.name = name
|
||||
self.tricks = [] # creates a new empty list for each dog
|
||||
|
||||
def add_trick(self, trick):
|
||||
self.tricks.append(trick)
|
||||
|
||||
|
||||
d = Dog('Fido')
|
||||
d.add_trick('roll over')
|
||||
print(d.tricks)
|
||||
|
||||
def test_func():
|
||||
k = [1, 2, 3]
|
||||
sum = 0
|
||||
for i in range(k, 1, 2):
|
||||
sum += 1
|
||||
print(sum)
|
||||
|
||||
def greet(greeting, name):
|
||||
"""
|
||||
This function greets to
|
||||
the person passed in as
|
||||
a parameter
|
||||
"""
|
||||
print(greeting + name + ". Good morning!")
|
||||
|
||||
|
||||
# def greet(greeting, name, msg1, msg2):
|
||||
# """
|
||||
# This function greets to
|
||||
# the person passed in as
|
||||
# a parameter
|
||||
# """
|
||||
# print(greeting + name + ". Good morning!")
|
||||
|
||||
|
||||
greet("a", "b")
|
||||
|
||||
|
||||
def greet2():
|
||||
print("whatever")
|
||||
|
||||
|
||||
def greet3(name):
|
||||
greet2()
|
||||
greet("hey", "dude", "", "")
|
||||
print("whatever" + name)
|
||||
|
||||
def greet3():
|
||||
pass
|
||||
|
||||
|
||||
greet2()
|
||||
|
||||
greet("name", "name")
|
||||
|
||||
greet3("name")
|
||||
greet3("")
|
||||
|
||||
greet("1", "2")
|
||||
|
||||
|
||||
def greeting(greet: int, *, g):
|
||||
"""
|
||||
This function greets to
|
||||
the person passed in as
|
||||
a parameter
|
||||
"""
|
||||
print(greet + g + ". Good morning!")
|
||||
|
||||
|
||||
np.empty(1, order="F")
|
||||
np.empty(1, order="F")
|
@ -1,19 +0,0 @@
|
||||
import pandas as pd
|
||||
import io
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
pow()
|
||||
|
||||
|
||||
arg = 111
|
||||
bufio = io
|
||||
filename = 'my_excel.xls'
|
||||
|
||||
|
||||
|
||||
|
||||
df = pd.read_excel(abc, defgh)
|
@ -1,9 +0,0 @@
|
||||
[package]
|
||||
name = "hello"
|
||||
version = "0.1.0"
|
||||
authors = ["Ray-X <rayx.cn@gmail.com>"]
|
||||
edition = "2018"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
[dependencies]
|
@ -1,89 +0,0 @@
|
||||
use std::io;
|
||||
|
||||
trait Show {
|
||||
fn show(&self) -> String;
|
||||
}
|
||||
|
||||
impl Show for i32 {
|
||||
fn show(&self) -> String {
|
||||
format!("four-byte signed {}", self)
|
||||
}
|
||||
}
|
||||
|
||||
impl Show for f64 {
|
||||
fn show(&self) -> String {
|
||||
format!("eight-byte float {}", self)
|
||||
}
|
||||
}
|
||||
fn another_function(x: i32, y: i32) {
|
||||
println!("The value of x is: {}, y {}", x, y);
|
||||
}
|
||||
fn fun1(x: i32, y: i32) {
|
||||
println!("The value of x is: {}, y {}", x, y);
|
||||
}
|
||||
|
||||
impl<Iter> Iterator for Iter
|
||||
where Iter: Iterator,
|
||||
{
|
||||
type Item = i32;
|
||||
fn next(&mut self) -> Option<i32> {
|
||||
Some(42)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
fn add(left: i32, right: i32) -> i32 {
|
||||
return left + right;
|
||||
}
|
||||
|
||||
fn add4(left: i32, right: i32, t: i32, f: i32) -> i32 {
|
||||
return left + right + t + f;
|
||||
}
|
||||
|
||||
struct Foo<'a> {
|
||||
x: &'a i32,
|
||||
}
|
||||
struct Boo<'b> {
|
||||
x: &'b i32,
|
||||
}
|
||||
|
||||
const CAMEL_CASE: i32 = 42;
|
||||
|
||||
fn bug(left: i32, rigth: i32) -> i32 {
|
||||
return left;
|
||||
}
|
||||
|
||||
fn test_signature(a: i32, b: i32, c: i32) -> i32 {
|
||||
a + b - c
|
||||
}
|
||||
fn test(a: i32) {}
|
||||
fn test2() {
|
||||
test(1)
|
||||
}
|
||||
fn test3() {
|
||||
test(1);
|
||||
test2()
|
||||
}
|
||||
|
||||
fn main() {
|
||||
test_signature(1, 2, 3);
|
||||
let x = || 42;
|
||||
bug(x(), 32);
|
||||
bug(x(), 32);
|
||||
|
||||
add(add(1, 2), 3);
|
||||
add(add(1, 2), 3);
|
||||
let answer = 42;
|
||||
let maybe_pi = 3.14;
|
||||
let v: Vec<&Show> = vec![&answer, &maybe_pi];
|
||||
for d in v.iter() {
|
||||
println!("show {}", d.show());
|
||||
}
|
||||
add4(1, 2, 3, add(1, 2));
|
||||
add4(add(1, 2), 3, add(3, 4), 4);
|
||||
let y = &5; // this is the same as `let _y = 5; let y = &_y;`
|
||||
let f = Foo { x: y };
|
||||
let z = &5; // this is the same as `let _y = 5; let y = &_y;`
|
||||
let f22 = Boo { x: z };
|
||||
another_function(11, 2);
|
||||
}
|
@ -1,6 +0,0 @@
|
||||
std="lua52+vim"
|
||||
|
||||
[rules]
|
||||
global_usage = "allow"
|
||||
multiple_statements = "allow"
|
||||
unused_variable = "allow"
|
@ -1,4 +0,0 @@
|
||||
indent_type = "Spaces"
|
||||
indent_width = 2
|
||||
column_width = 120
|
||||
quote_style = "AutoPreferSingle"
|
@ -1,69 +0,0 @@
|
||||
local busted = require('plenary/busted')
|
||||
|
||||
local eq = assert.are.same
|
||||
local cur_dir = vim.fn.expand('%:p:h')
|
||||
-- local status = require("plenary.reload").reload_module("go.nvim")
|
||||
-- status = require("plenary.reload").reload_module("nvim-treesitter")
|
||||
|
||||
-- local ulog = require('go.utils').log
|
||||
describe('should run lsp call hierarchy', function()
|
||||
vim.cmd([[packadd navigator.lua]])
|
||||
vim.cmd([[packadd guihua.lua]])
|
||||
local status = require('plenary.reload').reload_module('navigator')
|
||||
status = require('plenary.reload').reload_module('guihua')
|
||||
status = require('plenary.reload').reload_module('lspconfig')
|
||||
|
||||
local path = cur_dir .. '/tests/fixtures/interface.go' -- %:p:h ? %:p
|
||||
local cmd = " silent exe 'e " .. path .. "'"
|
||||
vim.cmd(cmd)
|
||||
vim.cmd([[cd %:p:h]])
|
||||
local bufn = vim.fn.bufnr('')
|
||||
require('navigator').setup({
|
||||
debug = true, -- log output, set to true and log path: ~/.local/share/nvim/gh.log
|
||||
width = 0.75, -- max width ratio (number of cols for the floating window) / (window width)
|
||||
height = 0.3, -- max list window height, 0.3 by default
|
||||
preview_height = 0.35, -- max height of preview windows
|
||||
border = 'none',
|
||||
})
|
||||
|
||||
-- allow gopls start
|
||||
for _ = 1, 20 do
|
||||
vim.wait(400, function() end)
|
||||
local found = false
|
||||
for _, client in ipairs(vim.lsp.get_clients()) do
|
||||
if client.name == 'gopls' then
|
||||
found = true
|
||||
break
|
||||
end
|
||||
end
|
||||
if found then
|
||||
break
|
||||
end
|
||||
end
|
||||
|
||||
it('should show panel', function()
|
||||
vim.fn.setpos('.', { bufn, 24, 15, 0 })
|
||||
require('navigator.hierarchy').incoming_calls_panel()
|
||||
|
||||
vim.wait(300, function() end)
|
||||
|
||||
local panel = require('guihua.panel').debug()
|
||||
eq(panel.name, 'Panel')
|
||||
|
||||
vim.wait(500, function() end)
|
||||
panel = require('guihua.panel').debug()
|
||||
print(vim.inspect(panel))
|
||||
-- eq(
|
||||
-- panel.activePanel.sections[1].header[1],
|
||||
-- '──────────Call Hierarchy──────────'
|
||||
-- )
|
||||
-- eq(panel.activePanel.sections[1].nodes[1].name, 'measure')
|
||||
end)
|
||||
|
||||
it('should not crash and show hierarchy', function()
|
||||
vim.fn.setpos('.', { bufn, 24, 15, 0 })
|
||||
local ret = require('navigator.hierarchy')._call_hierarchy()
|
||||
vim.wait(400, function() end)
|
||||
eq(ret, ret) -- make sure doesn't crash the result
|
||||
end)
|
||||
end)
|
@ -1,217 +0,0 @@
|
||||
local golden_result = {
|
||||
{
|
||||
col = 9,
|
||||
display_filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
full_text = 'package main',
|
||||
kind = '🚀',
|
||||
lnum = 1,
|
||||
node_scope = {
|
||||
['end'] = {
|
||||
character = 0,
|
||||
line = 12,
|
||||
},
|
||||
start = {
|
||||
character = 0,
|
||||
line = 0,
|
||||
},
|
||||
},
|
||||
node_text = 'main',
|
||||
indent = '',
|
||||
range = {
|
||||
['end'] = {
|
||||
character = 12,
|
||||
line = 0,
|
||||
},
|
||||
start = {
|
||||
character = 8,
|
||||
line = 0,
|
||||
},
|
||||
},
|
||||
text = ' 🚀 main \t package main',
|
||||
type = 'namespace',
|
||||
uri = 'file:///tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
},
|
||||
{
|
||||
col = 6,
|
||||
display_filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
full_text = 'func interfaceTest()',
|
||||
kind = ' ',
|
||||
lnum = 5,
|
||||
indent = '',
|
||||
node_scope = {
|
||||
['end'] = {
|
||||
character = 1,
|
||||
line = 11,
|
||||
},
|
||||
start = {
|
||||
character = 0,
|
||||
line = 4,
|
||||
},
|
||||
},
|
||||
node_text = 'interfaceTest',
|
||||
range = {
|
||||
['end'] = {
|
||||
character = 18,
|
||||
line = 4,
|
||||
},
|
||||
start = {
|
||||
character = 5,
|
||||
line = 4,
|
||||
},
|
||||
},
|
||||
text = ' interfaceTest\t func interfaceTest()',
|
||||
type = 'function',
|
||||
uri = 'file:///tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
},
|
||||
{
|
||||
col = 2,
|
||||
display_filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
full_text = 'r := rect{width: 3, height: 4}',
|
||||
kind = ' ',
|
||||
lnum = 6,
|
||||
node_scope = {
|
||||
['end'] = {
|
||||
character = 1,
|
||||
line = 11,
|
||||
},
|
||||
start = {
|
||||
character = 21,
|
||||
line = 4,
|
||||
},
|
||||
},
|
||||
|
||||
indent = ' ',
|
||||
node_text = 'r',
|
||||
range = {
|
||||
['end'] = {
|
||||
character = 2,
|
||||
line = 5,
|
||||
},
|
||||
start = {
|
||||
character = 1,
|
||||
line = 5,
|
||||
},
|
||||
},
|
||||
text = ' r \t r := rect{width: 3, height: 4}',
|
||||
type = 'var',
|
||||
uri = 'file:///tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
},
|
||||
{
|
||||
col = 2,
|
||||
display_filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
full_text = 'c := circle{radius: 5}',
|
||||
kind = ' ',
|
||||
lnum = 7,
|
||||
node_scope = {
|
||||
['end'] = {
|
||||
character = 1,
|
||||
line = 11,
|
||||
},
|
||||
start = {
|
||||
character = 21,
|
||||
line = 4,
|
||||
},
|
||||
},
|
||||
node_text = 'c',
|
||||
indent = ' ',
|
||||
range = {
|
||||
['end'] = {
|
||||
character = 2,
|
||||
line = 6,
|
||||
},
|
||||
start = {
|
||||
character = 1,
|
||||
line = 6,
|
||||
},
|
||||
},
|
||||
text = ' c \t c := circle{radius: 5}',
|
||||
type = 'var',
|
||||
uri = 'file:///tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
},
|
||||
{
|
||||
col = 2,
|
||||
display_filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
filename = '/tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
full_text = 'd := circle{radius: 10}',
|
||||
kind = ' ',
|
||||
lnum = 10,
|
||||
indent = ' ',
|
||||
node_scope = {
|
||||
['end'] = {
|
||||
character = 1,
|
||||
line = 11,
|
||||
},
|
||||
start = {
|
||||
character = 21,
|
||||
line = 4,
|
||||
},
|
||||
},
|
||||
node_text = 'd',
|
||||
range = {
|
||||
['end'] = {
|
||||
character = 2,
|
||||
line = 9,
|
||||
},
|
||||
start = {
|
||||
character = 1,
|
||||
line = 9,
|
||||
},
|
||||
},
|
||||
text = ' d \t d := circle{radius: 10}',
|
||||
type = 'var',
|
||||
uri = 'file:///tmp/github/ray-x/navigator.lua/tests/fixtures/interface_test.go',
|
||||
},
|
||||
}
|
||||
|
||||
print(golden_result[1].node_text)
|
||||
|
||||
local busted = require('plenary/busted')
|
||||
|
||||
local eq = assert.are.same
|
||||
local cur_dir = vim.fn.expand('%:p:h')
|
||||
-- local status = require("plenary.reload").reload_module("go.nvim")
|
||||
-- status = require("plenary.reload").reload_module("nvim-treesitter")
|
||||
|
||||
-- local ulog = require('go.utils').log
|
||||
describe('should run lsp reference', function()
|
||||
-- vim.fn.readfile('minimal.vim')
|
||||
it('should show ts nodes', function()
|
||||
local status = require('plenary.reload').reload_module('navigator')
|
||||
local status = require('plenary.reload').reload_module('guihua')
|
||||
local status = require('plenary.reload').reload_module('lspconfig')
|
||||
|
||||
vim.cmd([[packadd nvim-lspconfig]])
|
||||
vim.cmd([[packadd navigator.lua]])
|
||||
vim.cmd([[packadd guihua.lua]])
|
||||
local path = cur_dir .. '/tests/fixtures/interface_test.go' -- %:p:h ? %:p
|
||||
local cmd = " silent exe 'e " .. path .. "'"
|
||||
vim.cmd(cmd)
|
||||
vim.cmd([[cd %:p:h]])
|
||||
local bufn = vim.fn.bufnr('')
|
||||
-- require'lspconfig'.gopls.setup {}
|
||||
require('navigator').setup({
|
||||
debug = true, -- log output, set to true and log path: ~/.local/share/nvim/gh.log
|
||||
})
|
||||
|
||||
-- allow gopls start
|
||||
for i = 1, 10 do
|
||||
vim.wait(400, function() end)
|
||||
local clients = vim.lsp.get_clients()
|
||||
print('lsp clients: ', #clients)
|
||||
if #clients > 0 then
|
||||
break
|
||||
end
|
||||
end
|
||||
|
||||
vim.fn.setpos('.', { bufn, 15, 4, 0 }) -- width
|
||||
|
||||
vim.bo.filetype = 'go'
|
||||
local view, items, w = require('navigator.treesitter').buf_ts()
|
||||
eq(items[1].node_text, golden_result[1].node_text)
|
||||
eq(items[2].node_text, golden_result[2].node_text)
|
||||
end)
|
||||
end)
|
@ -1,21 +0,0 @@
|
||||
local func = function(p, uv)
|
||||
local before = os.time()
|
||||
local async
|
||||
async = uv.new_async(function(a, b, c)
|
||||
p('in async notify callback')
|
||||
p(a, b, c)
|
||||
uv.close(async)
|
||||
end)
|
||||
local args = {500, 'string', nil, false, 5, "helloworld", async}
|
||||
local unpack = unpack or table.unpack
|
||||
uv.new_thread(function(num, s, null, bool, five, hw, asy)
|
||||
local uv2 = require 'luv'
|
||||
uv2.async_send(asy, 'a', true, 250)
|
||||
uv2.sleep(1000)
|
||||
end, unpack(args)):join()
|
||||
local elapsed = (os.time() - before) * 1000
|
||||
assert(elapsed >= 1000, "elapsed should be at least delay ")
|
||||
end
|
||||
|
||||
local uv = vim.uv or vim.loop
|
||||
func(print, uv)
|
@ -1,58 +0,0 @@
|
||||
[selene]
|
||||
base = "lua52"
|
||||
name = "vim"
|
||||
|
||||
[vim]
|
||||
any = true
|
||||
|
||||
[_G]
|
||||
property = true
|
||||
writable = "new-fields"
|
||||
|
||||
[_NgConfigValues]
|
||||
any = true
|
||||
# property = true
|
||||
# writable = "full-write"
|
||||
|
||||
[debug]
|
||||
property = true
|
||||
|
||||
[[describe.args]]
|
||||
type = "string"
|
||||
[[describe.args]]
|
||||
type = "function"
|
||||
|
||||
[[it.args]]
|
||||
type = "string"
|
||||
[[it.args]]
|
||||
type = "function"
|
||||
|
||||
[[before_each.args]]
|
||||
type = "function"
|
||||
[[after_each.args]]
|
||||
type = "function"
|
||||
|
||||
[assert.is_not]
|
||||
any = true
|
||||
|
||||
[[assert.equals.args]]
|
||||
type = "any"
|
||||
[[assert.equals.args]]
|
||||
type = "any"
|
||||
[[assert.equals.args]]
|
||||
type = "any"
|
||||
required = false
|
||||
|
||||
[[assert.same.args]]
|
||||
type = "any"
|
||||
[[assert.same.args]]
|
||||
type = "any"
|
||||
|
||||
[[assert.truthy.args]]
|
||||
type = "any"
|
||||
|
||||
[[assert.spy.args]]
|
||||
type = "any"
|
||||
|
||||
[[assert.stub.args]]
|
||||
type = "any"
|
@ -1,47 +0,0 @@
|
||||
---
|
||||
base: lua52
|
||||
name: vim
|
||||
globals:
|
||||
_G:
|
||||
property: new-fields
|
||||
_NgConfigValues:
|
||||
any: true
|
||||
after_each:
|
||||
args:
|
||||
- type: function
|
||||
assert.equals:
|
||||
args:
|
||||
- type: any
|
||||
- type: any
|
||||
- required: false
|
||||
type: any
|
||||
assert.is_not:
|
||||
any: true
|
||||
assert.same:
|
||||
args:
|
||||
- type: any
|
||||
- type: any
|
||||
assert.spy:
|
||||
args:
|
||||
- type: any
|
||||
assert.stub:
|
||||
args:
|
||||
- type: any
|
||||
assert.truthy:
|
||||
args:
|
||||
- type: any
|
||||
before_each:
|
||||
args:
|
||||
- type: function
|
||||
debug:
|
||||
property: read-only
|
||||
describe:
|
||||
args:
|
||||
- type: string
|
||||
- type: function
|
||||
it:
|
||||
args:
|
||||
- type: string
|
||||
- type: function
|
||||
vim:
|
||||
any: true
|
Loading…
Reference in New Issue