forked from HemulGM/ChatGPT
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathChatGPT.Code.pas
151 lines (123 loc) · 3.47 KB
/
ChatGPT.Code.pas
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
unit ChatGPT.Code;
interface
uses
System.SysUtils, FMX.Graphics, System.UITypes, System.Generics.Collections,
FMX.TextLayout;
type
TKeyWord = class
Word: TArray<string>;
Font: TFont;
Color: TAlphaColor;
constructor Create;
destructor Destroy; override;
end;
TKeyWords = class(TObjectList<TKeyWord>)
function FindWord(const Value: string; out Key: TKeyWord): Boolean;
end;
TTextAttributedRangeData = record
public
Range: TTextRange;
Attribute: TTextAttribute;
constructor Create(const ARange: TTextRange; const AAttribute: TTextAttribute);
end;
TLineTextAttributedRange = class(TList<TTextAttributedRangeData>)
private
FText: string;
public
property Text: string read FText write FText;
end;
TCodeSyntaxClass = class of TCodeSyntax;
TRegisteredSyntax = record
SyntaxClass: TCodeSyntaxClass;
Languages: TArray<string>;
end;
TCachedAttributes = TDictionary<Integer, TArray<TTextAttributedRangeData>>;
TCodeSyntax = class abstract
private
class var
FRegitered: TList<TRegisteredSyntax>;
protected
FCached: TCachedAttributes;
FDefaultFont: TFont;
FDefaultColor: TAlphaColor;
public
constructor Create(DefaultFont: TFont; DefaultColor: TAlphaColor); virtual;
destructor Destroy; override;
function GetAttributesForLine(const Line: string; const Index: Integer): TArray<TTextAttributedRangeData>; virtual; abstract;
procedure DropCache; virtual;
class function FindSyntax(const Language: string; DefaultFont: TFont; DefaultColor: TAlphaColor): TCodeSyntax;
class procedure RegisterSyntax(Languages: TArray<string>; CodeSyntaxClass: TCodeSyntaxClass);
end;
implementation
{ TKeyWord }
constructor TKeyWord.Create;
begin
inherited;
Font := TFont.Create;
end;
destructor TKeyWord.Destroy;
begin
Font.Free;
inherited;
end;
{ TKeyWords }
function TKeyWords.FindWord(const Value: string; out Key: TKeyWord): Boolean;
begin
var LowValue := Value.ToLower;
for var KeyWord in Self do
for var Word in KeyWord.Word do
begin
if Word = LowValue then
begin
Key := KeyWord;
Exit(True);
end;
end;
Result := False;
end;
{ TTextAttributedRangeData }
constructor TTextAttributedRangeData.Create(const ARange: TTextRange; const AAttribute: TTextAttribute);
begin
Self.Range := ARange;
Self.Attribute := AAttribute;
end;
{ TCodeSyntax }
constructor TCodeSyntax.Create(DefaultFont: TFont; DefaultColor: TAlphaColor);
begin
inherited Create;
FCached := TCachedAttributes.Create;
FDefaultFont := DefaultFont;
FDefaultColor := DefaultColor;
end;
destructor TCodeSyntax.Destroy;
begin
FCached.Free;
inherited;
end;
procedure TCodeSyntax.DropCache;
begin
FCached.Clear;
end;
class function TCodeSyntax.FindSyntax(const Language: string; DefaultFont: TFont; DefaultColor: TAlphaColor): TCodeSyntax;
begin
if not Assigned(FRegitered) then
Exit(nil);
for var Item in FRegitered do
for var Lang in Item.Languages do
if Lang = Language.ToLower then
Exit(Item.SyntaxClass.Create(DefaultFont, DefaultColor));
Result := nil;
end;
class procedure TCodeSyntax.RegisterSyntax(Languages: TArray<string>; CodeSyntaxClass: TCodeSyntaxClass);
begin
if not Assigned(FRegitered) then
FRegitered := TList<TRegisteredSyntax>.Create;
var Reg: TRegisteredSyntax;
Reg.SyntaxClass := CodeSyntaxClass;
Reg.Languages := Languages;
FRegitered.Add(Reg);
end;
initialization
finalization
TCodeSyntax.FRegitered.Free;
end.