Clarify ownership for NativeHandle::mHandle

Change-Id: I0835278df1aa78f10d5493d7ef2c9e4a15c0fee9
This commit is contained in:
Wonsik Kim 2014-03-20 15:42:03 +09:00
parent a2910877a6
commit c4cc584bbd
2 changed files with 15 additions and 9 deletions

View File

@ -26,9 +26,11 @@ namespace android {
class NativeHandle: public LightRefBase<NativeHandle> {
public:
// Create a refcounted wrapper around a native_handle_t.
// Create a refcounted wrapper around a native_handle_t, and declare
// whether the wrapper owns the handle (so that it should clean up the
// handle upon destruction) or not.
// If handle is NULL, no NativeHandle will be created.
static sp<NativeHandle> create(native_handle_t* handle);
static sp<NativeHandle> create(native_handle_t* handle, bool ownsHandle);
const native_handle_t* handle() const {
return mHandle;
@ -38,10 +40,11 @@ private:
// for access to the destructor
friend class LightRefBase<NativeHandle>;
NativeHandle(native_handle_t* handle);
NativeHandle(native_handle_t* handle, bool ownsHandle);
virtual ~NativeHandle();
native_handle_t* mHandle;
bool mOwnsHandle;
// non-copyable
NativeHandle(const NativeHandle&);

View File

@ -19,17 +19,20 @@
namespace android {
sp<NativeHandle> NativeHandle::create(native_handle_t* handle) {
return handle ? new NativeHandle(handle) : NULL;
sp<NativeHandle> NativeHandle::create(
native_handle_t* handle, bool ownsHandle) {
return handle ? new NativeHandle(handle, ownsHandle) : NULL;
}
NativeHandle::NativeHandle(native_handle_t* handle)
: mHandle(handle)
NativeHandle::NativeHandle(native_handle_t* handle, bool ownsHandle)
: mHandle(handle), mOwnsHandle(ownsHandle)
{}
NativeHandle::~NativeHandle() {
native_handle_close(mHandle);
native_handle_delete(mHandle);
if (mOwnsHandle) {
native_handle_close(mHandle);
native_handle_delete(mHandle);
}
}
} // namespace android