aboutsummaryrefslogtreecommitdiff
path: root/alacritty/src
diff options
context:
space:
mode:
authorMads Marquart <mads@marquart.dk>2024-11-21 01:36:25 +0100
committerGitHub <noreply@github.com>2024-11-21 00:36:25 +0000
commit4f739a7e2b933f6828ebf64654c8a8c573bf0ec1 (patch)
tree895bc8798df5d6f517a45243b7fd2752141abf0b /alacritty/src
parent1063706f8e8a84139e5d2b464a4978e9d840ea17 (diff)
downloadr-alacritty-4f739a7e2b933f6828ebf64654c8a8c573bf0ec1.tar.gz
r-alacritty-4f739a7e2b933f6828ebf64654c8a8c573bf0ec1.tar.bz2
r-alacritty-4f739a7e2b933f6828ebf64654c8a8c573bf0ec1.zip
Switch to new objc2 crates
Diffstat (limited to 'alacritty/src')
-rw-r--r--alacritty/src/display/window.rs28
-rw-r--r--alacritty/src/macos/locale.rs56
2 files changed, 31 insertions, 53 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()));
}
}
diff --git a/alacritty/src/macos/locale.rs b/alacritty/src/macos/locale.rs
index 2a47ace8..46996515 100644
--- a/alacritty/src/macos/locale.rs
+++ b/alacritty/src/macos/locale.rs
@@ -1,13 +1,12 @@
#![allow(clippy::let_unit_value)]
use std::ffi::{CStr, CString};
-use std::os::raw::c_char;
-use std::{env, slice, str};
+use std::{env, str};
use libc::{setlocale, LC_ALL, LC_CTYPE};
use log::debug;
-use objc::runtime::{Class, Object};
-use objc::{msg_send, sel, sel_impl};
+use objc2::sel;
+use objc2_foundation::{NSLocale, NSObjectProtocol};
const FALLBACK_LOCALE: &str = "UTF-8";
@@ -50,9 +49,7 @@ pub fn set_locale_environment() {
/// Determine system locale based on language and country code.
fn system_locale() -> String {
unsafe {
- let locale_class = Class::get("NSLocale").unwrap();
- let locale: *const Object = msg_send![locale_class, currentLocale];
- let _: () = msg_send![locale_class, release];
+ let locale = NSLocale::currentLocale();
// `localeIdentifier` returns extra metadata with the locale (including currency and
// collator) on newer versions of macOS. This is not a valid locale, so we use
@@ -61,38 +58,19 @@ fn system_locale() -> String {
// https://developer.apple.com/documentation/foundation/nslocale/1416263-localeidentifier?language=objc
// https://developer.apple.com/documentation/foundation/nslocale/1643060-countrycode?language=objc
// https://developer.apple.com/documentation/foundation/nslocale/1643026-languagecode?language=objc
- let is_language_code_supported: bool =
- msg_send![locale, respondsToSelector: sel!(languageCode)];
- let is_country_code_supported: bool =
- msg_send![locale, respondsToSelector: sel!(countryCode)];
- let locale_id = if is_language_code_supported && is_country_code_supported {
- let language_code: *const Object = msg_send![locale, languageCode];
- let language_code_str = nsstring_as_str(language_code).to_owned();
- let _: () = msg_send![language_code, release];
-
- let country_code: *const Object = msg_send![locale, countryCode];
- let country_code_str = nsstring_as_str(country_code).to_owned();
- let _: () = msg_send![country_code, release];
-
- format!("{}_{}.UTF-8", &language_code_str, &country_code_str)
+ let is_language_code_supported: bool = locale.respondsToSelector(sel!(languageCode));
+ let is_country_code_supported: bool = locale.respondsToSelector(sel!(countryCode));
+ if is_language_code_supported && is_country_code_supported {
+ let language_code = locale.languageCode();
+ #[allow(deprecated)]
+ if let Some(country_code) = locale.countryCode() {
+ format!("{}_{}.UTF-8", language_code, country_code)
+ } else {
+ // Fall back to en_US in case the country code is not available.
+ "en_US.UTF-8".into()
+ }
} else {
- let identifier: *const Object = msg_send![locale, localeIdentifier];
- let identifier_str = nsstring_as_str(identifier).to_owned();
- let _: () = msg_send![identifier, release];
-
- identifier_str + ".UTF-8"
- };
-
- let _: () = msg_send![locale, release];
-
- locale_id
+ locale.localeIdentifier().to_string() + ".UTF-8"
+ }
}
}
-
-const UTF8_ENCODING: usize = 4;
-
-unsafe fn nsstring_as_str<'a>(nsstring: *const Object) -> &'a str {
- let cstr: *const c_char = msg_send![nsstring, UTF8String];
- let len: usize = msg_send![nsstring, lengthOfBytesUsingEncoding: UTF8_ENCODING];
- str::from_utf8(slice::from_raw_parts(cstr as *const u8, len)).unwrap()
-}