mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 05:21:31 +11:00
iOS: Fix a few instances of UB (#2428)
* Fix iOS 32-bit * Fix a few invalid message sends on iOS
This commit is contained in:
parent
66aa6c945d
commit
a43a15b4a0
|
@ -7,6 +7,7 @@ use std::{
|
||||||
sync::mpsc::{self, Receiver, Sender},
|
sync::mpsc::{self, Receiver, Sender},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
use objc::runtime::Object;
|
||||||
use raw_window_handle::{RawDisplayHandle, UiKitDisplayHandle};
|
use raw_window_handle::{RawDisplayHandle, UiKitDisplayHandle};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
@ -113,7 +114,7 @@ impl<T: 'static> EventLoop<T> {
|
||||||
F: 'static + FnMut(Event<'_, T>, &RootEventLoopWindowTarget<T>, &mut ControlFlow),
|
F: 'static + FnMut(Event<'_, T>, &RootEventLoopWindowTarget<T>, &mut ControlFlow),
|
||||||
{
|
{
|
||||||
unsafe {
|
unsafe {
|
||||||
let application: *mut c_void = msg_send![class!(UIApplication), sharedApplication];
|
let application: *mut Object = msg_send![class!(UIApplication), sharedApplication];
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
application,
|
application,
|
||||||
ptr::null_mut(),
|
ptr::null_mut(),
|
||||||
|
|
|
@ -374,7 +374,7 @@ pub trait NSStringRust: Sized {
|
||||||
|
|
||||||
impl NSStringRust for id {
|
impl NSStringRust for id {
|
||||||
unsafe fn initWithUTF8String_(self, c_string: *const c_char) -> id {
|
unsafe fn initWithUTF8String_(self, c_string: *const c_char) -> id {
|
||||||
msg_send![self, initWithUTF8String: c_string as id]
|
msg_send![self, initWithUTF8String: c_string]
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe fn stringByAppendingString_(self, other: id) -> id {
|
unsafe fn stringByAppendingString_(self, other: id) -> id {
|
||||||
|
|
|
@ -177,7 +177,7 @@ impl MonitorHandle {
|
||||||
pub fn retained_new(uiscreen: id) -> MonitorHandle {
|
pub fn retained_new(uiscreen: id) -> MonitorHandle {
|
||||||
unsafe {
|
unsafe {
|
||||||
assert_main_thread!("`MonitorHandle` can only be cloned on the main thread on iOS");
|
assert_main_thread!("`MonitorHandle` can only be cloned on the main thread on iOS");
|
||||||
let _: () = msg_send![uiscreen, retain];
|
let _: id = msg_send![uiscreen, retain];
|
||||||
}
|
}
|
||||||
MonitorHandle {
|
MonitorHandle {
|
||||||
inner: Inner { uiscreen },
|
inner: Inner { uiscreen },
|
||||||
|
|
|
@ -262,7 +262,7 @@ unsafe fn get_view_class(root_view_class: &'static Class) -> &'static Class {
|
||||||
let scale_factor: CGFloat = msg_send![object, contentScaleFactor];
|
let scale_factor: CGFloat = msg_send![object, contentScaleFactor];
|
||||||
PhysicalPosition::from_logical::<(f64, f64), f64>(
|
PhysicalPosition::from_logical::<(f64, f64), f64>(
|
||||||
(logical_location.x as _, logical_location.y as _),
|
(logical_location.x as _, logical_location.y as _),
|
||||||
scale_factor,
|
scale_factor as f64,
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
touch_events.push(EventWrapper::StaticEvent(Event::WindowEvent {
|
touch_events.push(EventWrapper::StaticEvent(Event::WindowEvent {
|
||||||
|
|
|
@ -411,8 +411,8 @@ impl Window {
|
||||||
|
|
||||||
let frame = match window_attributes.inner_size {
|
let frame = match window_attributes.inner_size {
|
||||||
Some(dim) => {
|
Some(dim) => {
|
||||||
let scale_factor = msg_send![screen, scale];
|
let scale_factor: CGFloat = msg_send![screen, scale];
|
||||||
let size = dim.to_logical::<f64>(scale_factor);
|
let size = dim.to_logical::<f64>(scale_factor as f64);
|
||||||
CGRect {
|
CGRect {
|
||||||
origin: screen_bounds.origin,
|
origin: screen_bounds.origin,
|
||||||
size: CGSize {
|
size: CGSize {
|
||||||
|
@ -427,8 +427,8 @@ impl Window {
|
||||||
let view = view::create_view(&window_attributes, &platform_attributes, frame);
|
let view = view::create_view(&window_attributes, &platform_attributes, frame);
|
||||||
|
|
||||||
let gl_or_metal_backed = {
|
let gl_or_metal_backed = {
|
||||||
let view_class: id = msg_send![view, class];
|
let view_class: *const Class = msg_send![view, class];
|
||||||
let layer_class: id = msg_send![view_class, layerClass];
|
let layer_class: *const Class = msg_send![view_class, layerClass];
|
||||||
let is_metal: BOOL =
|
let is_metal: BOOL =
|
||||||
msg_send![layer_class, isSubclassOfClass: class!(CAMetalLayer)];
|
msg_send![layer_class, isSubclassOfClass: class!(CAMetalLayer)];
|
||||||
let is_gl: BOOL = msg_send![layer_class, isSubclassOfClass: class!(CAEAGLLayer)];
|
let is_gl: BOOL = msg_send![layer_class, isSubclassOfClass: class!(CAEAGLLayer)];
|
||||||
|
|
Loading…
Reference in a new issue