Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(37)

Side by Side Diff: base/threading/post_task_and_reply_impl.h

Issue 2180953002: Support PostTaskAndReply from a sequenced task. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // This file contains the implementation shared by
6 // TaskRunner::PostTaskAndReply and WorkerPool::PostTaskAndReply.
7
8 #ifndef BASE_THREADING_POST_TASK_AND_REPLY_IMPL_H_ 5 #ifndef BASE_THREADING_POST_TASK_AND_REPLY_IMPL_H_
9 #define BASE_THREADING_POST_TASK_AND_REPLY_IMPL_H_ 6 #define BASE_THREADING_POST_TASK_AND_REPLY_IMPL_H_
10 7
8 #include "base/base_export.h"
11 #include "base/callback_forward.h" 9 #include "base/callback_forward.h"
12 #include "base/location.h" 10 #include "base/location.h"
13 11
14 namespace base { 12 namespace base {
15 namespace internal { 13 namespace internal {
16 14
17 // Inherit from this in a class that implements PostTask appropriately 15 using PostTaskCallback =
18 // for sending to a destination thread. 16 Callback<bool(const tracked_objects::Location&, const Closure& task)>;
19 //
20 // Note that 'reply' will always get posted back to your current
21 // MessageLoop.
22 //
23 // If you're looking for a concrete implementation of
24 // PostTaskAndReply, you probably want base::SingleThreadTaskRunner, or you
25 // may want base::WorkerPool.
26 class PostTaskAndReplyImpl {
27 public:
28 virtual ~PostTaskAndReplyImpl() = default;
29 17
30 // Implementation for TaskRunner::PostTaskAndReply and 18 // Posts |task| via |post_task_callback|. Then, when |task| completes its
31 // WorkerPool::PostTaskAndReply. 19 // execution, posts |reply| to the sequence from which this function was
32 bool PostTaskAndReply(const tracked_objects::Location& from_here, 20 // invoked. Can only be called when SequencedTaskRunnerHandle::IsSet().
gab 2016/07/25 17:57:44 Indeed, this was also the conclusion from https://
fdoray 2016/07/25 20:40:04 PostTaskAndReply() doesn't have to be called on a
33 const Closure& task, 21 bool BASE_EXPORT PostTaskAndReply(const tracked_objects::Location& from_here,
34 const Closure& reply); 22 const Closure& task,
35 23 const Closure& reply,
36 private: 24 const PostTaskCallback& post_task_callback);
37 virtual bool PostTask(const tracked_objects::Location& from_here,
38 const Closure& task) = 0;
39 };
40 25
41 } // namespace internal 26 } // namespace internal
42 } // namespace base 27 } // namespace base
43 28
44 #endif // BASE_THREADING_POST_TASK_AND_REPLY_IMPL_H_ 29 #endif // BASE_THREADING_POST_TASK_AND_REPLY_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698