-
Notifications
You must be signed in to change notification settings - Fork 29
Expand file tree
/
Copy pathPasLS.DocumentHighlight.pas
More file actions
94 lines (74 loc) · 3.13 KB
/
PasLS.DocumentHighlight.pas
File metadata and controls
94 lines (74 loc) · 3.13 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
86
87
88
89
90
91
92
93
// 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.DocumentHighlight;
{$mode objfpc}{$H+}
{$scopedenums on}
interface
uses
{ RTL }
SysUtils, Classes,
{ Code Tools }
CodeToolManager, CodeCache,
{ Protocol }
LSP.Base, LSP.Basic,
{ Other }
LSP.BaseTypes, PasLS.CodeUtils, LSP.DocumentHighlight;
Type
{ TDocumentHighlightRequest
https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#textDocument_documentHighlight
The document highlight request is sent from the client to the server to resolve a
document highlights for a given text document position. For programming languages
this usually highlights all references to the symbol scoped to this file.
However we kept `textDocument/documentHighlight` and `textDocument/references`
separate requests since the first one is allowed to be more fuzzy.
Symbol matches usually have a DocumentHighlightKind of Read or Write whereas fuzzy or
textual matches use Textas the kind. }
TDocumentHighlightRequest = class(specialize TLSPRequest<TDocumentHighlightParams, TDocumentHighlightItems>)
function Process(var Params: TDocumentHighlightParams): TDocumentHighlightItems; override;
end;
implementation
function TDocumentHighlightRequest.Process(var Params: TDocumentHighlightParams): TDocumentHighlightItems;
var
Code: TCodeBuffer;
X, Y: Integer;
NewCode: TCodeBuffer;
NewX, NewY, NewTopLine: integer;
begin
Result:=TDocumentHighlightItems.Create;
with Params do
begin
Code := CodeToolBoss.FindFile(textDocument.LocalPath);
X := position.character + 1;
Y := position.line + 1;
if CodeToolBoss.FindBlockCounterPart(Code, X, Y, NewCode, NewX, NewY, NewTopLine) then
begin
// Show start/end indentifier if the range spans more than 1 line
if NewY - Y <> 0 then
begin
TDocumentHighlight.Create(Result,TDocumentHighlightKind.Text, GetIdentifierRangeAtPos(NewCode, NewX, NewY - 1));
TDocumentHighlight.Create(Result,TDocumentHighlightKind.Text, GetIdentifierRangeAtPos(NewCode, X, Y - 1))
end
else
begin
// TODO: make this an option to show single line ranges?
//Item := TDocumentHighlight(Result.Add);
//Item.kind := TDocumentHighlightKind.Text;
//Item.range := TRange.Create(NewY - 1, NewX - 1, Y - 1, X - 1);
end;
end
else
end;
end;
end.