mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 13:31:29 +11:00
fix unnecessary cast
lint (#2596)
* fix clippy lints on Windows
* fix lints on other platforms
* a couple more
* again
* don't know what's goging on anymore
* fix examples
* comon
* how about now?
* this is getting annoying
* hmmm
* explicitly set a type
* 😢
* don't cast on x64 targets
* apply code review requests
* fix attributes on expressions
* fix ios
This commit is contained in:
parent
da7422c6e1
commit
402cbd55f9
|
@ -25,7 +25,7 @@ fn main() {
|
||||||
.with_inner_size(LogicalSize::new(200.0f32, 200.0f32))
|
.with_inner_size(LogicalSize::new(200.0f32, 200.0f32))
|
||||||
.with_position(Position::Logical(LogicalPosition::new(0.0, 0.0)))
|
.with_position(Position::Logical(LogicalPosition::new(0.0, 0.0)))
|
||||||
.with_visible(true);
|
.with_visible(true);
|
||||||
// `with_parent_window` is unsafe. Parent window must a valid window.
|
// `with_parent_window` is unsafe. Parent window must be a valid window.
|
||||||
builder = unsafe { builder.with_parent_window(Some(parent)) };
|
builder = unsafe { builder.with_parent_window(Some(parent)) };
|
||||||
let child_window = builder.build(event_loop).unwrap();
|
let child_window = builder.build(event_loop).unwrap();
|
||||||
|
|
||||||
|
@ -44,8 +44,7 @@ fn main() {
|
||||||
.build(&event_loop)
|
.build(&event_loop)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
let root = parent_window;
|
println!("parent window: {:?})", parent_window);
|
||||||
println!("parent window: {:?})", root);
|
|
||||||
|
|
||||||
event_loop.run(move |event: Event<'_, ()>, event_loop, control_flow| {
|
event_loop.run(move |event: Event<'_, ()>, event_loop, control_flow| {
|
||||||
*control_flow = ControlFlow::Wait;
|
*control_flow = ControlFlow::Wait;
|
||||||
|
@ -71,7 +70,7 @@ fn main() {
|
||||||
},
|
},
|
||||||
..
|
..
|
||||||
} => {
|
} => {
|
||||||
spawn_child_window(&root, event_loop, &mut windows);
|
spawn_child_window(&parent_window, event_loop, &mut windows);
|
||||||
}
|
}
|
||||||
_ => (),
|
_ => (),
|
||||||
}
|
}
|
||||||
|
|
14
src/dpi.rs
14
src/dpi.rs
|
@ -519,18 +519,8 @@ impl Size {
|
||||||
max.into().to_physical::<f64>(scale_factor),
|
max.into().to_physical::<f64>(scale_factor),
|
||||||
);
|
);
|
||||||
|
|
||||||
let clamp = |input: f64, min: f64, max: f64| {
|
let width = input.width.clamp(min.width, max.width);
|
||||||
if input < min {
|
let height = input.height.clamp(min.height, max.height);
|
||||||
min
|
|
||||||
} else if input > max {
|
|
||||||
max
|
|
||||||
} else {
|
|
||||||
input
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
let width = clamp(input.width, min.width, max.width);
|
|
||||||
let height = clamp(input.height, min.height, max.height);
|
|
||||||
|
|
||||||
PhysicalSize::new(width, height).into()
|
PhysicalSize::new(width, height).into()
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use std::{
|
use std::{
|
||||||
collections::{BTreeSet, VecDeque},
|
collections::{BTreeSet, VecDeque},
|
||||||
fmt,
|
fmt,
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use objc2::foundation::NSObject;
|
use objc2::foundation::NSObject;
|
||||||
use objc2::{class, declare_class, msg_send, ClassType};
|
use objc2::{class, declare_class, msg_send, ClassType};
|
||||||
|
|
||||||
|
@ -105,7 +107,6 @@ declare_class!(
|
||||||
&& scale_factor > 0.0,
|
&& scale_factor > 0.0,
|
||||||
"invalid scale_factor set on UIView",
|
"invalid scale_factor set on UIView",
|
||||||
);
|
);
|
||||||
let scale_factor = scale_factor as f64;
|
|
||||||
let bounds: CGRect = msg_send![self, bounds];
|
let bounds: CGRect = msg_send![self, bounds];
|
||||||
let screen: id = msg_send![window, screen];
|
let screen: id = msg_send![window, screen];
|
||||||
let screen_space: id = msg_send![screen, coordinateSpace];
|
let screen_space: id = msg_send![screen, coordinateSpace];
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use std::{
|
use std::{
|
||||||
collections::VecDeque,
|
collections::VecDeque,
|
||||||
ops::{Deref, DerefMut},
|
ops::{Deref, DerefMut},
|
||||||
|
|
|
@ -257,7 +257,7 @@ impl MonitorHandle {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn scale_factor(&self) -> f64 {
|
pub fn scale_factor(&self) -> f64 {
|
||||||
x11_or_wayland!(match self; MonitorHandle(m) => m.scale_factor() as f64)
|
x11_or_wayland!(match self; MonitorHandle(m) => m.scale_factor() as _)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -437,7 +437,7 @@ impl Window {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn scale_factor(&self) -> f64 {
|
pub fn scale_factor(&self) -> f64 {
|
||||||
x11_or_wayland!(match self; Window(w) => w.scale_factor() as f64)
|
x11_or_wayland!(match self; Window(w) => w.scale_factor() as _)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -57,7 +57,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
F: Fn(&Arc<UnownedWindow>) -> Ret,
|
F: Fn(&Arc<UnownedWindow>) -> Ret,
|
||||||
{
|
{
|
||||||
let mut deleted = false;
|
let mut deleted = false;
|
||||||
let window_id = WindowId(window_id as u64);
|
let window_id = WindowId(window_id as _);
|
||||||
let wt = get_xtarget(&self.target);
|
let wt = get_xtarget(&self.target);
|
||||||
let result = wt
|
let result = wt
|
||||||
.windows
|
.windows
|
||||||
|
@ -347,7 +347,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
|
|
||||||
// These are both in physical space.
|
// These are both in physical space.
|
||||||
let new_inner_size = (xev.width as u32, xev.height as u32);
|
let new_inner_size = (xev.width as u32, xev.height as u32);
|
||||||
let new_inner_position = (xev.x as i32, xev.y as i32);
|
let new_inner_position = (xev.x, xev.y);
|
||||||
|
|
||||||
let (mut resized, moved) = {
|
let (mut resized, moved) = {
|
||||||
let mut shared_state_lock = window.shared_state_lock();
|
let mut shared_state_lock = window.shared_state_lock();
|
||||||
|
@ -520,7 +520,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
|
|
||||||
// In the event that the window's been destroyed without being dropped first, we
|
// In the event that the window's been destroyed without being dropped first, we
|
||||||
// cleanup again here.
|
// cleanup again here.
|
||||||
wt.windows.borrow_mut().remove(&WindowId(window as u64));
|
wt.windows.borrow_mut().remove(&WindowId(window as _));
|
||||||
|
|
||||||
// Since all XIM stuff needs to happen from the same thread, we destroy the input
|
// Since all XIM stuff needs to happen from the same thread, we destroy the input
|
||||||
// context here instead of when dropping the window.
|
// context here instead of when dropping the window.
|
||||||
|
@ -1021,8 +1021,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
if self.window_exists(xev.event) {
|
if self.window_exists(xev.event) {
|
||||||
let id = xev.detail as u64;
|
let id = xev.detail as u64;
|
||||||
let modifiers = self.device_mod_state.modifiers();
|
let modifiers = self.device_mod_state.modifiers();
|
||||||
let location =
|
let location = PhysicalPosition::new(xev.event_x, xev.event_y);
|
||||||
PhysicalPosition::new(xev.event_x as f64, xev.event_y as f64);
|
|
||||||
|
|
||||||
// Mouse cursor position changes when touch events are received.
|
// Mouse cursor position changes when touch events are received.
|
||||||
// Only the first concurrently active touch ID moves the mouse cursor.
|
// Only the first concurrently active touch ID moves the mouse cursor.
|
||||||
|
|
|
@ -711,7 +711,7 @@ struct XExtension {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn mkwid(w: ffi::Window) -> crate::window::WindowId {
|
fn mkwid(w: ffi::Window) -> crate::window::WindowId {
|
||||||
crate::window::WindowId(crate::platform_impl::platform::WindowId(w as u64))
|
crate::window::WindowId(crate::platform_impl::platform::WindowId(w as _))
|
||||||
}
|
}
|
||||||
fn mkdid(w: c_int) -> crate::event::DeviceId {
|
fn mkdid(w: c_int) -> crate::event::DeviceId {
|
||||||
crate::event::DeviceId(crate::platform_impl::DeviceId::X(DeviceId(w)))
|
crate::event::DeviceId(crate::platform_impl::DeviceId::X(DeviceId(w)))
|
||||||
|
|
|
@ -108,6 +108,7 @@ impl std::hash::Hash for MonitorHandle {
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn mode_refresh_rate_millihertz(mode: &XRRModeInfo) -> Option<u32> {
|
pub fn mode_refresh_rate_millihertz(mode: &XRRModeInfo) -> Option<u32> {
|
||||||
if mode.dotClock > 0 && mode.hTotal > 0 && mode.vTotal > 0 {
|
if mode.dotClock > 0 && mode.hTotal > 0 && mode.vTotal > 0 {
|
||||||
|
#[allow(clippy::unnecessary_cast)]
|
||||||
Some((mode.dotClock as u64 * 1000 / (mode.hTotal as u64 * mode.vTotal as u64)) as u32)
|
Some((mode.dotClock as u64 * 1000 / (mode.hTotal as u64 * mode.vTotal as u64)) as u32)
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
|
@ -123,8 +124,8 @@ impl MonitorHandle {
|
||||||
primary: bool,
|
primary: bool,
|
||||||
) -> Option<Self> {
|
) -> Option<Self> {
|
||||||
let (name, scale_factor, video_modes) = unsafe { xconn.get_output_info(resources, crtc)? };
|
let (name, scale_factor, video_modes) = unsafe { xconn.get_output_info(resources, crtc)? };
|
||||||
let dimensions = unsafe { ((*crtc).width as u32, (*crtc).height as u32) };
|
let dimensions = unsafe { ((*crtc).width, (*crtc).height) };
|
||||||
let position = unsafe { ((*crtc).x as i32, (*crtc).y as i32) };
|
let position = unsafe { ((*crtc).x, (*crtc).y) };
|
||||||
|
|
||||||
// Get the refresh rate of the current video mode.
|
// Get the refresh rate of the current video mode.
|
||||||
let current_mode = unsafe { (*crtc).mode };
|
let current_mode = unsafe { (*crtc).mode };
|
||||||
|
@ -175,7 +176,7 @@ impl MonitorHandle {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn native_identifier(&self) -> u32 {
|
pub fn native_identifier(&self) -> u32 {
|
||||||
self.id as u32
|
self.id as _
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn size(&self) -> PhysicalSize<u32> {
|
pub fn size(&self) -> PhysicalSize<u32> {
|
||||||
|
|
|
@ -129,12 +129,12 @@ impl FrameExtentsHeuristic {
|
||||||
width.saturating_add(
|
width.saturating_add(
|
||||||
self.frame_extents
|
self.frame_extents
|
||||||
.left
|
.left
|
||||||
.saturating_add(self.frame_extents.right) as u32,
|
.saturating_add(self.frame_extents.right) as _,
|
||||||
),
|
),
|
||||||
height.saturating_add(
|
height.saturating_add(
|
||||||
self.frame_extents
|
self.frame_extents
|
||||||
.top
|
.top
|
||||||
.saturating_add(self.frame_extents.bottom) as u32,
|
.saturating_add(self.frame_extents.bottom) as _,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -198,7 +198,7 @@ impl<'a> NormalHints<'a> {
|
||||||
|
|
||||||
pub fn get_position(&self) -> Option<(i32, i32)> {
|
pub fn get_position(&self) -> Option<(i32, i32)> {
|
||||||
has_flag(self.size_hints.flags, ffi::PPosition)
|
has_flag(self.size_hints.flags, ffi::PPosition)
|
||||||
.then(|| (self.size_hints.x as i32, self.size_hints.y as i32))
|
.then(|| (self.size_hints.x, self.size_hints.y))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_resize_increments(&self) -> Option<(u32, u32)> {
|
pub fn get_resize_increments(&self) -> Option<(u32, u32)> {
|
||||||
|
|
|
@ -126,11 +126,8 @@ impl XConnection {
|
||||||
|
|
||||||
let scale_factor = match dpi_env {
|
let scale_factor = match dpi_env {
|
||||||
EnvVarDPI::Randr => calc_dpi_factor(
|
EnvVarDPI::Randr => calc_dpi_factor(
|
||||||
((*crtc).width as u32, (*crtc).height as u32),
|
((*crtc).width, (*crtc).height),
|
||||||
(
|
((*output_info).mm_width as _, (*output_info).mm_height as _),
|
||||||
(*output_info).mm_width as u64,
|
|
||||||
(*output_info).mm_height as u64,
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
EnvVarDPI::Scale(dpi_override) => {
|
EnvVarDPI::Scale(dpi_override) => {
|
||||||
if !validate_scale_factor(dpi_override) {
|
if !validate_scale_factor(dpi_override) {
|
||||||
|
@ -146,11 +143,8 @@ impl XConnection {
|
||||||
dpi / 96.
|
dpi / 96.
|
||||||
} else {
|
} else {
|
||||||
calc_dpi_factor(
|
calc_dpi_factor(
|
||||||
((*crtc).width as u32, (*crtc).height as u32),
|
((*crtc).width, (*crtc).height),
|
||||||
(
|
((*output_info).mm_width as _, (*output_info).mm_height as _),
|
||||||
(*output_info).mm_width as u64,
|
|
||||||
(*output_info).mm_height as u64,
|
|
||||||
),
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1551,14 +1551,14 @@ impl UnownedWindow {
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn id(&self) -> WindowId {
|
pub fn id(&self) -> WindowId {
|
||||||
WindowId(self.xwindow as u64)
|
WindowId(self.xwindow as _)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn request_redraw(&self) {
|
pub fn request_redraw(&self) {
|
||||||
self.redraw_sender
|
self.redraw_sender
|
||||||
.sender
|
.sender
|
||||||
.send(WindowId(self.xwindow as u64))
|
.send(WindowId(self.xwindow as _))
|
||||||
.unwrap();
|
.unwrap();
|
||||||
self.redraw_sender.waker.wake().unwrap();
|
self.redraw_sender.waker.wake().unwrap();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use std::collections::VecDeque;
|
use std::collections::VecDeque;
|
||||||
|
|
||||||
use objc2::foundation::NSObject;
|
use objc2::foundation::NSObject;
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use std::{collections::VecDeque, fmt};
|
use std::{collections::VecDeque, fmt};
|
||||||
|
|
||||||
use core_foundation::{
|
use core_foundation::{
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
mod r#async;
|
mod r#async;
|
||||||
|
|
||||||
pub(crate) use self::r#async::*;
|
pub(crate) use self::r#async::*;
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use std::{boxed::Box, collections::VecDeque, os::raw::*, ptr, str, sync::Mutex};
|
use std::{boxed::Box, collections::VecDeque, os::raw::*, ptr, str, sync::Mutex};
|
||||||
|
|
||||||
use objc2::declare::{Ivar, IvarDrop};
|
use objc2::declare::{Ivar, IvarDrop};
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use std::{
|
use std::{
|
||||||
collections::VecDeque,
|
collections::VecDeque,
|
||||||
f64, ops,
|
f64, ops,
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#![allow(clippy::unnecessary_cast)]
|
||||||
|
|
||||||
use std::ptr;
|
use std::ptr;
|
||||||
|
|
||||||
use objc2::declare::{Ivar, IvarDrop};
|
use objc2::declare::{Ivar, IvarDrop};
|
||||||
|
|
|
@ -322,8 +322,8 @@ impl<T: 'static> Shared<T> {
|
||||||
};
|
};
|
||||||
// First, we send the `ScaleFactorChanged` event:
|
// First, we send the `ScaleFactorChanged` event:
|
||||||
let current_size = crate::dpi::PhysicalSize {
|
let current_size = crate::dpi::PhysicalSize {
|
||||||
width: canvas.width() as u32,
|
width: canvas.width(),
|
||||||
height: canvas.height() as u32,
|
height: canvas.height(),
|
||||||
};
|
};
|
||||||
let logical_size = current_size.to_logical::<f64>(old_scale);
|
let logical_size = current_size.to_logical::<f64>(old_scale);
|
||||||
let mut new_size = logical_size.to_physical(new_scale);
|
let mut new_size = logical_size.to_physical(new_scale);
|
||||||
|
|
|
@ -238,16 +238,16 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
|
|
||||||
// The size to restore to after exiting fullscreen.
|
// The size to restore to after exiting fullscreen.
|
||||||
let mut intended_size = PhysicalSize {
|
let mut intended_size = PhysicalSize {
|
||||||
width: raw.width() as u32,
|
width: raw.width(),
|
||||||
height: raw.height() as u32,
|
height: raw.height(),
|
||||||
};
|
};
|
||||||
canvas.on_fullscreen_change(move || {
|
canvas.on_fullscreen_change(move || {
|
||||||
// If the canvas is marked as fullscreen, it is moving *into* fullscreen
|
// If the canvas is marked as fullscreen, it is moving *into* fullscreen
|
||||||
// If it is not, it is moving *out of* fullscreen
|
// If it is not, it is moving *out of* fullscreen
|
||||||
let new_size = if backend::is_fullscreen(&raw) {
|
let new_size = if backend::is_fullscreen(&raw) {
|
||||||
intended_size = PhysicalSize {
|
intended_size = PhysicalSize {
|
||||||
width: raw.width() as u32,
|
width: raw.width(),
|
||||||
height: raw.height() as u32,
|
height: raw.height(),
|
||||||
};
|
};
|
||||||
|
|
||||||
backend::window_size().to_physical(backend::scale_factor())
|
backend::window_size().to_physical(backend::scale_factor())
|
||||||
|
|
|
@ -65,7 +65,7 @@ pub fn get_monitor_dpi(hmonitor: HMONITOR) -> Option<u32> {
|
||||||
// MSDN says that "the values of *dpiX and *dpiY are identical. You only need to
|
// MSDN says that "the values of *dpiX and *dpiY are identical. You only need to
|
||||||
// record one of the values to determine the DPI and respond appropriately".
|
// record one of the values to determine the DPI and respond appropriately".
|
||||||
// https://msdn.microsoft.com/en-us/library/windows/desktop/dn280510(v=vs.85).aspx
|
// https://msdn.microsoft.com/en-us/library/windows/desktop/dn280510(v=vs.85).aspx
|
||||||
return Some(dpi_x as u32);
|
return Some(dpi_x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ pub unsafe fn hwnd_dpi(hwnd: HWND) -> u32 {
|
||||||
// We are on Windows 10 Anniversary Update (1607) or later.
|
// We are on Windows 10 Anniversary Update (1607) or later.
|
||||||
match GetDpiForWindow(hwnd) {
|
match GetDpiForWindow(hwnd) {
|
||||||
0 => BASE_DPI, // 0 is returned if hwnd is invalid
|
0 => BASE_DPI, // 0 is returned if hwnd is invalid
|
||||||
dpi => dpi as u32,
|
dpi => dpi,
|
||||||
}
|
}
|
||||||
} else if let Some(GetDpiForMonitor) = *GET_DPI_FOR_MONITOR {
|
} else if let Some(GetDpiForMonitor) = *GET_DPI_FOR_MONITOR {
|
||||||
// We are on Windows 8.1 or later.
|
// We are on Windows 8.1 or later.
|
||||||
|
@ -98,7 +98,7 @@ pub unsafe fn hwnd_dpi(hwnd: HWND) -> u32 {
|
||||||
let mut dpi_x = 0;
|
let mut dpi_x = 0;
|
||||||
let mut dpi_y = 0;
|
let mut dpi_y = 0;
|
||||||
if GetDpiForMonitor(monitor, MDT_EFFECTIVE_DPI, &mut dpi_x, &mut dpi_y) == S_OK {
|
if GetDpiForMonitor(monitor, MDT_EFFECTIVE_DPI, &mut dpi_x, &mut dpi_y) == S_OK {
|
||||||
dpi_x as u32
|
dpi_x
|
||||||
} else {
|
} else {
|
||||||
BASE_DPI
|
BASE_DPI
|
||||||
}
|
}
|
||||||
|
|
|
@ -169,7 +169,7 @@ impl FileDropHandler {
|
||||||
let drop_format = FORMATETC {
|
let drop_format = FORMATETC {
|
||||||
cfFormat: CF_HDROP as u16,
|
cfFormat: CF_HDROP as u16,
|
||||||
ptd: ptr::null_mut(),
|
ptd: ptr::null_mut(),
|
||||||
dwAspect: DVASPECT_CONTENT as u32,
|
dwAspect: DVASPECT_CONTENT,
|
||||||
lindex: -1,
|
lindex: -1,
|
||||||
tymed: TYMED_HGLOBAL as u32,
|
tymed: TYMED_HGLOBAL as u32,
|
||||||
};
|
};
|
||||||
|
|
|
@ -1151,8 +1151,7 @@ unsafe fn public_window_callback_inner<T: 'static>(
|
||||||
|
|
||||||
let windowpos = lparam as *const WINDOWPOS;
|
let windowpos = lparam as *const WINDOWPOS;
|
||||||
if (*windowpos).flags & SWP_NOMOVE != SWP_NOMOVE {
|
if (*windowpos).flags & SWP_NOMOVE != SWP_NOMOVE {
|
||||||
let physical_position =
|
let physical_position = PhysicalPosition::new((*windowpos).x, (*windowpos).y);
|
||||||
PhysicalPosition::new((*windowpos).x as i32, (*windowpos).y as i32);
|
|
||||||
userdata.send_event(Event::WindowEvent {
|
userdata.send_event(Event::WindowEvent {
|
||||||
window_id: RootWindowId(WindowId(window)),
|
window_id: RootWindowId(WindowId(window)),
|
||||||
event: Moved(physical_position),
|
event: Moved(physical_position),
|
||||||
|
@ -2437,7 +2436,7 @@ unsafe extern "system" fn thread_event_target_callback<T: 'static>(
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
_ if msg == *EXEC_MSG_ID => {
|
_ if msg == *EXEC_MSG_ID => {
|
||||||
let mut function: ThreadExecFn = Box::from_raw(wparam as usize as *mut _);
|
let mut function: ThreadExecFn = Box::from_raw(wparam as *mut _);
|
||||||
function();
|
function();
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,8 +90,8 @@ impl WinIcon {
|
||||||
0,
|
0,
|
||||||
wide_path.as_ptr(),
|
wide_path.as_ptr(),
|
||||||
IMAGE_ICON,
|
IMAGE_ICON,
|
||||||
width as i32,
|
width,
|
||||||
height as i32,
|
height,
|
||||||
LR_DEFAULTSIZE | LR_LOADFROMFILE,
|
LR_DEFAULTSIZE | LR_LOADFROMFILE,
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
@ -113,8 +113,8 @@ impl WinIcon {
|
||||||
util::get_instance_handle(),
|
util::get_instance_handle(),
|
||||||
resource_id as PCWSTR,
|
resource_id as PCWSTR,
|
||||||
IMAGE_ICON,
|
IMAGE_ICON,
|
||||||
width as i32,
|
width,
|
||||||
height as i32,
|
height,
|
||||||
LR_DEFAULTSIZE,
|
LR_DEFAULTSIZE,
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
|
|
@ -241,7 +241,7 @@ impl MonitorHandle {
|
||||||
i += 1;
|
i += 1;
|
||||||
|
|
||||||
const REQUIRED_FIELDS: u32 =
|
const REQUIRED_FIELDS: u32 =
|
||||||
(DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT | DM_DISPLAYFREQUENCY) as u32;
|
DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT | DM_DISPLAYFREQUENCY;
|
||||||
assert!(has_flag(mode.dmFields, REQUIRED_FIELDS));
|
assert!(has_flag(mode.dmFields, REQUIRED_FIELDS));
|
||||||
|
|
||||||
// Use Ord impl of RootVideoMode
|
// Use Ord impl of RootVideoMode
|
||||||
|
@ -249,7 +249,7 @@ impl MonitorHandle {
|
||||||
video_mode: VideoMode {
|
video_mode: VideoMode {
|
||||||
size: (mode.dmPelsWidth, mode.dmPelsHeight),
|
size: (mode.dmPelsWidth, mode.dmPelsHeight),
|
||||||
bit_depth: mode.dmBitsPerPel as u16,
|
bit_depth: mode.dmBitsPerPel as u16,
|
||||||
refresh_rate_millihertz: mode.dmDisplayFrequency as u32 * 1000,
|
refresh_rate_millihertz: mode.dmDisplayFrequency * 1000,
|
||||||
monitor: self.clone(),
|
monitor: self.clone(),
|
||||||
native_video_mode: Box::new(mode),
|
native_video_mode: Box::new(mode),
|
||||||
},
|
},
|
||||||
|
|
|
@ -140,7 +140,7 @@ impl Window {
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn outer_position(&self) -> Result<PhysicalPosition<i32>, NotSupportedError> {
|
pub fn outer_position(&self) -> Result<PhysicalPosition<i32>, NotSupportedError> {
|
||||||
util::WindowArea::Outer.get_rect(self.hwnd())
|
util::WindowArea::Outer.get_rect(self.hwnd())
|
||||||
.map(|rect| Ok(PhysicalPosition::new(rect.left as i32, rect.top as i32)))
|
.map(|rect| Ok(PhysicalPosition::new(rect.left, rect.top)))
|
||||||
.expect("Unexpected GetWindowRect failure; please report this error to https://github.com/rust-windowing/winit")
|
.expect("Unexpected GetWindowRect failure; please report this error to https://github.com/rust-windowing/winit")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -150,7 +150,7 @@ impl Window {
|
||||||
if unsafe { ClientToScreen(self.hwnd(), &mut position) } == false.into() {
|
if unsafe { ClientToScreen(self.hwnd(), &mut position) } == false.into() {
|
||||||
panic!("Unexpected ClientToScreen failure: please report this error to https://github.com/rust-windowing/winit")
|
panic!("Unexpected ClientToScreen failure: please report this error to https://github.com/rust-windowing/winit")
|
||||||
}
|
}
|
||||||
Ok(PhysicalPosition::new(position.x as i32, position.y as i32))
|
Ok(PhysicalPosition::new(position.x, position.y))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
Loading…
Reference in a new issue