summaryrefslogtreecommitdiffstats
path: root/ipc/chromium/src/base/process_posix.cc
diff options
context:
space:
mode:
Diffstat (limited to 'ipc/chromium/src/base/process_posix.cc')
-rw-r--r--ipc/chromium/src/base/process_posix.cc62
1 files changed, 62 insertions, 0 deletions
diff --git a/ipc/chromium/src/base/process_posix.cc b/ipc/chromium/src/base/process_posix.cc
new file mode 100644
index 000000000..d8ea644c6
--- /dev/null
+++ b/ipc/chromium/src/base/process_posix.cc
@@ -0,0 +1,62 @@
+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim: set ts=8 sts=2 et sw=2 tw=80: */
+// Copyright (c) 2008 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 "base/process.h"
+#include "base/process_util.h"
+
+namespace base {
+
+void Process::Close() {
+ process_ = 0;
+ // if the process wasn't termiated (so we waited) or the state
+ // wasn't already collected w/ a wait from process_utils, we're gonna
+ // end up w/ a zombie when it does finally exit.
+}
+
+void Process::Terminate(int result_code) {
+ // result_code isn't supportable.
+ if (!process_)
+ return;
+ // We don't wait here. It's the responsibility of other code to reap the
+ // child.
+ KillProcess(process_, result_code, false);
+}
+
+bool Process::IsProcessBackgrounded() const {
+ // http://code.google.com/p/chromium/issues/detail?id=8083
+ return false;
+}
+
+bool Process::SetProcessBackgrounded(bool value) {
+ // http://code.google.com/p/chromium/issues/detail?id=8083
+ // Just say we did it to keep renderer happy at the moment. Need to finish
+ // cleaning this up w/in higher layers since windows is probably the only
+ // one that can raise priorities w/o privileges.
+ return true;
+}
+
+bool Process::EmptyWorkingSet() {
+ // http://code.google.com/p/chromium/issues/detail?id=8083
+ return false;
+}
+
+ProcessId Process::pid() const {
+ if (process_ == 0)
+ return 0;
+
+ return GetProcId(process_);
+}
+
+bool Process::is_current() const {
+ return process_ == GetCurrentProcessHandle();
+}
+
+// static
+Process Process::Current() {
+ return Process(GetCurrentProcessHandle());
+}
+
+} // namspace base