From 2ea12fed0b4177a4caff56ab5486e789e0bb9143 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Tue, 14 Apr 2015 15:40:59 +0000 Subject: major memory leak fix git-svn-id: http://svn.miranda-ng.org/main/trunk@12815 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- plugins/IEView/src/IEView.cpp | 105 ++++++++++++++---------------------------- plugins/IEView/src/IEView.h | 76 +++++++++++++++--------------- plugins/IEView/src/Version.h | 2 +- 3 files changed, 74 insertions(+), 109 deletions(-) diff --git a/plugins/IEView/src/IEView.cpp b/plugins/IEView/src/IEView.cpp index 8959771b86..5b5594b575 100644 --- a/plugins/IEView/src/IEView.cpp +++ b/plugins/IEView/src/IEView.cpp @@ -744,16 +744,14 @@ STDMETHODIMP IEView::ProcessUrlAction(LPCWSTR pwszUrl, DWORD dwAction, BYTE *pPo //dwPolicy = URLPOLICY_DISALLOW; //dwPolicy = URLPOLICY_ALLOW; } - else { - return INET_E_DEFAULT_ACTION; - } + else return INET_E_DEFAULT_ACTION; + if (cbPolicy >= sizeof(DWORD)) { *(DWORD*)pPolicy = dwPolicy; return S_OK; } - else { - return S_FALSE; - } + + return S_FALSE; } return INET_E_DEFAULT_ACTION; } @@ -841,28 +839,7 @@ void IEView::scrollToBottomSoft() } void IEView::scrollToBottom() -{/* - IHTMLDocument2 *document = getDocument(); - if (document != NULL) { - wchar_t *p = NULL; - if (SUCCEEDED(document->get_readyState(&p))) { - int licznik = 0; - do { - if (FAILED(document->get_readyState(&p))) { - break; - } - licznik++; - if (licznik == 1) break; - Sleep(10); - } while (!wcscmp(p, L"loading")); - } - IHTMLWindow2* pWindow = NULL; - if (SUCCEEDED(document->get_parentWindow( &pWindow )) && pWindow != NULL) { - pWindow->scrollBy( 0, 0x01FFFFFF ); - } - document->Release(); - }*/ - +{ IHTMLDocument2 *document = getDocument(); if (document != NULL) { IHTMLElementCollection *collection; @@ -900,17 +877,16 @@ void IEView::write(const wchar_t *text) { IHTMLDocument2 *document = getDocument(); if (document != NULL) { - SAFEARRAY *safe_array = SafeArrayCreateVector(VT_VARIANT, 0, 1); + SAFEARRAY *safe_array = ::SafeArrayCreateVector(VT_VARIANT, 0, 1); if (safe_array != NULL) { - VARIANT *variant; - BSTR bstr; - SafeArrayAccessData(safe_array, (LPVOID *)&variant); + VARIANT *variant; + ::SafeArrayAccessData(safe_array, (LPVOID *)&variant); variant->vt = VT_BSTR; - variant->bstrVal = bstr = SysAllocString(text); - SafeArrayUnaccessData(safe_array); + BSTR bstr = variant->bstrVal = ::SysAllocString(text); + ::SafeArrayUnaccessData(safe_array); document->write(safe_array); - //SysFreeString(bstr); -> SafeArrayDestroy should be enough - SafeArrayDestroy(safe_array); + ::SysFreeString(bstr); + ::SafeArrayDestroy(safe_array); } document->Release(); } @@ -1036,8 +1012,7 @@ void IEView::clear(IEVIEWEVENT *event) void* IEView::getSelection(IEVIEWEVENT *event) { - mir_free(selectedText); - selectedText = getSelection(); + replaceStrT(selectedText, getSelection()); if (selectedText == NULL || wcslen(selectedText) == 0) return NULL; @@ -1080,9 +1055,9 @@ void IEView::translateAccelerator(UINT uMsg, WPARAM wParam, LPARAM lParam) /** * Returns the selected text within the active document **/ -BSTR IEView::getSelection() +WCHAR* IEView::getSelection() { - BSTR text = NULL; + TCHAR *res = NULL; IHTMLDocument2 *document = getDocument(); if (document != NULL) { IHTMLSelectionObject *pSelection = NULL; @@ -1091,8 +1066,11 @@ BSTR IEView::getSelection() if (SUCCEEDED(pSelection->createRange(&pDisp)) && pDisp != NULL) { IHTMLTxtRange *pRange = NULL; if (SUCCEEDED(pDisp->QueryInterface(IID_IHTMLTxtRange, (void**)&pRange))) { - if (SUCCEEDED(pRange->get_text(&text))) - text = mir_tstrdup(text); + BSTR text = NULL; + if (SUCCEEDED(pRange->get_text(&text))) { + res = mir_wstrdup(text); + ::SysFreeString(text); + } pRange->Release(); } @@ -1102,14 +1080,14 @@ BSTR IEView::getSelection() } document->Release(); } - return text; + return res; } /** * Returns the destination url (href) of the given anchor element (or parent anchor element) **/ -BSTR IEView::getHrefFromAnchor(IHTMLElement *element) +WCHAR* IEView::getHrefFromAnchor(IHTMLElement *element) { if (element != NULL) { IHTMLAnchorElement * pAnchor; @@ -1117,25 +1095,19 @@ BSTR IEView::getHrefFromAnchor(IHTMLElement *element) VARIANT variant; BSTR url = NULL; if (SUCCEEDED(element->getAttribute(L"href", 2, &variant)) && (variant.vt == VT_BSTR)) { - url = mir_tstrdup(variant.bstrVal); + url = mir_wstrdup(variant.bstrVal); SysFreeString(variant.bstrVal); } - //pAnchor->get_href( &url ); - // if (url!=NULL) { - // url2 = Utils::dupString(url); - // SysFreeString(url); - // url = url2; - // } + pAnchor->Release(); return url; } - else { - IHTMLElement * parent; - if (SUCCEEDED(element->get_parentElement(&parent)) && (parent != NULL)) { - BSTR url = getHrefFromAnchor(parent); - parent->Release(); - return url; - } + + IHTMLElement *parent; + if (SUCCEEDED(element->get_parentElement(&parent)) && (parent != NULL)) { + BSTR url = getHrefFromAnchor(parent); + parent->Release(); + return url; } } return NULL; @@ -1152,25 +1124,18 @@ bool IEView::mouseActivate() bool IEView::mouseClick(POINT pt) { bool result = false; - if (GetFocus() != hwnd) { + if (GetFocus() != hwnd) getFocus = true; - } + IHTMLDocument2 *document = getDocument(); if (document != NULL) { IHTMLElement *element; if (SUCCEEDED(document->elementFromPoint(pt.x, pt.y, &element)) && element != NULL) { - // IHTMLAnchorElement * pAnchor; - // if (SUCCEEDED(element->QueryInterface(IID_IHTMLAnchorElement, (void**)&pAnchor)) && (pAnchor!=NULL)) { - // element->click(); - // result = true; - // pAnchor->Release(); - // } - BSTR url = getHrefFromAnchor(element); + WCHAR *url = getHrefFromAnchor(element); if (url != NULL) { - if ((GetKeyState(VK_SHIFT) & 0x8000) && !(GetKeyState(VK_CONTROL) & 0x8000) - && !(GetKeyState(VK_MENU) & 0x8000)) { + if ((GetKeyState(VK_SHIFT) & 0x8000) && !(GetKeyState(VK_CONTROL) & 0x8000) && !(GetKeyState(VK_MENU) & 0x8000)) SendMessage(GetParent(hwnd), WM_COMMAND, IDCANCEL, 0); - } + CallService(MS_UTILS_OPENURL, OUF_NEWWINDOW | OUF_TCHAR, (LPARAM)url); mir_free(url); result = true; diff --git a/plugins/IEView/src/IEView.h b/plugins/IEView/src/IEView.h index 6d49975d7a..6f4aa7eb60 100644 --- a/plugins/IEView/src/IEView.h +++ b/plugins/IEView/src/IEView.h @@ -509,50 +509,50 @@ private: STDMETHOD(GetZoneMappings)(DWORD dwZone, IEnumString **ppenumString, DWORD dwFlags); IHTMLDocument2 *getDocument(); - BSTR getHrefFromAnchor(IHTMLElement *element); - BSTR getSelection(); - void setBorder(); + WCHAR* getHrefFromAnchor(IHTMLElement *element); + WCHAR* getSelection(); + void setBorder(); protected: - void navigate(const char *); - void navigate(const wchar_t *); + void navigate(const char *); + void navigate(const wchar_t *); public: IEView(HWND parent, HTMLBuilder* builder, int x, int y, int cx, int cy); // IEView::IEView(HWND parent, SmileyWindow* smileyWindow, int x, int y, int cx, int cy); virtual ~IEView(); - void waitWhileBusy(); - HWND getHWND(); - void translateAccelerator(UINT uMsg, WPARAM wParam, LPARAM lParam); - bool mouseClick(POINT pt); - bool mouseActivate(); - bool setFocus(HWND prevFocus); - void setWindowPos(int x, int y, int cx, int cy); - HTMLBuilder* getBuilder(); - - void write(const wchar_t *text); - void write(const char *text); - void writef(const char *fmt, ...); - void documentClose(); - void rebuildLog(); - void scrollToBottom(); - void scrollToBottomSoft(); - void scrollToTop(); - - void setMainWndProc(WNDPROC); - WNDPROC getMainWndProc(); - void setDocWndProc(WNDPROC); - WNDPROC getDocWndProc(); - void setServerWndProc(WNDPROC); - WNDPROC getServerWndProc(); - - void appendEventOld(IEVIEWEVENT * event); - void appendEvent(IEVIEWEVENT * event); - void clear(IEVIEWEVENT * event); - void* getSelection(IEVIEWEVENT * event); - void navigate(IEVIEWNAVIGATE * nav); - void saveDocument(); - - void setContact(MCONTACT hContact); + void waitWhileBusy(); + HWND getHWND(); + void translateAccelerator(UINT uMsg, WPARAM wParam, LPARAM lParam); + bool mouseClick(POINT pt); + bool mouseActivate(); + bool setFocus(HWND prevFocus); + void setWindowPos(int x, int y, int cx, int cy); + HTMLBuilder* getBuilder(); + + void write(const wchar_t *text); + void write(const char *text); + void writef(const char *fmt, ...); + void documentClose(); + void rebuildLog(); + void scrollToBottom(); + void scrollToBottomSoft(); + void scrollToTop(); + + void setMainWndProc(WNDPROC); + WNDPROC getMainWndProc(); + void setDocWndProc(WNDPROC); + WNDPROC getDocWndProc(); + void setServerWndProc(WNDPROC); + WNDPROC getServerWndProc(); + + void appendEventOld(IEVIEWEVENT * event); + void appendEvent(IEVIEWEVENT * event); + void clear(IEVIEWEVENT * event); + void* getSelection(IEVIEWEVENT * event); + void navigate(IEVIEWNAVIGATE * nav); + void saveDocument(); + + void setContact(MCONTACT hContact); static IEView* get(HWND); static void init(); diff --git a/plugins/IEView/src/Version.h b/plugins/IEView/src/Version.h index a7523e31ad..4452266fa0 100644 --- a/plugins/IEView/src/Version.h +++ b/plugins/IEView/src/Version.h @@ -1,7 +1,7 @@ #define __MAJOR_VERSION 1 #define __MINOR_VERSION 4 #define __RELEASE_NUM 0 -#define __BUILD_NUM 3 +#define __BUILD_NUM 4 #include -- cgit v1.2.3