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