diff --git a/ndk/CHANGELOG.md b/ndk/CHANGELOG.md index 0368edf8..2e4a0c00 100644 --- a/ndk/CHANGELOG.md +++ b/ndk/CHANGELOG.md @@ -1,5 +1,7 @@ # Unreleased +- ndk/native_window: Use `release`/`acquire` for `Drop` and `Clone` respectively + # 0.5.0 (2021-11-22) - **Breaking:** Replace `add_fd_with_callback` `ident` with constant value `ALOOPER_POLL_CALLBACK`, diff --git a/ndk/src/native_window.rs b/ndk/src/native_window.rs index 05de25cb..c2c4f2e2 100644 --- a/ndk/src/native_window.rs +++ b/ndk/src/native_window.rs @@ -1,7 +1,7 @@ -//! Bindings for `ANativeWindow` +//! Bindings for [`ffi::ANativeWindow`] use std::ptr::NonNull; -#[derive(Clone, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)] +#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)] pub struct NativeWindow { ptr: NonNull, } @@ -9,9 +9,24 @@ pub struct NativeWindow { unsafe impl Send for NativeWindow {} unsafe impl Sync for NativeWindow {} +impl Drop for NativeWindow { + fn drop(&mut self) { + unsafe { ffi::ANativeWindow_release(self.ptr.as_ptr()) } + } +} + +impl Clone for NativeWindow { + fn clone(&self) -> Self { + unsafe { + ffi::ANativeWindow_acquire(self.ptr.as_ptr()); + Self { ptr: self.ptr } + } + } +} + impl NativeWindow { /// # Safety - /// `ptr` must be a valid pointer to an Android `ANativeWindow`. + /// `ptr` must be a valid pointer to an Android [`ffi::ANativeWindow`]. pub unsafe fn from_ptr(ptr: NonNull) -> Self { Self { ptr } }