0
Files
src/content/browser/startup_task_runner.h
Avi Drissman 4e1b7bc33d Update copyright headers in content/
The methodology used to generate this CL is documented in
https://crbug.com/1098010#c34.

No-Try: true
No-Presubmit: true
Bug: 1098010
Change-Id: I8c0f009d16350271f07d8e5e561085822cc9dd27
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3895935
Owners-Override: Avi Drissman <avi@chromium.org>
Reviewed-by: Mark Mentovai <mark@chromium.org>
Commit-Queue: Mark Mentovai <mark@chromium.org>
Auto-Submit: Avi Drissman <avi@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1047456}
2022-09-15 14:03:50 +00:00

73 lines
2.5 KiB
C++

// 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/callback.h"
#include "base/task/single_thread_task_runner.h"
#include "base/time/time.h"
#include "content/common/content_export.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.
using StartupTask = base::OnceCallback<int(void)>;
// 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 {
public:
// Constructor: Note that |startup_complete_callback| is optional. If it is
// not null it will be called once all the startup tasks have run.
StartupTaskRunner(base::OnceCallback<void(int)> startup_complete_callback,
scoped_refptr<base::SingleThreadTaskRunner> proxy);
StartupTaskRunner(const StartupTaskRunner&) = delete;
StartupTaskRunner& operator=(const StartupTaskRunner&) = delete;
~StartupTaskRunner();
// Add a task to the queue of startup tasks to be run.
void AddTask(StartupTask callback);
// Start running the tasks asynchronously.
void StartRunningTasksAsync();
// Run all tasks, or all remaining tasks, synchronously
void RunAllTasksNow();
private:
friend class base::RefCounted<StartupTaskRunner>;
std::list<StartupTask> task_list_;
void WrappedTask();
base::OnceCallback<void(int)> startup_complete_callback_;
// Stores the time that the last post of a WrappedTask occurred. Used for
// gathering metrics.
base::TimeTicks last_wrapped_task_post_time_;
scoped_refptr<base::SingleThreadTaskRunner> proxy_;
};
} // namespace content
#endif // CONTENT_BROWSER_STARTUP_TASK_RUNNER_H_