aboutsummaryrefslogtreecommitdiff
path: root/alacritty/src/display/window.rs
diff options
context:
space:
mode:
Diffstat (limited to 'alacritty/src/display/window.rs')
-rw-r--r--alacritty/src/display/window.rs28
1 files changed, 14 insertions, 14 deletions
diff --git a/alacritty/src/display/window.rs b/alacritty/src/display/window.rs
index 5f0790b6..3d6989a0 100644
--- a/alacritty/src/display/window.rs
+++ b/alacritty/src/display/window.rs
@@ -20,9 +20,8 @@ use std::fmt::{self, Display, Formatter};
#[cfg(target_os = "macos")]
use {
- cocoa::appkit::NSColorSpace,
- cocoa::base::{id, nil, NO, YES},
- objc::{msg_send, sel, sel_impl},
+ objc2_app_kit::{NSColorSpace, NSView},
+ objc2_foundation::is_main_thread,
winit::platform::macos::{OptionAsAlt, WindowAttributesExtMacOS, WindowExtMacOS},
};
@@ -451,16 +450,15 @@ impl Window {
/// This prevents rendering artifacts from showing up when the window is transparent.
#[cfg(target_os = "macos")]
pub fn set_has_shadow(&self, has_shadows: bool) {
- let ns_view = match self.raw_window_handle() {
- RawWindowHandle::AppKit(handle) => handle.ns_view.as_ptr() as id,
+ let view = match self.raw_window_handle() {
+ RawWindowHandle::AppKit(handle) => {
+ assert!(is_main_thread());
+ unsafe { handle.ns_view.cast::<NSView>().as_ref() }
+ },
_ => return,
};
- let value = if has_shadows { YES } else { NO };
- unsafe {
- let ns_window: id = msg_send![ns_view, window];
- let _: id = msg_send![ns_window, setHasShadow: value];
- }
+ view.window().unwrap().setHasShadow(has_shadows);
}
/// Select tab at the given `index`.
@@ -495,13 +493,15 @@ impl Window {
#[cfg(target_os = "macos")]
fn use_srgb_color_space(window: &WinitWindow) {
- let ns_view = match window.window_handle().unwrap().as_raw() {
- RawWindowHandle::AppKit(handle) => handle.ns_view.as_ptr() as id,
+ let view = match window.window_handle().unwrap().as_raw() {
+ RawWindowHandle::AppKit(handle) => {
+ assert!(is_main_thread());
+ unsafe { handle.ns_view.cast::<NSView>().as_ref() }
+ },
_ => return,
};
unsafe {
- let ns_window: id = msg_send![ns_view, window];
- let _: () = msg_send![ns_window, setColorSpace: NSColorSpace::sRGBColorSpace(nil)];
+ view.window().unwrap().setColorSpace(Some(&NSColorSpace::sRGBColorSpace()));
}
}