* Fixed crash when deleting watches (#10075). Patch by Martin Friebe

git-svn-id: trunk@13733 -
This commit is contained in:
marc 2008-01-12 17:36:07 +00:00
parent b929239e3c
commit b6485030ed
2 changed files with 45 additions and 27 deletions

View File

@ -270,6 +270,7 @@ type
private private
FSlave: TBaseBreakPoint; FSlave: TBaseBreakPoint;
function GetDebugger: TDebugger; function GetDebugger: TDebugger;
procedure SetSlave(const ASlave : TBaseBreakPoint);
protected protected
procedure DoChanged; override; procedure DoChanged; override;
procedure DoStateChange(const AOldState: TDBGState); virtual; procedure DoStateChange(const AOldState: TDBGState); virtual;
@ -278,7 +279,7 @@ type
constructor Create(ACollection: TCollection); override; constructor Create(ACollection: TCollection); override;
destructor Destroy; override; destructor Destroy; override;
function GetSourceLine: integer; override; function GetSourceLine: integer; override;
property Slave: TBaseBreakPoint read FSlave write FSlave; property Slave: TBaseBreakPoint read FSlave write SetSlave;
end; end;
TDBGBreakPointClass = class of TDBGBreakPoint; TDBGBreakPointClass = class of TDBGBreakPoint;
@ -478,6 +479,7 @@ type
private private
FSlave: TBaseWatch; FSlave: TBaseWatch;
function GetDebugger: TDebugger; function GetDebugger: TDebugger;
procedure SetSlave(const ASlave : TBaseWatch);
protected protected
procedure DoChanged; override; procedure DoChanged; override;
procedure DoChange; virtual; procedure DoChange; virtual;
@ -486,7 +488,7 @@ type
public public
constructor Create(ACollection: TCollection); override; constructor Create(ACollection: TCollection); override;
destructor Destroy; override; destructor Destroy; override;
property Slave: TBaseWatch read FSlave write FSlave; property Slave: TBaseWatch read FSlave write SetSlave;
end; end;
TDBGWatchClass = class of TDBGWatch; TDBGWatchClass = class of TDBGWatch;
@ -2015,7 +2017,8 @@ begin
SBP := FSlave; SBP := FSlave;
FSlave := nil; FSlave := nil;
if SBP <> nil if SBP <> nil
then SBP.Changed; then SBP.DoChanged; // In case UpdateCount 0
inherited Destroy; inherited Destroy;
end; end;
@ -2054,6 +2057,12 @@ begin
Result := TDBGBreakPoints(Collection).FDebugger; Result := TDBGBreakPoints(Collection).FDebugger;
end; end;
procedure TDBGBreakPoint.SetSlave(const ASlave : TBaseBreakPoint);
begin
Assert(FSlave = nil, 'TDBGBreakPoint.SetSlave already has a slave');
FSlave := ASlave;
end;
{ =========================================================================== } { =========================================================================== }
{ TIDEBreakPoints } { TIDEBreakPoints }
{ =========================================================================== } { =========================================================================== }
@ -2647,7 +2656,7 @@ begin
SW := FSlave; SW := FSlave;
FSlave := nil; FSlave := nil;
if SW <> nil if SW <> nil
then SW.Changed; then SW.DoChanged; // in case UpDateCount was 0
inherited Destroy; inherited Destroy;
end; end;
@ -2671,6 +2680,12 @@ begin
Result := TDBGWatches(Collection).FDebugger; Result := TDBGWatches(Collection).FDebugger;
end; end;
procedure TDBGWatch.SetSlave(const ASlave : TBaseWatch);
begin
Assert(FSlave = nil, 'TDBGWatch.SetSlave already has a slave');
FSlave := ASlave;
end;
{ =========================================================================== } { =========================================================================== }
{ TBaseWatches } { TBaseWatches }
{ =========================================================================== } { =========================================================================== }

View File

@ -207,7 +207,6 @@ type
procedure UpdateSourceMarkImage; procedure UpdateSourceMarkImage;
procedure UpdateSourceMarkLineColor; procedure UpdateSourceMarkLineColor;
public public
constructor Create(ACollection: TCollection); override;
destructor Destroy; override; destructor Destroy; override;
procedure ResetMaster; procedure ResetMaster;
function GetSourceLine: integer; override; function GetSourceLine: integer; override;
@ -233,12 +232,13 @@ type
FMaster: TDBGWatch; FMaster: TDBGWatch;
protected protected
procedure AssignTo(Dest: TPersistent); override; procedure AssignTo(Dest: TPersistent); override;
procedure DoChanged; override;
function GetValid: TValidState; override; function GetValid: TValidState; override;
function GetValue: String; override; function GetValue: String; override;
procedure SetEnabled(const AValue: Boolean); override; procedure SetEnabled(const AValue: Boolean); override;
procedure SetExpression(const AValue: String); override; procedure SetExpression(const AValue: String); override;
public public
constructor Create(ACollection: TCollection); override; destructor Destroy; override;
procedure ResetMaster; procedure ResetMaster;
end; end;
@ -255,6 +255,7 @@ type
procedure NotifyRemove(const AWatch: TIDEWatch); override; procedure NotifyRemove(const AWatch: TIDEWatch); override;
public public
constructor Create(const AManager: TDebugManager); constructor Create(const AManager: TDebugManager);
destructor Destroy; override;
property Master: TDBGWatches read FMaster write SetMaster; property Master: TDBGWatches read FMaster write SetMaster;
end; end;
@ -294,7 +295,6 @@ type
protected protected
procedure AssignTo(Dest: TPersistent); override; procedure AssignTo(Dest: TPersistent); override;
public public
constructor Create(ACollection: TCollection); override;
procedure ResetMaster; procedure ResetMaster;
end; end;
@ -315,7 +315,6 @@ type
protected protected
procedure DoChanged; override; procedure DoChanged; override;
public public
constructor Create(ACollection: TCollection); override;
procedure ResetMaster; procedure ResetMaster;
end; end;
@ -465,11 +464,22 @@ begin
if (TManagedWatches(GetOwner).FMaster <> nil) if (TManagedWatches(GetOwner).FMaster <> nil)
and (Dest is TDBGWatch) and (Dest is TDBGWatch)
then begin then begin
Assert(FMaster=nil, 'TManagedWatch.AssignTo already has a master');
if FMaster<>nil then FMaster.Slave := nil;
FMaster := TDBGWatch(Dest); FMaster := TDBGWatch(Dest);
FMaster.Slave := Self; FMaster.Slave := Self;
end; end;
end; end;
procedure TManagedWatch.DoChanged;
begin
if (FMaster <> nil)
and (FMaster.Slave = nil)
then FMaster := nil;
inherited DoChanged;
end;
function TManagedWatch.GetValid: TValidState; function TManagedWatch.GetValid: TValidState;
begin begin
if FMaster = nil if FMaster = nil
@ -498,13 +508,15 @@ begin
if FMaster <> nil then FMaster.Expression := AValue; if FMaster <> nil then FMaster.Expression := AValue;
end; end;
constructor TManagedWatch.Create(ACollection: TCollection); destructor TManagedWatch.Destroy;
begin begin
inherited Create(ACollection); ResetMaster;
inherited Destroy;
end; end;
procedure TManagedWatch.ResetMaster; procedure TManagedWatch.ResetMaster;
begin begin
if FMaster <> nil then FMaster.Slave := nil;
FMaster := nil; FMaster := nil;
end; end;
@ -561,14 +573,14 @@ begin
inherited Create(TManagedWatch); inherited Create(TManagedWatch);
end; end;
{ TManagedException } destructor TManagedWatches.Destroy;
constructor TManagedException.Create(ACollection: TCollection);
begin begin
FMaster := nil; if Master <> nil then FMaster.OnChange := nil;
inherited Create(ACollection); inherited Destroy;
end; end;
{ TManagedException }
procedure TManagedException.DoChanged; procedure TManagedException.DoChanged;
var var
E: TDBGExceptions; E: TDBGExceptions;
@ -636,12 +648,6 @@ begin
end; end;
end; end;
constructor TManagedSignal.Create(ACollection: TCollection);
begin
FMaster := nil;
inherited Create(ACollection);
end;
procedure TManagedSignal.ResetMaster; procedure TManagedSignal.ResetMaster;
begin begin
FMaster := nil; FMaster := nil;
@ -807,17 +813,13 @@ begin
if (TManagedBreakPoints(GetOwner).FMaster <> nil) if (TManagedBreakPoints(GetOwner).FMaster <> nil)
and (Dest is TDBGBreakPoint) and (Dest is TDBGBreakPoint)
then begin then begin
Assert(FMaster=nil, 'TManagedBreakPoint.AssignTO already has Master');
if FMaster <> nil then FMaster.Slave := nil;
FMaster := TDBGBreakPoint(Dest); FMaster := TDBGBreakPoint(Dest);
FMaster.Slave := Self; FMaster.Slave := Self;
end; end;
end; end;
constructor TManagedBreakPoint.Create(ACollection: TCollection);
begin
inherited Create(ACollection);
FMaster := nil;
end;
destructor TManagedBreakPoint.Destroy; destructor TManagedBreakPoint.Destroy;
begin begin
if FMaster <> nil if FMaster <> nil
@ -854,6 +856,7 @@ end;
procedure TManagedBreakPoint.ResetMaster; procedure TManagedBreakPoint.ResetMaster;
begin begin
if FMaster <> nil then FMaster.Slave := nil;
FMaster := nil; FMaster := nil;
Changed; Changed;
end; end;