aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authornyamatongwe <unknown>2004-07-30 23:57:48 +0000
committernyamatongwe <unknown>2004-07-30 23:57:48 +0000
commitcbe718276c8e78c5552e4c598361dab690549a7f (patch)
treeedb2de9b1bfbd9ba9e60efe8e92b4cdb69041578
parent78a4ba81f904deb46a94716341fc9d0a1fe2d8e2 (diff)
downloadscintilla-mirror-cbe718276c8e78c5552e4c598361dab690549a7f.tar.gz
Fixed bitmap leaks from system caret patch.
-rw-r--r--win32/ScintillaWin.cxx7
1 files changed, 6 insertions, 1 deletions
diff --git a/win32/ScintillaWin.cxx b/win32/ScintillaWin.cxx
index b3afb4d5a..be21fa4d5 100644
--- a/win32/ScintillaWin.cxx
+++ b/win32/ScintillaWin.cxx
@@ -306,6 +306,7 @@ void ScintillaWin::Finalise() {
ScintillaBase::Finalise();
SetTicking(false);
SetIdle(false);
+ DestroySystemCaret();
::RevokeDragDrop(MainHWND());
::OleUninitialize();
}
@@ -765,6 +766,7 @@ sptr_t ScintillaWin::WndProc(unsigned int iMessage, uptr_t wParam, sptr_t lParam
case WM_SETFOCUS:
SetFocusState(true);
RealizeWindowPalette(false);
+ DestroySystemCaret();
CreateSystemCaret();
break;
@@ -2147,7 +2149,10 @@ BOOL ScintillaWin::CreateSystemCaret() {
BOOL ScintillaWin::DestroySystemCaret() {
::HideCaret(MainHWND());
BOOL retval = ::DestroyCaret();
- ::DeleteObject(sysCaretBitmap);
+ if (sysCaretBitmap) {
+ ::DeleteObject(sysCaretBitmap);
+ sysCaretBitmap = 0;
+ }
return retval;
}