File: workspace.go

package info (click to toggle)
golang-github-cue-lang-cue 0.14.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 19,644 kB
  • sloc: makefile: 20; sh: 15
file content (104 lines) | stat: -rw-r--r-- 3,452 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// 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 server

import (
	"context"
	"errors"
	"fmt"

	"cuelang.org/go/internal/golangorgx/gopls/protocol"
	"cuelang.org/go/internal/golangorgx/gopls/settings"
	"cuelang.org/go/internal/golangorgx/tools/event"
)

// AddFolders gets called from Initialized, and from
// DidChangeWorkspaceFolders, to add the specified set of
// WorkspaceFolders to the session.
func (s *server) AddFolders(ctx context.Context, folders map[protocol.WorkspaceFolder]protocol.DocumentURI) error {
	if s.Options().VerboseWorkDoneProgress {
		work := s.progress.Start(ctx, DiagnosticWorkTitle(FromInitialWorkspaceLoad), "Calculating diagnostics for initial workspace load...", nil, nil)
		defer work.EndAsync(ctx, "Done.")
	}

	folderErrs := make(map[protocol.DocumentURI]error)

	for folder, uri := range folders {
		wf, err := s.workspace.EnsureFolder(uri, folder.Name)
		if err != nil {
			folderErrs[uri] = err
			continue
		}
		options, err := s.fetchFolderOptions(ctx, uri)
		if err != nil {
			folderErrs[uri] = err
			continue
		}
		wf.UpdateOptions(options)
	}

	if len(folderErrs) > 0 {
		errMsg := "Error loading workspace folders:\n"
		for uri, err := range folderErrs {
			errMsg += fmt.Sprintf("failed to load view for %s: %v\n", uri, err)
		}
		return errors.New(errMsg)
	}

	// Register for file watching notifications, if they are supported.
	return s.UpdateWatchedFiles(ctx)
}

func (s *server) DidChangeWorkspaceFolders(ctx context.Context, params *protocol.DidChangeWorkspaceFoldersParams) error {
	for _, folder := range params.Event.Removed {
		dir, err := protocol.ParseDocumentURI(folder.URI)
		if err != nil {
			return fmt.Errorf("invalid folder %q: %v", folder.URI, err)
		}
		s.workspace.RemoveFolder(dir)
	}
	validFolders, err := validateWorkspaceFolders(params.Event.Added)
	if err == nil {
		err = s.AddFolders(ctx, validFolders)
	}
	// DidChangeWorkspaceFolders is a notification, so if there's an
	// error, we show it rather than return it.
	if err != nil {
		s.client.ShowMessage(ctx, &protocol.ShowMessageParams{Type: protocol.Error, Message: err.Error()})
	}
	return nil
}

func (s *server) DidChangeConfiguration(ctx context.Context, _ *protocol.DidChangeConfigurationParams) error {
	ctx, done := event.Start(ctx, "lsp.Server.didChangeConfiguration")
	defer done()

	if s.Options().VerboseWorkDoneProgress {
		work := s.progress.Start(ctx, DiagnosticWorkTitle(FromDidChangeConfiguration), "Calculating diagnostics...", nil, nil)
		defer work.EndAsync(ctx, "Done.")
	}

	// Apply any changes to the session-level settings.
	options, err := s.fetchFolderOptions(ctx, "")
	// DidChangeConfiguration is a notification, so if there's an
	// error, we show it rather than return it.
	if err != nil {
		s.client.ShowMessage(ctx, &protocol.ShowMessageParams{Type: protocol.Error, Message: err.Error()})
		return nil
	}
	s.SetOptions(options)

	fetchFolderOptions := func(dir protocol.DocumentURI) (*settings.Options, error) {
		return s.fetchFolderOptions(ctx, dir)
	}
	err = s.workspace.UpdateFolderOptions(fetchFolderOptions)
	// DidChangeConfiguration is a notification, so if there's an
	// error, we show it rather than return it.
	if err != nil {
		s.client.ShowMessage(ctx, &protocol.ShowMessageParams{Type: protocol.Error, Message: err.Error()})
		return nil
	}
	return nil
}