214 lines
7.3 KiB
Go
214 lines
7.3 KiB
Go
|
// SPDX-FileCopyrightText: 2019 The Go Language Server Authors
|
|||
|
// SPDX-License-Identifier: BSD-3-Clause
|
|||
|
|
|||
|
package protocol
|
|||
|
|
|||
|
import (
|
|||
|
"strconv"
|
|||
|
|
|||
|
"go.lsp.dev/uri"
|
|||
|
)
|
|||
|
|
|||
|
// WorkspaceFolder response of Workspace folders request.
|
|||
|
type WorkspaceFolder struct {
|
|||
|
// URI is the associated URI for this workspace folder.
|
|||
|
URI string `json:"uri"`
|
|||
|
|
|||
|
// Name is the name of the workspace folder. Used to refer to this
|
|||
|
// workspace folder in the user interface.
|
|||
|
Name string `json:"name"`
|
|||
|
}
|
|||
|
|
|||
|
// DidChangeWorkspaceFoldersParams params of DidChangeWorkspaceFolders notification.
|
|||
|
type DidChangeWorkspaceFoldersParams struct {
|
|||
|
// Event is the actual workspace folder change event.
|
|||
|
Event WorkspaceFoldersChangeEvent `json:"event"`
|
|||
|
}
|
|||
|
|
|||
|
// WorkspaceFoldersChangeEvent is the workspace folder change event.
|
|||
|
type WorkspaceFoldersChangeEvent struct {
|
|||
|
// Added is the array of added workspace folders
|
|||
|
Added []WorkspaceFolder `json:"added"`
|
|||
|
|
|||
|
// Removed is the array of the removed workspace folders
|
|||
|
Removed []WorkspaceFolder `json:"removed"`
|
|||
|
}
|
|||
|
|
|||
|
// DidChangeConfigurationParams params of DidChangeConfiguration notification.
|
|||
|
type DidChangeConfigurationParams struct {
|
|||
|
// Settings is the actual changed settings
|
|||
|
Settings interface{} `json:"settings,omitempty"`
|
|||
|
}
|
|||
|
|
|||
|
// ConfigurationParams params of Configuration request.
|
|||
|
type ConfigurationParams struct {
|
|||
|
Items []ConfigurationItem `json:"items"`
|
|||
|
}
|
|||
|
|
|||
|
// ConfigurationItem a ConfigurationItem consists of the configuration section to ask for and an additional scope URI.
|
|||
|
// The configuration section ask for is defined by the server and doesn’t necessarily need to correspond to the configuration store used be the client.
|
|||
|
// So a server might ask for a configuration cpp.formatterOptions but the client stores the configuration in a XML store layout differently.
|
|||
|
// It is up to the client to do the necessary conversion. If a scope URI is provided the client should return the setting scoped to the provided resource.
|
|||
|
// If the client for example uses EditorConfig to manage its settings the configuration should be returned for the passed resource URI. If the client can’t provide a configuration setting for a given scope then null need to be present in the returned array.
|
|||
|
type ConfigurationItem struct {
|
|||
|
// ScopeURI is the scope to get the configuration section for.
|
|||
|
ScopeURI uri.URI `json:"scopeUri,omitempty"`
|
|||
|
|
|||
|
// Section is the configuration section asked for.
|
|||
|
Section string `json:"section,omitempty"`
|
|||
|
}
|
|||
|
|
|||
|
// DidChangeWatchedFilesParams params of DidChangeWatchedFiles notification.
|
|||
|
type DidChangeWatchedFilesParams struct {
|
|||
|
// Changes is the actual file events.
|
|||
|
Changes []*FileEvent `json:"changes,omitempty"`
|
|||
|
}
|
|||
|
|
|||
|
// FileEvent an event describing a file change.
|
|||
|
type FileEvent struct {
|
|||
|
// Type is the change type.
|
|||
|
Type FileChangeType `json:"type"`
|
|||
|
|
|||
|
// URI is the file's URI.
|
|||
|
URI uri.URI `json:"uri"`
|
|||
|
}
|
|||
|
|
|||
|
// FileChangeType is the file event type.
|
|||
|
type FileChangeType float64
|
|||
|
|
|||
|
const (
|
|||
|
// FileChangeTypeCreated is the file got created.
|
|||
|
FileChangeTypeCreated FileChangeType = 1
|
|||
|
// FileChangeTypeChanged is the file got changed.
|
|||
|
FileChangeTypeChanged FileChangeType = 2
|
|||
|
// FileChangeTypeDeleted is the file got deleted.
|
|||
|
FileChangeTypeDeleted FileChangeType = 3
|
|||
|
)
|
|||
|
|
|||
|
// String implements fmt.Stringer.
|
|||
|
func (t FileChangeType) String() string {
|
|||
|
switch t {
|
|||
|
case FileChangeTypeCreated:
|
|||
|
return "Created"
|
|||
|
case FileChangeTypeChanged:
|
|||
|
return "Changed"
|
|||
|
case FileChangeTypeDeleted:
|
|||
|
return "Deleted"
|
|||
|
default:
|
|||
|
return strconv.FormatFloat(float64(t), 'f', -10, 64)
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// DidChangeWatchedFilesRegistrationOptions describe options to be used when registering for file system change events.
|
|||
|
type DidChangeWatchedFilesRegistrationOptions struct {
|
|||
|
// Watchers is the watchers to register.
|
|||
|
Watchers []FileSystemWatcher `json:"watchers"`
|
|||
|
}
|
|||
|
|
|||
|
// FileSystemWatcher watchers of DidChangeWatchedFiles Registration options.
|
|||
|
type FileSystemWatcher struct {
|
|||
|
// GlobPattern is the glob pattern to watch.
|
|||
|
//
|
|||
|
// Glob patterns can have the following syntax:
|
|||
|
// - `*` to match one or more characters in a path segment
|
|||
|
// - `?` to match on one character in a path segment
|
|||
|
// - `**` to match any number of path segments, including none
|
|||
|
// - `{}` to group conditions (e.g. `**/*.{ts,js}` matches all TypeScript and JavaScript files)
|
|||
|
// - `[]` to declare a range of characters to match in a path segment (e.g., `example.[0-9]` to match on `example.0`, `example.1`, …)
|
|||
|
// - `[!...]` to negate a range of characters to match in a path segment (e.g., `example.[!0-9]` to match on `example.a`, `example.b`, but not `example.0`)
|
|||
|
GlobPattern string `json:"globPattern"`
|
|||
|
|
|||
|
// Kind is the kind of events of interest. If omitted it defaults
|
|||
|
// to WatchKind.Create | WatchKind.Change | WatchKind.Delete
|
|||
|
// which is 7.
|
|||
|
Kind WatchKind `json:"kind,omitempty"`
|
|||
|
}
|
|||
|
|
|||
|
// WatchKind kind of FileSystemWatcher kind.
|
|||
|
type WatchKind float64
|
|||
|
|
|||
|
const (
|
|||
|
// WatchKindCreate interested in create events.
|
|||
|
WatchKindCreate WatchKind = 1
|
|||
|
|
|||
|
// WatchKindChange interested in change events.
|
|||
|
WatchKindChange WatchKind = 2
|
|||
|
|
|||
|
// WatchKindDelete interested in delete events.
|
|||
|
WatchKindDelete WatchKind = 4
|
|||
|
)
|
|||
|
|
|||
|
// String implements fmt.Stringer.
|
|||
|
func (k WatchKind) String() string {
|
|||
|
switch k {
|
|||
|
case WatchKindCreate:
|
|||
|
return "Create"
|
|||
|
case WatchKindChange:
|
|||
|
return "Change"
|
|||
|
case WatchKindDelete:
|
|||
|
return "Delete"
|
|||
|
default:
|
|||
|
return strconv.FormatFloat(float64(k), 'f', -10, 64)
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// WorkspaceSymbolParams is the parameters of a Workspace Symbol request.
|
|||
|
type WorkspaceSymbolParams struct {
|
|||
|
WorkDoneProgressParams
|
|||
|
PartialResultParams
|
|||
|
|
|||
|
// Query a query string to filter symbols by.
|
|||
|
//
|
|||
|
// Clients may send an empty string here to request all symbols.
|
|||
|
Query string `json:"query"`
|
|||
|
}
|
|||
|
|
|||
|
// ExecuteCommandParams params of Execute a command.
|
|||
|
type ExecuteCommandParams struct {
|
|||
|
WorkDoneProgressParams
|
|||
|
|
|||
|
// Command is the identifier of the actual command handler.
|
|||
|
Command string `json:"command"`
|
|||
|
|
|||
|
// Arguments that the command should be invoked with.
|
|||
|
Arguments []interface{} `json:"arguments,omitempty"`
|
|||
|
}
|
|||
|
|
|||
|
// ExecuteCommandRegistrationOptions execute command registration options.
|
|||
|
type ExecuteCommandRegistrationOptions struct {
|
|||
|
// Commands is the commands to be executed on the server
|
|||
|
Commands []string `json:"commands"`
|
|||
|
}
|
|||
|
|
|||
|
// ApplyWorkspaceEditParams params of Applies a WorkspaceEdit.
|
|||
|
type ApplyWorkspaceEditParams struct {
|
|||
|
// Label an optional label of the workspace edit. This label is
|
|||
|
// presented in the user interface for example on an undo
|
|||
|
// stack to undo the workspace edit.
|
|||
|
Label string `json:"label,omitempty"`
|
|||
|
|
|||
|
// Edit is the edits to apply.
|
|||
|
Edit WorkspaceEdit `json:"edit"`
|
|||
|
}
|
|||
|
|
|||
|
// ApplyWorkspaceEditResponse response of Applies a WorkspaceEdit.
|
|||
|
type ApplyWorkspaceEditResponse struct {
|
|||
|
// Applied indicates whether the edit was applied or not.
|
|||
|
Applied bool `json:"applied"`
|
|||
|
|
|||
|
// FailureReason an optional textual description for why the edit was not applied.
|
|||
|
// This may be used by the server for diagnostic logging or to provide
|
|||
|
// a suitable error for a request that triggered the edit.
|
|||
|
//
|
|||
|
// @since 3.16.0.
|
|||
|
FailureReason string `json:"failureReason,omitempty"`
|
|||
|
|
|||
|
// FailedChange depending on the client's failure handling strategy "failedChange"
|
|||
|
// might contain the index of the change that failed. This property is
|
|||
|
// only available if the client signals a "failureHandlingStrategy"
|
|||
|
// in its client capabilities.
|
|||
|
//
|
|||
|
// @since 3.16.0.
|
|||
|
FailedChange uint32 `json:"failedChange,omitempty"`
|
|||
|
}
|