| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 /* | |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | |
| 3 * Copyright (C) 2006-2015 Eyeo GmbH | |
| 4 * | |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | |
| 6 * it under the terms of the GNU General Public License version 3 as | |
| 7 * published by the Free Software Foundation. | |
| 8 * | |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 12 * GNU General Public License for more details. | |
| 13 * | |
| 14 * You should have received a copy of the GNU General Public License | |
| 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | |
| 16 */ | |
| 17 | |
| 1 #include "PluginStdAfx.h" | 18 #include "PluginStdAfx.h" |
| 2 #include "PluginUserSettings.h" | 19 #include "PluginUserSettings.h" |
| 3 #include <algorithm> | 20 #include <algorithm> |
| 4 #include "PluginSettings.h" | 21 #include "PluginSettings.h" |
| 5 #include "PluginClient.h" | 22 #include "PluginClient.h" |
| 6 #include "../shared/Dictionary.h" | 23 #include "../shared/Dictionary.h" |
| 7 #include <unordered_map> | 24 #include <unordered_map> |
| 8 | 25 |
| 9 namespace | 26 namespace |
| 10 { | 27 { |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 64 | 81 |
| 65 // ENTRY POINT | 82 // ENTRY POINT |
| 66 STDMETHODIMP CPluginUserSettings::QueryInterface(REFIID riid, void **ppvObj) | 83 STDMETHODIMP CPluginUserSettings::QueryInterface(REFIID riid, void **ppvObj) |
| 67 { | 84 { |
| 68 if (!ppvObj) | 85 if (!ppvObj) |
| 69 { | 86 { |
| 70 return E_POINTER; | 87 return E_POINTER; |
| 71 } | 88 } |
| 72 if (riid == IID_IUnknown || riid == IID_IDispatch) // GUID comparison does not throw | 89 if (riid == IID_IUnknown || riid == IID_IDispatch) // GUID comparison does not throw |
| 73 { | 90 { |
| 74 *ppvObj = static_cast<void *>(this); | 91 *ppvObj = static_cast<void*>(this); |
| 75 return S_OK; | 92 return S_OK; |
| 76 } | 93 } |
| 77 return E_NOINTERFACE; | 94 return E_NOINTERFACE; |
| 78 } | 95 } |
| 79 | 96 |
| 80 /** | 97 /** |
| 81 * \par Limitation | 98 * \par Limitation |
| 82 * CPluginUserSettings is not allocated on the heap. | 99 * CPluginUserSettings is not allocated on the heap. |
| 83 * It appears only as a member variable in CPluginTabBase. | 100 * It appears only as a member variable in CPluginTabBase. |
| 84 * 'AddRef' and 'Release' don't need reference counting because they don't pre sent COM factories. | 101 * 'AddRef' and 'Release' don't need reference counting because they don't pre sent COM factories. |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 114 { | 131 { |
| 115 if (!name || !id) | 132 if (!name || !id) |
| 116 { | 133 { |
| 117 return E_POINTER; | 134 return E_POINTER; |
| 118 } | 135 } |
| 119 if (count != 1) | 136 if (count != 1) |
| 120 { | 137 { |
| 121 return E_FAIL; | 138 return E_FAIL; |
| 122 } | 139 } |
| 123 auto item = methodIndex.find(*name); // unordered_map::find is not declared noexcept | 140 auto item = methodIndex.find(*name); // unordered_map::find is not declared noexcept |
| 124 if (item==methodIndex.end()) | 141 if (item == methodIndex.end()) |
| 125 { | 142 { |
| 126 return DISP_E_UNKNOWNNAME; | 143 return DISP_E_UNKNOWNNAME; |
| 127 } | 144 } |
| 128 *id = item->second; | 145 *id = item->second; |
| 129 } | 146 } |
| 130 catch (...) | 147 catch (...) |
| 131 { | 148 { |
| 132 return E_FAIL; | 149 return E_FAIL; |
| 133 } | 150 } |
| 134 return S_OK; | 151 return S_OK; |
| 135 } | 152 } |
| 136 | 153 |
| 137 CStringW sGetMessage(const CString& section, const CString& key) | 154 CStringW sGetMessage(const CString& section, const CString& key) |
| 138 { | 155 { |
| 139 Dictionary* dictionary = Dictionary::GetInstance(); | 156 Dictionary* dictionary = Dictionary::GetInstance(); |
| 140 return CStringW(dictionary->Lookup(std::string(CW2A(section)), std::string(CW2 A(key))).c_str()); | 157 return CStringW(dictionary->Lookup(std::string(CW2A(section)), std::string(CW2 A(key))).c_str()); |
| 141 } | 158 } |
| 142 | 159 |
| 143 STDMETHODIMP CPluginUserSettings::Invoke(DISPID dispidMember, REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS* pDispparams, VARIANT* pVarResult, | 160 STDMETHODIMP CPluginUserSettings::Invoke(DISPID dispidMember, REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS* pDispparams, VARIANT* pVarResult, |
| 144 EXCEPINFO* pExcepinfo, UINT* pArgErr) | 161 EXCEPINFO* pExcepinfo, UINT* pArgErr) |
| 145 { | 162 { |
| 146 try | 163 try |
| 147 { | 164 { |
| 148 if (!pDispparams || !pExcepinfo) | 165 if (!pDispparams) |
|
sergei
2015/01/09 15:42:54
pExcepinfo can be nullptr, it's not an error.
Eric
2015/01/09 16:25:24
I'm mostly trying to add an exception handler in t
| |
| 149 { | 166 { |
| 150 return E_POINTER; | 167 return E_POINTER; |
| 151 } | 168 } |
| 152 if (pDispparams->cNamedArgs != 0) | 169 if (pDispparams->cNamedArgs != 0) |
| 153 { | 170 { |
| 154 return DISP_E_NONAMEDARGS; | 171 return DISP_E_NONAMEDARGS; |
| 155 } | 172 } |
| 156 CPluginSettings* settings = CPluginSettings::GetInstance(); | 173 CPluginSettings* settings = CPluginSettings::GetInstance(); |
| 157 switch (dispidMember) | 174 switch (dispidMember) |
| 158 { | 175 { |
| 159 case dispatchID_GetMessage: | 176 case dispatchID_GetMessage: |
| 160 { | 177 { |
| 161 if (pDispparams->cArgs != 2) | 178 if (pDispparams->cArgs != 2) |
| 162 { | 179 { |
| 163 return DISP_E_BADPARAMCOUNT; | 180 return DISP_E_BADPARAMCOUNT; |
| 164 } | 181 } |
| 165 if (pDispparams->rgvarg[0].vt != VT_BSTR || pDispparams->rgvarg[1].vt != VT_BSTR) | 182 if (pDispparams->rgvarg[0].vt != VT_BSTR || pDispparams->rgvarg[1].vt != VT_BSTR) |
| 166 { | 183 { |
| 167 return DISP_E_TYPEMISMATCH; | 184 return DISP_E_TYPEMISMATCH; |
| 168 } | 185 } |
| 169 if (pVarResult) | 186 if (pVarResult) |
|
sergei
2015/01/09 15:42:54
Wouldn't it better here and below to have
if (!pVa
Eric
2015/01/09 16:25:24
No. It's not an error to ignore the return value.
sergei
2015/01/30 16:01:40
What is about GetAppLocale and below? We should te
Eric
2015/02/02 14:46:39
Indeed, there were four defect where 'pVarResult'
| |
| 170 { | 187 { |
| 171 CComBSTR key = pDispparams->rgvarg[0].bstrVal; | 188 CComBSTR key = pDispparams->rgvarg[0].bstrVal; |
| 172 CComBSTR section = pDispparams->rgvarg[1].bstrVal; | 189 CComBSTR section = pDispparams->rgvarg[1].bstrVal; |
| 173 CStringW message = sGetMessage((BSTR)section, (BSTR)key); | 190 CStringW message = sGetMessage((BSTR)section, (BSTR)key); |
| 174 | 191 |
| 175 pVarResult->vt = VT_BSTR; | 192 pVarResult->vt = VT_BSTR; |
| 176 pVarResult->bstrVal = SysAllocString(message); | 193 pVarResult->bstrVal = SysAllocString(message); |
| 177 } | 194 } |
| 178 } | 195 } |
| 179 break; | 196 break; |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 191 pVarResult->lVal = static_cast<LONG>(languageList.size()); | 208 pVarResult->lVal = static_cast<LONG>(languageList.size()); |
| 192 } | 209 } |
| 193 } | 210 } |
| 194 break; | 211 break; |
| 195 case dispatchID_GetLanguageByIndex: | 212 case dispatchID_GetLanguageByIndex: |
| 196 { | 213 { |
| 197 if (pDispparams->cArgs != 1) | 214 if (pDispparams->cArgs != 1) |
| 198 { | 215 { |
| 199 return DISP_E_BADPARAMCOUNT; | 216 return DISP_E_BADPARAMCOUNT; |
| 200 } | 217 } |
| 201 if (VT_I4 != pDispparams->rgvarg[0].vt) | 218 if (pDispparams->rgvarg[0].vt != VT_I4) |
| 202 { | 219 { |
| 203 return DISP_E_TYPEMISMATCH; | 220 return DISP_E_TYPEMISMATCH; |
| 204 } | 221 } |
| 205 if (pVarResult) | 222 if (pVarResult) |
| 206 { | 223 { |
| 207 int indx = pDispparams->rgvarg[0].lVal; | 224 int index = pDispparams->rgvarg[0].lVal; |
| 208 | 225 |
| 209 std::map<CString, CString> languageTitleList = settings->GetFilterLang uageTitleList(); | 226 std::map<CString, CString> languageTitleList = settings->GetFilterLang uageTitleList(); |
| 210 | 227 |
| 211 if (indx < 0 || indx >= (int)languageTitleList.size()) | 228 if (index < 0 || index >= static_cast<int>(languageTitleList.size()) ) |
| 212 return DISP_E_EXCEPTION; | 229 return DISP_E_EXCEPTION; |
| 213 | 230 |
| 214 CString language; | 231 CString language; |
| 215 | 232 |
| 216 int curIndx = 0; | 233 int loopIndex = 0; |
| 217 for(std::map<CString, CString>::const_iterator it = languageTitleList. begin(); it != languageTitleList.end(); ++it) | 234 for (std::map<CString, CString>::const_iterator it = languageTitleList .begin(); it != languageTitleList.end(); ++it) |
| 218 { | 235 { |
| 219 if (curIndx == indx) | 236 if (loopIndex == index) |
| 220 { | 237 { |
| 221 language = it->first; | 238 language = it->first; |
| 222 break; | 239 break; |
| 223 } | 240 } |
| 224 curIndx++; | 241 ++loopIndex; |
| 225 } | 242 } |
| 226 | 243 |
| 227 pVarResult->vt = VT_BSTR; | 244 pVarResult->vt = VT_BSTR; |
| 228 pVarResult->bstrVal = SysAllocString(language); | 245 pVarResult->bstrVal = SysAllocString(language); |
| 229 } | 246 } |
| 230 } | 247 } |
| 231 break; | 248 break; |
| 232 case dispatchID_GetLanguageTitleByIndex: | 249 case dispatchID_GetLanguageTitleByIndex: |
| 233 { | 250 { |
| 234 if (pDispparams->cArgs != 1) | 251 if (pDispparams->cArgs != 1) |
| 235 { | 252 { |
| 236 return DISP_E_BADPARAMCOUNT; | 253 return DISP_E_BADPARAMCOUNT; |
| 237 } | 254 } |
| 238 if (VT_I4 != pDispparams->rgvarg[0].vt) | 255 if (pDispparams->rgvarg[0].vt != VT_I4) |
| 239 { | 256 { |
| 240 return DISP_E_TYPEMISMATCH; | 257 return DISP_E_TYPEMISMATCH; |
| 241 } | 258 } |
| 242 if (pVarResult) | 259 if (pVarResult) |
| 243 { | 260 { |
| 244 int indx = pDispparams->rgvarg[0].lVal; | 261 int index = pDispparams->rgvarg[0].lVal; |
| 245 | 262 |
| 246 std::map<CString, CString> languageTitleList = settings->GetFilterLang uageTitleList(); | 263 std::map<CString, CString> languageTitleList = settings->GetFilterLang uageTitleList(); |
| 247 | 264 |
| 248 if (indx < 0 || indx >= (int)languageTitleList.size()) | 265 if (index < 0 || index >= static_cast<int>(languageTitleList.size()) ) |
| 249 return DISP_E_EXCEPTION; | 266 return DISP_E_EXCEPTION; |
| 250 | 267 |
| 251 CString languageTitle; | 268 CString languageTitle; |
| 252 | 269 |
| 253 int curIndx = 0; | 270 int loopIndex = 0; |
| 254 for(std::map<CString, CString>::const_iterator it = languageTitleList. begin(); it != languageTitleList.end(); ++it) | 271 for (std::map<CString, CString>::const_iterator it = languageTitleList .begin(); it != languageTitleList.end(); ++it) |
| 255 { | 272 { |
| 256 if (curIndx == indx) | 273 if (loopIndex == index) |
| 257 { | 274 { |
| 258 languageTitle = it->second; | 275 languageTitle = it->second; |
| 259 break; | 276 break; |
| 260 } | 277 } |
| 261 curIndx++; | 278 loopIndex++; |
| 262 } | 279 } |
| 263 | 280 |
| 264 pVarResult->vt = VT_BSTR; | 281 pVarResult->vt = VT_BSTR; |
| 265 pVarResult->bstrVal = SysAllocString(languageTitle); | 282 pVarResult->bstrVal = SysAllocString(languageTitle); |
| 266 } | 283 } |
| 267 } | 284 } |
| 268 break; | 285 break; |
| 269 case dispatchID_SetLanguage: | 286 case dispatchID_SetLanguage: |
| 270 { | 287 { |
| 271 if (pDispparams->cArgs != 1) | 288 if (pDispparams->cArgs != 1) |
| 272 { | 289 { |
| 273 return DISP_E_BADPARAMCOUNT; | 290 return DISP_E_BADPARAMCOUNT; |
| 274 } | 291 } |
| 275 if (VT_BSTR != pDispparams->rgvarg[0].vt) | 292 if (pDispparams->rgvarg[0].vt != VT_BSTR) |
| 276 { | 293 { |
| 277 return DISP_E_TYPEMISMATCH; | 294 return DISP_E_TYPEMISMATCH; |
| 278 } | 295 } |
| 279 CComBSTR url = pDispparams->rgvarg[0].bstrVal; | 296 CComBSTR url = pDispparams->rgvarg[0].bstrVal; |
| 280 settings->SetSubscription((BSTR)url); | 297 settings->SetSubscription((BSTR)url); |
| 281 } | 298 } |
| 282 break; | 299 break; |
| 283 case dispatchID_GetLanguage: | 300 case dispatchID_GetLanguage: |
| 284 { | 301 { |
| 285 if (pDispparams->cArgs != 0) | 302 if (pDispparams->cArgs != 0) |
| (...skipping 30 matching lines...) Expand all Loading... | |
| 316 pVarResult->bstrVal = SysAllocString(sWhiteList); | 333 pVarResult->bstrVal = SysAllocString(sWhiteList); |
| 317 } | 334 } |
| 318 } | 335 } |
| 319 break; | 336 break; |
| 320 case dispatchID_AddWhitelistDomain: | 337 case dispatchID_AddWhitelistDomain: |
| 321 { | 338 { |
| 322 if (pDispparams->cArgs != 1) | 339 if (pDispparams->cArgs != 1) |
| 323 { | 340 { |
| 324 return DISP_E_BADPARAMCOUNT; | 341 return DISP_E_BADPARAMCOUNT; |
| 325 } | 342 } |
| 326 if (VT_BSTR != pDispparams->rgvarg[0].vt) | 343 if (pDispparams->rgvarg[0].vt != VT_BSTR) |
| 327 { | 344 { |
| 328 return DISP_E_TYPEMISMATCH; | 345 return DISP_E_TYPEMISMATCH; |
| 329 } | 346 } |
| 330 CComBSTR domain = pDispparams->rgvarg[0].bstrVal; | 347 CComBSTR domain = pDispparams->rgvarg[0].bstrVal; |
| 331 if (domain.Length()) | 348 if (domain.Length()) |
| 332 { | 349 { |
| 333 settings->AddWhiteListedDomain((BSTR)domain); | 350 settings->AddWhiteListedDomain((BSTR)domain); |
| 334 } | 351 } |
| 335 } | 352 } |
| 336 break; | 353 break; |
| 337 case dispatchID_RemoveWhitelistDomain: | 354 case dispatchID_RemoveWhitelistDomain: |
| 338 { | 355 { |
| 339 if (pDispparams->cArgs != 1) | 356 if (pDispparams->cArgs != 1) |
| 340 { | 357 { |
| 341 return DISP_E_BADPARAMCOUNT; | 358 return DISP_E_BADPARAMCOUNT; |
| 342 } | 359 } |
| 343 if (VT_BSTR != pDispparams->rgvarg[0].vt) | 360 if (pDispparams->rgvarg[0].vt != VT_BSTR) |
| 344 { | 361 { |
| 345 return DISP_E_TYPEMISMATCH; | 362 return DISP_E_TYPEMISMATCH; |
| 346 } | 363 } |
| 347 CComBSTR domain = pDispparams->rgvarg[0].bstrVal; | 364 CComBSTR domain = pDispparams->rgvarg[0].bstrVal; |
| 348 if (domain.Length()) | 365 if (domain.Length()) |
| 349 { | 366 { |
| 350 settings->RemoveWhiteListedDomain((BSTR)domain); | 367 settings->RemoveWhiteListedDomain((BSTR)domain); |
| 351 } | 368 } |
| 352 } | 369 } |
| 353 break; | 370 break; |
| 354 case dispatchID_GetAppLocale: | 371 case dispatchID_GetAppLocale: |
| 355 { | 372 { |
| 356 if (pDispparams->cArgs != 0) | 373 if (pDispparams->cArgs != 0) |
| 357 { | 374 { |
| 358 return DISP_E_BADPARAMCOUNT; | 375 return DISP_E_BADPARAMCOUNT; |
| 359 } | 376 } |
| 360 pVarResult->vt = VT_BSTR; | 377 if (pVarResult) |
| 361 pVarResult->bstrVal = SysAllocString(settings->GetAppLocale()); | 378 { |
| 379 pVarResult->vt = VT_BSTR; | |
| 380 pVarResult->bstrVal = SysAllocString(settings->GetAppLocale()); | |
| 381 } | |
| 362 } | 382 } |
| 363 break; | 383 break; |
| 364 case dispatchID_GetDocumentationLink: | 384 case dispatchID_GetDocumentationLink: |
| 365 { | 385 { |
| 366 if (pDispparams->cArgs != 0) | 386 if (pDispparams->cArgs != 0) |
| 367 { | 387 { |
| 368 return DISP_E_BADPARAMCOUNT; | 388 return DISP_E_BADPARAMCOUNT; |
| 369 } | 389 } |
| 370 pVarResult->vt = VT_BSTR; | 390 if (pVarResult) |
| 371 pVarResult->bstrVal = SysAllocString(settings->GetDocumentationLink()); | 391 { |
| 392 pVarResult->vt = VT_BSTR; | |
| 393 pVarResult->bstrVal = SysAllocString(settings->GetDocumentationLink()) ; | |
| 394 } | |
| 372 } | 395 } |
| 373 break; | 396 break; |
| 374 case dispatchID_IsAcceptableAdsEnabled: | 397 case dispatchID_IsAcceptableAdsEnabled: |
| 375 { | 398 { |
| 376 if (pDispparams->cArgs != 0) | 399 if (pDispparams->cArgs != 0) |
| 377 { | 400 { |
| 378 return DISP_E_BADPARAMCOUNT; | 401 return DISP_E_BADPARAMCOUNT; |
| 379 } | 402 } |
| 380 pVarResult->vt = VT_BOOL; | 403 if (pVarResult) |
| 381 pVarResult->boolVal = CPluginClient::GetInstance()->IsAcceptableAdsEnabl ed() ? VARIANT_TRUE : VARIANT_FALSE; | 404 { |
| 405 pVarResult->vt = VT_BOOL; | |
| 406 pVarResult->boolVal = CPluginClient::GetInstance()->IsAcceptableAdsEna bled() ? VARIANT_TRUE : VARIANT_FALSE; | |
| 407 } | |
| 382 } | 408 } |
| 383 break; | 409 break; |
| 384 case dispatchID_SetAcceptableAdsEnabled: | 410 case dispatchID_SetAcceptableAdsEnabled: |
| 385 { | 411 { |
| 386 if (pDispparams->cArgs != 1) | 412 if (pDispparams->cArgs != 1) |
| 387 { | 413 { |
| 388 return DISP_E_BADPARAMCOUNT; | 414 return DISP_E_BADPARAMCOUNT; |
| 389 } | 415 } |
| 390 if (pDispparams->rgvarg[0].vt != VT_BOOL) | 416 if (pDispparams->rgvarg[0].vt != VT_BOOL) |
| 391 { | 417 { |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 402 client->RemoveSubscription(client->GetPref(L"subscriptions_exceptionsu rl", L"")); | 428 client->RemoveSubscription(client->GetPref(L"subscriptions_exceptionsu rl", L"")); |
| 403 } | 429 } |
| 404 } | 430 } |
| 405 break; | 431 break; |
| 406 case dispatchID_IsUpdate: | 432 case dispatchID_IsUpdate: |
| 407 { | 433 { |
| 408 if (pDispparams->cArgs != 0) | 434 if (pDispparams->cArgs != 0) |
| 409 { | 435 { |
| 410 return DISP_E_BADPARAMCOUNT; | 436 return DISP_E_BADPARAMCOUNT; |
| 411 } | 437 } |
| 412 pVarResult->vt = VT_BOOL; | 438 if (pVarResult) |
| 413 pVarResult->boolVal = CPluginClient::GetInstance()->GetPref(L"displayUpd atePage", false) ? VARIANT_TRUE : VARIANT_FALSE; | 439 { |
| 440 pVarResult->vt = VT_BOOL; | |
| 441 pVarResult->boolVal = CPluginClient::GetInstance()->GetPref(L"displayU pdatePage", false) ? VARIANT_TRUE : VARIANT_FALSE; | |
| 442 } | |
| 414 } | 443 } |
| 415 break; | 444 break; |
| 416 default: | 445 default: |
| 417 return DISP_E_MEMBERNOTFOUND; | 446 return DISP_E_MEMBERNOTFOUND; |
| 418 break; | 447 break; |
| 419 } | 448 } |
| 420 } | 449 } |
| 421 catch(...) | 450 catch (...) |
| 422 { | 451 { |
| 423 return E_FAIL; | 452 return E_FAIL; |
| 424 } | 453 } |
| 425 return S_OK; | 454 return S_OK; |
| 426 } | 455 } |
| 427 | |
| LEFT | RIGHT |