From febc871e5204fc0236f862b979396c6a15301ba6 Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Wed, 22 Jan 2014 18:52:14 -0500 Subject: [PATCH] Fix HGLOBAL leak in plClipboard --- .../Plasma/PubUtilLib/plClipboard/plClipboard.cpp | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/Sources/Plasma/PubUtilLib/plClipboard/plClipboard.cpp b/Sources/Plasma/PubUtilLib/plClipboard/plClipboard.cpp index d3a167a9..4d4b25d8 100755 --- a/Sources/Plasma/PubUtilLib/plClipboard/plClipboard.cpp +++ b/Sources/Plasma/PubUtilLib/plClipboard/plClipboard.cpp @@ -43,6 +43,8 @@ Mead, WA 99021 #include "plClipboard.h" #include "hsWindows.h" +#include + plClipboard& plClipboard::GetInstance() { static plClipboard theInstance; @@ -93,8 +95,8 @@ void plClipboard::SetClipboardText(const plString& text) if (len == 0) return; - HGLOBAL copy = ::GlobalAlloc(GMEM_MOVEABLE, (len + 1) * sizeof(wchar_t)); - if (copy == NULL) + std::unique_ptr copy(::GlobalAlloc(GMEM_MOVEABLE, (len + 1) * sizeof(wchar_t)), ::GlobalFree); + if (!copy) return; if (!::OpenClipboard(NULL)) @@ -102,12 +104,12 @@ void plClipboard::SetClipboardText(const plString& text) ::EmptyClipboard(); - wchar_t* target = (wchar_t*)::GlobalLock(copy); + wchar_t* target = (wchar_t*)::GlobalLock(copy.get()); memcpy(target, buf.GetData(), (len + 1) * sizeof(wchar_t)); target[len] = '\0'; - ::GlobalUnlock(copy); + ::GlobalUnlock(copy.get()); - ::SetClipboardData(CF_UNICODETEXT, copy); + ::SetClipboardData(CF_UNICODETEXT, copy.get()); ::CloseClipboard(); #endif }