📄 synhighlighterjava.pas
字号:
begin
if KeyComp('double') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func66: TtkTokenKind;
begin
if KeyComp('try') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func68: TtkTokenKind;
begin
if KeyComp('true') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func69: TtkTokenKind;
begin
if KeyComp('public') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func71: TtkTokenKind;
begin
if KeyComp('boolean') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func76: TtkTokenKind;
begin
if KeyComp('default') then Result := tkKey else
if KeyComp('const') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func77: TtkTokenKind;
begin
if KeyComp('native') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func78: TtkTokenKind;
begin
if KeyComp('static') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func84: TtkTokenKind;
begin
if KeyComp('super') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func85: TtkTokenKind;
begin
if KeyComp('short') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func86: TtkTokenKind;
begin
if KeyComp('finally') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func88: TtkTokenKind;
begin
if KeyComp('switch') then Result := tkKey else
if KeyComp('assert') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func89: TtkTokenKind;
begin
if KeyComp('throw') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func90: TtkTokenKind;
begin
if KeyComp('interface') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func92: TtkTokenKind;
begin
if KeyComp('abstract') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func97: TtkTokenKind;
begin
if KeyComp('import') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func98: TtkTokenKind;
begin
if KeyComp('extends') then Result := tkKey else
if KeyComp('private') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func102: TtkTokenKind;
begin
if KeyComp('return') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func104: TtkTokenKind;
begin
if KeyComp('volatile') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func109: TtkTokenKind;
begin
if KeyComp('continue') then Result := tkKey else
if KeyComp('throws') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func115: TtkTokenKind;
begin
if KeyComp('protected') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func116: TtkTokenKind;
begin
if KeyComp('instanceof') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func119: TtkTokenKind;
begin
if KeyComp('strictfp') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func129: TtkTokenKind;
begin
if KeyComp('transient') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func136: TtkTokenKind;
begin
if KeyComp('implements') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.Func172: TtkTokenKind;
begin
if KeyComp('synchronized') then Result := tkKey else Result := tkIdentifier;
end;
function TSynJavaSyn.AltFunc: TtkTokenKind;
begin
Result := tkIdentifier;
end;
function TSynJavaSyn.IdentKind(MayBe: PChar): TtkTokenKind;
var
HashKey: Integer;
begin
fToIdent := MayBe;
HashKey := KeyHash(MayBe);
if HashKey < 173 then Result := fIdentFuncTable[HashKey] else Result := tkIdentifier;
end;
procedure TSynJavaSyn.MakeMethodTables;
var
I: Char;
begin
for I := #0 to #255 do
case I of
'&': fProcTable[I] := AndSymbolProc;
#39: fProcTable[I] := AsciiCharProc;
'@': fProcTable[I] := AtSymbolProc;
'}': fProcTable[I] := BraceCloseProc;
'{': fProcTable[I] := BraceOpenProc;
#13: fProcTable[I] := CRProc;
':': fProcTable[I] := ColonProc;
',': fProcTable[I] := CommaProc;
'=': fProcTable[I] := EqualProc;
'>': fProcTable[I] := GreaterProc;
'A'..'Z', 'a'..'z', '_', '$': fProcTable[I] := IdentProc;
#10: fProcTable[I] := LFProc;
'<': fProcTable[I] := LowerProc;
'-': fProcTable[I] := MinusProc;
'*': fProcTable[I] := MultiplyProc;
'!': fProcTable[I] := NotSymbolProc;
#0: fProcTable[I] := NullProc;
'0'..'9': fProcTable[I] := NumberProc;
'|': fProcTable[I] := OrSymbolProc;
'+': fProcTable[I] := PlusProc;
'.': fProcTable[I] := PointProc;
'#': fProcTable[I] := PoundProc;
'?': fProcTable[I] := QuestionProc;
'%': fProcTable[I] := RemainderSymbolProc;
')': fProcTable[I] := RoundCloseProc;
'(': fProcTable[I] := RoundOpenProc;
';': fProcTable[I] := SemiColonProc;
'/': fProcTable[I] := SlashProc;
#1..#9, #11, #12, #14..#32: fProcTable[I] := SpaceProc;
']': fProcTable[I] := SquareCloseProc;
'[': fProcTable[I] := SquareOpenProc;
#34: fProcTable[I] := StringProc;
'~': fProcTable[I] := TildeProc;
'^': fProcTable[I] := XOrSymbolProc;
else
if (I in TSynSpecialChars) then
fProcTable[I] := IdentProc
else
fProcTable[I] := UnknownProc;
end;
end;
constructor TSynJavaSyn.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
fCommentAttri := TSynHighlighterAttributes.Create(SYNS_AttrComment);
fCommentAttri.Style := [fsItalic];
AddAttribute(fCommentAttri);
fDocumentAttri := TSynHighlighterAttributes.Create(SYNS_AttrDocumentation);
fDocumentAttri.Style := [fsItalic];
AddAttribute(fDocumentAttri);
fIdentifierAttri := TSynHighlighterAttributes.Create(SYNS_AttrIdentifier);
AddAttribute(fIdentifierAttri);
fInvalidAttri := TSynHighlighterAttributes.Create(SYNS_AttrInvalidSymbol);
AddAttribute(fInvalidAttri);
fKeyAttri := TSynHighlighterAttributes.Create(SYNS_AttrReservedWord);
fKeyAttri.Style := [fsBold];
AddAttribute(fKeyAttri);
fNumberAttri := TSynHighlighterAttributes.Create(SYNS_AttrNumber);
AddAttribute(fNumberAttri);
fSpaceAttri := TSynHighlighterAttributes.Create(SYNS_AttrSpace);
fSpaceAttri.Foreground := clWindow;
AddAttribute(fSpaceAttri);
fStringAttri := TSynHighlighterAttributes.Create(SYNS_AttrString);
AddAttribute(fStringAttri);
fSymbolAttri := TSynHighlighterAttributes.Create(SYNS_AttrSymbol);
AddAttribute(fSymbolAttri);
fRange := rsUnknown;
SetAttributesOnChange(DefHighlightChange);
InitIdent;
MakeMethodTables;
fDefaultFilter := SYNS_FilterJava;
end; { Create }
procedure TSynJavaSyn.SetLine(NewValue: String; LineNumber:Integer);
begin
fLine := PChar(NewValue);
Run := 0;
fEol := False;
fLineNumber := LineNumber;
Next;
end; { SetLine }
procedure TSynJavaSyn.CommentProc;
begin
if fRange = rsComment then
fTokenID := tkComment
else
fTokenID := tkDocument;
case FLine[Run] of
#0:
begin
NullProc;
exit;
end;
#10:
begin
LFProc;
exit;
end;
#13:
begin
CRProc;
exit;
end;
end;
while FLine[Run] <> #0 do
case FLine[Run] of
'*':
if fLine[Run + 1] = '/' then
begin
inc(Run, 2);
fRange := rsUnknown;
break;
end
else inc(Run);
#10: break;
#13: break;
else inc(Run);
end;
end;
procedure TSynJavaSyn.AndSymbolProc;
begin
case FLine[Run + 1] of
'=': {and assign}
begin
inc(Run, 2);
fTokenID := tkSymbol;
FExtTokenID := xtkAndAssign;
end;
'&': {conditional and}
begin
inc(Run, 2);
fTokenID := tkSymbol;
FExtTokenID := xtkCondAnd;
end;
else {and}
begin
inc(Run);
fTokenID := tkSymbol;
FExtTokenID := xtkAnd;
end;
end;
end;
procedure TSynJavaSyn.AsciiCharProc;
begin
fTokenID := tkString;
repeat
case FLine[Run] of
#0, #10, #13: break;
#92: Inc(Run); // backslash, if we have an escaped single character, skip to the next
end;
if FLine[Run] <> #0 then inc(Run); //Add check here to prevent overrun from backslash being last char
until FLine[Run] = #39;
if FLine[Run] <> #0 then inc(Run);
end;
procedure TSynJavaSyn.AtSymbolProc;
begin
fTokenID := tkInvalid;
inc(Run);
end;
procedure TSynJavaSyn.BraceCloseProc;
begin
inc(Run);
fTokenId := tkSymbol;
FExtTokenID := xtkBraceClose;
end;
procedure TSynJavaSyn.BraceOpenProc;
begin
inc(Run);
fTokenId := tkSymbol;
FExtTokenID := xtkBraceOpen;
end;
procedure TSynJavaSyn.CRProc;
begin
fTokenID := tkSpace;
Case FLine[Run + 1] of
#10: inc(Run, 2);
else inc(Run);
end;
end;
procedure TSynJavaSyn.ColonProc;
begin
inc(Run); {colon - conditional}
fTokenID := tkSymbol;
FExtTokenID := xtkColon;
end;
procedure TSynJavaSyn.CommaProc;
begin
inc(Run);
fTokenID := tkSymbol; //tkInvalid; //DDH Addition from Eden Kirin
fExtTokenID := xtkComma; //GBN 13/12/2001
end;
procedure TSynJavaSyn.EqualProc;
begin
case FLine[Run + 1] of
'=': {logical equal}
begin
inc(Run, 2);
fTokenID := tkSymbol;
FExtTokenID := xtkLogEqual;
end;
else {assign}
begin
inc(Run);
fTokenID := tkSymbol;
FExtTokenID := xtkAssign;
end;
end;
end;
procedure TSynJavaSyn.GreaterProc;
begin
Case FLine[Run + 1] of
'=': {greater than or equal to}
begin
inc(Run, 2);
fTokenID := tkSymbol;
FExtTokenID := xtkGreaterThanEqual;
end;
'>':
begin
Case FLine[Run + 2] of
'=': {shift right assign}
begin
inc(Run, 3);
FExtTokenID := xtkShiftRightAssign;
end;
'>':
if FLine[Run + 3] = '=' then
begin
inc(Run, 4); {unsigned shift right assign}
FExtTokenID := xtkUnsignShiftRightAssign;
end
else
begin
inc(Run, 3); {unsigned shift right}
FExtTokenID := xtkUnsignShiftRight;
end;
else {shift right}
begin
inc(Run, 2);
FExtTokenID := xtkShiftRight;
end;
end;
fTokenID := tkSymbol;
end;
else {greater than}
begin
inc(Run);
fTokenID := tkSymbol;
FExtTokenID := xtkGreaterThan;
end;
end;
end;
procedure TSynJavaSyn.IdentProc;
begin
fTokenID := IdentKind((fLine + Run));
inc(Run, fStringLen);
while Identifiers[fLine[Run]] do inc(Run);
end;
procedure TSynJavaSyn.LFProc;
begin
fTokenID := tkSpace;
inc(Run);
end;
procedure TSynJavaSyn.LowerProc;
begin
case FLine[Run + 1] of
'=': {less than or equal to}
begin
inc(Run, 2);
fTokenID := tkSymbol;
FExtTokenID := xtkLessThanEqual;
end;
'<':
begin
if FLine[Run + 2] = '=' then {shift left assign}
begin
inc(Run, 3);
FExtTokenID := xtkShiftLeftAssign;
end
else {shift left}
begin
inc(Run, 2);
FExtTokenID := xtkShiftLeft;
end;
fTokenID := tkSymbol;
end;
else {less than}
begin
inc(Run);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -