Fix device description leak (#2758)

* Fix device description leak

* Update CHANGELOG.md

---------

Co-authored-by: Xiaopeng Li <lixiaopeng.jetspark@bytedance.com>
This commit is contained in:
Xiaopeng Li 2023-05-08 22:58:34 +08:00 committed by GitHub
parent 25c4e2e451
commit 92592ec605
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 18 additions and 13 deletions

View file

@ -24,6 +24,7 @@ And please only add new entries to the top of this list, right below the `# Unre
- On macOS, fix empty marked text blocking regular input. - On macOS, fix empty marked text blocking regular input.
- On macOS, fix potential panic when getting refresh rate. - On macOS, fix potential panic when getting refresh rate.
- On macOS, fix crash when calling `Window::set_ime_position` from another thread. - On macOS, fix crash when calling `Window::set_ime_position` from another thread.
- On macOS, fixed memory leak when getting monitor handle.
# 0.28.3 # 0.28.3

View file

@ -39,6 +39,9 @@ extern_methods!(
} }
pub fn display_id(&self) -> u32 { pub fn display_id(&self) -> u32 {
let key = ns_string!("NSScreenNumber");
objc2::rc::autoreleasepool(|_| {
let device_description = self.deviceDescription(); let device_description = self.deviceDescription();
// Retrieve the CGDirectDisplayID associated with this screen // Retrieve the CGDirectDisplayID associated with this screen
@ -47,13 +50,14 @@ extern_methods!(
// to be an NSNumber. See documentation for `deviceDescription` for details: // to be an NSNumber. See documentation for `deviceDescription` for details:
// <https://developer.apple.com/documentation/appkit/nsscreen/1388360-devicedescription?language=objc> // <https://developer.apple.com/documentation/appkit/nsscreen/1388360-devicedescription?language=objc>
let obj = device_description let obj = device_description
.get(ns_string!("NSScreenNumber")) .get(key)
.expect("failed getting screen display id from device description"); .expect("failed getting screen display id from device description");
let obj: *const Object = obj; let obj: *const Object = obj;
let obj: *const NSNumber = obj.cast(); let obj: *const NSNumber = obj.cast();
let obj: &NSNumber = unsafe { &*obj }; let obj: &NSNumber = unsafe { &*obj };
obj.as_u32() obj.as_u32()
})
} }
#[sel(backingScaleFactor)] #[sel(backingScaleFactor)]