Compare commits

...

6 Commits

Author SHA1 Message Date
David Jenkins
da170ea768 Merge branch 'NewPostSyncCheckEvent' into 'main'
Cocoa: Hybrid lclSyncCheck posting for performance and app response during modal loops

See merge request freepascal.org/lazarus/lazarus!384
2025-04-03 19:45:33 +00:00
Martin
439afd6033 Codetools: fix parsing of "class of" with deprecated or unit-name prefix. 2025-04-03 21:18:45 +02:00
Martin
4027fdb098 IDE, SynEdit: refactor some color settings for Pas-Highlighter 2025-04-03 18:32:24 +02:00
zeljan1
1158c4ab59 ListViewFilterEdit: must clear previous items. issue #41559 2025-04-03 18:15:08 +02:00
zeljan1
33c532e60e Qt,Qt5,Qt6: fixed focus indication. issue #41562 2025-04-03 17:48:00 +02:00
David Jenkins
b692996666 Cocoa: Hybrid lclSyncCheck posting for performance and app response during modal loops
hole bunches of revisions on this one: r24031, 24036, 24045, 24048, 24053, 24054, 24055, 24059

We were trying to solved issues we say with mouse tracking and button clicking while BC was performing background tasks and also the rest of BC becoming non-responsive to the user when modal-loops where in effect.

Original code posted app specific syncCheckEvents to the main queue in TCocoaWidgetSet.SendCheckSyncronizeMessage.  When BC was running background tasks we would fill up the queue with those events and end up causing flaking mouse drag / button click performance.

Laz trunks response to that was to switch away from posting the events and instead in SendCheckSynchronizeMessage() do a call to performSelectorOnMainThread('lclSyncCheck').

This gives good performance when running our background tasks for performSelectorOnMainThread does not allow for calls to lclSyncCheck when modal loops are running.  Dmitri was not concerned as that is standard Mac behavior and so the trunk continues with that method.

However, our users expect BC to still be responsive in the main text window when other forms are open.  So we have implemented a hybrid method:

We post events to the main queue so that are seen even when in modal loops but we only post one at a time so the queue isn't stormed.  When there is an existing event in the queue we get better responsiveness by calling performSelectOrOnMainThread.

When we send an event through the queue we need to recognize it nextEventMatching so that we can do the call to lclSyncEvent and we need to know that an event has been queued.

The event queue receives NSEvents but stores Carbon Events - dropping the initial NSEvent instance.  So the NSEvent that is dequeued is not the same instance of the one that entered.   So a direct EventSent == EventDqueued does not work.  Nor does sending a certaint Type of event (we cannot guarantee it is the exact one we sent).

However, the event queue does carry around a static event ref that we can use.  syncCheckEventRef is the EventRef of the NSEvent we create and post.  Inside of nextEventMatching we check the dq'd event ref to find our event when it has come through.  Meanwhile syncCheckEventRef <> nil is our indication that a event is on the queue and no more should be queued until that one clears.

It is possible for the queue to be flushed and our event disappears. This would be a problem as we would never set syncCheckeventRef to nil and never post new events.  So we use an event of type NSPeriodic and even if it is flushed off the queue, the NSPeriodic mask will still be set and we can use:

(Event = nil) and (Mask == NSPeriodic)

to indicate that an event 'was' there but should now be cleared.

lclPostSyncCheckEvent handles either posting an event or calling performSelectOrOnMainThread based on whether there is an event in the queue or not.  This is called in SendCheckSynchronizeMessage instead of the direct call to performSelectOrOnMainThread.

nextEventMatching() now checks for an Event with ref that matches syncCheckEventRef or a nil event with mask == NSPeriodic to indicate that syncCheckEventRef should be cleared and lclSyncCheck() called.
2024-11-15 13:28:23 +00:00
31 changed files with 371 additions and 57 deletions

View File

@ -4708,8 +4708,16 @@ begin
CreateChildNode; CreateChildNode;
CurNode.Desc:=ctnIdentifier; CurNode.Desc:=ctnIdentifier;
CurNode.EndPos:=CurPos.EndPos; CurNode.EndPos:=CurPos.EndPos;
EndChildNode;
ReadNextAtom; ReadNextAtom;
while CurPos.Flag = cafPoint do begin
// TMyClassClass = class of unit1.TMyClass
ReadNextAtom;
AtomIsIdentifierSaveE(20250403202500);
CurNode.EndPos:=CurPos.EndPos;
ReadNextAtom;
end;
EndChildNode;
ReadHintModifiers(False);
if CurPos.Flag<>cafSemicolon then if CurPos.Flag<>cafSemicolon then
SaveRaiseCharExpectedButAtomFound(20170421195756,';'); SaveRaiseCharExpectedButAtomFound(20170421195756,';');
end else begin end else begin

View File

@ -6,6 +6,7 @@ interface
type type
TClassOfMy = class of TMy{declaration:fdt_classof.TMy}; TClassOfMy = class of TMy{declaration:fdt_classof.TMy};
TClass1OfMy = class of TMy{declaration:fdt_classof.TMy} deprecated 'abc' experimental;
{ TMy } { TMy }
@ -14,6 +15,8 @@ type
class procedure Run; class procedure Run;
end; end;
TClass2OfMy = class of fdt_classof.TMy{declaration!:fdt_classof.TMy};
procedure DoIt; procedure DoIt;
implementation implementation

View File

@ -156,6 +156,7 @@ begin
fFilteredListview.RemoveFreeNotification(Self); fFilteredListview.RemoveFreeNotification(Self);
ForceFilter(''); ForceFilter('');
end; end;
fOriginalData.Clear;
fFilteredListview := AValue; fFilteredListview := AValue;
if Assigned(fFilteredListview) then if Assigned(fFilteredListview) then
begin begin

View File

@ -93,6 +93,18 @@ msgstr ""
msgid "Comment" msgid "Comment"
msgstr "" msgstr ""
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "" msgstr ""

View File

@ -95,6 +95,18 @@ msgstr "Třída"
msgid "Comment" msgid "Comment"
msgstr "Komentář" msgstr "Komentář"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Podmínka" msgstr "Podmínka"

View File

@ -97,6 +97,18 @@ msgstr "Klasse"
msgid "Comment" msgid "Comment"
msgstr "Kommentar" msgstr "Kommentar"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Bedingung" msgstr "Bedingung"

View File

@ -95,6 +95,18 @@ msgstr "Clase"
msgid "Comment" msgid "Comment"
msgstr "Comentario" msgstr "Comentario"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Condición" msgstr "Condición"

View File

@ -88,6 +88,18 @@ msgstr "Luokka"
msgid "Comment" msgid "Comment"
msgstr "Kommentti" msgstr "Kommentti"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Ehdot" msgstr "Ehdot"

View File

@ -95,6 +95,18 @@ msgstr "Classe"
msgid "Comment" msgid "Comment"
msgstr "Commentaire" msgstr "Commentaire"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Condition" msgstr "Condition"

View File

@ -93,6 +93,18 @@ msgstr "מחלקה"
msgid "Comment" msgid "Comment"
msgstr "הערה" msgstr "הערה"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "תנאי" msgstr "תנאי"

View File

@ -95,6 +95,18 @@ msgstr "Osztály"
msgid "Comment" msgid "Comment"
msgstr "Megjegyzés" msgstr "Megjegyzés"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Feltétel" msgstr "Feltétel"

View File

@ -96,6 +96,18 @@ msgstr ""
msgid "Comment" msgid "Comment"
msgstr "" msgstr ""
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "" msgstr ""

View File

@ -96,6 +96,18 @@ msgstr "Classe"
msgid "Comment" msgid "Comment"
msgstr "Commento" msgstr "Commento"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Condizione" msgstr "Condizione"

View File

@ -96,6 +96,18 @@ msgstr "Klasė"
msgid "Comment" msgid "Comment"
msgstr "Komentaras" msgstr "Komentaras"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Sąlyga" msgstr "Sąlyga"

View File

@ -93,6 +93,18 @@ msgstr ""
msgid "Comment" msgid "Comment"
msgstr "" msgstr ""
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "" msgstr ""

View File

@ -96,6 +96,18 @@ msgstr "Klasa"
msgid "Comment" msgid "Comment"
msgstr "Komentarz" msgstr "Komentarz"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Warunek" msgstr "Warunek"

View File

@ -85,6 +85,18 @@ msgstr ""
msgid "Comment" msgid "Comment"
msgstr "" msgstr ""
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "" msgstr ""

View File

@ -95,6 +95,18 @@ msgstr "Classe"
msgid "Comment" msgid "Comment"
msgstr "Comentário" msgstr "Comentário"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Condição" msgstr "Condição"

View File

@ -95,6 +95,18 @@ msgstr "Класс"
msgid "Comment" msgid "Comment"
msgstr "Комментарий" msgstr "Комментарий"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Условие" msgstr "Условие"

View File

@ -99,6 +99,18 @@ msgstr "Sınıf"
msgid "Comment" msgid "Comment"
msgstr "Açıklama" msgstr "Açıklama"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Şart" msgstr "Şart"

View File

@ -98,6 +98,18 @@ msgstr "Клас"
msgid "Comment" msgid "Comment"
msgstr "Коментар" msgstr "Коментар"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "Умова" msgstr "Умова"

View File

@ -96,6 +96,18 @@ msgstr "类"
msgid "Comment" msgid "Comment"
msgstr "注释" msgstr "注释"
#: syneditstrconst.syns_attrcommentansi
msgid "Ansi Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentcurly
msgid "Curly Comment"
msgstr ""
#: syneditstrconst.syns_attrcommentslash
msgid "Slash Comment"
msgstr ""
#: syneditstrconst.syns_attrcondition #: syneditstrconst.syns_attrcondition
msgid "Condition" msgid "Condition"
msgstr "状态" msgstr "状态"

View File

@ -66,6 +66,9 @@ resourcestring
SYNS_AttrCharacter = 'Character'; SYNS_AttrCharacter = 'Character';
SYNS_AttrClass = 'Class'; SYNS_AttrClass = 'Class';
SYNS_AttrComment = 'Comment'; SYNS_AttrComment = 'Comment';
SYNS_AttrCommentAnsi = 'Ansi Comment';
SYNS_AttrCommentCurly = 'Curly Comment';
SYNS_AttrCommentSlash = 'Slash Comment';
SYNS_AttrIDEDirective = 'IDE Directive'; SYNS_AttrIDEDirective = 'IDE Directive';
SYNS_AttrCondition = 'Condition'; SYNS_AttrCondition = 'Condition';
SYNS_AttrDataType = 'Data type'; SYNS_AttrDataType = 'Data type';
@ -199,6 +202,9 @@ const
SYNS_XML_AttrCharacter = 'Character'; SYNS_XML_AttrCharacter = 'Character';
SYNS_XML_AttrClass = 'Class'; SYNS_XML_AttrClass = 'Class';
SYNS_XML_AttrComment = 'Comment'; SYNS_XML_AttrComment = 'Comment';
SYNS_XML_AttrCommentAnsi = 'Ansi Comment';
SYNS_XML_AttrCommentCurly = 'Curly Comment';
SYNS_XML_AttrCommentSlash = 'Slash Comment';
SYNS_XML_AttrIDEDirective = 'IDE Directive'; SYNS_XML_AttrIDEDirective = 'IDE Directive';
SYNS_XML_AttrCondition = 'Condition'; SYNS_XML_AttrCondition = 'Condition';
SYNS_XML_AttrDataType = 'Data type'; SYNS_XML_AttrDataType = 'Data type';

View File

@ -188,7 +188,11 @@ type
reaDeclVarName, reaDeclVarName,
reaDeclTypeName, reaDeclTypeName,
reaDeclType, reaDeclType,
reaDeclValue reaDeclValue,
// other
reCommentAnsi,
reCommentCurly,
reCommentSlash
); );
TRequiredStates = set of TRequiredState; TRequiredStates = set of TRequiredState;
@ -595,6 +599,9 @@ type
PSynPasSynCustomTokenInfoListEx = ^TSynPasSynCustomTokenInfoListEx; PSynPasSynCustomTokenInfoListEx = ^TSynPasSynCustomTokenInfoListEx;
private private
FCaseLabelAttriMatchesElseOtherwise: Boolean; FCaseLabelAttriMatchesElseOtherwise: Boolean;
FCommentAnsiAttri: TSynHighlighterAttributesModifier;
FCommentCurlyAttri: TSynHighlighterAttributesModifier;
FCommentSlashAttri: TSynHighlighterAttributesModifier;
FNestedBracketAttribs: TSynHighlighterAttributesModifierCollection; FNestedBracketAttribs: TSynHighlighterAttributesModifierCollection;
FNestedBracketMergedMarkup: TSynSelectedColorMergeResult; FNestedBracketMergedMarkup: TSynSelectedColorMergeResult;
FHighNestedBracketAttrib: integer; FHighNestedBracketAttrib: integer;
@ -605,7 +612,6 @@ type
Lists: array of TSynPasSynCustomTokenInfoListEx; Lists: array of TSynPasSynCustomTokenInfoListEx;
end; end;
FCustomTokenMarkup, FCustomCommentTokenMarkup: TSynHighlighterAttributesModifier; FCustomTokenMarkup, FCustomCommentTokenMarkup: TSynHighlighterAttributesModifier;
FCustomTokenMarkupSlash, FCustomTokenMarkupAnsi, FCustomTokenMarkupBor: TSynHighlighterAttributesModifier;
FCustomTokenMergedMarkup, FCustomCommentTokenMergedMarkup: TSynSelectedColorMergeResult; FCustomTokenMergedMarkup, FCustomCommentTokenMergedMarkup: TSynSelectedColorMergeResult;
FCurIDEDirectiveAttri: TSynSelectedColorMergeResult; FCurIDEDirectiveAttri: TSynSelectedColorMergeResult;
@ -987,6 +993,9 @@ type
property AsmAttri: TSynHighlighterAttributes read fAsmAttri write fAsmAttri; property AsmAttri: TSynHighlighterAttributes read fAsmAttri write fAsmAttri;
property CommentAttri: TSynHighlighterAttributes read fCommentAttri property CommentAttri: TSynHighlighterAttributes read fCommentAttri
write fCommentAttri; write fCommentAttri;
property CommentAnsiAttri: TSynHighlighterAttributesModifier read FCommentAnsiAttri write FCommentAnsiAttri;
property CommentCurlyAttri: TSynHighlighterAttributesModifier read FCommentCurlyAttri write FCommentCurlyAttri;
property CommentSlashAttri: TSynHighlighterAttributesModifier read FCommentSlashAttri write FCommentSlashAttri;
property IDEDirectiveAttri: TSynHighlighterAttributesModifier read FIDEDirectiveAttri property IDEDirectiveAttri: TSynHighlighterAttributesModifier read FIDEDirectiveAttri
write FIDEDirectiveAttri; write FIDEDirectiveAttri;
property IdentifierAttri: TSynHighlighterAttributes read fIdentifierAttri property IdentifierAttri: TSynHighlighterAttributes read fIdentifierAttri
@ -1596,9 +1605,6 @@ begin
FNeedCustomTokenBuild := False; FNeedCustomTokenBuild := False;
FCustomTokenMarkup := nil; FCustomTokenMarkup := nil;
FCustomCommentTokenMarkup := nil; FCustomCommentTokenMarkup := nil;
FCustomTokenMarkupSlash := nil;
FCustomTokenMarkupAnsi := nil;
FCustomTokenMarkupBor := nil;
for i := 0 to 255 do begin for i := 0 to 255 do begin
for j := 0 to length(FCustomTokenInfo[i].Lists) - 1 do for j := 0 to length(FCustomTokenInfo[i].Lists) - 1 do
FreeAndNil(FCustomTokenInfo[i].Lists[j].List); FreeAndNil(FCustomTokenInfo[i].Lists[j].List);
@ -1625,23 +1631,6 @@ begin
FCustomTokenInfo[h].MatchTokenKinds := FCustomTokenInfo[h].MatchTokenKinds + mtk; FCustomTokenInfo[h].MatchTokenKinds := FCustomTokenInfo[h].MatchTokenKinds + mtk;
for tk in mtk do begin for tk in mtk do begin
case tk of
tkSlashComment:
if t = '*' then begin
FCustomTokenMarkupSlash := FSynCustomTokens[i].Markup;
continue;
end;
tkAnsiComment:
if t = '*' then begin
FCustomTokenMarkupAnsi := FSynCustomTokens[i].Markup;
continue;
end;
tkBorComment:
if t = '*' then begin
FCustomTokenMarkupBor := FSynCustomTokens[i].Markup;
continue;
end;
end;
Lst := FindList(h, tk); Lst := FindList(h, tk);
Lst^.List.AddObject(UpperCase(t), FSynCustomTokens[i]); Lst^.List.AddObject(UpperCase(t), FSynCustomTokens[i]);
end; end;
@ -3943,7 +3932,7 @@ end;
constructor TSynPasSyn.Create(AOwner: TComponent); constructor TSynPasSyn.Create(AOwner: TComponent);
begin begin
inherited Create(AOwner); inherited Create(AOwner);
FCaseLabelAttriMatchesElseOtherwise := True;; FCaseLabelAttriMatchesElseOtherwise := True;
FStringKeywordMode := spsmDefault; FStringKeywordMode := spsmDefault;
FExtendedKeywordsMode := False; FExtendedKeywordsMode := False;
CreateDividerDrawConfig; CreateDividerDrawConfig;
@ -3953,6 +3942,12 @@ begin
fCommentAttri := TSynHighlighterAttributes.Create(@SYNS_AttrComment, SYNS_XML_AttrComment); fCommentAttri := TSynHighlighterAttributes.Create(@SYNS_AttrComment, SYNS_XML_AttrComment);
fCommentAttri.Style:= [fsItalic]; fCommentAttri.Style:= [fsItalic];
AddAttribute(fCommentAttri); AddAttribute(fCommentAttri);
FCommentAnsiAttri := TSynHighlighterAttributesModifier.Create(@SYNS_AttrCommentAnsi, SYNS_XML_AttrCommentAnsi);
AddAttribute(FCommentAnsiAttri);
FCommentCurlyAttri := TSynHighlighterAttributesModifier.Create(@SYNS_AttrCommentCurly, SYNS_XML_AttrCommentCurly);
AddAttribute(FCommentCurlyAttri);
FCommentSlashAttri := TSynHighlighterAttributesModifier.Create(@SYNS_AttrCommentSlash, SYNS_XML_AttrCommentSlash);
AddAttribute(FCommentSlashAttri);
FIDEDirectiveAttri := TSynHighlighterAttributesModifier.Create(@SYNS_AttrIDEDirective, SYNS_XML_AttrIDEDirective); FIDEDirectiveAttri := TSynHighlighterAttributesModifier.Create(@SYNS_AttrIDEDirective, SYNS_XML_AttrIDEDirective);
AddAttribute(FIDEDirectiveAttri); AddAttribute(FIDEDirectiveAttri);
// FCurIDEDirectiveAttri, FCurCaseLabelAttri, FCurProcTypeDeclExtraAttr // FCurIDEDirectiveAttri, FCurCaseLabelAttri, FCurProcTypeDeclExtraAttr
@ -4182,7 +4177,8 @@ var
p: LongInt; p: LongInt;
IsInWord, WasInWord, ct: Boolean; IsInWord, WasInWord, ct: Boolean;
begin begin
FCustomCommentTokenMarkup := FCustomTokenMarkupBor; if reCommentCurly in FRequiredStates then
FCustomCommentTokenMarkup := FCommentCurlyAttri;
fTokenID := tkComment; fTokenID := tkComment;
if rsIDEDirective in fRange then if rsIDEDirective in fRange then
fTokenID := tkIDEDirective; fTokenID := tkIDEDirective;
@ -4500,7 +4496,8 @@ begin
dec(Run); dec(Run);
StartPascalCodeFoldBlock(cfbtBorCommand); StartPascalCodeFoldBlock(cfbtBorCommand);
FCustomCommentTokenMarkup := FCustomTokenMarkupBor; if reCommentCurly in FRequiredStates then
FCustomCommentTokenMarkup := FCommentCurlyAttri;
if not (FIsInNextToEOL or IsScanning) then if not (FIsInNextToEOL or IsScanning) then
GetCustomSymbolToken(tkBorComment, 1, FCustomTokenMarkup); GetCustomSymbolToken(tkBorComment, 1, FCustomTokenMarkup);
@ -4737,7 +4734,8 @@ var
IsInWord, WasInWord, ct: Boolean; IsInWord, WasInWord, ct: Boolean;
begin begin
fTokenID := tkComment; fTokenID := tkComment;
FCustomCommentTokenMarkup := FCustomTokenMarkupAnsi; if reCommentAnsi in FRequiredStates then
FCustomCommentTokenMarkup := FCommentAnsiAttri;
if (not (FIsInNextToEOL or IsScanning)) then begin if (not (FIsInNextToEOL or IsScanning)) then begin
if FUsePasDoc and (fLine[Run] = '@') then begin if FUsePasDoc and (fLine[Run] = '@') then begin
@ -4863,7 +4861,8 @@ begin
Dec(Run); Dec(Run);
StartPascalCodeFoldBlock(cfbtAnsiComment); StartPascalCodeFoldBlock(cfbtAnsiComment);
FCustomCommentTokenMarkup := FCustomTokenMarkupAnsi; if reCommentAnsi in FRequiredStates then
FCustomCommentTokenMarkup := FCommentAnsiAttri;
if not (FIsInNextToEOL or IsScanning) then if not (FIsInNextToEOL or IsScanning) then
GetCustomSymbolToken(tkAnsiComment, 2, FCustomTokenMarkup); GetCustomSymbolToken(tkAnsiComment, 2, FCustomTokenMarkup);
@ -5061,7 +5060,8 @@ end;
procedure TSynPasSyn.SlashProc; procedure TSynPasSyn.SlashProc;
begin begin
if fLine[Run+1] = '/' then begin if fLine[Run+1] = '/' then begin
FCustomCommentTokenMarkup := FCustomTokenMarkupSlash; if reCommentSlash in FRequiredStates then
FCustomCommentTokenMarkup := FCommentSlashAttri;
FIsInSlash := True; FIsInSlash := True;
fTokenID := tkComment; fTokenID := tkComment;
@ -5093,7 +5093,8 @@ var
AtSlashOpen: Boolean; AtSlashOpen: Boolean;
begin begin
if FIsInSlash and (not (FIsInNextToEOL or IsScanning)) then begin if FIsInSlash and (not (FIsInNextToEOL or IsScanning)) then begin
FCustomCommentTokenMarkup := FCustomTokenMarkupSlash; if reCommentSlash in FRequiredStates then
FCustomCommentTokenMarkup := FCommentSlashAttri;
fTokenID := tkComment; fTokenID := tkComment;
if (fLine[Run] = '@') then begin if (fLine[Run] = '@') then begin
@ -5113,7 +5114,8 @@ begin
AtSlashOpen := (fLine[Run] = '/') and (fLine[Run + 1] = '/') and not FIsInSlash; AtSlashOpen := (fLine[Run] = '/') and (fLine[Run + 1] = '/') and not FIsInSlash;
if FIsInSlash or AtSlashOpen then begin if FIsInSlash or AtSlashOpen then begin
FIsInSlash := True; FIsInSlash := True;
FCustomCommentTokenMarkup := FCustomTokenMarkupSlash; if reCommentSlash in FRequiredStates then
FCustomCommentTokenMarkup := FCommentSlashAttri;
// Continue fold block // Continue fold block
fTokenID := tkComment; fTokenID := tkComment;
@ -7309,6 +7311,10 @@ begin
FRequiredStates := []; FRequiredStates := [];
if FCommentAnsiAttri.IsEnabled then Include(FRequiredStates, reCommentAnsi);
if FCommentCurlyAttri.IsEnabled then Include(FRequiredStates, reCommentCurly);
if FCommentSlashAttri.IsEnabled then Include(FRequiredStates, reCommentSlash);
//if fPasDocKeyWordAttri.IsEnabled then begin //if fPasDocKeyWordAttri.IsEnabled then begin
//end; //end;
//if fPasDocSymbolAttri.IsEnabled then begin //if fPasDocSymbolAttri.IsEnabled then begin

View File

@ -25,7 +25,7 @@ unit editor_color_options;
interface interface
uses uses
Classes, Controls, Math, Types, typinfo, sysutils, Classes, Controls, Math, Types, typinfo, fgl, sysutils,
// LazUtils // LazUtils
Laz2_XMLCfg, LazFileUtils, LazUTF8, LazLoggerBase, Laz2_XMLCfg, LazFileUtils, LazUTF8, LazLoggerBase,
// LCL // LCL
@ -1162,13 +1162,53 @@ begin
end; end;
procedure TEditorColorOptionsFrame.FillColorElementListBox; procedure TEditorColorOptionsFrame.FillColorElementListBox;
function GetParentNameForLanguageElement(AnAttr: TColorSchemeAttribute;
out AParentName, AGroupName: String): boolean;
begin
AGroupName := '';
AParentName := FCurrentHighlighter.LanguageName;
Result := True;
if hafCustomWords in AnAttr.Features then begin
AParentName := AParentName + ' ' + dlgAddHiAttrGroup_Suffix_Custom;
end
else
if strlcomp(PChar(AnAttr.StoredName), PChar(NESTED_BRACKET_STOREDNAME), length(NESTED_BRACKET_STOREDNAME)) = 0
then begin
AParentName := AParentName + ' ' + dlgAddHiAttrGroup_Suffix_NBrackets;
end
else
if hafAlpha in AnAttr.Features then begin
AParentName := AParentName + ' ' + dlgAddHiAttrGroup_Suffix_Extended;
case AnAttr.StoredName of
//SYNS_XML_AttrIDEDirective,
SYNS_XML_AttrCommentAnsi, SYNS_XML_AttrCommentCurly, SYNS_XML_AttrCommentSlash,
SYNS_XML_AttrPasDocKey, SYNS_XML_AttrPasDocSymbol, SYNS_XML_AttrPasDocUnknown:
AGroupName := dlgAddHiAttrGroup_Comment;
SYNS_XML_AttrProcedureHeaderName, SYNS_XML_AttrPropertyName,
SYNS_XML_AttrProcedureHeaderParam, SYNS_XML_AttrProcedureHeaderResult,
SYNS_XML_AttrProcedureHeaderType, SYNS_XML_AttrProcedureHeaderValue:
AGroupName := dlgAddHiAttrGroup_ProgHeader;
SYNS_XML_AttrDeclarationVarConstName, SYNS_XML_AttrDeclarationTypeName,
SYNS_XML_AttrDeclarationType, SYNS_XML_AttrDeclarationValue:
AGroupName := dlgAddHiAttrGroup_DeclSection;
end;
end
else
Result := False;
end;
type
TGroupNodes = specialize TFPGMap<String, TTreeNode>;
var var
i, AttriIdx: Integer; i, AttriIdx: Integer;
ParentName: String; ParentName, GroupName: String;
ParentNode: TTreeNode; ParentNode: TTreeNode;
j: TAhaGroupName; j: TAhaGroupName;
Attr: TColorSchemeAttribute; Attr: TColorSchemeAttribute;
NewNode, DefNode, p, ComplWindowEntryParentNode: TTreeNode; NewNode, DefNode, p, ComplWindowEntryParentNode: TTreeNode;
GroupNodes: TGroupNodes;
begin begin
ColorElementTree.BeginUpdate; ColorElementTree.BeginUpdate;
ColorElementTree.Items.Clear; ColorElementTree.Items.Clear;
@ -1185,6 +1225,7 @@ begin
if not(j in [agnDefault, agnLanguage, agnRegistered]) then if not(j in [agnDefault, agnLanguage, agnRegistered]) then
ColorElementTree.Items.Add(nil, AdditionalHighlightGroupNames[j]).Visible := False; ColorElementTree.Items.Add(nil, AdditionalHighlightGroupNames[j]).Visible := False;
GroupNodes := TGroupNodes.Create;
// Fill Attributes in // Fill Attributes in
ComplWindowEntryParentNode := nil; ComplWindowEntryParentNode := nil;
DefNode := nil; DefNode := nil;
@ -1196,25 +1237,18 @@ begin
agnLanguage: agnLanguage:
begin begin
ParentNode := ColorElementTree.Items.GetFirstNode; ParentNode := ColorElementTree.Items.GetFirstNode;
if FIsEditingDefaults then begin if GetParentNameForLanguageElement(Attr, ParentName, GroupName) then begin
ParentName := AdditionalHighlightGroupNames[agnDefault];
end
else
if hafCustomWords in Attr.Features then begin
ParentName := FCurrentHighlighter.LanguageName + ' ' + dlgAddHiAttrGroup_Suffix_Custom;
ParentNode := ColorElementTree.Items.FindTopLvlNode(ParentName); ParentNode := ColorElementTree.Items.FindTopLvlNode(ParentName);
end if ParentNode = nil then
else ParentNode := ColorElementTree.Items.Add(nil, ParentName);
if strlcomp(PChar(Attr.StoredName), PChar(NESTED_BRACKET_STOREDNAME), length(NESTED_BRACKET_STOREDNAME)) = 0
then begin if GroupName <> '' then begin
ParentName := FCurrentHighlighter.LanguageName + ' ' + dlgAddHiAttrGroup_Suffix_NBrackets; ParentName := GroupName;
ParentNode := ColorElementTree.Items.FindTopLvlNode(ParentName); p := ParentNode;
end if not GroupNodes.TryGetData(GroupName, ParentNode) then begin
else begin ParentNode := ColorElementTree.Items.AddChild(p, GroupName);
ParentName := FCurrentHighlighter.LanguageName; GroupNodes.Add(GroupName, ParentNode);
if hafAlpha in Attr.Features then begin end;
ParentName := ParentName + ' ' + dlgAddHiAttrGroup_Suffix_Extended;
ParentNode := ColorElementTree.Items.FindTopLvlNode(ParentName);
end; end;
end; end;
end; end;
@ -1261,6 +1295,9 @@ begin
FindCurHighlightElement; FindCurHighlightElement;
if assigned(ComplWindowEntryParentNode) then if assigned(ComplWindowEntryParentNode) then
ComplWindowEntryParentNode.Collapse(True); ComplWindowEntryParentNode.Collapse(True);
for i := 0 to GroupNodes.Count - 1 do
GroupNodes.Data[i].Collapse(False);
GroupNodes.Free;
end; end;
procedure TEditorColorOptionsFrame.SetColorElementsToDefaults(OnlySelected: Boolean); procedure TEditorColorOptionsFrame.SetColorElementsToDefaults(OnlySelected: Boolean);

View File

@ -2202,6 +2202,9 @@ resourcestring
dlgAddHiAttrGroup_Suffix_Custom = '(Custom)'; dlgAddHiAttrGroup_Suffix_Custom = '(Custom)';
dlgAddHiAttrGroup_Suffix_NBrackets = '(Nested Brackets)'; dlgAddHiAttrGroup_Suffix_NBrackets = '(Nested Brackets)';
dlgAddHiAttrGroup_Suffix_EntryType = '(entry type)'; dlgAddHiAttrGroup_Suffix_EntryType = '(entry type)';
dlgAddHiAttrGroup_Comment = 'Comments';
dlgAddHiAttrGroup_ProgHeader = 'Procedure Header';
dlgAddHiAttrGroup_DeclSection = 'Declaration Sections';
dlgEditAccessCaptionLockedInView = 'Locked, if text in view'; dlgEditAccessCaptionLockedInView = 'Locked, if text in view';

View File

@ -69,6 +69,7 @@ type
{ TCocoaApplication } { TCocoaApplication }
TCocoaApplication = objcclass(NSApplication) TCocoaApplication = objcclass(NSApplication)
syncCheckEventRef: EventRef;
aloop : TApplicationMainLoop; aloop : TApplicationMainLoop;
isrun : Boolean; isrun : Boolean;
modals : NSMutableDictionary; modals : NSMutableDictionary;
@ -89,6 +90,7 @@ type
function nextEventMatchingMask_untilDate_inMode_dequeue(mask: NSUInteger; expiration: NSDate; mode: NSString; deqFlag: LCLObjCBoolean): NSEvent; override; function nextEventMatchingMask_untilDate_inMode_dequeue(mask: NSUInteger; expiration: NSDate; mode: NSString; deqFlag: LCLObjCBoolean): NSEvent; override;
function runModalForWindow(theWindow: NSWindow): NSInteger; override; function runModalForWindow(theWindow: NSWindow): NSInteger; override;
procedure lclPostSyncCheckEvent; message 'lclPostSyncCheckEvent';
procedure lclSyncCheck(arg: id); message 'lclSyncCheck:'; procedure lclSyncCheck(arg: id); message 'lclSyncCheck:';
{$ifdef COCOAPPRUNNING_OVERRIDEPROPERTY} {$ifdef COCOAPPRUNNING_OVERRIDEPROPERTY}
function isRunning: objc.ObjCBOOL; override; function isRunning: objc.ObjCBOOL; override;
@ -687,6 +689,13 @@ begin
Exit; Exit;
end; end;
if (not Assigned(Result) and ((mask and NSPeriodicMask) <> 0)) or
(Assigned(Result) and (Result.eventRef = syncCheckEventRef)) then
begin
syncCheckEventRef := nil;
lclSyncCheck(nil);
end;
if (Result.type_=NSApplicationDefined) and (Result.subtype=LazarusApplicationDefinedSubtypeWakeup) then if (Result.type_=NSApplicationDefined) and (Result.subtype=LazarusApplicationDefinedSubtypeWakeup) then
Result:= nil; Result:= nil;
@ -730,6 +739,21 @@ begin
Result:=inherited runModalForWindow(theWindow); Result:=inherited runModalForWindow(theWindow);
end; end;
procedure TCocoaApplication.lclPostSyncCheckEvent;
var ev: NSEvent;
begin
if not Assigned(syncCheckEventRef) then
begin
ev := NSEvent.otherEventWithType_location_modifierFlags_timestamp_windowNumber_context_subtype_data1_data2(
NSPeriodic, NSPoint(CGPointZero), 0, 0, 0, nil, 0, 0, 0);
syncCheckEventRef := ev.eventRef;
postEvent_atStart(ev, False);
end
else
performSelectorOnMainThread_withObject_waitUntilDone(
ObjCSelector('lclSyncCheck:'), nil, false);
end;
procedure TCocoaApplication.lclSyncCheck(arg: id); procedure TCocoaApplication.lclSyncCheck(arg: id);
begin begin
{$ifdef COCOALOOPNATIVE} {$ifdef COCOALOOPNATIVE}

View File

@ -50,9 +50,7 @@ end;
procedure TCocoaWidgetSet.SendCheckSynchronizeMessage; procedure TCocoaWidgetSet.SendCheckSynchronizeMessage;
begin begin
InitApplication TCocoaApplication(NSApp).lclPostSyncCheckEvent;
.performSelectorOnMainThread_withObject_waitUntilDone(
ObjCSelector('lclSyncCheck:'), nil, false);
end; end;
{------------------------------------------------------------------------------ {------------------------------------------------------------------------------

View File

@ -5008,7 +5008,7 @@ end;
procedure TQtWidget.setFocus; procedure TQtWidget.setFocus;
begin begin
if getFocusPolicy <> QtNoFocus then if getFocusPolicy <> QtNoFocus then
QWidget_setFocus(Widget, QtOtherFocusReason) {issue #10155} QWidget_setFocus(Widget, QtTabFocusReason) {issue #10155}
else else
QWidget_setFocus(Widget); QWidget_setFocus(Widget);
end; end;

View File

@ -5164,7 +5164,7 @@ end;
procedure TQtWidget.setFocus; procedure TQtWidget.setFocus;
begin begin
if getFocusPolicy <> QtNoFocus then if getFocusPolicy <> QtNoFocus then
QWidget_setFocus(Widget, QtOtherFocusReason) {issue #10155} QWidget_setFocus(Widget, QtTabFocusReason) {issue #10155}
else else
QWidget_setFocus(Widget); QWidget_setFocus(Widget);
end; end;

View File

@ -5168,7 +5168,7 @@ end;
procedure TQtWidget.setFocus; procedure TQtWidget.setFocus;
begin begin
if getFocusPolicy <> QtNoFocus then if getFocusPolicy <> QtNoFocus then
QWidget_setFocus(Widget, QtOtherFocusReason) {issue #10155} QWidget_setFocus(Widget, QtTabFocusReason) {issue #10155}
else else
QWidget_setFocus(Widget); QWidget_setFocus(Widget);
end; end;