Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2342)

Unified Diff: ceee/ie/plugin/bho/browser_helper_object.cc

Issue 6106004: Added loading of nested BHO. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ceee/ie/plugin/bho/browser_helper_object.h ('k') | ceee/ie/plugin/toolband/brand_specific_resources.rc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ceee/ie/plugin/bho/browser_helper_object.cc
===================================================================
--- ceee/ie/plugin/bho/browser_helper_object.cc (revision 71215)
+++ ceee/ie/plugin/bho/browser_helper_object.cc (working copy)
@@ -14,6 +14,7 @@
#include "base/json/json_reader.h"
#include "base/json/json_writer.h"
#include "base/logging.h"
+#include "base/string_split.h"
#include "base/string_util.h"
#include "base/tuple.h"
#include "base/utf_string_conversions.h"
@@ -120,6 +121,25 @@
"Refused to instantiate the BHO when the visual component is hidden.";
return E_FAIL;
}
+
+ const wchar_t* bho_list = NULL;
+ LoadString(_pModule->m_hInstResource, IDS_CEEE_NESTED_BHO_LIST,
Sigurður Ásgeirsson 2011/01/13 19:34:15 we like to ::-prefix Win32 api calls.
Vitaly Buka corp 2011/01/13 21:06:45 Done.
+ reinterpret_cast<wchar_t*>(&bho_list), 0);
+ if (bho_list == NULL) {
+ LOG(ERROR) << "Failed to load string: " << GetLastError();
+ } else {
+ std::vector<std::wstring> guids;
+ base::SplitString(bho_list, ',', &guids);
+ for (size_t i = 0; i < guids.size(); ++i) {
+ CLSID clsid;
+ base::win::ScopedComPtr<IObjectWithSite> factory;
+ if (SUCCEEDED(CLSIDFromString(guids[i].c_str(), &clsid)) &&
Sigurður Ásgeirsson 2011/01/13 19:34:15 Log on error.
Vitaly Buka corp 2011/01/13 21:06:45 Done.
+ SUCCEEDED(factory.CreateInstance(clsid))) {
+ nested_bho_.push_back(factory);
+ }
+ }
+ }
+
return S_OK;
}
@@ -128,6 +148,7 @@
// for unit testing.
broker_rpc().Disconnect();
web_browser_.Release();
+ nested_bho_.clear();
}
void BrowserHelperObject::ReportAddonTimes(const char* name,
@@ -165,7 +186,11 @@
}
STDMETHODIMP BrowserHelperObject::SetSite(IUnknown* site) {
- typedef IObjectWithSiteImpl<BrowserHelperObject> SuperSite;
+ for (size_t i = 0; i < nested_bho_.size(); ++i) {
+ HRESULT hr = nested_bho_[i]->SetSite(site);
+ LOG_IF(ERROR, FAILED(hr)) << "Failed to set site of nested BHO" <<
+ com::LogWe(hr);
+ }
// From experience, we know the site may be set multiple times.
// Let's ignore second and subsequent set or unset.
@@ -193,6 +218,7 @@
FireOnUnmappedEvent();
}
+ typedef IObjectWithSiteImpl<BrowserHelperObject> SuperSite;
HRESULT hr = SuperSite::SetSite(site);
if (FAILED(hr))
return hr;
« no previous file with comments | « ceee/ie/plugin/bho/browser_helper_object.h ('k') | ceee/ie/plugin/toolband/brand_specific_resources.rc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698