xref: /aosp_15_r20/frameworks/native/cmds/dumpstate/TaskQueue.h (revision 38e8c45f13ce32b0dcecb25141ffecaf386fa17f)
1*38e8c45fSAndroid Build Coastguard Worker /*
2*38e8c45fSAndroid Build Coastguard Worker  * Copyright (C) 2020 The Android Open Source Project
3*38e8c45fSAndroid Build Coastguard Worker  *
4*38e8c45fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*38e8c45fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*38e8c45fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*38e8c45fSAndroid Build Coastguard Worker  *
8*38e8c45fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*38e8c45fSAndroid Build Coastguard Worker  *
10*38e8c45fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*38e8c45fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*38e8c45fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*38e8c45fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*38e8c45fSAndroid Build Coastguard Worker  * limitations under the License.
15*38e8c45fSAndroid Build Coastguard Worker  */
16*38e8c45fSAndroid Build Coastguard Worker 
17*38e8c45fSAndroid Build Coastguard Worker #ifndef FRAMEWORK_NATIVE_CMD_TASKQUEUE_H_
18*38e8c45fSAndroid Build Coastguard Worker #define FRAMEWORK_NATIVE_CMD_TASKQUEUE_H_
19*38e8c45fSAndroid Build Coastguard Worker 
20*38e8c45fSAndroid Build Coastguard Worker #include <mutex>
21*38e8c45fSAndroid Build Coastguard Worker #include <queue>
22*38e8c45fSAndroid Build Coastguard Worker 
23*38e8c45fSAndroid Build Coastguard Worker #include <android-base/macros.h>
24*38e8c45fSAndroid Build Coastguard Worker 
25*38e8c45fSAndroid Build Coastguard Worker namespace android {
26*38e8c45fSAndroid Build Coastguard Worker namespace os {
27*38e8c45fSAndroid Build Coastguard Worker namespace dumpstate {
28*38e8c45fSAndroid Build Coastguard Worker 
29*38e8c45fSAndroid Build Coastguard Worker /*
30*38e8c45fSAndroid Build Coastguard Worker  * A task queue for dumpstate to collect tasks such as adding file to the zip
31*38e8c45fSAndroid Build Coastguard Worker  * which are needed to run in a single thread. The task is a callable function
32*38e8c45fSAndroid Build Coastguard Worker  * included a cancel task boolean parameter. The TaskQueue could
33*38e8c45fSAndroid Build Coastguard Worker  * cancel the task in the destructor if the task has never been called.
34*38e8c45fSAndroid Build Coastguard Worker  */
35*38e8c45fSAndroid Build Coastguard Worker class TaskQueue {
36*38e8c45fSAndroid Build Coastguard Worker   public:
37*38e8c45fSAndroid Build Coastguard Worker     TaskQueue() = default;
38*38e8c45fSAndroid Build Coastguard Worker     ~TaskQueue();
39*38e8c45fSAndroid Build Coastguard Worker 
40*38e8c45fSAndroid Build Coastguard Worker     /*
41*38e8c45fSAndroid Build Coastguard Worker      * Adds a task into the queue.
42*38e8c45fSAndroid Build Coastguard Worker      *
43*38e8c45fSAndroid Build Coastguard Worker      * |f| Callable function to execute the task. The function must include a
44*38e8c45fSAndroid Build Coastguard Worker      *     boolean parameter for TaskQueue to notify whether the task is
45*38e8c45fSAndroid Build Coastguard Worker      *     cancelled or not.
46*38e8c45fSAndroid Build Coastguard Worker      * |args| A list of arguments.
47*38e8c45fSAndroid Build Coastguard Worker      */
add(F && f,Args &&...args)48*38e8c45fSAndroid Build Coastguard Worker     template<class F, class... Args> void add(F&& f, Args&&... args) {
49*38e8c45fSAndroid Build Coastguard Worker         auto func = std::bind(std::forward<F>(f), std::forward<Args>(args)...);
50*38e8c45fSAndroid Build Coastguard Worker         std::unique_lock lock(lock_);
51*38e8c45fSAndroid Build Coastguard Worker         tasks_.emplace([=](bool cancelled) {
52*38e8c45fSAndroid Build Coastguard Worker             std::invoke(func, cancelled);
53*38e8c45fSAndroid Build Coastguard Worker         });
54*38e8c45fSAndroid Build Coastguard Worker     }
55*38e8c45fSAndroid Build Coastguard Worker 
56*38e8c45fSAndroid Build Coastguard Worker     /*
57*38e8c45fSAndroid Build Coastguard Worker      * Invokes all tasks in the task queue.
58*38e8c45fSAndroid Build Coastguard Worker      *
59*38e8c45fSAndroid Build Coastguard Worker      * |do_cancel| true to cancel all tasks in the queue.
60*38e8c45fSAndroid Build Coastguard Worker      */
61*38e8c45fSAndroid Build Coastguard Worker     void run(bool do_cancel);
62*38e8c45fSAndroid Build Coastguard Worker 
63*38e8c45fSAndroid Build Coastguard Worker   private:
64*38e8c45fSAndroid Build Coastguard Worker     using Task = std::function<void(bool)>;
65*38e8c45fSAndroid Build Coastguard Worker 
66*38e8c45fSAndroid Build Coastguard Worker     std::mutex lock_;
67*38e8c45fSAndroid Build Coastguard Worker     std::queue<Task> tasks_;
68*38e8c45fSAndroid Build Coastguard Worker 
69*38e8c45fSAndroid Build Coastguard Worker     DISALLOW_COPY_AND_ASSIGN(TaskQueue);
70*38e8c45fSAndroid Build Coastguard Worker };
71*38e8c45fSAndroid Build Coastguard Worker 
72*38e8c45fSAndroid Build Coastguard Worker }  // namespace dumpstate
73*38e8c45fSAndroid Build Coastguard Worker }  // namespace os
74*38e8c45fSAndroid Build Coastguard Worker }  // namespace android
75*38e8c45fSAndroid Build Coastguard Worker 
76*38e8c45fSAndroid Build Coastguard Worker #endif //FRAMEWORK_NATIVE_CMD_TASKQUEUE_H_
77