📄 synhighlighterst.pas
字号:
end;
function TSynSTSyn.Func88: TtkTokenKind;
begin
if KeyComp('PROGRAM') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func93: TtkTokenKind;
begin
if KeyComp('END_FOR') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func95: TtkTokenKind;
begin
if KeyComp('END_VAR') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func96: TtkTokenKind;
begin
if KeyComp('RETURN') then Result := tkKey else
Result := tkIdentifier;
end;
function TSynSTSyn.Func99: TtkTokenKind;
begin
if KeyComp('EXTERNAL') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func101: TtkTokenKind;
begin
if KeyComp('STRUCT') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func102: TtkTokenKind;
begin
if KeyComp('FUNCTION') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func104: TtkTokenKind;
begin
if KeyComp('RESOURCE') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func106: TtkTokenKind;
begin
if KeyComp('VAR_EXTERNAL') then Result := tkKey else
if KeyComp('CONSTANT') then Result := tkKey else
Result := tkIdentifier;
end;
function TSynSTSyn.Func111: TtkTokenKind;
begin
if KeyComp('END_WHILE') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func114: TtkTokenKind;
begin
if KeyComp('END_STEP') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func116: TtkTokenKind;
begin
if KeyComp('END_ACTION') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func119: TtkTokenKind;
begin
if KeyComp('ANY_NUM') then Result := tkKey else
if KeyComp('END_REPEAT') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func120: TtkTokenKind;
begin
if KeyComp('END_TYPE') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func121: TtkTokenKind;
begin
if KeyComp('VAR_GLOBAL') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func139: TtkTokenKind;
begin
if KeyComp('TRANSITION') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func152: TtkTokenKind;
begin
if KeyComp('CONFIGURATION') then Result := tkKey else
if KeyComp('VAR_INPUT') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func155: TtkTokenKind;
begin
if KeyComp('END_STRUCT') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func158: TtkTokenKind;
begin
if KeyComp('END_RESOURCE') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func165: TtkTokenKind;
begin
if KeyComp('INITIAL_STEP') then Result := tkKey else
Result := tkIdentifier;
end;
function TSynSTSyn.Func168: TtkTokenKind;
begin
if KeyComp('INITIALIZATION') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func171: TtkTokenKind;
begin
if KeyComp('VAR_EXTERNAL') then Result := tkKey else
Result := tkIdentifier;
end;
function TSynSTSyn.Func182: TtkTokenKind;
begin
if KeyComp('VAR_IN_OUT') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func185: TtkTokenKind;
begin
if KeyComp('VAR_OUTPUT') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func193: TtkTokenKind;
begin
if KeyComp('END_TRANSITION') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.Func206: TtkTokenKind;
begin
if KeyComp('END_CONFIGURATION') then Result := tkKey else Result := tkIdentifier;
end;
function TSynSTSyn.AltFunc: TtkTokenKind;
begin
Result := tkIdentifier
end;
function TSynSTSyn.IdentKind(MayBe: PChar): TtkTokenKind;
var
HashKey: Integer;
begin
fToIdent := MayBe;
HashKey := KeyHash(MayBe);
if HashKey < 207 then Result := fIdentFuncTable[HashKey] else
Result := tkIdentifier;
end;
procedure TSynSTSyn.MakeMethodTables;
var
I: Char;
begin
for I := #0 to #255 do
case I of
#0: fProcTable[I] := NullProc;
#10: fProcTable[I] := LFProc;
#13: fProcTable[I] := CRProc;
#1..#9, #11, #12, #14..#32:
fProcTable[I] := SpaceProc;
'#': fProcTable[I] := AsciiCharProc;
'$': fProcTable[I] := IntegerProc;
#39: fProcTable[I] := StringProc;
'0'..'9': fProcTable[I] := NumberProc;
'A'..'Z', 'a'..'z', '_':
fProcTable[I] := IdentProc;
'{': fProcTable[I] := BraceOpenProc;
'}', '!', '"', '%', '&', '('..'/', ':'..'@', '['..'^', '`', '~':
begin
case I of
'(': fProcTable[I] := RoundOpenProc;
'.': fProcTable[I] := PointProc;
';': fProcTable[I] := SemicolonProc;
'/': fProcTable[I] := SlashProc;
':', '>': fProcTable[I] := ColonOrGreaterProc;
'<': fProcTable[I] := LowerProc;
'@': fProcTable[I] := AddressOpProc;
else
fProcTable[I] := SymbolProc;
end;
end;
else
fProcTable[I] := UnknownProc;
end;
end;
constructor TSynSTSyn.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
fAsmAttri := TSynHighlighterAttributes.Create(SYNS_AttrAssembler);
AddAttribute(fAsmAttri);
fCommentAttri := TSynHighlighterAttributes.Create(SYNS_AttrComment);
fCommentAttri.Style:= [fsItalic];
AddAttribute(fCommentAttri);
fIdentifierAttri := TSynHighlighterAttributes.Create(SYNS_AttrIdentifier);
AddAttribute(fIdentifierAttri);
fKeyAttri := TSynHighlighterAttributes.Create(SYNS_AttrReservedWord);
fKeyAttri.Style:= [fsBold];
AddAttribute(fKeyAttri);
fNumberAttri := TSynHighlighterAttributes.Create(SYNS_AttrNumber);
AddAttribute(fNumberAttri);
fSpaceAttri := TSynHighlighterAttributes.Create(SYNS_AttrSpace);
AddAttribute(fSpaceAttri);
fStringAttri := TSynHighlighterAttributes.Create(SYNS_AttrString);
AddAttribute(fStringAttri);
fSymbolAttri := TSynHighlighterAttributes.Create(SYNS_AttrSymbol);
AddAttribute(fSymbolAttri);
SetAttributesOnChange(DefHighlightChange);
InitIdent;
MakeMethodTables;
fRange := rsUnknown;
fAsmStart := False;
fDefaultFilter := SYNS_FilterST;
end; { Create }
procedure TSynSTSyn.SetLine(NewValue: string; LineNumber:Integer);
begin
fLine := PChar(NewValue);
Run := 0;
fLineNumber := LineNumber;
Next;
end; { SetLine }
procedure TSynSTSyn.AddressOpProc;
begin
fTokenID := tkSymbol;
inc(Run);
if fLine[Run] = '@' then inc(Run);
end;
procedure TSynSTSyn.AsciiCharProc;
begin
fTokenID := tkString;
inc(Run);
while FLine[Run] in ['0'..'9'] do inc(Run);
end;
procedure TSynSTSyn.BorProc;
begin
case fLine[Run] of
#0: NullProc;
#10: LFProc;
#13: CRProc;
else begin
fTokenID := tkComment;
repeat
if fLine[Run] = '}' then begin
Inc(Run);
if fRange = rsBorAsm then
fRange := rsAsm
else
fRange := rsUnKnown;
break;
end;
Inc(Run);
until fLine[Run] in [#0, #10, #13];
end;
end;
end;
procedure TSynSTSyn.BraceOpenProc;
begin
if fRange = rsAsm then
fRange := rsBorAsm
else
fRange := rsBor;
BorProc;
end;
procedure TSynSTSyn.ColonOrGreaterProc;
begin
fTokenID := tkSymbol;
inc(Run);
if fLine[Run] = '=' then inc(Run);
end;
procedure TSynSTSyn.CRProc;
begin
fTokenID := tkSpace;
inc(Run);
if fLine[Run] = #10 then inc(Run);
end;
procedure TSynSTSyn.IdentProc;
begin
fTokenID := IdentKind((fLine + Run));
inc(Run, fStringLen);
while Identifiers[fLine[Run]] do inc(Run);
end;
procedure TSynSTSyn.IntegerProc;
begin
inc(Run);
fTokenID := tkNumber;
while FLine[Run] in ['0'..'9', 'A'..'F', 'a'..'f'] do inc(Run);
end;
procedure TSynSTSyn.LFProc;
begin
fTokenID := tkSpace;
inc(Run);
end;
procedure TSynSTSyn.LowerProc;
begin
fTokenID := tkSymbol;
inc(Run);
if fLine[Run] in ['=', '>'] then inc(Run);
end;
procedure TSynSTSyn.NullProc;
begin
fTokenID := tkNull;
end;
procedure TSynSTSyn.NumberProc;
begin
inc(Run);
fTokenID := tkNumber;
while FLine[Run] in ['0'..'9', '.', 'e', 'E'] do
begin
case FLine[Run] of
'.':
if FLine[Run + 1] = '.' then break;
end;
inc(Run);
end;
end;
procedure TSynSTSyn.PointProc;
begin
fTokenID := tkSymbol;
inc(Run);
if fLine[Run] in ['.', ')'] then inc(Run);
end;
procedure TSynSTSyn.AnsiProc;
begin
case fLine[Run] of
#0: NullProc;
#10: LFProc;
#13: CRProc;
else
fTokenID := tkComment;
repeat
if (fLine[Run] = '*') and (fLine[Run + 1] = ')') then begin
Inc(Run, 2);
if fRange = rsAnsiAsm then
fRange := rsAsm
else
fRange := rsUnKnown;
break;
end;
Inc(Run);
until fLine[Run] in [#0, #10, #13];
end;
end;
procedure TSynSTSyn.RoundOpenProc;
begin
Inc(Run);
case fLine[Run] of
'*':
begin
Inc(Run);
if fRange = rsAsm then
fRange := rsAnsiAsm
else
fRange := rsAnsi;
fTokenID := tkComment;
if not (fLine[Run] in [#0, #10, #13]) then
AnsiProc;
end;
'.':
begin
inc(Run);
fTokenID := tkSymbol;
end;
else
fTokenID := tkSymbol;
end;
end;
procedure TSynSTSyn.SemicolonProc;
begin
Inc(Run);
fTokenID := tkSymbol;
if fRange = rsProperty then
fRange := rsUnknown;
end;
procedure TSynSTSyn.SlashProc;
begin
Inc(Run);
if fLine[Run] = '/' then begin
fTokenID := tkComment;
repeat
Inc(Run);
until fLine[Run] in [#0, #10, #13];
end else
fTokenID := tkSymbol;
end;
procedure TSynSTSyn.SpaceProc;
begin
inc(Run);
fTokenID := tkSpace;
while FLine[Run] in [#1..#9, #11, #12, #14..#32] do inc(Run);
end;
procedure TSynSTSyn.StringProc;
begin
fTokenID := tkString;
Inc(Run);
while not (fLine[Run] in [#0, #10, #13]) do begin
if fLine[Run] = #39 then begin
Inc(Run);
if fLine[Run] <> #39 then
break;
end;
Inc(Run);
end;
end;
procedure TSynSTSyn.SymbolProc;
begin
inc(Run);
fTokenID := tkSymbol;
end;
procedure TSynSTSyn.UnknownProc;
begin
{$IFDEF SYN_MBCSSUPPORT}
if FLine[Run] in LeadBytes then
Inc(Run, 2)
else
{$ENDIF}
inc(Run);
fTokenID := tkUnknown;
end;
procedure TSynSTSyn.Next;
begin
fAsmStart := False;
fTokenPos := Run;
case fRange of
rsAnsi, rsAnsiAsm:
AnsiProc;
rsBor, rsBorAsm:
BorProc;
else
fProcTable[fLine[Run]];
end;
end;
function TSynSTSyn.GetDefaultAttribute(Index: integer):
TSynHighlighterAttributes;
begin
case Index of
SYN_ATTR_COMMENT: Result := fCommentAttri;
SYN_ATTR_IDENTIFIER: Result := fIdentifierAttri;
SYN_ATTR_KEYWORD: Result := fKeyAttri;
SYN_ATTR_STRING: Result := fStringAttri;
SYN_ATTR_WHITESPACE: Result := fSpaceAttri;
else
Result := nil;
end;
end;
function TSynSTSyn.GetEol: Boolean;
begin
Result := fTokenID = tkNull;
end;
function TSynSTSyn.GetToken: string;
var
Len: LongInt;
begin
Len := Run - fTokenPos;
SetString(Result, (FLine + fTokenPos), Len);
end;
function TSynSTSyn.GetTokenID: TtkTokenKind;
begin
if not fAsmStart and (fRange = rsAsm)
and not (fTokenId in [tkNull, tkComment, tkSpace])
then
Result := tkAsm
else
Result := fTokenId;
end;
function TSynSTSyn.GetTokenAttribute: TSynHighlighterAttributes;
begin
case GetTokenID of
tkAsm: Result := fAsmAttri;
tkComment: Result := fCommentAttri;
tkIdentifier: Result := fIdentifierAttri;
tkKey: Result := fKeyAttri;
tkNumber: Result := fNumberAttri;
tkSpace: Result := fSpaceAttri;
tkString: Result := fStringAttri;
tkSymbol: Result := fSymbolAttri;
tkUnknown: Result := fSymbolAttri;
else
Result := nil;
end;
end;
function TSynSTSyn.GetTokenKind: integer;
begin
Result := Ord(GetTokenID);
end;
function TSynSTSyn.GetTokenPos: Integer;
begin
Result := fTokenPos;
end;
function TSynSTSyn.GetRange: Pointer;
begin
Result := Pointer(fRange);
end;
procedure TSynSTSyn.SetRange(Value: Pointer);
begin
fRange := TRangeState(Value);
end;
procedure TSynSTSyn.ResetRange;
begin
fRange:= rsUnknown;
end;
function TSynSTSyn.GetIdentChars: TSynIdentChars;
begin
Result := ['_', '0'..'9', 'a'..'z', 'A'..'Z'];
end;
class function TSynSTSyn.GetLanguageName: string;
begin
Result := SYNS_LangST;
end;
function TSynSTSyn.IsFilterStored: boolean;
begin
Result := fDefaultFilter <> SYNS_FilterST;
end;
initialization
MakeIdentTable;
{$IFNDEF SYN_CPPB_1}
RegisterPlaceableHighlighter(TSynSTSyn);
{$ENDIF}
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -