From b25edb985ddd2752afc9a49576d8195612c5e63b Mon Sep 17 00:00:00 2001 From: the_fiddler Date: Sun, 2 Sep 2007 00:13:52 +0000 Subject: [PATCH] Improved the Disposable pattern (finalizer was not needed). Removed Dispose() call from glWindow_Destroy function. Added obsolete warning to the Create and OnCreate events/methods. --- Source/OpenTK/GameWindow.cs | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/Source/OpenTK/GameWindow.cs b/Source/OpenTK/GameWindow.cs index 21d1f3d6..1efd2197 100644 --- a/Source/OpenTK/GameWindow.cs +++ b/Source/OpenTK/GameWindow.cs @@ -64,7 +64,7 @@ namespace OpenTK this.isExiting = true; this.OnDestroy(EventArgs.Empty); glWindow.Destroy -= glWindow_Destroy; - this.Dispose(); + //this.Dispose(); } void glWindow_CreateInputDriver(object sender, EventArgs e) @@ -224,12 +224,14 @@ namespace OpenTK #region OnCreate + [Obsolete("The Create event is obsolete and will be removed on later versions. Use the Load event instead.")] public event CreateEvent Create; /// /// Raises the Create event. Override in derived classes to initialize resources. /// /// + [Obsolete("The OnCreate method is obsolete and will be removed on later versions. Use the OnLoad method instead.")] public virtual void OnCreate(EventArgs e) { Debug.WriteLine("Firing GameWindow.Create event"); @@ -582,7 +584,6 @@ namespace OpenTK public void Dispose() { Dispose(true); - GC.SuppressFinalize(this); } private void Dispose(bool manual) @@ -590,10 +591,16 @@ namespace OpenTK if (!disposed) { // Is this safe? Maybe 'Debug' has been disposed, too... - Debug.Print("{0} disposing GameWindow.", manual ? "Manually" : "Automatically"); + //Debug.Print("{0} disposing GameWindow.", manual ? "Manually" : "Automatically"); if (manual) { + if (driver != null) + { + driver.Dispose(); + driver = null; + } + if (glWindow != null) { glWindow.Dispose(); @@ -604,11 +611,6 @@ namespace OpenTK } } - ~GameWindow() - { - Dispose(false); - } - #endregion } }