Chromium Code Reviews| Index: ceee/ie/plugin/bho/events_funnel.cc |
| =================================================================== |
| --- ceee/ie/plugin/bho/events_funnel.cc (revision 66617) |
| +++ ceee/ie/plugin/bho/events_funnel.cc (working copy) |
| @@ -7,21 +7,18 @@ |
| #include "ceee/ie/plugin/bho/events_funnel.h" |
| +#include <atlbase.h> |
| #include "base/json/json_writer.h" |
| #include "base/logging.h" |
| #include "base/values.h" |
| +#include "ceee/ie/broker/broker_rpc_client.h" |
| #include "ceee/ie/common/ceee_module_util.h" |
| -EventsFunnel::EventsFunnel(bool keep_broker_alive) |
| - : keep_broker_alive_(keep_broker_alive) { |
| - if (keep_broker_alive_) |
| - ceee_module_util::AddRefModuleWorkerThread(); |
| +EventsFunnel::EventsFunnel() { |
| } |
| EventsFunnel::~EventsFunnel() { |
| - if (keep_broker_alive_) |
| - ceee_module_util::ReleaseModuleWorkerThread(); |
| } |
| HRESULT EventsFunnel::SendEvent(const char* event_name, |
| @@ -36,7 +33,21 @@ |
| base::JSONWriter::Write(&list, false, &event_args_str); |
| } |
| - EventsFunnel thread_locker(!keep_broker_alive_); |
| - ceee_module_util::FireEventToBroker(event_name, event_args_str); |
| - return S_OK; |
| + return SendEventToBroker(event_name, event_args_str.c_str()); |
| } |
| + |
| +HRESULT EventsFunnel::SendEventToBroker(const char* event_name, |
| + const char* event_args) { |
| + if (!broker_rpc_client_.get()) { |
| + broker_rpc_client_.reset(new BrokerRpcClient()); |
| + if (!broker_rpc_client_.get()) |
| + return E_OUTOFMEMORY; |
| + HRESULT hr = BrokerRpcClient::StartServer(); |
| + if (FAILED(hr)) |
| + return hr; |
|
Sigurður Ásgeirsson
2010/11/19 18:29:30
Do you want to do broker_rpc_client_.reset() on fa
Vitaly Buka corp
2010/11/19 20:30:38
No. It is by design. It prevents from new attempts
|
| + hr = broker_rpc_client_->Connect(); |
| + if (FAILED(hr)) |
| + return hr; |
| + } |
| + return broker_rpc_client_->FireEvent(event_name, event_args); |
| +} |