Chromium Code Reviews| Index: chrome/browser/process_singleton_startup_lock.h |
| diff --git a/chrome/browser/process_singleton_startup_lock.h b/chrome/browser/process_singleton_startup_lock.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..3505180f929b8adc005f0b8146bad942dbd7eafd |
| --- /dev/null |
| +++ b/chrome/browser/process_singleton_startup_lock.h |
| @@ -0,0 +1,57 @@ |
| +// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef CHROME_BROWSER_PROCESS_SINGLETON_STARTUP_LOCK_H_ |
| +#define CHROME_BROWSER_PROCESS_SINGLETON_STARTUP_LOCK_H_ |
| + |
| +#include <set> |
| +#include <utility> |
| +#include <vector> |
| + |
| +#include "base/basictypes.h" |
| +#include "base/command_line.h" |
| +#include "base/files/file_path.h" |
| +#include "base/threading/non_thread_safe.h" |
| +#include "chrome/browser/process_singleton.h" |
| + |
| +// Provides a ProcessSingleton::NotificationCallback that can queue up |
| +// command-line invocations during startup and execute them when startup |
| +// completes. |
| +// |
| +// The object starts in a locked state. |Unlock()| must be called |
| +// when the process is prepared to handle command-line invocations. |
| +// |
| +// Once unlocked, notifications are forwarded to a wrapped NotificationCallback. |
| +class ProcessSingletonStartupLock : public base::NonThreadSafe { |
| + public: |
| + explicit ProcessSingletonStartupLock( |
| + const ProcessSingleton::NotificationCallback& original_callback); |
| + ~ProcessSingletonStartupLock(); |
| + |
| + // Returns the callback that should be supplied to ProcessSingleton. |
|
gab
2013/03/28 13:45:53
I don't think this comment should state whom this
erikwright (departed)
2013/04/04 01:39:51
Done.
|
| + // The callback is only valid during the lifetime of the |
| + // ProcessSingletonStartupLock instance. |
|
gab
2013/03/28 13:45:53
I think this "validity" part of the comment is sup
erikwright (departed)
2013/04/04 01:39:51
The caller must be aware of this. It is an error t
|
| + ProcessSingleton::NotificationCallback AsNotificationCallback(); |
| + |
| + // Executes previously queued command-line invocations and allows future |
| + // invocations to be executed immediately. |
| + void Unlock(); |
| + |
| + bool locked() { return locked_; } |
| + |
| + private: |
| + typedef std::pair<CommandLine::StringVector, base::FilePath> |
| + DelayedStartupMessage; |
| + |
| + bool NotificationCallbackImpl(const CommandLine& command_line, |
| + const base::FilePath& current_directory); |
| + |
| + bool locked_; |
| + std::vector<DelayedStartupMessage> saved_startup_messages_; |
| + ProcessSingleton::NotificationCallback original_callback_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(ProcessSingletonStartupLock); |
| +}; |
| + |
| +#endif // CHROME_BROWSER_PROCESS_SINGLETON_STARTUP_LOCK_H_ |