 Chromium Code Reviews
 Chromium Code Reviews Issue 8139028:
  Add WorkerPool::PostTaskAndReply and use in DHCP code.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src
    
  
    Issue 8139028:
  Add WorkerPool::PostTaskAndReply and use in DHCP code.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src| Index: base/message_loop_proxy.cc | 
| diff --git a/base/message_loop_proxy.cc b/base/message_loop_proxy.cc | 
| index c8217042fe6a540c2df3309d59a3caf7c1a389a2..3ff7b0f3c9e73e3b7e196b5135bf1341ef78113d 100644 | 
| --- a/base/message_loop_proxy.cc | 
| +++ b/base/message_loop_proxy.cc | 
| @@ -6,63 +6,26 @@ | 
| #include "base/bind.h" | 
| #include "base/location.h" | 
| +#include "base/threading/post_task_and_reply_impl.h" | 
| namespace base { | 
| namespace { | 
| -// This relay class remembers the MessageLoop that it was created on, and | 
| -// ensures that both the |task| and |reply| Closures are deleted on this same | 
| -// thread. Also, |task| is guaranteed to be deleted before |reply| is run or | 
| -// deleted. | 
| -// | 
| -// If this is not possible because the originating MessageLoop is no longer | 
| -// available, the the |task| and |reply| Closures are leaked. Leaking is | 
| -// considered preferable to having a thread-safetey violations caused by | 
| -// invoking the Closure destructor on the wrong thread. | 
| -class PostTaskAndReplyRelay { | 
| +class PostTaskAndReplyMessageLoopProxy : public internal::PostTaskAndReplyImpl { | 
| public: | 
| - PostTaskAndReplyRelay(const tracked_objects::Location& from_here, | 
| - const Closure& task, const Closure& reply) | 
| - : from_here_(from_here), | 
| - origin_loop_(MessageLoopProxy::current()) { | 
| - task_ = task; | 
| - reply_ = reply; | 
| + PostTaskAndReplyMessageLoopProxy(MessageLoopProxy* destination) | 
| + : destination_(destination) { | 
| } | 
| - ~PostTaskAndReplyRelay() { | 
| - DCHECK(origin_loop_->BelongsToCurrentThread()); | 
| - task_.Reset(); | 
| - reply_.Reset(); | 
| + protected: | 
| + bool PostTask(const tracked_objects::Location& from_here, | 
| 
willchan no longer on Chromium
2011/10/13 22:33:45
Please use the virtual keyword for this guy (style
 
Jói
2011/10/13 22:46:07
Done.
 | 
| + const base::Closure& task) { | 
| + return destination_->PostTask(from_here, task); | 
| } | 
| - void Run() { | 
| - task_.Run(); | 
| - origin_loop_->PostTask( | 
| - from_here_, | 
| - Bind(&PostTaskAndReplyRelay::RunReplyAndSelfDestruct, | 
| - base::Unretained(this))); | 
| - } | 
| - | 
| - private: | 
| - void RunReplyAndSelfDestruct() { | 
| - DCHECK(origin_loop_->BelongsToCurrentThread()); | 
| - | 
| - // Force |task_| to be released before |reply_| is to ensure that no one | 
| - // accidentally depends on |task_| keeping one of its arguments alive while | 
| - // |reply_| is executing. | 
| - task_.Reset(); | 
| - | 
| - reply_.Run(); | 
| - | 
| - // Cue mission impossible theme. | 
| - delete this; | 
| - } | 
| - | 
| - tracked_objects::Location from_here_; | 
| - scoped_refptr<MessageLoopProxy> origin_loop_; | 
| - Closure reply_; | 
| - Closure task_; | 
| + // Non-owning. | 
| + MessageLoopProxy* destination_; | 
| }; | 
| } // namespace | 
| @@ -77,15 +40,8 @@ bool MessageLoopProxy::PostTaskAndReply( | 
| const tracked_objects::Location& from_here, | 
| const Closure& task, | 
| const Closure& reply) { | 
| - PostTaskAndReplyRelay* relay = | 
| - new PostTaskAndReplyRelay(from_here, task, reply); | 
| - if (!PostTask(from_here, Bind(&PostTaskAndReplyRelay::Run, | 
| - Unretained(relay)))) { | 
| - delete relay; | 
| - return false; | 
| - } | 
| - | 
| - return true; | 
| + return PostTaskAndReplyMessageLoopProxy(this).PostTaskAndReply( | 
| + from_here, task, reply); | 
| } | 
| void MessageLoopProxy::OnDestruct() const { |