| Index: src/plugin/PluginUtil.cpp |
| =================================================================== |
| --- a/src/plugin/PluginUtil.cpp |
| +++ b/src/plugin/PluginUtil.cpp |
| @@ -16,11 +16,13 @@ |
| */ |
| #include "PluginStdAfx.h" |
| +#include "../shared/Utils.h" |
| +#include <memory> |
| #include <algorithm> |
|
Oleksandr
2015/03/19 04:39:32
algorithm, stdexcept, vector, shlwapi.h, PluginSet
|
| #include <stdexcept> |
| #include <vector> |
| - |
| -#include "../shared/Utils.h" |
| +#include <WinInet.h> |
| +#include <shlwapi.h> |
| #include "PluginUtil.h" |
| #include "PluginSettings.h" |
| @@ -54,4 +56,32 @@ |
| return std::wstring(); |
| } |
| return std::wstring(locationUrl, locationUrl.Length()); |
| -} |
| +} |
| + |
| +void UnescapeUrl(std::wstring& url) |
| +{ |
| + try |
| + { |
| + DWORD result_length = INTERNET_MAX_URL_LENGTH; |
| + std::unique_ptr<wchar_t[]> result(new wchar_t[result_length]); |
| + HRESULT hr = UrlUnescapeW(const_cast<wchar_t*>(url.c_str()), result.get(), &result_length, 0); |
| + if (hr == S_OK) |
| + { |
| + url = std::wstring(result.get(), result_length); |
| + } |
| + /* |
| + * Do nothing. This masks error return values from UrlUnescape without logging the error. |
| + */ |
| + } |
| + catch(std::bad_alloc e) |
| + { |
| + /* |
| + * When the code has a systematic way of handling bad_alloc, we'll rethrow (probably). |
| + * Until then, we mask the exception and make no modification. |
| + */ |
| + } |
| + catch(...) |
| + { |
| + // no modification if any other exception |
| + } |
| +} |