// Copyright 2013 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CONTENT_BROWSER_STARTUP_TASK_RUNNER_H_ #define CONTENT_BROWSER_STARTUP_TASK_RUNNER_H_ #include <list> #include "base/functional/callback.h" #include "base/task/single_thread_task_runner.h" #include "content/common/content_export.h" #include "base/task/single_thread_task_runner.h" #include "build/build_config.h" #include "content/public/browser/browser_main_runner.h" namespace content { // A startup task is a void function returning the status on completion. // a status of > 0 indicates a failure, and that no further startup tasks should // be run. StartupTask; // This class runs startup tasks. The tasks are either run immediately inline, // or are queued one at a time on the UI thread's message loop. If the events // are queued, UI events that are received during startup will be acted upon // between startup tasks. The motivation for this is that, on targets where the // UI is already started, it allows us to keep the UI responsive during startup. // // Note that this differs from a SingleThreadedTaskRunner in that there may be // no opportunity to handle UI events between the tasks of a // SingleThreadedTaskRunner. class CONTENT_EXPORT StartupTaskRunner { … }; } // namespace content #endif // CONTENT_BROWSER_STARTUP_TASK_RUNNER_H_