Index: mojo/runner/scoped_user_data_dir.cc |
diff --git a/mojo/runner/scoped_user_data_dir.cc b/mojo/runner/scoped_user_data_dir.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..44d8ef326af9b99aba9c17dd21889335b221ee3b |
--- /dev/null |
+++ b/mojo/runner/scoped_user_data_dir.cc |
@@ -0,0 +1,36 @@ |
+// Copyright 2015 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. |
+ |
+#include "mojo/runner/scoped_user_data_dir.h" |
+ |
+#include "base/command_line.h" |
+#include "base/logging.h" |
+#include "mojo/runner/switches.h" |
+ |
+namespace mojo { |
+namespace runner { |
+ |
+ScopedUserDataDir::ScopedUserDataDir() { |
+ base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); |
+ if (command_line->HasSwitch(switches::kUseTemporaryUserDataDir)) { |
+ if (command_line->HasSwitch(switches::kUserDataDir)) { |
+ LOG(ERROR) << "Can not have both --user-data-dir and " |
+ << "--use-temporary-user-data-dir in the same process."; |
+ return; |
+ } |
+ |
+ if (!temp_dir_.CreateUniqueTempDir()) { |
+ LOG(ERROR) << "Failed to create a temporary user data dir."; |
+ return; |
+ } |
+ |
+ command_line->AppendSwitchPath(switches::kUserDataDir, temp_dir_.path()); |
msw
2015/06/24 23:00:35
Heh, the irony here is that you're appending --use
|
+ } |
+} |
+ |
+ScopedUserDataDir::~ScopedUserDataDir() { |
+} |
+ |
+} // namespace runner |
+} // namespace mojo |