Possibly the worst things you can do is not call a destructor for an object. This article shows a way to avoid this.
So what we want is a way to call the destructor automatically if you forget to do it. Now I could be accused of encouraging lazy programming. So what you should do is put a ShowMessage call saying something like “Oi dipstick, you haven’t called a destructor”. That way you avoid corrupting data and your mistakes are easily found.
Heres the main code to be added after your implementation:
Var cvList : Tlist;
Const InTidy : boolean =false;
procedure Remove(V : TCompoundVolume);
var Index : integer;
begin
If InTidy then
exit;
For Index := cvlist.count-1 downto 0 do
if cvlist[Index] = v then
cvlist.Delete(Index);
end;
procedure Tidylist;
var Index : integer;
begin
if InTidy then
exit;
InTidy := true;
for Index := cvlist.count-1 downto 0 do
if assigned(Cvlist[Index]) then
begin
TObject(Cvlist[index]).Free;
cvlist.Delete(Index);
end;
InTidy := false;
end;
In the class creator add this line
cvList.Add(Self);
and in the destructor add this
Remove(Self);
And in your unit, add the lines or modify the Initialization/finalization sections
Initialization
cvlist := tlist.Create;
finalization
TidyList;
cvlist.free;
If your destructor is called by you, the call to Remove will remove it from the list. This needs the check in case you forgot to call it and it tries to call Remove while the destructor is called from TidyList.