Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[LSP] Add textDocument/references & prepareRename, Enhancements for resolving symbols #79988

Closed
wants to merge 59 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
694f133
Add `==` for lsp Position and Range
Booksbaum Jul 28, 2023
e16bf58
Remove `SymbolInformation`
Booksbaum Jul 28, 2023
7f56f29
Emit no `children` element when there are no `children`
Booksbaum Jul 28, 2023
2da094d
Note if a symbol is local to a script file
Booksbaum Jul 28, 2023
0f39373
Add & Enable `references`
Booksbaum Jul 28, 2023
232592d
Add `ReferenceParams`
Booksbaum Jul 28, 2023
4805fc1
Implement `references`
Booksbaum Jul 28, 2023
7598f63
Use `find usages` methods for `rename`
Booksbaum Jul 28, 2023
f07f438
Fix: cannot find reference/rename variable declared in other script
Booksbaum Jul 28, 2023
08116b0
Fix: `resolve_symbol` resolves parameter to its function
Booksbaum Jul 28, 2023
ec3f941
Add `textDocument/prepareRename`
Booksbaum Jul 28, 2023
d344685
Change `prepareRename` to return `range`
Booksbaum Jul 28, 2023
1698f73
Format code
Booksbaum Jul 28, 2023
b7ba9a6
Enhancement: `get_identifier_under_position` (& `resolve_symbol`) now…
Booksbaum Jul 28, 2023
cb1a06f
Enhancement: handle `includeDeclaration` in `textDocument/references`
Booksbaum Jul 28, 2023
fe0ebc1
Add rename-is-valid check to `textDocument/rename`
Booksbaum Jul 28, 2023
2723f74
Add LSP test suite (`[Modules][GDScript][LSP]`)
Booksbaum Jul 28, 2023
3cd3226
Change LSP tests to use inline markers
Booksbaum Jul 28, 2023
6073cd1
Fix/Adjust ranges in `DocumentSymbol`
Booksbaum Jul 28, 2023
5d4c46b
Fix: Incorrect Position when `\t` somewhere before column
Booksbaum Jul 28, 2023
ecbf032
Add more tests for ranges & indentation
Booksbaum Jul 28, 2023
c0bb4f9
Simplify `find_all_usages`
Booksbaum Jul 28, 2023
f9f1a65
Add: Check for all names unique in tests
Booksbaum Jul 28, 2023
65f5ecc
Fix: Char after Cursor gets lost while marking Cursor in String
Booksbaum Jul 28, 2023
e954647
Add: Check for errors in GDScripts used in tests
Booksbaum Jul 28, 2023
f7ab8b1
Rename SUBCASEs
Booksbaum Jul 28, 2023
fd1e2da
Enhancement: Only return non-local `DocumentSymbol`s
Booksbaum Jul 28, 2023
d4c9a0f
Fix: resolve_symbol resolves to wrong symbol in certain cases
Booksbaum Jul 28, 2023
b9d73c9
Use docs from GDScriptParser instead of extra doc parser
Booksbaum Jul 28, 2023
26a44d7
Handle lambda in fields
Booksbaum Jul 28, 2023
e27c1b6
Add: Test front and back of identifiers too
Booksbaum Jul 28, 2023
0a11358
Add some safety check & tests for lsp Position to Godot Position
Booksbaum Jul 28, 2023
c7f7b79
Fix: `GDScriptLanguage::lookup_code` cannot resolve inner class
Booksbaum Jul 28, 2023
bc49f1f
Partial Fix: Cannot resolve Values in Named Enum
Booksbaum Jul 28, 2023
8ea1cf1
Add test for ctor
Booksbaum Jul 28, 2023
4bafe99
Fix: Cannot resolve variable decl when shadowing variable with same name
Booksbaum Jul 28, 2023
cc5b77c
Fix: properties with extra get/set functions throw exception in `Exte…
Booksbaum Jul 28, 2023
389faf3
Enhancement: Run following tests if a `resolve_symbol` returns null
Booksbaum Jul 28, 2023
a81d8c1
Remove unused symbol
Booksbaum Jul 28, 2023
430ecf9
Add more nested class tests
Booksbaum Jul 28, 2023
a972f8b
Note about `resolve_symbol` inside comments & strings
Booksbaum Jul 28, 2023
56efcef
Inline `==` for Position & Range
Booksbaum Jul 28, 2023
1d7a6f0
Fix: in tests on Windows: unescaped `:` (`C:/...`) in `root_uri`
Booksbaum Jul 28, 2023
5055289
Cleanup
Booksbaum Jul 28, 2023
8531623
Fix: Range for GoTo Definition/Declaration spans getter/setter
Booksbaum Jul 28, 2023
9322115
Adjust comments to upper case sentences
Booksbaum Jul 28, 2023
9bd8b8c
Use `p_` prefix for parameters
Booksbaum Jul 28, 2023
80ed1c4
Adjust includes
Booksbaum Jul 28, 2023
3871a2a
Space after `//`
Booksbaum Jul 28, 2023
77e3096
Pass by reference
Booksbaum Jul 28, 2023
e3482de
Comments
Booksbaum Jul 28, 2023
4c2c9de
More comments
Booksbaum Jul 28, 2023
5227442
include `gdscript_analyzer` with `modules`
Booksbaum Jul 28, 2023
5670d21
Add default case
Booksbaum Jul 28, 2023
4d2ddab
Fix: missing `break`
Booksbaum Jul 28, 2023
83cc3a8
Consume `GodotPosition` in `GodotRange` ctor
Booksbaum Jul 28, 2023
6e45ce7
`finish_language` after tests
Booksbaum Jul 29, 2023
1a8d10c
Fix: LSP tests fail when run together with GDScript tests
Booksbaum Jul 29, 2023
ea0b97a
Guard LSP tests behind `TOOLS_ENABLED`
Booksbaum Jul 29, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Cleanup
  • Loading branch information
Booksbaum committed Jul 28, 2023
commit 5055289b9c756176f4316d1ad5b833fd25017d45
12 changes: 6 additions & 6 deletions modules/gdscript/language_server/gdscript_extend_parser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -687,15 +687,15 @@ String ExtendGDScriptParser::get_identifier_under_position(const lsp::Position &
// ->
// ```gdscript
// var member| := some_func|(some_variable|)
// ^
// | cursor on `some_variable, position on `)`
// ^
// | cursor on `some_func`, pos on `(`
// ^
// ^ ^ ^
// | | | cursor on `some_variable, position on `)`
// | |
// | | cursor on `some_func`, pos on `(`
// |
// | cursor on `member`, pos on ` ` (space)
// ```
// -> move position to previous character if:
// * position not on valid identifier char
// * position not on valid identifier char
// * prev position is valid identifier char
lsp::Position pos = p_position;
if (
Expand Down
7 changes: 3 additions & 4 deletions modules/gdscript/language_server/gdscript_extend_parser.h
Original file line number Diff line number Diff line change
Expand Up @@ -54,21 +54,20 @@
typedef HashMap<String, const lsp::DocumentSymbol *> ClassMembers;

/**
* Represents a Position as used by GDScript Parser. Use for conversion to and from `lsp::Position`
* Represents a Position as used by GDScript Parser. Used for conversion to and from `lsp::Position`
*
* Difference to `lsp::Position`:
* * line & char/column: 1-based
* * LSP: both 0-based
* * tabs are expanded to columns using tab size `text_editor/behavior/indent/size`
* * tabs are expanded to columns using tab size (`text_editor/behavior/indent/size`)
* * LSP: tab is single char
*
* Example:
* ```gdscript
* →→var my_value = 42
* 01230123 my_value = 42
* ```
* `_` is at:
* * Godot: `column=12`\
* * Godot: `column=12`
* * using `indent/size=4`
* * Note: counting starts at `1`!
* * LSP: `character=8`
Expand Down
11 changes: 5 additions & 6 deletions modules/gdscript/language_server/gdscript_workspace.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,6 @@ const lsp::DocumentSymbol *GDScriptWorkspace::get_local_symbol_at(const ExtendGD
const lsp::DocumentSymbol *parent = current;
current = nullptr;
for (const lsp::DocumentSymbol &child : parent->children) {
//TODO: use scope instead range: might be usage in initializer (-> ref outer)
if (child.range.contains(p_position)) {
current = &child;
break;
Expand Down Expand Up @@ -437,19 +436,19 @@ Error GDScriptWorkspace::parse_script(const String &p_path, const String &p_cont
return err;
}

bool is_valid_rename_target(const lsp::DocumentSymbol *symbol) {
bool is_valid_rename_target(const lsp::DocumentSymbol *p_symbol) {
// must be valid symbol
if (!symbol) {
if (!p_symbol) {
return false;
}

// cannot rename builtin
if (!symbol->native_class.is_empty()) {
if (!p_symbol->native_class.is_empty()) {
return false;
}

// source must be available
if (symbol->script_path.is_empty()) {
if (p_symbol->script_path.is_empty()) {
return false;
}

Expand Down Expand Up @@ -479,7 +478,7 @@ bool GDScriptWorkspace::can_rename(const lsp::TextDocumentPositionParams &p_doc_

String path = get_file_path(p_doc_pos.textDocument.uri);
if (const ExtendGDScriptParser *parser = get_parse_result(path)) {
String _ = parser->get_identifier_under_position(p_doc_pos.position, r_range);
parser->get_identifier_under_position(p_doc_pos.position, r_range);
r_symbol = *reference_symbol;
return true;
}
Expand Down
22 changes: 11 additions & 11 deletions modules/gdscript/tests/test_lsp.h
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,9 @@ namespace GDScriptTests {
const String root = "modules/gdscript/tests/lsp_project/";

// `memdelete` returned `GDScriptLanguageProtocol` after use!
GDScriptLanguageProtocol *initialize(const String &root) {
GDScriptLanguageProtocol *initialize(const String &p_root) {
Error err = OK;
Ref<DirAccess> dir(DirAccess::open(root, &err));
Ref<DirAccess> dir(DirAccess::open(p_root, &err));
REQUIRE_MESSAGE(err == OK, "Could not open specified root directory");
String absolute_root = dir->get_current_dir();
init_language(absolute_root);
Expand All @@ -89,23 +89,23 @@ GDScriptLanguageProtocol *initialize(const String &root) {
return proto;
}

lsp::Position pos(const int line, const int character) {
lsp::Position pos(const int p_line, const int p_character) {
lsp::Position p;
p.line = line;
p.character = character;
p.line = p_line;
p.character = p_character;
return p;
}
lsp::Range range(const lsp::Position start, const lsp::Position end) {
lsp::Range range(const lsp::Position p_start, const lsp::Position p_end) {
lsp::Range r;
r.start = start;
r.end = end;
r.start = p_start;
r.end = p_end;
return r;
}

lsp::TextDocumentPositionParams posIn(const lsp::DocumentUri &uri, const lsp::Position pos) {
lsp::TextDocumentPositionParams posIn(const lsp::DocumentUri &p_uri, const lsp::Position p_pos) {
lsp::TextDocumentPositionParams params;
params.textDocument.uri = uri;
params.position = pos;
params.textDocument.uri = p_uri;
params.position = p_pos;
return params;
}

Expand Down