Index: base/memory/shared_memory_handle_mac.cc |
diff --git a/base/memory/shared_memory_handle_mac.cc b/base/memory/shared_memory_handle_mac.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..d2ecdb62f61748036dc07a83801b2aad7ea5d39e |
--- /dev/null |
+++ b/base/memory/shared_memory_handle_mac.cc |
@@ -0,0 +1,78 @@ |
+// 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 "base/memory/shared_memory_handle.h" |
+ |
+#include <unistd.h> |
Tom Sepez
2015/06/17 18:51:55
nit: system includes come first.
erikchen
2015/06/18 17:58:33
In the base/ module (and I think most of chrome),
|
+ |
+#include "base/posix/eintr_wrapper.h" |
+ |
+#if defined(OS_MACOSX) && !defined(OS_IOS) |
+namespace base { |
+ |
+SharedMemoryHandle::SharedMemoryHandle() : type_(POSIX), file_descriptor_() { |
+} |
+ |
+SharedMemoryHandle::SharedMemoryHandle(const FileDescriptor& file_descriptor) |
+ : type_(POSIX), file_descriptor_(file_descriptor) { |
+} |
+ |
+SharedMemoryHandle::SharedMemoryHandle(int fd, bool auto_close) |
+ : type_(POSIX), file_descriptor_(fd, auto_close) { |
+} |
+ |
+SharedMemoryHandle::SharedMemoryHandle(const SharedMemoryHandle& handle) |
+ : type_(handle.type_), file_descriptor_(handle.file_descriptor_) { |
+} |
+ |
+SharedMemoryHandle& SharedMemoryHandle::operator=( |
+ const SharedMemoryHandle& handle) { |
+ type_ = handle.type_; |
Tom Sepez
2015/06/17 18:51:55
Does this make sense? Do you want to dup the file
erikchen
2015/06/18 17:58:33
Added the check to compare "this" and "&handle".
|
+ file_descriptor_ = handle.file_descriptor_; |
+ return *this; |
+} |
+ |
+bool SharedMemoryHandle::operator==(const SharedMemoryHandle& handle) const { |
+ return type_ == handle.type_ && file_descriptor_ == handle.file_descriptor_; |
+} |
+ |
+bool SharedMemoryHandle::operator!=(const SharedMemoryHandle& handle) const { |
+ return !operator==(handle); |
+} |
Tom Sepez
2015/06/17 18:51:55
nit: typically avoid invoking operators directly,
erikchen
2015/06/18 17:58:33
Done.
|
+ |
+SharedMemoryHandle::Type SharedMemoryHandle::GetType() const { |
+ return type_; |
+} |
+ |
+void SharedMemoryHandle::SetType(SharedMemoryHandle::Type type) { |
+ DCHECK(type == POSIX || type == MACH); |
+ type_ = type; |
+} |
+ |
+void SharedMemoryHandle::SetFileHandle(int fd, bool auto_close) { |
+ DCHECK_EQ(type_, POSIX); |
+ file_descriptor_.fd = fd; |
+ file_descriptor_.auto_close = auto_close; |
+} |
+ |
+FileDescriptor* SharedMemoryHandle::GetFileDescriptor() { |
+ DCHECK_EQ(type_, POSIX); |
+ return &file_descriptor_; |
+} |
+ |
+const FileDescriptor* SharedMemoryHandle::GetFileDescriptor() const { |
+ DCHECK_EQ(type_, POSIX); |
+ return &file_descriptor_; |
+} |
+ |
+SharedMemoryHandle SharedMemoryHandle::Duplicate() const { |
+ DCHECK_EQ(type_, POSIX); |
+ int duped_handle = HANDLE_EINTR(dup(file_descriptor_.fd)); |
+ if (duped_handle < 0) |
+ return SharedMemoryHandle(); |
+ return SharedMemoryHandle(duped_handle, true); |
+} |
+ |
+} // namespace base |
+#endif // defined(OS_MACOSX) && !defined(OS_IOS) |