mirror of
https://github.com/golang/go
synced 2024-11-19 03:24:40 -07:00
7201abb308
The initial workspace load was happening when a view was created, in serial. It should really just be kicked off in a separate goroutine once we create a new view. Implementing this change required some other significant changes, particularly the additional work being done by the WorkspacePackageIDs method. Some other changes had to be made while debugging. In particular, the modification to the circular dependencies test was a consequence of golang/go#36265. Change-Id: I97586c9574f6c4106172d7983e4c6fad412e6aa1 Reviewed-on: https://go-review.googlesource.com/c/tools/+/212102 Run-TryBot: Rebecca Stambler <rstambler@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Heschi Kreinick <heschi@google.com>
59 lines
1.6 KiB
Go
59 lines
1.6 KiB
Go
// Copyright 2019 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package lsp
|
|
|
|
import (
|
|
"context"
|
|
|
|
"golang.org/x/tools/internal/lsp/protocol"
|
|
"golang.org/x/tools/internal/lsp/source"
|
|
"golang.org/x/tools/internal/span"
|
|
errors "golang.org/x/xerrors"
|
|
)
|
|
|
|
func (s *Server) changeFolders(ctx context.Context, event protocol.WorkspaceFoldersChangeEvent) error {
|
|
for _, folder := range event.Removed {
|
|
view := s.session.View(folder.Name)
|
|
if view != nil {
|
|
view.Shutdown(ctx)
|
|
} else {
|
|
return errors.Errorf("view %s for %v not found", folder.Name, folder.URI)
|
|
}
|
|
}
|
|
s.addFolders(ctx, event.Added)
|
|
return nil
|
|
}
|
|
|
|
func (s *Server) addView(ctx context.Context, name string, uri span.URI) (source.View, source.Snapshot, error) {
|
|
s.stateMu.Lock()
|
|
state := s.state
|
|
s.stateMu.Unlock()
|
|
if state < serverInitialized {
|
|
return nil, nil, errors.Errorf("addView called before server initialized")
|
|
}
|
|
|
|
options := s.session.Options()
|
|
if err := s.fetchConfig(ctx, name, uri, &options); err != nil {
|
|
return nil, nil, err
|
|
}
|
|
return s.session.NewView(ctx, name, uri, options)
|
|
}
|
|
|
|
func (s *Server) updateConfiguration(ctx context.Context, changed interface{}) error {
|
|
// go through all the views getting the config
|
|
for _, view := range s.session.Views() {
|
|
options := s.session.Options()
|
|
if err := s.fetchConfig(ctx, view.Name(), view.Folder(), &options); err != nil {
|
|
return err
|
|
}
|
|
view, err := view.SetOptions(ctx, options)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
go s.diagnoseSnapshot(ctx, view.Snapshot())
|
|
}
|
|
return nil
|
|
}
|