1
0
mirror of https://github.com/golang/go synced 2024-09-30 16:08:36 -06:00
go/internal/lsp/source
Robert Findley 88346e9948 internal/lsp: refactor workspace Symbol method
This is based on Paul Jolly's CL 228760, updated to use the new cache
API, support the symbolStyle configuration option, and lift up the
concept of symbol score for later improvement.

From that CL:

There are a number of issues with the current implementation:

* test variant packages are not handled correctly, meaning duplicate
  symbols are returned
* fuzzy results are not ordered by score

We refactor the implementation of workspace symbol to use a
symbolCollector that carries context during the walk for symbols. As
part of resolving the test variant issue, we first determine a list of
packages to walk.

(*symbolCollector).collectPackages gathers the packages we are going to
inspect for symbols. This pre-step is required in order to filter out
any "duplicate" *types.Package. The duplicates arise for packages that
have test variants.  For example, if package mod.com/p has test files,
then we will visit two packages that have the PkgPath() mod.com/p: the
first is the actual package mod.com/p, the second is a special version
that includes the non-XTest _test.go files. If we were to walk both of
of these packages, then we would get duplicate matching symbols and we
would waste effort. Therefore where test variants exist we walk those
(because they include any symbols defined in non-XTest _test.go files).

One further complication is that even after this filtering, packages
between views might not be "identical" because they can be built using
different build constraints (via the "env" config option). Therefore on
a per view basis we first build up a map of PkgPath() -> *types.Package
preferring the test variants if they exist. Then we merge the results
between views, de-duping by *types.Package.

Finally, when we come to walk these packages and start gathering
symbols, we ignore any files we have already seen (due to different
*types.Package for the same import path as a result of different build
constraints), keeping track of those symbols via symbolCollector.

Then we walk that list of packages in much the same way as before.

For golang/go#40548

Co-authored-by: Paul Jolly <paul@myitcv.io>
Change-Id: I8af5bdedbd4a6c3631a213d73a735aea556a13ae
Reviewed-on: https://go-review.googlesource.com/c/tools/+/247818
Run-TryBot: Robert Findley <rfindley@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Rebecca Stambler <rstambler@golang.org>
2020-08-27 18:13:30 +00:00
..
call_hierarchy.go internal/lsp: add outgoing calls call hierarchy 2020-08-20 01:08:01 +00:00
code_lens.go internal/lsp: add "run file benchmarks" code lens 2020-08-12 18:37:58 +00:00
command.go internal/lsp: fix builds and tests for go1.12+ 2020-08-27 14:30:46 +00:00
comment_test.go internal/lsp: convert comments to markdown before sending to client 2019-10-04 18:35:38 +00:00
comment.go internal/lsp/source: use space character in markdown formatting 2020-08-26 03:44:07 +00:00
completion_builtin.go internal/lsp/source: fix a couple issues completing append() args 2020-08-15 16:56:00 +00:00
completion_format.go internal/lsp/source: fix a couple issues completing append() args 2020-08-15 16:56:00 +00:00
completion_keywords.go internal/lsp/source: improve unnamed type completion 2020-08-12 23:05:10 +00:00
completion_labels.go internal/lsp: use one context throughout completion 2020-04-06 16:51:37 +00:00
completion_literal.go internal/lsp/source: improve func literal completions 2020-08-15 16:17:26 +00:00
completion_printf_test.go internal/lsp/source: improve completion of printf operands 2020-08-21 13:58:45 +00:00
completion_printf.go internal/lsp/source: improve completion of printf operands 2020-08-21 13:58:45 +00:00
completion_snippet.go internal/lsp: remove source.Cache 2020-08-05 22:08:24 +00:00
completion_statements.go internal/lsp: remove source.Cache 2020-08-05 22:08:24 +00:00
completion.go internal/lsp: add completion suggestions for import statements 2020-08-27 18:03:53 +00:00
deep_completion_test.go internal/lsp/source: fix bug in deep completion score tracking 2020-08-08 16:17:06 +00:00
deep_completion.go internal/lsp/source: fix bug in deep completion score tracking 2020-08-08 16:17:06 +00:00
diagnostics.go internal/lsp: separate LSP files from FS files 2020-08-03 22:16:06 +00:00
extract.go internal/lsp/source: do not allow extraction of an import spec 2020-08-27 16:06:11 +00:00
folding_range.go internal/lsp: remove source.Cache 2020-08-05 22:08:24 +00:00
format_test.go internal/lsp: handle bad formatting with CRLF line endings 2020-07-28 16:05:17 +00:00
format.go internal/lsp: remove source.Cache 2020-08-05 22:08:24 +00:00
gc_annotations.go internal/lsp: in gc_details change command to use a temporary file. 2020-08-11 15:37:30 +00:00
highlight.go internal/lsp: fix builds and tests for go1.12+ 2020-08-27 14:30:46 +00:00
hover.go internal/lsp: remove source.Cache 2020-08-05 22:08:24 +00:00
identifier_test.go internal/lsp/source: add a unit test for searchForEnclosing 2020-07-28 18:51:24 +00:00
identifier.go internal/lsp: add outgoing calls call hierarchy 2020-08-20 01:08:01 +00:00
implementation.go internal/lsp: fix builds and tests for go1.12+ 2020-08-27 14:30:46 +00:00
options.go internal/lsp/regtest: add a workspace symbols benchmark 2020-08-27 01:05:19 +00:00
references.go internal/lsp/source: sort references and implementations results 2020-08-26 22:01:59 +00:00
rename_check.go internal/lsp/source: fix nil pointer in rename_check 2020-08-17 02:38:11 +00:00
rename.go internal/lsp: remove source.Cache 2020-08-05 22:08:24 +00:00
signature_help.go internal/lsp: fix builds and tests for go1.12+ 2020-08-27 14:30:46 +00:00
source_test.go internal/lsp: ignore period ('.') triggered completions in comments 2020-08-26 04:07:57 +00:00
symbols.go internal/lsp: fix builds and tests for go1.12+ 2020-08-27 14:30:46 +00:00
types_format.go internal/lsp/source: improve func literal completions 2020-08-15 16:17:26 +00:00
util_test.go internal/lsp/source: fix panic in formatZeroValue for invalid type 2020-08-21 17:11:49 +00:00
util.go internal/lsp/source: fix panic in formatZeroValue for invalid type 2020-08-21 17:11:49 +00:00
view.go internal/lsp/cache: don't always type check in default mode 2020-08-19 19:22:15 +00:00
workspace_symbol_test.go internal/lsp: refactor workspace Symbol method 2020-08-27 18:13:30 +00:00
workspace_symbol.go internal/lsp: refactor workspace Symbol method 2020-08-27 18:13:30 +00:00