OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef MOJO_EDK_EMBEDDER_SCOPED_PLATFORM_HANDLE_H_ | 5 #ifndef MOJO_EDK_EMBEDDER_SCOPED_PLATFORM_HANDLE_H_ |
6 #define MOJO_EDK_EMBEDDER_SCOPED_PLATFORM_HANDLE_H_ | 6 #define MOJO_EDK_EMBEDDER_SCOPED_PLATFORM_HANDLE_H_ |
7 | 7 |
8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
9 #include "base/move.h" | 9 #include "base/move.h" |
10 #include "mojo/edk/embedder/platform_handle.h" | 10 #include "mojo/edk/embedder/platform_handle.h" |
11 #include "mojo/edk/system/system_impl_export.h" | 11 #include "mojo/edk/system/system_impl_export.h" |
12 | 12 |
13 namespace mojo { | 13 namespace mojo { |
14 namespace embedder { | 14 namespace embedder { |
15 | 15 |
16 class MOJO_SYSTEM_IMPL_EXPORT ScopedPlatformHandle { | 16 class MOJO_SYSTEM_IMPL_EXPORT ScopedPlatformHandle { |
17 MOVE_ONLY_TYPE_FOR_CPP_03(ScopedPlatformHandle, RValue) | 17 MOVE_ONLY_TYPE_WITH_MOVE_CONSTRUCTOR_FOR_CPP_03(ScopedPlatformHandle) |
18 | 18 |
19 public: | 19 public: |
20 ScopedPlatformHandle() {} | 20 ScopedPlatformHandle() {} |
21 explicit ScopedPlatformHandle(PlatformHandle handle) : handle_(handle) {} | 21 explicit ScopedPlatformHandle(PlatformHandle handle) : handle_(handle) {} |
22 ~ScopedPlatformHandle() { handle_.CloseIfNecessary(); } | 22 ~ScopedPlatformHandle() { handle_.CloseIfNecessary(); } |
23 | 23 |
24 // Move-only constructor and operator=. | 24 // Move-only constructor and operator=. |
25 ScopedPlatformHandle(RValue other) : handle_(other.object->release()) {} | 25 ScopedPlatformHandle(ScopedPlatformHandle&& other) |
26 ScopedPlatformHandle& operator=(RValue other) { | 26 : handle_(other.release()) {} |
27 handle_ = other.object->release(); | 27 ScopedPlatformHandle& operator=(ScopedPlatformHandle&& other) { |
28 handle_ = other.release(); | |
jamesr
2015/04/03 17:02:45
this operator is incorrect, it doesn't handle self
mgraczyk
2015/04/03 18:30:00
Care to elaborate?
Here's how I see it. The requi
jamesr
2015/04/03 19:18:23
Hmm, good point but I think having an idiomaticall
mgraczyk
2015/04/03 19:33:39
I agree and added the check.
Although, too many "
| |
28 return *this; | 29 return *this; |
29 } | 30 } |
30 | 31 |
31 const PlatformHandle& get() const { return handle_; } | 32 const PlatformHandle& get() const { return handle_; } |
32 | 33 |
33 void swap(ScopedPlatformHandle& other) { | 34 void swap(ScopedPlatformHandle& other) { |
34 PlatformHandle temp = handle_; | 35 PlatformHandle temp = handle_; |
35 handle_ = other.handle_; | 36 handle_ = other.handle_; |
36 other.handle_ = temp; | 37 other.handle_ = temp; |
37 } | 38 } |
(...skipping 12 matching lines...) Expand all Loading... | |
50 bool is_valid() const { return handle_.is_valid(); } | 51 bool is_valid() const { return handle_.is_valid(); } |
51 | 52 |
52 private: | 53 private: |
53 PlatformHandle handle_; | 54 PlatformHandle handle_; |
54 }; | 55 }; |
55 | 56 |
56 } // namespace embedder | 57 } // namespace embedder |
57 } // namespace mojo | 58 } // namespace mojo |
58 | 59 |
59 #endif // MOJO_EDK_EMBEDDER_SCOPED_PLATFORM_HANDLE_H_ | 60 #endif // MOJO_EDK_EMBEDDER_SCOPED_PLATFORM_HANDLE_H_ |
OLD | NEW |