Compare commits

...

6 Commits

Author SHA1 Message Date
Massimo Magnano
41c97b1e03 Merge branch 'main' into 'main'
Solved GTK2 TMenuItem.Default property does not works #41528

See merge request freepascal.org/lazarus/lazarus!449
2025-04-03 21:45:33 +02: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
Massimo Magnano
37ce318225 Solved GTK2 TMenuItem.Default property does not works #41528 2025-03-12 17:44:26 +01:00
36 changed files with 448 additions and 102 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

@ -1309,9 +1309,12 @@ begin
// Only one item in a menu or submenu can be default. // Only one item in a menu or submenu can be default.
for i:=0 to FParent.Count-1 do for i:=0 to FParent.Count-1 do
if FParent[i].Default then if FParent[i].Default then
FParent[i].FDefault := False; FParent[i].Default := False;
FDefault:= AValue; FDefault:= AValue;
MenuChanged(True); if HandleAllocated and not (csReading in ComponentState) and ((FParent <> nil) or (FMenu = nil)) then
TWSMenuItemClass(WidgetSetClass).SetDefault(Self, AValue);
MenuChanged(False);
OwnerFormDesignerModified(Self);
end; end;
{------------------------------------------------------------------------------ {------------------------------------------------------------------------------

View File

@ -302,7 +302,9 @@ type
procedure _SetCallbackEx(const AMsg: LongInt; const AGTKObject: PGTKObject; const ALCLObject: TObject; Direct: Boolean); procedure _SetCallbackEx(const AMsg: LongInt; const AGTKObject: PGTKObject; const ALCLObject: TObject; Direct: Boolean);
procedure SetCallbackEx(const AMsg: LongInt; const AGTKObject: PGTKObject; const ALCLObject: TObject; Direct: Boolean); procedure SetCallbackEx(const AMsg: LongInt; const AGTKObject: PGTKObject; const ALCLObject: TObject; Direct: Boolean);
procedure SetCommonCallbacks(const AGTKObject: PGTKObject; const ALCLObject: TObject); procedure SetCommonCallbacks(const AGTKObject: PGTKObject; const ALCLObject: TObject);
procedure SetLabelCaption(const ALabel: PGtkLabel; const ACaption: String); function SetLabelCaption(const ALabel: PGtkLabel; const ACaption: String): String;
function SetLabelCaptionMarkup(const ALabel: PGtkLabel; const ACaption: String;
AmpersandsEscape: Boolean=True; MarkupsEscape: Boolean=True): String;
procedure SetSelectionMode(Sender: TObject; Widget: PGtkWidget; procedure SetSelectionMode(Sender: TObject; Widget: PGtkWidget;
MultiSelect, {%H-}ExtendedSelect: Boolean); MultiSelect, {%H-}ExtendedSelect: Boolean);
function ForceLineBreaks(DC : hDC; Src: PChar; MaxWidthInPixels : Longint; function ForceLineBreaks(DC : hDC; Src: PChar; MaxWidthInPixels : Longint;

View File

@ -6023,11 +6023,17 @@ var
MenuItemWidget: PGtkWidget); MenuItemWidget: PGtkWidget);
var var
LabelWidget: PGtkLabel; LabelWidget: PGtkLabel;
s: String;
begin begin
if (MenuItemWidget = nil) or (LCLMenuItem = nil) then if (MenuItemWidget = nil) or (LCLMenuItem = nil) then
Exit; Exit;
LabelWidget := g_object_get_data(PGObject(MenuItemWidget), 'LCLLabel'); LabelWidget := g_object_get_data(PGObject(MenuItemWidget), 'LCLLabel');
Gtk2Widgetset.SetLabelCaption(LabelWidget, LCLMenuItem.Caption); if LCLMenuItem.Default then
Gtk2Widgetset.SetLabelCaptionMarkup(LabelWidget,
'<b>'+EscapeMarkups(Ampersands2Underscore(LCLMenuItem.Caption))+'</b>',
False, False)
else Gtk2Widgetset.SetLabelCaption(LabelWidget, LCLMenuItem.Caption);
gtk_widget_set_direction(PGtkWidget(LabelWidget), WidgetDirection[UseRTL]); gtk_widget_set_direction(PGtkWidget(LabelWidget), WidgetDirection[UseRTL]);
end; end;
@ -6057,15 +6063,24 @@ var
if LabelWidget = nil then if LabelWidget = nil then
begin begin
// create a label for the ShortCut // create a label for the ShortCut
LabelWidget := PGtkLabel(gtk_label_new(PChar(Pointer(s)))); LabelWidget := PGtkLabel(gtk_label_new(''));
g_object_set_data(PGObject(MenuItemWidget), 'LCLShortCutLabel', LabelWidget); g_object_set_data(PGObject(MenuItemWidget), 'LCLShortCutLabel', LabelWidget);
gtk_label_set_use_markup(LabelWidget, True);
gtk_container_add(GTK_CONTAINER(HBoxWidget), PGtkWidget(LabelWidget)); gtk_container_add(GTK_CONTAINER(HBoxWidget), PGtkWidget(LabelWidget));
if LCLMenuItem.Default then
gtk_label_set_markup(LabelWidget, PChar('<b>'+EscapeMarkups(s)+'</b>'))
else gtk_label_set_text(LabelWidget, PChar(s));
gtk_widget_show(PGtkWidget(LabelWidget)); gtk_widget_show(PGtkWidget(LabelWidget));
end end
else else
begin begin
gtk_label_set_text(LabelWidget, PChar(Pointer(s))); if LCLMenuItem.Default then
gtk_label_set_markup(LabelWidget, PChar('<b>'+EscapeMarkups(s)+'</b>'))
else gtk_label_set_text(LabelWidget, PChar(s));
end; end;
gtk_widget_set_direction(PGtkWidget(LabelWidget), GTK_TEXT_DIR_LTR); //Shortcut always LTR gtk_widget_set_direction(PGtkWidget(LabelWidget), GTK_TEXT_DIR_LTR); //Shortcut always LTR
if UseRTL then if UseRTL then
gtk_misc_set_alignment(GTK_MISC(LabelWidget), 0.0, 0.5) gtk_misc_set_alignment(GTK_MISC(LabelWidget), 0.0, 0.5)
@ -6114,6 +6129,8 @@ var
gtk_container_add(GTK_CONTAINER(HBoxWidget), PGtkWidget(LabelWidget)); gtk_container_add(GTK_CONTAINER(HBoxWidget), PGtkWidget(LabelWidget));
SetMenuItemLabelText(LCLMenuItem, MenuItemWidget); SetMenuItemLabelText(LCLMenuItem, MenuItemWidget);
//gtk_accel_label_set_accel_widget(GTK_ACCEL_LABEL(LabelWidget), MenuItemWidget); //gtk_accel_label_set_accel_widget(GTK_ACCEL_LABEL(LabelWidget), MenuItemWidget);
gtk_label_set_use_underline(LabelWidget, True);
gtk_label_set_use_markup(LabelWidget, True);
gtk_widget_show(PGtkWidget(LabelWidget)); gtk_widget_show(PGtkWidget(LabelWidget));
end; end;
@ -9162,6 +9179,19 @@ begin
end; end;
end; end;
function EscapeMarkups(const Str: String): String;
var
s_escaped: Pgchar;
begin
s_escaped:= g_markup_escape_text(PChar(Str), Length(Str));
//MaxM: maybe #95 but even with the escape it is seen as _ and treated as mnemonic
Result:= StringReplace(s_escaped, '__', '&#32;', [rfReplaceAll]);
g_free(s_escaped);
end;
{------------------------------------------------------------------------------- {-------------------------------------------------------------------------------
Creates a new PChar. Deletes escaping ampersands, replaces the first single Creates a new PChar. Deletes escaping ampersands, replaces the first single
ampersand with an underscore and deletes all other single ampersands. ampersand with an underscore and deletes all other single ampersands.
@ -9182,30 +9212,32 @@ end;
-------------------------------------------------------------------------------} -------------------------------------------------------------------------------}
function Ampersands2Underscore(const ASource: String): String; function Ampersands2Underscore(const ASource: String): String;
var var
n: Integer; n, len: Integer;
FirstFound: Boolean; FirstFound: Boolean;
s: String;
begin begin
//TODO: escape underscores //TODO: escape underscores
FirstFound := False; FirstFound := False;
Result := ASource;
n := 1; n := 1;
while n <= Length(Result) do Result:= '';
len:= Length(ASource);
while n <= len do
begin begin
if Result[n] = '&' then case ASource[n] of
begin '_': Result := Result + '__';
if FirstFound '&': if (n < len) and (ASource[n+1] = '&') then // got &&
or ( (n < Length(Result)) and (Result[n+1] = '&') ) // got && begin
then begin Result:= Result + '&';
Delete(Result, n, 1); Inc(n); // Skip the second & of &&
if not FirstFound then end
Inc(n); // Skip the second & of && else if not(FirstFound) then
end begin
else begin Result:= Result+ '_';
FirstFound := True; FirstFound:= True;
Result[n] := '_'; end;
end; else Result:= Result+ ASource[n];
end; end;
Inc(n); inc(n);
end; end;
end; end;

View File

@ -591,6 +591,9 @@ procedure ConnectInternalWidgetsSignals(AWidget: PGtkWidget;
//-- //--
// markups
function EscapeMarkups(const Str: String): String;
// accelerators // accelerators
function Ampersands2Underscore(Src: PChar): PChar; function Ampersands2Underscore(Src: PChar): PChar;
function Ampersands2Underscore(const ASource: String): String; function Ampersands2Underscore(const ASource: String): String;

View File

@ -950,32 +950,22 @@ begin
ConnectSignal(AGTKObject,'grab-notify',@gtk2GrabNotify, ALCLObject); ConnectSignal(AGTKObject,'grab-notify',@gtk2GrabNotify, ALCLObject);
end; end;
procedure TGtk2WidgetSet.SetLabelCaption(const ALabel: PGtkLabel; function TGtk2WidgetSet.SetLabelCaption(const ALabel: PGtkLabel;
const ACaption: String); const ACaption: String): String;
var
s: String;
i: Integer;
begin begin
s := ''; Result:= Ampersands2Underscore(ACaption);
i := 1; gtk_label_set_text_with_mnemonic(ALabel, PChar(Result));
while i <= Length(ACaption) do end;
begin
case ACaption[i] of function TGtk2WidgetSet.SetLabelCaptionMarkup(const ALabel: PGtkLabel;
'_': s := s + '__'; const ACaption: String; AmpersandsEscape: Boolean; MarkupsEscape: Boolean): String;
'&': begin
if (i < Length(ACaption)) and (ACaption[i + 1] = '&') then Result:= ACaption;
begin if AmpersandsEscape then Result:= Ampersands2Underscore(Result);
s := s + '&'; if MarkupsEscape then Result:= EscapeMarkups(Result);
inc(i);
end gtk_label_set_use_markup(ALabel, True);
else gtk_label_set_markup_with_mnemonic(ALabel, PChar(Result));
s := s + '_';
else
s := s + ACaption[i];
end;
inc(i);
end;
gtk_label_set_text_with_mnemonic(ALabel, PChar(s));
end; end;
{------------------------------------------------------------------------------ {------------------------------------------------------------------------------

View File

@ -44,6 +44,7 @@ type
class procedure SetShortCut(const AMenuItem: TMenuItem; const ShortCutK1, ShortCutK2: TShortCut); override; class procedure SetShortCut(const AMenuItem: TMenuItem; const ShortCutK1, ShortCutK2: TShortCut); override;
class procedure SetVisible(const AMenuItem: TMenuItem; const Visible: boolean); override; class procedure SetVisible(const AMenuItem: TMenuItem; const Visible: boolean); override;
class function SetCheck(const AMenuItem: TMenuItem; const Checked: boolean): boolean; override; class function SetCheck(const AMenuItem: TMenuItem; const Checked: boolean): boolean; override;
class function SetDefault(const AMenuItem: TMenuItem; const ADefault: boolean): boolean; override;
class function SetEnable(const AMenuItem: TMenuItem; const Enabled: boolean): boolean; override; class function SetEnable(const AMenuItem: TMenuItem; const Enabled: boolean): boolean; override;
class function SetRadioItem(const AMenuItem: TMenuItem; const {%H-}RadioItem: boolean): boolean; override; class function SetRadioItem(const AMenuItem: TMenuItem; const {%H-}RadioItem: boolean): boolean; override;
class function SetRightJustify(const AMenuItem: TMenuItem; const Justified: boolean): boolean; override; class function SetRightJustify(const AMenuItem: TMenuItem; const Justified: boolean): boolean; override;
@ -452,6 +453,23 @@ begin
end; end;
end; end;
class function TGtk2WSMenuItem.SetDefault(const AMenuItem: TMenuItem; const ADefault: boolean): boolean;
var
MenuItemWidget: PGtkWidget;
begin
Result:= False;
if not WSCheckMenuItem(AMenuItem, 'SetDefault') then
Exit;
MenuItemWidget:={%H-}PGtkWidget(AMenuItem.Handle);
UpdateInnerMenuItem(AMenuItem,MenuItemWidget);
// gtk_widget_set_sensitive({%H-}PGtkWidget(AMenuItem.Handle), AMenuItem.Enabled);
Result:= True;
end;
class function TGtk2WSMenuItem.SetEnable(const AMenuItem: TMenuItem; class function TGtk2WSMenuItem.SetEnable(const AMenuItem: TMenuItem;
const Enabled: boolean): boolean; const Enabled: boolean): boolean;
begin begin

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;

View File

@ -59,6 +59,7 @@ type
class procedure SetShortCut(const AMenuItem: TMenuItem; const ShortCutK1, ShortCutK2: TShortCut); virtual; class procedure SetShortCut(const AMenuItem: TMenuItem; const ShortCutK1, ShortCutK2: TShortCut); virtual;
class procedure SetVisible(const AMenuItem: TMenuItem; const Visible: boolean); virtual; class procedure SetVisible(const AMenuItem: TMenuItem; const Visible: boolean); virtual;
class function SetCheck(const AMenuItem: TMenuItem; const Checked: boolean): boolean; virtual; class function SetCheck(const AMenuItem: TMenuItem; const Checked: boolean): boolean; virtual;
class function SetDefault(const AMenuItem: TMenuItem; const ADefault: boolean): boolean; virtual;
class function SetEnable(const AMenuItem: TMenuItem; const Enabled: boolean): boolean; virtual; class function SetEnable(const AMenuItem: TMenuItem; const Enabled: boolean): boolean; virtual;
class function SetRadioItem(const AMenuItem: TMenuItem; const RadioItem: boolean): boolean; virtual; class function SetRadioItem(const AMenuItem: TMenuItem; const RadioItem: boolean): boolean; virtual;
class function SetRightJustify(const AMenuItem: TMenuItem; const Justified: boolean): boolean; virtual; class function SetRightJustify(const AMenuItem: TMenuItem; const Justified: boolean): boolean; virtual;
@ -157,6 +158,11 @@ begin
Result := false; Result := false;
end; end;
class function TWSMenuItem.SetDefault(const AMenuItem: TMenuItem; const ADefault: boolean): boolean;
begin
Result := false;
end;
class function TWSMenuItem.SetEnable(const AMenuItem: TMenuItem; const Enabled: boolean): boolean; class function TWSMenuItem.SetEnable(const AMenuItem: TMenuItem; const Enabled: boolean): boolean;
begin begin
Result := false; Result := false;