Free SDL surface after updating the window icon

The SDL surface is no longer needed and will cause a memory leak if not
freed. Additionally, the decoded BitmapData should not be unlocked until
after updating the window icon, as it may be moved by the GC otherwise.
This commit is contained in:
Stefanos A. 2013-09-29 23:36:28 +02:00
parent 420ec232f3
commit cfdb5bc95a

View file

@ -407,24 +407,37 @@ namespace OpenTK.Platform.SDL2
} }
set set
{ {
IntPtr surface = IntPtr.Zero; // Set the new icon, if any, or clear the current
// icon if null
if (value != null) if (value != null)
{ {
using (Bitmap bmp = value.ToBitmap()) using (Bitmap bmp = value.ToBitmap())
{ {
// Decode the icon into a SDL surface
var data = bmp.LockBits( var data = bmp.LockBits(
new Rectangle(0, 0, value.Width, value.Height), new Rectangle(0, 0, value.Width, value.Height),
ImageLockMode.ReadWrite, ImageLockMode.ReadWrite,
PixelFormat.Format32bppArgb); PixelFormat.Format32bppArgb);
surface = SDL.SDL_CreateRGBSurfaceFrom( IntPtr surface = SDL.SDL_CreateRGBSurfaceFrom(
data.Scan0, data.Width, data.Height, 32, data.Width * 4, data.Scan0, data.Width, data.Height, 32, data.Stride,
0x00ff0000u, 0x0000ff00u, 0x000000ffu, 0xff000000u); 0x00ff0000u, 0x0000ff00u, 0x000000ffu, 0xff000000u);
// Update the window icon
SDL.SDL_SetWindowIcon(window.Handle, surface);
// Free the SDL surface as it is no longer needed
SDL.SDL_FreeSurface(surface);
bmp.UnlockBits(data); bmp.UnlockBits(data);
} }
} }
SDL.SDL_SetWindowIcon(window.Handle, surface); else
{
// Clear the window icon
SDL.SDL_SetWindowIcon(window.Handle, IntPtr.Zero);
}
icon = value; icon = value;
IconChanged(this, EventArgs.Empty); IconChanged(this, EventArgs.Empty);
} }