mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-04-05 19:58:02 +02:00
Compare commits
6 Commits
7cfe6f4286
...
41c97b1e03
Author | SHA1 | Date | |
---|---|---|---|
![]() |
41c97b1e03 | ||
![]() |
439afd6033 | ||
![]() |
4027fdb098 | ||
![]() |
1158c4ab59 | ||
![]() |
33c532e60e | ||
![]() |
37ce318225 |
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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 ""
|
||||||
|
@ -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"
|
||||||
|
@ -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"
|
||||||
|
@ -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"
|
||||||
|
@ -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"
|
||||||
|
@ -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"
|
||||||
|
@ -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 "תנאי"
|
||||||
|
@ -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"
|
||||||
|
@ -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 ""
|
||||||
|
@ -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"
|
||||||
|
@ -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"
|
||||||
|
@ -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 ""
|
||||||
|
@ -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"
|
||||||
|
@ -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 ""
|
||||||
|
@ -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"
|
||||||
|
@ -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 "Условие"
|
||||||
|
@ -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"
|
||||||
|
@ -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 "Умова"
|
||||||
|
@ -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 "状态"
|
||||||
|
@ -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';
|
||||||
|
@ -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
|
||||||
|
@ -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);
|
||||||
|
@ -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';
|
||||||
|
@ -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;
|
||||||
|
|
||||||
{------------------------------------------------------------------------------
|
{------------------------------------------------------------------------------
|
||||||
|
@ -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;
|
||||||
|
@ -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, '__', ' ', [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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
{------------------------------------------------------------------------------
|
{------------------------------------------------------------------------------
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user