| Index: ppapi/proxy/host_dispatcher.h
|
| diff --git a/ppapi/proxy/host_dispatcher.h b/ppapi/proxy/host_dispatcher.h
|
| index c1ba15feb1144ca0691665e2094d00ea3a562fc9..3285c4a0f300cf3eaf8ba5eb62c5c82f616b92e9 100644
|
| --- a/ppapi/proxy/host_dispatcher.h
|
| +++ b/ppapi/proxy/host_dispatcher.h
|
| @@ -10,7 +10,8 @@
|
| #include <vector>
|
|
|
| #include "base/compiler_specific.h"
|
| -#include "base/memory/ref_counted.h"
|
| +#include "base/memory/weak_ptr.h"
|
| +#include "base/observer_list.h"
|
| #include "base/process/process.h"
|
| #include "ipc/message_filter.h"
|
| #include "ppapi/c/pp_instance.h"
|
| @@ -27,11 +28,13 @@ namespace proxy {
|
| class PPAPI_PROXY_EXPORT HostDispatcher : public Dispatcher {
|
| public:
|
| // This interface receives notifications about sync messages being sent by
|
| - // the dispatcher to the plugin process. It is used to detect a hung plugin.
|
| + // the dispatcher to the plugin process. Some parts of Chrome may need to
|
| + // know whether we are sending a synchronous message to the plugin; e.g. to
|
| + // detect a hung plugin or to avoid re-entering JavaScript.
|
| //
|
| // Note that there can be nested sync messages, so the begin/end status
|
| // actually represents a stack of blocking messages.
|
| - class SyncMessageStatusReceiver : public IPC::MessageFilter {
|
| + class SyncMessageStatusObserver {
|
| public:
|
| // Notification that a sync message is about to be sent out.
|
| virtual void BeginBlockOnSyncMessage() = 0;
|
| @@ -41,7 +44,7 @@ class PPAPI_PROXY_EXPORT HostDispatcher : public Dispatcher {
|
| virtual void EndBlockOnSyncMessage() = 0;
|
|
|
| protected:
|
| - virtual ~SyncMessageStatusReceiver() {}
|
| + virtual ~SyncMessageStatusObserver() {}
|
| };
|
|
|
| // Constructor for the renderer side. This will take a reference to the
|
| @@ -50,7 +53,6 @@ class PPAPI_PROXY_EXPORT HostDispatcher : public Dispatcher {
|
| // You must call InitHostWithChannel after the constructor.
|
| HostDispatcher(PP_Module module,
|
| PP_GetInterface_Func local_get_interface,
|
| - SyncMessageStatusReceiver* sync_status,
|
| const PpapiPermissions& permissions);
|
| ~HostDispatcher();
|
|
|
| @@ -102,6 +104,13 @@ class PPAPI_PROXY_EXPORT HostDispatcher : public Dispatcher {
|
| // Returns the proxy interface for talking to the implementation.
|
| const PPB_Proxy_Private* ppb_proxy() const { return ppb_proxy_; }
|
|
|
| + // Register an observer that will be invoked when the dispatcher begins
|
| + // sending a sync message and finishes sending a sync message.
|
| + // Returns a Closure that can be used to unregister the observer (the Closure
|
| + // is bound to a weak pointer, so is safe to call even after the
|
| + // HostDispatcher is gone.)
|
| + base::Closure AddSyncMessageStatusObserver(SyncMessageStatusObserver* obs);
|
| +
|
| void AddFilter(IPC::Listener* listener);
|
|
|
| protected:
|
| @@ -114,7 +123,7 @@ class PPAPI_PROXY_EXPORT HostDispatcher : public Dispatcher {
|
| const std::string& source,
|
| const std::string& value);
|
|
|
| - scoped_refptr<SyncMessageStatusReceiver> sync_status_;
|
| + void RemoveSyncMessageStatusObserver(SyncMessageStatusObserver* obs);
|
|
|
| PP_Module pp_module_;
|
|
|
| @@ -133,8 +142,12 @@ class PPAPI_PROXY_EXPORT HostDispatcher : public Dispatcher {
|
| // ultimately call back into the plugin.
|
| bool allow_plugin_reentrancy_;
|
|
|
| + ObserverList<SyncMessageStatusObserver> sync_status_observer_list_;
|
| +
|
| std::vector<IPC::Listener*> filters_;
|
|
|
| + base::WeakPtrFactory<HostDispatcher> weak_ptr_factory_;
|
| +
|
| DISALLOW_COPY_AND_ASSIGN(HostDispatcher);
|
| };
|
|
|
|
|