mirror of
https://gitlab.com/freepascal.org/lazarus/lazarus.git
synced 2025-08-12 02:56:01 +02:00
Merged revision(s) 62037 #fc63e31186 from trunk:
FpDebug: Prevent a stack overflow, recursive display of record in record constructor "TFoo.Create(a: TFoo)". Outer "AFlags" were hidden, preventing the recursion from being detected ........ git-svn-id: branches/fixes_2_0@62063 -
This commit is contained in:
parent
360d9bb7a4
commit
be966557d4
@ -164,7 +164,7 @@ var
|
||||
Result := i > 0;
|
||||
end;
|
||||
|
||||
Function MembersAsGdbText(out AText: String; WithVisibilty: Boolean; AFlags: TTypeDeclarationFlags = []): Boolean;
|
||||
Function MembersAsGdbText(out AText: String; WithVisibilty: Boolean; ANewFlags: TTypeDeclarationFlags = []): Boolean;
|
||||
var
|
||||
CurVis: TDbgSymbolMemberVisibility;
|
||||
|
||||
@ -187,15 +187,16 @@ var
|
||||
begin
|
||||
Result := True;
|
||||
AText := '';
|
||||
ANewFlags := ANewFlags + AFlags;
|
||||
c := ADbgSymbol.MemberCount;
|
||||
i := 0;
|
||||
while (i < c) and Result do begin
|
||||
m := ADbgSymbol.Member[i];
|
||||
AddVisibility(m.MemberVisibility, i= 0);
|
||||
if tdfStopAfterPointer in AFlags then
|
||||
if tdfStopAfterPointer in ANewFlags then
|
||||
Result := GetTypeName(s, m)
|
||||
else
|
||||
Result := GetTypeAsDeclaration(s, m, [tdfIncludeVarName, tdfStopAfterPointer] + AFlags, AnIndent + 4);
|
||||
Result := GetTypeAsDeclaration(s, m, [tdfIncludeVarName, tdfStopAfterPointer] + ANewFlags, AnIndent + 4);
|
||||
if Result then
|
||||
AText := AText + GetIndent + s + ';' + LineEnding;
|
||||
inc(i);
|
||||
|
Loading…
Reference in New Issue
Block a user