-
Notifications
You must be signed in to change notification settings - Fork 29
Expand file tree
/
Copy pathPasLS.ExecuteCommand.pas
More file actions
86 lines (64 loc) · 2.38 KB
/
PasLS.ExecuteCommand.pas
File metadata and controls
86 lines (64 loc) · 2.38 KB
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
// Pascal Language Server
// Copyright 2022 Ryan Joseph
// This file is part of Pascal Language Server.
// Pascal Language Server is free software: you can redistribute it
// and/or modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation, either version 3 of
// the License, or (at your option) any later version.
// Pascal Language Server is distributed in the hope that it will be
// useful, but WITHOUT ANY WARRANTY; without even the implied warranty
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with Pascal Language Server. If not, see
// <https://www.gnu.org/licenses/>.
unit PasLS.ExecuteCommand;
{$mode objfpc}{$H+}
interface
uses
{ RTL }
SysUtils, Classes, FPJSON,
{ Protocol }
LSP.BaseTypes, LSP.Base, LSP.Streaming, LSP.WorkDoneProgress, LSP.ExecuteCommand;
Type
{ TExecuteCommandRequest
https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#workspace_executeCommand
The `workspace/executeCommand` request is sent from the client to the server to trigger
command execution on the server. In most cases the server creates a `WorkspaceEdit` structure
and applies the changes to the workspace using the request `workspace/applyEdit` which is sent
from the server to the client.
Response:
result: LSPAny | null
error: code and message set in case an exception happens during the request.
}
TExecuteCommandRequest = class(specialize TLSPRequest<TExecuteCommandParams, TLSPStreamable>)
function Process(var Params: TExecuteCommandParams): TLSPStreamable; override;
end;
implementation
uses
PasLS.Commands;
function TExecuteCommandRequest.Process(var Params: TExecuteCommandParams): TLSPStreamable;
var
aCommandClass : TCustomCommandClass;
aCommand : TCustomCommand;
begin
result := nil;
aCommandClass:=CommandFactory.FindCommandClass(Params.command);
if aCommandClass<>Nil then
try
aCommand:=aCommandClass.Create(Self.Transport);
result:=aCommand.Execute(Params.Arguments);
finally
aCommand.Free;
end;
{ case command of
'pasls.formatCode':
begin
end;
'pasls.invertAssignment':
begin
end;
end;}
end;
initialization
end.