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;
CurNode.Desc:=ctnIdentifier;
CurNode.EndPos:=CurPos.EndPos;
EndChildNode;
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
SaveRaiseCharExpectedButAtomFound(20170421195756,';');
end else begin

View File

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

View File

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

View File

@ -93,6 +93,18 @@ msgstr ""
msgid "Comment"
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
msgid "Condition"
msgstr ""

View File

@ -95,6 +95,18 @@ msgstr "Třída"
msgid "Comment"
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
msgid "Condition"
msgstr "Podmínka"

View File

@ -97,6 +97,18 @@ msgstr "Klasse"
msgid "Comment"
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
msgid "Condition"
msgstr "Bedingung"

View File

@ -95,6 +95,18 @@ msgstr "Clase"
msgid "Comment"
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
msgid "Condition"
msgstr "Condición"

View File

@ -88,6 +88,18 @@ msgstr "Luokka"
msgid "Comment"
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
msgid "Condition"
msgstr "Ehdot"

View File

@ -95,6 +95,18 @@ msgstr "Classe"
msgid "Comment"
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
msgid "Condition"
msgstr "Condition"

View File

@ -93,6 +93,18 @@ msgstr "מחלקה"
msgid "Comment"
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
msgid "Condition"
msgstr "תנאי"

View File

@ -95,6 +95,18 @@ msgstr "Osztály"
msgid "Comment"
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
msgid "Condition"
msgstr "Feltétel"

View File

@ -96,6 +96,18 @@ msgstr ""
msgid "Comment"
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
msgid "Condition"
msgstr ""

View File

@ -96,6 +96,18 @@ msgstr "Classe"
msgid "Comment"
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
msgid "Condition"
msgstr "Condizione"

View File

@ -96,6 +96,18 @@ msgstr "Klasė"
msgid "Comment"
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
msgid "Condition"
msgstr "Sąlyga"

View File

@ -93,6 +93,18 @@ msgstr ""
msgid "Comment"
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
msgid "Condition"
msgstr ""

View File

@ -96,6 +96,18 @@ msgstr "Klasa"
msgid "Comment"
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
msgid "Condition"
msgstr "Warunek"

View File

@ -85,6 +85,18 @@ msgstr ""
msgid "Comment"
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
msgid "Condition"
msgstr ""

View File

@ -95,6 +95,18 @@ msgstr "Classe"
msgid "Comment"
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
msgid "Condition"
msgstr "Condição"

View File

@ -95,6 +95,18 @@ msgstr "Класс"
msgid "Comment"
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
msgid "Condition"
msgstr "Условие"

View File

@ -99,6 +99,18 @@ msgstr "Sınıf"
msgid "Comment"
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
msgid "Condition"
msgstr "Şart"

View File

@ -98,6 +98,18 @@ msgstr "Клас"
msgid "Comment"
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
msgid "Condition"
msgstr "Умова"

View File

@ -96,6 +96,18 @@ msgstr "类"
msgid "Comment"
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
msgid "Condition"
msgstr "状态"

View File

@ -66,6 +66,9 @@ resourcestring
SYNS_AttrCharacter = 'Character';
SYNS_AttrClass = 'Class';
SYNS_AttrComment = 'Comment';
SYNS_AttrCommentAnsi = 'Ansi Comment';
SYNS_AttrCommentCurly = 'Curly Comment';
SYNS_AttrCommentSlash = 'Slash Comment';
SYNS_AttrIDEDirective = 'IDE Directive';
SYNS_AttrCondition = 'Condition';
SYNS_AttrDataType = 'Data type';
@ -199,6 +202,9 @@ const
SYNS_XML_AttrCharacter = 'Character';
SYNS_XML_AttrClass = 'Class';
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_AttrCondition = 'Condition';
SYNS_XML_AttrDataType = 'Data type';

View File

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

View File

@ -25,7 +25,7 @@ unit editor_color_options;
interface
uses
Classes, Controls, Math, Types, typinfo, sysutils,
Classes, Controls, Math, Types, typinfo, fgl, sysutils,
// LazUtils
Laz2_XMLCfg, LazFileUtils, LazUTF8, LazLoggerBase,
// LCL
@ -1162,13 +1162,53 @@ begin
end;
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
i, AttriIdx: Integer;
ParentName: String;
ParentName, GroupName: String;
ParentNode: TTreeNode;
j: TAhaGroupName;
Attr: TColorSchemeAttribute;
NewNode, DefNode, p, ComplWindowEntryParentNode: TTreeNode;
GroupNodes: TGroupNodes;
begin
ColorElementTree.BeginUpdate;
ColorElementTree.Items.Clear;
@ -1185,6 +1225,7 @@ begin
if not(j in [agnDefault, agnLanguage, agnRegistered]) then
ColorElementTree.Items.Add(nil, AdditionalHighlightGroupNames[j]).Visible := False;
GroupNodes := TGroupNodes.Create;
// Fill Attributes in
ComplWindowEntryParentNode := nil;
DefNode := nil;
@ -1196,25 +1237,18 @@ begin
agnLanguage:
begin
ParentNode := ColorElementTree.Items.GetFirstNode;
if FIsEditingDefaults then begin
ParentName := AdditionalHighlightGroupNames[agnDefault];
end
else
if hafCustomWords in Attr.Features then begin
ParentName := FCurrentHighlighter.LanguageName + ' ' + dlgAddHiAttrGroup_Suffix_Custom;
if GetParentNameForLanguageElement(Attr, ParentName, GroupName) then begin
ParentNode := ColorElementTree.Items.FindTopLvlNode(ParentName);
end
else
if strlcomp(PChar(Attr.StoredName), PChar(NESTED_BRACKET_STOREDNAME), length(NESTED_BRACKET_STOREDNAME)) = 0
then begin
ParentName := FCurrentHighlighter.LanguageName + ' ' + dlgAddHiAttrGroup_Suffix_NBrackets;
ParentNode := ColorElementTree.Items.FindTopLvlNode(ParentName);
end
else begin
ParentName := FCurrentHighlighter.LanguageName;
if hafAlpha in Attr.Features then begin
ParentName := ParentName + ' ' + dlgAddHiAttrGroup_Suffix_Extended;
ParentNode := ColorElementTree.Items.FindTopLvlNode(ParentName);
if ParentNode = nil then
ParentNode := ColorElementTree.Items.Add(nil, ParentName);
if GroupName <> '' then begin
ParentName := GroupName;
p := ParentNode;
if not GroupNodes.TryGetData(GroupName, ParentNode) then begin
ParentNode := ColorElementTree.Items.AddChild(p, GroupName);
GroupNodes.Add(GroupName, ParentNode);
end;
end;
end;
end;
@ -1261,6 +1295,9 @@ begin
FindCurHighlightElement;
if assigned(ComplWindowEntryParentNode) then
ComplWindowEntryParentNode.Collapse(True);
for i := 0 to GroupNodes.Count - 1 do
GroupNodes.Data[i].Collapse(False);
GroupNodes.Free;
end;
procedure TEditorColorOptionsFrame.SetColorElementsToDefaults(OnlySelected: Boolean);

View File

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

View File

@ -69,6 +69,7 @@ type
{ TCocoaApplication }
TCocoaApplication = objcclass(NSApplication)
syncCheckEventRef: EventRef;
aloop : TApplicationMainLoop;
isrun : Boolean;
modals : NSMutableDictionary;
@ -89,6 +90,7 @@ type
function nextEventMatchingMask_untilDate_inMode_dequeue(mask: NSUInteger; expiration: NSDate; mode: NSString; deqFlag: LCLObjCBoolean): NSEvent; override;
function runModalForWindow(theWindow: NSWindow): NSInteger; override;
procedure lclPostSyncCheckEvent; message 'lclPostSyncCheckEvent';
procedure lclSyncCheck(arg: id); message 'lclSyncCheck:';
{$ifdef COCOAPPRUNNING_OVERRIDEPROPERTY}
function isRunning: objc.ObjCBOOL; override;
@ -687,6 +689,13 @@ begin
Exit;
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
Result:= nil;
@ -730,6 +739,21 @@ begin
Result:=inherited runModalForWindow(theWindow);
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);
begin
{$ifdef COCOALOOPNATIVE}

View File

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

View File

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

View File

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

View File

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