From 619b3da9fbb37c57aedfc039cc813f6acf5569be Mon Sep 17 00:00:00 2001 From: Jedidiah Barber Date: Sun, 17 Nov 2024 17:15:53 +1300 Subject: Refactored Finalize subprograms and made note of potential future Widget issues there in fltk.ads --- src/fltk-widgets-valuators-dials.adb | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) (limited to 'src/fltk-widgets-valuators-dials.adb') diff --git a/src/fltk-widgets-valuators-dials.adb b/src/fltk-widgets-valuators-dials.adb index f3cdf87..a796a8c 100644 --- a/src/fltk-widgets-valuators-dials.adb +++ b/src/fltk-widgets-valuators-dials.adb @@ -103,16 +103,20 @@ package body FLTK.Widgets.Valuators.Dials is + procedure Extra_Final + (This : in out Dial) is + begin + Extra_Final (Valuator (This)); + end Extra_Final; + + procedure Finalize (This : in out Dial) is begin - if This.Void_Ptr /= Null_Pointer and then - This in Dial'Class - then + Extra_Final (This); + if This.Void_Ptr /= Null_Pointer and This.Needs_Dealloc then free_fl_dial (This.Void_Ptr); - This.Void_Ptr := Null_Pointer; end if; - Finalize (Valuator (This)); end Finalize; -- cgit