Fix of HBITMAP leak in GAPI driver by Dmitry Yakimov.
Fixes Bugzilla #371. --HG-- branch : SDL-1.2 extra : convert_revision : svn%3Ac70aab31-4412-0410-b14c-859654838e24/branches/SDL-1.2%402247
This commit is contained in:
parent
cafb1ab206
commit
55d74eb418
1 changed files with 3 additions and 2 deletions
|
@ -1178,7 +1178,7 @@ static void GAPI_WinPAINT(_THIS, HDC hdc)
|
|||
// draw current offscreen buffer on hdc
|
||||
|
||||
int bpp = 16; // we always use either 8 or 16 bpp internally
|
||||
|
||||
HGDIOBJ prevObject;
|
||||
unsigned short *bitmapData;
|
||||
HBITMAP hb;
|
||||
HDC srcDC;
|
||||
|
@ -1216,10 +1216,11 @@ static void GAPI_WinPAINT(_THIS, HDC hdc)
|
|||
// FIXME: prevent misalignment, but I've never seen non aligned width of screen
|
||||
memcpy(bitmapData, this->hidden->buffer, pHeader->biSizeImage);
|
||||
srcDC = CreateCompatibleDC(hdc);
|
||||
SelectObject(srcDC, hb);
|
||||
prevObject = SelectObject(srcDC, hb);
|
||||
|
||||
BitBlt(hdc, 0, 0, this->hidden->w, this->hidden->h, srcDC, 0, 0, SRCCOPY);
|
||||
|
||||
SelectObject(srcDC, prevObject);
|
||||
DeleteObject(hb);
|
||||
DeleteDC(srcDC);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue