17c804472Sopenharmony_ci/* 27c804472Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 37c804472Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 47c804472Sopenharmony_ci * you may not use this file except in compliance with the License. 57c804472Sopenharmony_ci * You may obtain a copy of the License at 67c804472Sopenharmony_ci * 77c804472Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 87c804472Sopenharmony_ci * 97c804472Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 107c804472Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 117c804472Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 127c804472Sopenharmony_ci * See the License for the specific language governing permissions and 137c804472Sopenharmony_ci * limitations under the License. 147c804472Sopenharmony_ci */ 157c804472Sopenharmony_ci 167c804472Sopenharmony_ci#include "EventRunner.h" 177c804472Sopenharmony_ci 187c804472Sopenharmony_cinamespace OHOS::AppExecFwk { 197c804472Sopenharmony_ciEventRunner& EventRunner::Current() 207c804472Sopenharmony_ci{ 217c804472Sopenharmony_ci static EventRunner mainRunner; 227c804472Sopenharmony_ci return mainRunner; 237c804472Sopenharmony_ci} 247c804472Sopenharmony_ci 257c804472Sopenharmony_ciEventRunner& EventRunner::GetMainEventRunner() 267c804472Sopenharmony_ci{ 277c804472Sopenharmony_ci return Current(); 287c804472Sopenharmony_ci} 297c804472Sopenharmony_ci 307c804472Sopenharmony_civoid EventRunner::SetMainThreadId(std::thread::id id) 317c804472Sopenharmony_ci{ 327c804472Sopenharmony_ci threadId = id; 337c804472Sopenharmony_ci} 347c804472Sopenharmony_ci 357c804472Sopenharmony_cistd::thread::id EventRunner::GetThreadId() 367c804472Sopenharmony_ci{ 377c804472Sopenharmony_ci return threadId; 387c804472Sopenharmony_ci} 397c804472Sopenharmony_ci 407c804472Sopenharmony_cibool EventRunner::IsCurrentRunnerThread() 417c804472Sopenharmony_ci{ 427c804472Sopenharmony_ci return std::this_thread::get_id() == threadId; 437c804472Sopenharmony_ci} 447c804472Sopenharmony_ci 457c804472Sopenharmony_civoid EventRunner::Run() 467c804472Sopenharmony_ci{ 477c804472Sopenharmony_ci const std::chrono::steady_clock::time_point now = std::chrono::steady_clock::now(); 487c804472Sopenharmony_ci std::vector<Callback> copyTasks; 497c804472Sopenharmony_ci // Process expired tasks. 507c804472Sopenharmony_ci { 517c804472Sopenharmony_ci std::lock_guard<std::mutex> lock(mutex); 527c804472Sopenharmony_ci while (!queue.empty()) { 537c804472Sopenharmony_ci const auto& top = queue.top(); 547c804472Sopenharmony_ci // If the task at the top of task queue has not yet expired, there is nothing more to do. 557c804472Sopenharmony_ci if (top.GetTargetTime() > now) { 567c804472Sopenharmony_ci break; 577c804472Sopenharmony_ci } 587c804472Sopenharmony_ci // Only record tasks without executing them when the task queue mutex is hold. 597c804472Sopenharmony_ci copyTasks.push_back(top.GetTask()); 607c804472Sopenharmony_ci queue.pop(); 617c804472Sopenharmony_ci } 627c804472Sopenharmony_ci } 637c804472Sopenharmony_ci { 647c804472Sopenharmony_ci // Flushing tasks here without holing onto the task queue mutex. 657c804472Sopenharmony_ci for (const auto& task : copyTasks) { 667c804472Sopenharmony_ci task(); 677c804472Sopenharmony_ci } 687c804472Sopenharmony_ci } 697c804472Sopenharmony_ci} 707c804472Sopenharmony_ci 717c804472Sopenharmony_civoid EventRunner::PushTask(const Callback &callback, std::chrono::steady_clock::time_point targetTime) 727c804472Sopenharmony_ci{ 737c804472Sopenharmony_ci static size_t order = 0; 747c804472Sopenharmony_ci std::lock_guard<std::mutex> lock(mutex); 757c804472Sopenharmony_ci order++; 767c804472Sopenharmony_ci queue.push({ order, callback, targetTime }); 777c804472Sopenharmony_ci} 787c804472Sopenharmony_ci}