Index: mojo/public/tests/simple_bindings_support.cc |
diff --git a/mojo/public/tests/simple_bindings_support.cc b/mojo/public/tests/simple_bindings_support.cc |
index a59a66e81d78cc8d92ac6827546afae3915baeec..979474dfe5acf289d3e42fc8742b5f13d54eecd8 100644 |
--- a/mojo/public/tests/simple_bindings_support.cc |
+++ b/mojo/public/tests/simple_bindings_support.cc |
@@ -15,52 +15,47 @@ SimpleBindingsSupport::SimpleBindingsSupport() { |
SimpleBindingsSupport::~SimpleBindingsSupport() { |
BindingsSupport::Set(NULL); |
- |
- for (WaiterList::iterator it = waiters_.begin(); it != waiters_.end(); ++it) |
- delete *it; |
} |
-BindingsSupport::AsyncWaitID SimpleBindingsSupport::AsyncWait( |
- Handle handle, |
- MojoWaitFlags flags, |
- AsyncWaitCallback* callback) { |
- Waiter* waiter = new Waiter(); |
- waiter->handle = handle; |
- waiter->flags = flags; |
- waiter->callback = callback; |
+bool SimpleBindingsSupport::AsyncWait(Handle handle, |
+ MojoWaitFlags flags, |
+ MojoDeadline deadline, |
+ AsyncWaitCallback* callback) { |
+ Waiter waiter; |
+ waiter.handle = handle; |
+ waiter.flags = flags; |
+ waiter.deadline = deadline; |
+ waiter.callback = callback; |
waiters_.push_back(waiter); |
- return waiter; |
+ return true; |
} |
-void SimpleBindingsSupport::CancelWait(AsyncWaitID async_wait_id) { |
- Waiter* waiter = static_cast<Waiter*>(async_wait_id); |
- |
- WaiterList::iterator it = waiters_.begin(); |
+void SimpleBindingsSupport::CancelWait(AsyncWaitCallback* callback) { |
+ std::list<Waiter>::iterator it = waiters_.begin(); |
while (it != waiters_.end()) { |
- if (*it == waiter) { |
- WaiterList::iterator doomed = it++; |
+ if (it->callback == callback) { |
+ std::list<Waiter>::iterator doomed = it++; |
waiters_.erase(doomed); |
} else { |
++it; |
} |
} |
- |
- delete waiter; |
} |
void SimpleBindingsSupport::Process() { |
typedef std::pair<AsyncWaitCallback*, MojoResult> Result; |
std::list<Result> results; |
- WaiterList::iterator it = waiters_.begin(); |
+ // TODO(darin): Honor given deadline. |
+ |
+ std::list<Waiter>::iterator it = waiters_.begin(); |
while (it != waiters_.end()) { |
- Waiter* waiter = *it; |
+ const Waiter& waiter = *it; |
MojoResult result; |
- if (IsReady(waiter->handle, waiter->flags, &result)) { |
- results.push_back(std::make_pair(waiter->callback, result)); |
- WaiterList::iterator doomed = it++; |
+ if (IsReady(waiter.handle, waiter.flags, &result)) { |
+ results.push_back(std::make_pair(waiter.callback, result)); |
+ std::list<Waiter>::iterator doomed = it++; |
waiters_.erase(doomed); |
- delete waiter; |
} else { |
++it; |
} |