📄 synhighlightercache.pas
字号:
'#': fProcTable[i] := DirectiveProc;
'&': fProcTable[i] := EmbeddedProc;
else fProcTable[I] := UnknownProc;
end;
end;
//------------------------------------------------------------------------------
constructor TSynCacheSyn.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
fClassAttri := TSynHighlighterAttributes.Create(SYNS_AttrClass);
AddAttribute(fClassAttri);
fCommentAttri := TSynHighlighterAttributes.Create(SYNS_AttrComment);
fCommentAttri.Style := [fsItalic];
AddAttribute(fCommentAttri);
fFunctionAttri := TSynHighlighterAttributes.Create(SYNS_AttrFunction);
AddAttribute(fFunctionAttri);
fIdentifierAttri := TSynHighlighterAttributes.Create(SYNS_AttrIdentifier);
AddAttribute(fIdentifierAttri);
fKeyAttri := TSynHighlighterAttributes.Create(SYNS_AttrReservedWord);
fKeyAttri.Style := [fsBold];
AddAttribute(fKeyAttri);
fNumberAttri := TSynHighlighterAttributes.Create(SYNS_AttrNumber);
AddAttribute(fNumberAttri);
fDirectiveAttri := TSynHighlighterAttributes.Create(SYNS_AttrDir);
AddAttribute(fDirectiveAttri);
fSpaceAttri := TSynHighlighterAttributes.Create(SYNS_AttrSpace);
AddAttribute(fSpaceAttri);
fStringAttri := TSynHighlighterAttributes.Create(SYNS_AttrString);
AddAttribute(fStringAttri);
fSymbolAttri := TSynHighlighterAttributes.Create(SYNS_AttrSymbol);
AddAttribute(fSymbolAttri);
fIndirectAttri := TSynHighlighterAttributes.Create(SYNS_AttrIndirect);
AddAttribute(fIndirectAttri);
fLabelAttri := TSynHighlighterAttributes.Create(SYNS_AttrLabel);
AddAttribute(fLabelAttri);
fMacroAttri := TSynHighlighterAttributes.Create(SYNS_AttrMacro);
AddAttribute(fMacroAttri);
fUserFunctionAttri := TSynHighlighterAttributes.Create(SYNS_AttrUserFunction);
AddAttribute(fUserFunctionAttri);
fEmbedSQLAttri := TSynHighlighterAttributes.Create(SYNS_AttrEmbedSQL);
AddAttribute(fEmbedSQLAttri);
fEmbedTextAttri := TSynHighlighterAttributes.Create(SYNS_AttrEmbedText);
AddAttribute(fEmbedTextAttri);
SetAttributesOnChange(DefHighlightChange);
InitIdent;
MakeMethodTables;
fDefaultFilter := SYNS_FilterCache;
fRange := rsUnknown;
end;
procedure TSynCacheSyn.SetLine(NewValue: string; LineNumber: Integer);
begin
fLine := PChar(NewValue);
Run := 0;
fLineNumber := LineNumber;
Next;
end;
procedure TSynCacheSyn.CRProc;
begin
fTokenID := tkSpace;
inc(Run);
if fLine[Run] = #10 then inc(Run);
// FCanKey := true;
FRange := rsUnknown;
end;
//------------------------------------------------------------------------------
procedure TSynCacheSyn.CommentProc;
begin
fTokenID := tkComment;
if FLine[Run+1]=';' then fTokenID := tkEmbedText;
while FLine[Run] <> #0 do begin
case FLine[Run] of
#10, #13: break;
end;
inc(Run);
end;
end;
//------------------------------------------------------------------------------
// higlight keywords and identifiers
//------------------------------------------------------------------------------
procedure TSynCacheSyn.IdentProc;
var
fir: char;
begin
if FTokenPos=0 then fTokenID := tkLabel
else begin
fir := FLine[ Run ];
if fir in [ '^' ] then FCanKey := true;
FRange := rsUnknown;
if FCanKey then fTokenID := IdentKind((fLine + Run))
else begin
fTokenID := tkIdentifier;
while ( Identifiers[fLine[Run]] ) or ( FLine[Run] in ['0'..'9']) do inc(Run);
exit;
end;
FRange := rsCommand;
inc(Run, fStringLen);
if (not ( FLine[Run] in [ #32, ':', #0, #10, #13 ] )) and ( fir <> '^' ) then
fTokenID := tkIdentifier;
end;
while ( Identifiers[fLine[Run]] ) or ( FLine[Run] in ['0'..'9']) do inc(Run);
// FCanKey := false;
// FSpaces := 0;
end;
//------------------------------------------------------------------------------
procedure TSynCacheSyn.LFProc;
begin
fTokenID := tkSpace;
FCanKey := true;
inc(Run);
end;
procedure TSynCacheSyn.NullProc;
begin
fTokenID := tkNull;
end;
//------------------------------------------------------------------------------
procedure TSynCacheSyn.NumberProc;
begin
if (fTokenPos = 0) and (FLine[Run] in ['0'..'9']) then begin
fTokenID := tkLabel;
while Identifiers[fLine[Run]] do inc(Run);
FCanKey := false;
exit;
end;
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;
// FCanKey := false;
FRange := rsUnknown;
end;
//------------------------------------------------------------------------------
procedure TSynCacheSyn.SpaceProc;
var
x: integer;
begin
x := Run;
inc(Run);
fTokenID := tkSpace;
while FLine[Run] in [#1..#9, #11, #12, #14..#32] do inc(Run);
FCanKey := true;
if FRange = rsCommand then
FCanKey := (Run - x > 1);
end;
//------------------------------------------------------------------------------
procedure TSynCacheSyn.StringProc;
begin
fTokenID := tkString;
if (FLine[Run + 1] = #34) and (FLine[Run + 2] = #34) then inc(Run, 2);
repeat
case FLine[Run] of
#0, #10, #13: break;
end;
inc(Run);
until FLine[Run] = #34;
if FLine[Run] <> #0 then inc(Run);
// FCanKey := false;
FRange := rsUnknown;
end;
//------------------------------------------------------------------------------
procedure TSynCacheSyn.UnknownProc;
begin
{$IFDEF SYN_MBCSSUPPORT}
if FLine[Run] in LeadBytes then
Inc(Run,2)
else
{$ENDIF}
inc(Run);
fTokenID := tkUnknown;
end;
//------------------------------------------------------------------------------
//------------------------------------------------------------------------------
procedure TSynCacheSyn.Next;
begin
fTokenPos := Run;
if FLine[Run] = #0 then NullProc
else
Case fRange of
rsSQL,
rsHTML: EmbeddedProc;
else fProcTable[fLine[Run]];
end;
end;
function TSynCacheSyn.GetDefaultAttribute(Index: integer): TSynHighlighterAttributes;
begin
case Index of
SYN_ATTR_COMMENT: Result := fCommentAttri;
SYN_ATTR_KEYWORD: Result := fKeyAttri;
SYN_ATTR_WHITESPACE: Result := fSpaceAttri;
SYN_ATTR_SYMBOL: Result := fSymbolAttri;
else
Result := nil;
end;
end;
function TSynCacheSyn.GetEol: Boolean;
begin
Result := fTokenID = tkNull;
end;
function TSynCacheSyn.GetRange: Pointer;
begin
Result := Pointer(fRange);
end;
function TSynCacheSyn.GetToken: String;
var
Len: LongInt;
begin
Len := Run - fTokenPos;
SetString(Result, (FLine + fTokenPos), Len);
end;
function TSynCacheSyn.GetTokenID: TtkTokenKind;
begin
Result := fTokenId;
end;
function TSynCacheSyn.GetTokenAttribute: TSynHighlighterAttributes;
begin
case GetTokenID of
tkClass: Result := fClassAttri;
tkComment: Result := fCommentAttri;
tkFunction: Result := fFunctionAttri;
tkIdentifier: Result := fIdentifierAttri;
tkKey: Result := fKeyAttri;
tkNumber: Result := fNumberAttri;
tkDirective: Result := fDirectiveAttri;
tkSpace: Result := fSpaceAttri;
tkString: Result := fStringAttri;
tkSymbol: Result := fSymbolAttri;
tkIndirect: Result := fIndirectAttri;
tkUnknown: Result := fIdentifierAttri;
tkLabel: Result := fLabelAttri;
tkMacro: Result := fMacroAttri;
tkUserFunction: Result := fUserFunctionAttri;
tkEmbedSQL: Result := fEmbedSQLAttri;
tkEmbedText: Result := fEmbedTextAttri;
else Result := nil;
end;
end;
function TSynCacheSyn.GetTokenKind: integer;
begin
Result := Ord(fTokenId);
end;
function TSynCacheSyn.GetTokenPos: Integer;
begin
Result := fTokenPos;
end;
procedure TSynCacheSyn.ReSetRange;
begin
fRange := rsUnknown;
end;
procedure TSynCacheSyn.SetRange(Value: Pointer);
begin
fRange := TRangeState(Value);
end;
//------------------------------------------------------------------------------
function TSynCacheSyn.GetIdentChars: TSynIdentChars;
begin
Result := ['0'..'9', 'a'..'z', 'A'..'Z', '^', '%'] + TSynSpecialChars;
end;
class function TSynCacheSyn.GetLanguageName: string;
begin
Result := SYNS_LangCache;
end;
//------------------------------------------------------------------------------
// highlight indirection syntax: @ident
//------------------------------------------------------------------------------
procedure TSynCacheSyn.IndirectProc;
begin
fTokenID := tkIndirect;
inc( Run );
while Identifiers[ FLine[Run] ] do inc( Run );
FRange := rsUnknown;
end;
//------------------------------------------------------------------------------
// highlight symbols
//------------------------------------------------------------------------------
procedure TSynCacheSyn.SymbolProc;
begin
fTokenID := tkSymbol;
inc( Run );
// FCanKey := false;
FRange := rsUnknown;
end;
//------------------------------------------------------------------------------
// highlight user defined functions and macros
// function: $$ident
// macro : $$$ident
//------------------------------------------------------------------------------
procedure TSynCacheSyn.FuncProc;
begin
case FLine[Run] of
'$': case FLine[ Run+1 ] of
'$': case Fline[ Run+2 ] of
'$': fTokenID := tkMacro;
else fTokenID := tkUserFunction;
end;
else begin
fTokenID := IdentKind((fLine + Run));
inc(Run, fStringLen);
if fTokenID = tkKey then fTokenID := tkFunction;
end;
end;
else fTokenID := tkIdentifier;
end;
while Identifiers[fLine[Run]] or (FLine[Run]='$' ) do inc(Run);
// FCanKey := false;
FRange := rsUnknown;
end;
//------------------------------------------------------------------------------
// highlight preprocesor directives and class syntax
// preprocesor: #identifier
// class : ##class
//------------------------------------------------------------------------------
procedure TSynCacheSyn.DirectiveProc;
var
i: integer;
begin
if FLine[Run+1]='#' then fTokenID := tkClass
else begin
for i:=fTokenPos downto 0 do
if not(FLine[i] in [ #32, '#' ]) then begin
fTokenID := tkSymbol;
inc( Run );
exit;
end;
fTokenID := tkDirective
end;
inc( Run );
while Identifiers[fLine[Run]] or (FLine[Run]='#') do inc(Run);
// FCanKey := false;
FRange := rsUnknown;
end;
//------------------------------------------------------------------------------
// highlight embeded SQL and HTML
// SQL : &sql( .... )
// HTML : &html< ..... >
//------------------------------------------------------------------------------
procedure TSynCacheSyn.EmbeddedProc;
begin
case fRange of
rsUnknown, rsCommand: begin
fTokenID := IdentKind( (fLine + Run) );
if fTokenID <> tkEmbedSQL then begin
fTokenID := tkSymbol;
inc( Run );
end else begin
fBrace := 1;
fFirstBrace := true;
inc( Run, fStringLen );
end;
end;
rsSQL: begin
fTokenID := tkEmbedSQL;
while (FLine[Run] <> #0) and (fBrace<>0) do begin
case FLine[Run] of
'(': if not fFirstBrace then inc(fBrace)
else fFirstBrace := false;
')': dec(fBrace);
end;
inc(Run);
end;
if fBrace=0 then fRange := rsUnknown;
end;
rsHTML: begin
fTokenID := tkEmbedSQL;
while (FLine[Run] <> #0) and (fBrace<>0) do begin
case FLine[Run] of
'<': if not fFirstBrace then inc(fBrace)
else fFirstBrace := false;
'>': dec(fBrace);
end;
inc(Run);
end;
if fBrace=0 then fRange := rsUnknown;
end;
end;
end;
initialization
MakeIdentTable;
{$IFNDEF SYN_CPPB_1} //mh 2000-07-14
RegisterPlaceableHighlighter(TSynCacheSyn);
{$ENDIF}
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -