| Index: mojo/edk/system/watcher_set.h
|
| diff --git a/mojo/edk/system/watcher_set.h b/mojo/edk/system/watcher_set.h
|
| index 8ae54a1b35270faf5d3fe8fc3b753764623362c1..2b7ef2c5ac1050b9c00bbf3c97468715754525f7 100644
|
| --- a/mojo/edk/system/watcher_set.h
|
| +++ b/mojo/edk/system/watcher_set.h
|
| @@ -5,45 +5,62 @@
|
| #ifndef MOJO_EDK_SYSTEM_WATCHER_SET_H_
|
| #define MOJO_EDK_SYSTEM_WATCHER_SET_H_
|
|
|
| -#include <unordered_map>
|
| +#include <map>
|
|
|
| -#include "base/callback.h"
|
| #include "base/macros.h"
|
| #include "base/memory/ref_counted.h"
|
| +#include "base/optional.h"
|
| #include "mojo/edk/system/handle_signals_state.h"
|
| -#include "mojo/edk/system/watcher.h"
|
| -#include "mojo/public/c/system/types.h"
|
| +#include "mojo/edk/system/watcher_dispatcher.h"
|
|
|
| namespace mojo {
|
| namespace edk {
|
|
|
| -// A WatcherSet maintains a set of Watchers attached to a single handle and
|
| -// keyed on an arbitrary user context.
|
| +// A WatcherSet maintains a set of references to WatcherDispatchers to be
|
| +// notified when a handle changes state.
|
| +//
|
| +// Dispatchers which may be watched by a watcher should own a WatcherSet and
|
| +// notify it of all relevant state changes.
|
| class WatcherSet {
|
| public:
|
| - WatcherSet();
|
| + // |owner| is the Dispatcher who owns this WatcherSet.
|
| + explicit WatcherSet(Dispatcher* owner);
|
| ~WatcherSet();
|
|
|
| - // Notifies all Watchers of a state change.
|
| - void NotifyForStateChange(const HandleSignalsState& state);
|
| + // Notifies all watchers of the handle's current signals state.
|
| + void NotifyState(const HandleSignalsState& state);
|
|
|
| - // Notifies all Watchers that their watched handle has been closed.
|
| + // Notifies all watchers that this handle has been closed.
|
| void NotifyClosed();
|
|
|
| - // Adds a new watcher to watch for signals in |signals| to be satisfied or
|
| - // unsatisfiable. |current_state| is the current signals state of the
|
| - // handle being watched.
|
| - MojoResult Add(MojoHandleSignals signals,
|
| - const Watcher::WatchCallback& callback,
|
| + // Adds a new watcher+context.
|
| + MojoResult Add(const scoped_refptr<WatcherDispatcher>& watcher,
|
| uintptr_t context,
|
| const HandleSignalsState& current_state);
|
|
|
| - // Removes a watcher from the set.
|
| - MojoResult Remove(uintptr_t context);
|
| + // Removes a watcher+context.
|
| + MojoResult Remove(WatcherDispatcher* watcher, uintptr_t context);
|
|
|
| private:
|
| - // A map of watchers keyed on context value.
|
| - std::unordered_map<uintptr_t, scoped_refptr<Watcher>> watchers_;
|
| + using ContextSet = std::set<uintptr_t>;
|
| +
|
| + struct Entry {
|
| + Entry(const scoped_refptr<WatcherDispatcher>& dispatcher);
|
| + Entry(Entry&& other);
|
| + ~Entry();
|
| +
|
| + Entry& operator=(Entry&& other);
|
| +
|
| + scoped_refptr<WatcherDispatcher> dispatcher;
|
| + ContextSet contexts;
|
| +
|
| + private:
|
| + DISALLOW_COPY_AND_ASSIGN(Entry);
|
| + };
|
| +
|
| + Dispatcher* const owner_;
|
| + std::map<WatcherDispatcher*, Entry> watchers_;
|
| + base::Optional<HandleSignalsState> last_known_state_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(WatcherSet);
|
| };
|
|
|