From f879bca21c7032cec64bf2c7b12bc866707be2d6 Mon Sep 17 00:00:00 2001 From: CrLF0710 Date: Tue, 18 Jun 2019 02:27:00 +0800 Subject: [PATCH] Migrate to 2018 edition. (#924) * Migrate to 2018 edition. * Use impl Iterator at one site. * Fix more rust 2018 idioms. --- Cargo.toml | 1 + examples/window_icon.rs | 2 +- src/error.rs | 10 +- src/event.rs | 6 +- src/event_loop.rs | 18 ++- src/icon.rs | 4 +- src/lib.rs | 26 +--- src/monitor.rs | 4 +- src/platform/android.rs | 10 +- src/platform/desktop.rs | 4 +- src/platform/ios.rs | 6 +- src/platform/unix.rs | 22 +-- src/platform/windows.rs | 10 +- src/platform_impl/android/mod.rs | 32 ++--- src/platform_impl/emscripten/mod.rs | 6 +- src/platform_impl/ios/app_state.rs | 18 +-- src/platform_impl/ios/event_loop.rs | 18 +-- src/platform_impl/ios/ffi.rs | 2 +- src/platform_impl/ios/mod.rs | 2 +- src/platform_impl/ios/monitor.rs | 8 +- src/platform_impl/ios/view.rs | 16 +-- src/platform_impl/ios/window.rs | 14 +- src/platform_impl/linux/mod.rs | 24 ++-- src/platform_impl/linux/wayland/event_loop.rs | 72 +++++----- src/platform_impl/linux/wayland/keyboard.rs | 18 +-- src/platform_impl/linux/wayland/mod.rs | 2 +- src/platform_impl/linux/wayland/pointer.rs | 22 +-- src/platform_impl/linux/wayland/touch.rs | 22 +-- src/platform_impl/linux/wayland/window.rs | 24 ++-- .../linux/x11/event_processor.rs | 18 +-- src/platform_impl/linux/x11/events.rs | 2 +- .../linux/x11/ime/input_method.rs | 4 +- src/platform_impl/linux/x11/mod.rs | 32 ++--- src/platform_impl/linux/x11/monitor.rs | 4 +- .../linux/x11/util/client_msg.rs | 6 +- src/platform_impl/linux/x11/util/geometry.rs | 2 +- src/platform_impl/linux/x11/util/hint.rs | 8 +- src/platform_impl/linux/x11/util/icon.rs | 2 +- src/platform_impl/linux/x11/util/input.rs | 10 +- src/platform_impl/linux/x11/util/memory.rs | 6 +- src/platform_impl/linux/x11/util/randr.rs | 4 +- src/platform_impl/linux/x11/window.rs | 46 +++---- src/platform_impl/linux/x11/xdisplay.rs | 8 +- src/platform_impl/macos/app.rs | 4 +- src/platform_impl/macos/app_delegate.rs | 2 +- src/platform_impl/macos/app_state.rs | 6 +- src/platform_impl/macos/event.rs | 4 +- src/platform_impl/macos/event_loop.rs | 4 +- src/platform_impl/macos/mod.rs | 4 +- src/platform_impl/macos/monitor.rs | 8 +- src/platform_impl/macos/observer.rs | 2 +- src/platform_impl/macos/util/async.rs | 4 +- src/platform_impl/macos/util/cursor.rs | 2 +- src/platform_impl/macos/util/mod.rs | 6 +- src/platform_impl/macos/view.rs | 4 +- src/platform_impl/macos/window.rs | 6 +- src/platform_impl/macos/window_delegate.rs | 4 +- src/platform_impl/windows/drop_handler.rs | 16 +-- src/platform_impl/windows/event.rs | 2 +- src/platform_impl/windows/event_loop.rs | 126 +++++++++--------- src/platform_impl/windows/icon.rs | 2 +- src/platform_impl/windows/mod.rs | 4 +- src/platform_impl/windows/monitor.rs | 8 +- src/platform_impl/windows/raw_input.rs | 4 +- src/platform_impl/windows/util.rs | 2 +- src/platform_impl/windows/window.rs | 10 +- src/platform_impl/windows/window_state.rs | 14 +- src/window.rs | 16 +-- tests/send_objects.rs | 2 +- tests/serde_objects.rs | 4 +- tests/sync_object.rs | 2 +- 71 files changed, 411 insertions(+), 436 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index e66d23f6..a4b8d9fa 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -3,6 +3,7 @@ name = "winit" version = "0.19.1" authors = ["The winit contributors", "Pierre Krieger "] description = "Cross-platform window creation library." +edition = "2018" keywords = ["windowing"] license = "Apache-2.0" readme = "README.md" diff --git a/examples/window_icon.rs b/examples/window_icon.rs index 2af5a6d7..94fb048a 100644 --- a/examples/window_icon.rs +++ b/examples/window_icon.rs @@ -43,7 +43,7 @@ fn main() { match event { CloseRequested => *control_flow = ControlFlow::Exit, DroppedFile(path) => { - use image::GenericImageView; + window.set_window_icon(Some(load_icon(&path))); }, diff --git a/src/error.rs b/src/error.rs index 83c37210..55ac7290 100644 --- a/src/error.rs +++ b/src/error.rs @@ -1,7 +1,7 @@ use std::fmt; use std::error; -use platform_impl; +use crate::platform_impl; /// An error whose cause it outside Winit's control. #[derive(Debug)] @@ -55,13 +55,13 @@ macro_rules! os_error { } impl fmt::Display for OsError { - fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { formatter.pad(&format!("os error at {}:{}: {}", self.file, self.line, self.error)) } } impl fmt::Display for ExternalError { - fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { match self { ExternalError::NotSupported(e) => e.fmt(formatter), ExternalError::Os(e) => e.fmt(formatter), @@ -70,13 +70,13 @@ impl fmt::Display for ExternalError { } impl fmt::Debug for NotSupportedError { - fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { formatter.debug_struct("NotSupportedError").finish() } } impl fmt::Display for NotSupportedError { - fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { formatter.pad("the requested operation is not supported by Winit") } } diff --git a/src/event.rs b/src/event.rs index 1d1a8fb5..e8db64a0 100644 --- a/src/event.rs +++ b/src/event.rs @@ -7,9 +7,9 @@ use std::time::Instant; use std::path::PathBuf; -use dpi::{LogicalPosition, LogicalSize}; -use window::WindowId; -use platform_impl; +use crate::dpi::{LogicalPosition, LogicalSize}; +use crate::window::WindowId; +use crate::platform_impl; /// Describes a generic event. #[derive(Clone, Debug, PartialEq)] diff --git a/src/event_loop.rs b/src/event_loop.rs index 476e7ed5..f45f07b5 100644 --- a/src/event_loop.rs +++ b/src/event_loop.rs @@ -13,9 +13,9 @@ use std::{fmt, error}; use std::time::Instant; use std::ops::Deref; -use platform_impl; -use event::Event; -use monitor::{AvailableMonitorsIter, MonitorHandle}; +use crate::platform_impl; +use crate::event::Event; +use crate::monitor::{AvailableMonitorsIter, MonitorHandle}; /// Provides a way to retrieve events from the system and from the windows that were registered to /// the events loop. @@ -46,13 +46,13 @@ pub struct EventLoopWindowTarget { } impl fmt::Debug for EventLoop { - fn fmt(&self, fmtr: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, fmtr: &mut fmt::Formatter<'_>) -> fmt::Result { fmtr.pad("EventLoop { .. }") } } impl fmt::Debug for EventLoopWindowTarget { - fn fmt(&self, fmtr: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, fmtr: &mut fmt::Formatter<'_>) -> fmt::Result { fmtr.pad("EventLoopWindowTarget { .. }") } } @@ -146,10 +146,8 @@ impl EventLoop { } /// Returns the list of all the monitors available on the system. - /// - // Note: should be replaced with `-> impl Iterator` once stable. #[inline] - pub fn available_monitors(&self) -> AvailableMonitorsIter { + pub fn available_monitors(&self) -> impl Iterator { let data = self.event_loop.available_monitors(); AvailableMonitorsIter{ data: data.into_iter() } } @@ -186,7 +184,7 @@ impl EventLoopProxy { } impl fmt::Debug for EventLoopProxy { - fn fmt(&self, fmtr: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, fmtr: &mut fmt::Formatter<'_>) -> fmt::Result { fmtr.pad("EventLoopProxy { .. }") } } @@ -197,7 +195,7 @@ impl fmt::Debug for EventLoopProxy { pub struct EventLoopClosed; impl fmt::Display for EventLoopClosed { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "{}", error::Error::description(self)) } } diff --git a/src/icon.rs b/src/icon.rs index c136b63e..cc775e8f 100644 --- a/src/icon.rs +++ b/src/icon.rs @@ -31,7 +31,7 @@ pub enum BadIcon { } impl fmt::Display for BadIcon { - fn fmt(&self, formatter: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { let msg = match self { &BadIcon::ByteCountNotDivisibleBy4 { byte_count } => format!( "The length of the `rgba` argument ({:?}) isn't divisible by 4, making it impossible to interpret as 32bpp RGBA pixels.", @@ -56,7 +56,7 @@ impl Error for BadIcon { "A valid icon cannot be created from these arguments" } - fn cause(&self) -> Option<&Error> { + fn cause(&self) -> Option<&dyn Error> { Some(self) } } diff --git a/src/lib.rs b/src/lib.rs index bfacb19f..94bac120 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -75,10 +75,11 @@ //! [`LoopDestroyed`]: ./event/enum.Event.html#variant.LoopDestroyed //! [`platform`]: ./platform/index.html +#![deny(rust_2018_idioms)] + #[allow(unused_imports)] #[macro_use] extern crate lazy_static; -extern crate libc; #[macro_use] extern crate log; #[cfg(feature = "serde")] @@ -86,35 +87,12 @@ extern crate log; extern crate serde; #[macro_use] extern crate derivative; - -#[cfg(target_os = "windows")] -extern crate winapi; #[macro_use] #[cfg(target_os = "windows")] extern crate bitflags; #[cfg(any(target_os = "macos", target_os = "ios"))] #[macro_use] extern crate objc; -#[cfg(target_os = "macos")] -extern crate cocoa; -#[cfg(target_os = "macos")] -extern crate dispatch; -#[cfg(target_os = "macos")] -extern crate core_foundation; -#[cfg(target_os = "macos")] -extern crate core_graphics; -#[cfg(target_os = "macos")] -extern crate core_video_sys; -#[cfg(any(target_os = "linux", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd"))] -extern crate x11_dl; -#[cfg(any(target_os = "linux", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd", target_os = "windows"))] -extern crate parking_lot; -#[cfg(any(target_os = "linux", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd"))] -extern crate percent_encoding; -#[cfg(any(target_os = "linux", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd"))] -extern crate smithay_client_toolkit as sctk; -#[cfg(any(target_os = "linux", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd"))] -extern crate calloop; pub mod dpi; #[macro_use] diff --git a/src/monitor.rs b/src/monitor.rs index 0e52a3c2..f32f7655 100644 --- a/src/monitor.rs +++ b/src/monitor.rs @@ -12,8 +12,8 @@ //! [window_get]: ../window/struct.Window.html#method.available_monitors use std::collections::vec_deque::IntoIter as VecDequeIter; -use platform_impl; -use dpi::{PhysicalPosition, PhysicalSize}; +use crate::platform_impl; +use crate::dpi::{PhysicalPosition, PhysicalSize}; /// An iterator over all available monitors. /// diff --git a/src/platform/android.rs b/src/platform/android.rs index 82a73453..e0a96ea7 100644 --- a/src/platform/android.rs +++ b/src/platform/android.rs @@ -1,18 +1,18 @@ #![cfg(any(target_os = "android"))] use std::os::raw::c_void; -use EventLoop; -use Window; -use WindowBuilder; +use crate::EventLoop; +use crate::Window; +use crate::WindowBuilder; /// Additional methods on `EventLoop` that are specific to Android. pub trait EventLoopExtAndroid { /// Makes it possible for glutin to register a callback when a suspend event happens on Android - fn set_suspend_callback(&self, cb: Option ()>>); + fn set_suspend_callback(&self, cb: Option ()>>); } impl EventLoopExtAndroid for EventLoop { - fn set_suspend_callback(&self, cb: Option ()>>) { + fn set_suspend_callback(&self, cb: Option ()>>) { self.event_loop.set_suspend_callback(cb); } } diff --git a/src/platform/desktop.rs b/src/platform/desktop.rs index 1fafb0dd..7ae56832 100644 --- a/src/platform/desktop.rs +++ b/src/platform/desktop.rs @@ -4,8 +4,8 @@ target_os = "linux", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd" ))] -use event::Event; -use event_loop::{EventLoop, EventLoopWindowTarget, ControlFlow}; +use crate::event::Event; +use crate::event_loop::{EventLoop, EventLoopWindowTarget, ControlFlow}; /// Additional methods on `EventLoop` that are specific to desktop platforms. pub trait EventLoopExtDesktop { diff --git a/src/platform/ios.rs b/src/platform/ios.rs index 85fcdff6..c14f9dcb 100644 --- a/src/platform/ios.rs +++ b/src/platform/ios.rs @@ -2,9 +2,9 @@ use std::os::raw::c_void; -use event_loop::EventLoop; -use monitor::MonitorHandle; -use window::{Window, WindowBuilder}; +use crate::event_loop::EventLoop; +use crate::monitor::MonitorHandle; +use crate::window::{Window, WindowBuilder}; /// Additional methods on `EventLoop` that are specific to iOS. pub trait EventLoopExtIOS { diff --git a/src/platform/unix.rs b/src/platform/unix.rs index 5f212fdf..4bfa1e2d 100644 --- a/src/platform/unix.rs +++ b/src/platform/unix.rs @@ -4,26 +4,26 @@ use std::os::raw; use std::ptr; use std::sync::Arc; -use sctk::window::{ButtonState, Theme}; +use smithay_client_toolkit::window::{ButtonState, Theme}; -use dpi::LogicalSize; -use event_loop::EventLoop; -use monitor::MonitorHandle; -use window::{Window, WindowBuilder}; +use crate::dpi::LogicalSize; +use crate::event_loop::EventLoop; +use crate::monitor::MonitorHandle; +use crate::window::{Window, WindowBuilder}; -use platform_impl::{ +use crate::platform_impl::{ EventLoop as LinuxEventLoop, Window as LinuxWindow, }; -use platform_impl::x11::XConnection; -use platform_impl::x11::ffi::XVisualInfo; +use crate::platform_impl::x11::XConnection; +use crate::platform_impl::x11::ffi::XVisualInfo; // TODO: stupid hack so that glutin can do its work #[doc(hidden)] -pub use platform_impl::x11; +pub use crate::platform_impl::x11; -pub use platform_impl::XNotSupported; -pub use platform_impl::x11::util::WindowType as XWindowType; +pub use crate::platform_impl::XNotSupported; +pub use crate::platform_impl::x11::util::WindowType as XWindowType; /// Theme for wayland client side decorations /// diff --git a/src/platform/windows.rs b/src/platform/windows.rs index 9f47365c..0202ac86 100644 --- a/src/platform/windows.rs +++ b/src/platform/windows.rs @@ -5,11 +5,11 @@ use std::os::raw::c_void; use libc; use winapi::shared::windef::HWND; -use event::DeviceId; -use monitor::MonitorHandle; -use event_loop::EventLoop; -use window::{Icon, Window, WindowBuilder}; -use platform_impl::EventLoop as WindowsEventLoop; +use crate::event::DeviceId; +use crate::monitor::MonitorHandle; +use crate::event_loop::EventLoop; +use crate::window::{Icon, Window, WindowBuilder}; +use crate::platform_impl::EventLoop as WindowsEventLoop; /// Additional methods on `EventLoop` that are specific to Windows. pub trait EventLoopExtWindows { diff --git a/src/platform_impl/android/mod.rs b/src/platform_impl/android/mod.rs index 86ea4ccb..6a9c086b 100644 --- a/src/platform_impl/android/mod.rs +++ b/src/platform_impl/android/mod.rs @@ -11,27 +11,27 @@ use std::os::raw::c_void; use std::sync::mpsc::{Receiver, channel}; use { - CreationError, - Event, - LogicalPosition, - LogicalSize, - CursorIcon, - PhysicalPosition, - PhysicalSize, - WindowAttributes, - WindowEvent, - WindowId as RootWindowId, + crate::CreationError, + crate::Event, + crate::LogicalPosition, + crate::LogicalSize, + crate::CursorIcon, + crate::PhysicalPosition, + crate::PhysicalSize, + crate::WindowAttributes, + crate::WindowEvent, + crate::WindowId as RootWindowId, }; use CreationError::OsError; -use error::{ExternalError, NotSupportedError}; -use events::{Touch, TouchPhase}; -use window::MonitorHandle as RootMonitorHandle; +use crate::error::{ExternalError, NotSupportedError}; +use crate::events::{Touch, TouchPhase}; +use crate::window::MonitorHandle as RootMonitorHandle; pub type OsError = std::io::Error; pub struct EventLoop { event_rx: Receiver, - suspend_callback: RefCell ()>>>, + suspend_callback: RefCell ()>>>, } #[derive(Clone)] @@ -136,7 +136,7 @@ impl EventLoop { }; } - pub fn set_suspend_callback(&self, cb: Option ()>>) { + pub fn set_suspend_callback(&self, cb: Option ()>>) { *self.suspend_callback.borrow_mut() = cb; } @@ -196,7 +196,7 @@ pub struct Window { pub struct MonitorHandle; impl fmt::Debug for MonitorHandle { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { #[derive(Debug)] struct MonitorHandle { name: Option, diff --git a/src/platform_impl/emscripten/mod.rs b/src/platform_impl/emscripten/mod.rs index dfc7272d..ab751098 100644 --- a/src/platform_impl/emscripten/mod.rs +++ b/src/platform_impl/emscripten/mod.rs @@ -9,9 +9,9 @@ use std::os::raw::{c_char, c_void, c_double, c_ulong, c_int}; use std::sync::atomic::{AtomicBool, Ordering}; use std::sync::{Mutex, Arc}; -use dpi::{LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize}; -use error::{ExternalError, NotSupportedError}; -use window::MonitorHandle as RootMonitorHandle; +use crate::dpi::{LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize}; +use crate::error::{ExternalError, NotSupportedError}; +use crate::window::MonitorHandle as RootMonitorHandle; const DOCUMENT_NAME: &'static str = "#document\0"; diff --git a/src/platform_impl/ios/app_state.rs b/src/platform_impl/ios/app_state.rs index 295891d5..ada8a9f9 100644 --- a/src/platform_impl/ios/app_state.rs +++ b/src/platform_impl/ios/app_state.rs @@ -4,11 +4,11 @@ use std::mem::ManuallyDrop; use std::os::raw::c_void; use std::time::Instant; -use event::{Event, StartCause}; -use event_loop::ControlFlow; +use crate::event::{Event, StartCause}; +use crate::event_loop::ControlFlow; -use platform_impl::platform::event_loop::{EventHandler, Never}; -use platform_impl::platform::ffi::{ +use crate::platform_impl::platform::event_loop::{EventHandler, Never}; +use crate::platform_impl::platform::ffi::{ id, CFAbsoluteTimeGetCurrent, CFRelease, @@ -39,10 +39,10 @@ enum AppStateImpl { Launching { queued_windows: Vec, queued_events: Vec>, - queued_event_handler: Box, + queued_event_handler: Box, }, ProcessingEvents { - event_handler: Box, + event_handler: Box, active_control_flow: ControlFlow, }, // special state to deal with reentrancy and prevent mutable aliasing. @@ -50,11 +50,11 @@ enum AppStateImpl { queued_events: Vec>, }, Waiting { - waiting_event_handler: Box, + waiting_event_handler: Box, start: Instant, }, PollFinished { - waiting_event_handler: Box, + waiting_event_handler: Box, }, Terminated, } @@ -134,7 +134,7 @@ impl AppState { } // requires main thread - pub unsafe fn will_launch(queued_event_handler: Box) { + pub unsafe fn will_launch(queued_event_handler: Box) { let mut this = AppState::get_mut(); let (queued_windows, queued_events) = match &mut this.app_state { &mut AppStateImpl::NotLaunched { diff --git a/src/platform_impl/ios/event_loop.rs b/src/platform_impl/ios/event_loop.rs index 589348c7..23c97bd3 100644 --- a/src/platform_impl/ios/event_loop.rs +++ b/src/platform_impl/ios/event_loop.rs @@ -5,16 +5,16 @@ use std::fmt::{self, Debug, Formatter}; use std::marker::PhantomData; use std::sync::mpsc::{self, Sender, Receiver}; -use event::Event; -use event_loop::{ +use crate::event::Event; +use crate::event_loop::{ ControlFlow, EventLoopWindowTarget as RootEventLoopWindowTarget, EventLoopClosed, }; -use platform::ios::Idiom; +use crate::platform::ios::Idiom; -use platform_impl::platform::app_state::AppState; -use platform_impl::platform::ffi::{ +use crate::platform_impl::platform::app_state::AppState; +use crate::platform_impl::platform::ffi::{ id, nil, CFIndex, @@ -42,9 +42,9 @@ use platform_impl::platform::ffi::{ UIApplicationMain, UIUserInterfaceIdiom, }; -use platform_impl::platform::monitor; -use platform_impl::platform::MonitorHandle; -use platform_impl::platform::view; +use crate::platform_impl::platform::monitor; +use crate::platform_impl::platform::MonitorHandle; +use crate::platform_impl::platform::view; pub struct EventLoopWindowTarget { receiver: Receiver, @@ -281,7 +281,7 @@ struct EventLoopHandler { } impl Debug for EventLoopHandler { - fn fmt(&self, formatter: &mut Formatter) -> fmt::Result { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { formatter.debug_struct("EventLoopHandler") .field("event_loop", &self.event_loop) .finish() diff --git a/src/platform_impl/ios/ffi.rs b/src/platform_impl/ios/ffi.rs index 8583dbd7..aa54594d 100644 --- a/src/platform_impl/ios/ffi.rs +++ b/src/platform_impl/ios/ffi.rs @@ -7,7 +7,7 @@ use std::os::raw::*; use objc::{Encode, Encoding}; use objc::runtime::Object; -use platform::ios::{Idiom, ValidOrientations}; +use crate::platform::ios::{Idiom, ValidOrientations}; pub type id = *mut Object; pub const nil: id = 0 as id; diff --git a/src/platform_impl/ios/mod.rs b/src/platform_impl/ios/mod.rs index 73dd2b2e..9d586bca 100644 --- a/src/platform_impl/ios/mod.rs +++ b/src/platform_impl/ios/mod.rs @@ -106,7 +106,7 @@ unsafe impl Sync for DeviceId {} pub enum OsError {} impl fmt::Display for OsError { - fn fmt(&self, _: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, _: &mut fmt::Formatter<'_>) -> fmt::Result { match self { _ => unreachable!() } diff --git a/src/platform_impl/ios/monitor.rs b/src/platform_impl/ios/monitor.rs index 152a5ecd..355e7148 100644 --- a/src/platform_impl/ios/monitor.rs +++ b/src/platform_impl/ios/monitor.rs @@ -4,10 +4,10 @@ use std::{ ops::{Deref, DerefMut}, }; -use dpi::{PhysicalPosition, PhysicalSize}; -use monitor::VideoMode; +use crate::dpi::{PhysicalPosition, PhysicalSize}; +use crate::monitor::VideoMode; -use platform_impl::platform::ffi::{id, nil, CGFloat, CGRect, CGSize, NSInteger, NSUInteger}; +use crate::platform_impl::platform::ffi::{id, nil, CGFloat, CGRect, CGSize, NSInteger, NSUInteger}; pub struct Inner { uiscreen: id, @@ -63,7 +63,7 @@ impl Drop for MonitorHandle { } impl fmt::Debug for MonitorHandle { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { #[derive(Debug)] struct MonitorHandle { name: Option, diff --git a/src/platform_impl/ios/view.rs b/src/platform_impl/ios/view.rs index 9205df43..7c4a1fc4 100644 --- a/src/platform_impl/ios/view.rs +++ b/src/platform_impl/ios/view.rs @@ -3,20 +3,20 @@ use std::collections::HashMap; use objc::declare::ClassDecl; use objc::runtime::{BOOL, Class, NO, Object, Sel, YES}; -use event::{ +use crate::event::{ DeviceId as RootDeviceId, Event, Touch, TouchPhase, WindowEvent }; -use platform::ios::MonitorHandleExtIOS; -use window::{WindowAttributes, WindowId as RootWindowId}; +use crate::platform::ios::MonitorHandleExtIOS; +use crate::window::{WindowAttributes, WindowId as RootWindowId}; -use platform_impl::platform::app_state::AppState; -use platform_impl::platform::DeviceId; -use platform_impl::platform::event_loop; -use platform_impl::platform::ffi::{ +use crate::platform_impl::platform::app_state::AppState; +use crate::platform_impl::platform::DeviceId; +use crate::platform_impl::platform::event_loop; +use crate::platform_impl::platform::ffi::{ id, nil, CGFloat, @@ -25,7 +25,7 @@ use platform_impl::platform::ffi::{ UIInterfaceOrientationMask, UITouchPhase, }; -use platform_impl::platform::window::{PlatformSpecificWindowBuilderAttributes}; +use crate::platform_impl::platform::window::{PlatformSpecificWindowBuilderAttributes}; // requires main thread unsafe fn get_view_class(root_view_class: &'static Class) -> &'static Class { diff --git a/src/platform_impl/ios/window.rs b/src/platform_impl/ios/window.rs index 2ebbb469..2945b87b 100644 --- a/src/platform_impl/ios/window.rs +++ b/src/platform_impl/ios/window.rs @@ -5,16 +5,16 @@ use std::{ use objc::runtime::{Class, NO, Object, YES}; -use dpi::{self, LogicalPosition, LogicalSize}; -use error::{ExternalError, NotSupportedError, OsError as RootOsError}; -use icon::Icon; -use monitor::MonitorHandle as RootMonitorHandle; -use platform::ios::{MonitorHandleExtIOS, ValidOrientations}; -use window::{ +use crate::dpi::{self, LogicalPosition, LogicalSize}; +use crate::error::{ExternalError, NotSupportedError, OsError as RootOsError}; +use crate::icon::Icon; +use crate::monitor::MonitorHandle as RootMonitorHandle; +use crate::platform::ios::{MonitorHandleExtIOS, ValidOrientations}; +use crate::window::{ CursorIcon, WindowAttributes, }; -use platform_impl::{ +use crate::platform_impl::{ platform::{ app_state::AppState, event_loop, diff --git a/src/platform_impl/linux/mod.rs b/src/platform_impl/linux/mod.rs index b54a4a25..efd96439 100644 --- a/src/platform_impl/linux/mod.rs +++ b/src/platform_impl/linux/mod.rs @@ -7,15 +7,15 @@ use std::os::raw::*; use std::sync::Arc; use parking_lot::Mutex; -use sctk::reexports::client::ConnectError; +use smithay_client_toolkit::reexports::client::ConnectError; -use dpi::{LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize}; -use icon::Icon; -use error::{ExternalError, NotSupportedError, OsError as RootOsError}; -use event::Event; -use event_loop::{EventLoopClosed, ControlFlow, EventLoopWindowTarget as RootELW}; -use monitor::{MonitorHandle as RootMonitorHandle, VideoMode}; -use window::{WindowAttributes, CursorIcon}; +use crate::dpi::{LogicalPosition, LogicalSize, PhysicalPosition, PhysicalSize}; +use crate::icon::Icon; +use crate::error::{ExternalError, NotSupportedError, OsError as RootOsError}; +use crate::event::Event; +use crate::event_loop::{EventLoopClosed, ControlFlow, EventLoopWindowTarget as RootELW}; +use crate::monitor::{MonitorHandle as RootMonitorHandle, VideoMode}; +use crate::window::{WindowAttributes, CursorIcon}; use self::x11::{XConnection, XError}; use self::x11::ffi::XVisualInfo; pub use self::x11::XNotSupported; @@ -59,7 +59,7 @@ pub enum OsError { } impl fmt::Display for OsError { - fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { match self { OsError::XError(e) => formatter.pad(&e.description), OsError::XMisc(e) => formatter.pad(e), @@ -529,7 +529,7 @@ impl EventLoop { } pub fn run_return(&mut self, callback: F) - where F: FnMut(::event::Event, &RootELW, &mut ControlFlow) + where F: FnMut(crate::event::Event, &RootELW, &mut ControlFlow) { match *self { EventLoop::Wayland(ref mut evlp) => evlp.run_return(callback), @@ -538,7 +538,7 @@ impl EventLoop { } pub fn run(self, callback: F) -> ! - where F: 'static + FnMut(::event::Event, &RootELW, &mut ControlFlow) + where F: 'static + FnMut(crate::event::Event, &RootELW, &mut ControlFlow) { match self { EventLoop::Wayland(evlp) => evlp.run(callback), @@ -554,7 +554,7 @@ impl EventLoop { } } - pub fn window_target(&self) -> &::event_loop::EventLoopWindowTarget { + pub fn window_target(&self) -> &crate::event_loop::EventLoopWindowTarget { match *self { EventLoop::Wayland(ref evl) => evl.window_target(), EventLoop::X(ref evl) => evl.window_target() diff --git a/src/platform_impl/linux/wayland/event_loop.rs b/src/platform_impl/linux/wayland/event_loop.rs index eddfa8e7..14156dd8 100644 --- a/src/platform_impl/linux/wayland/event_loop.rs +++ b/src/platform_impl/linux/wayland/event_loop.rs @@ -5,24 +5,24 @@ use std::rc::Rc; use std::sync::{Arc, Mutex}; use std::time::Instant; -use event_loop::{ControlFlow, EventLoopClosed, EventLoopWindowTarget as RootELW}; -use event::ModifiersState; -use dpi::{PhysicalPosition, PhysicalSize}; -use platform_impl::platform::sticky_exit_callback; -use monitor::VideoMode; +use crate::event_loop::{ControlFlow, EventLoopClosed, EventLoopWindowTarget as RootELW}; +use crate::event::ModifiersState; +use crate::dpi::{PhysicalPosition, PhysicalSize}; +use crate::platform_impl::platform::sticky_exit_callback; +use crate::monitor::VideoMode; use super::window::WindowStore; use super::WindowId; -use sctk::output::OutputMgr; -use sctk::reexports::client::protocol::{ +use smithay_client_toolkit::output::OutputMgr; +use smithay_client_toolkit::reexports::client::protocol::{ wl_keyboard, wl_output, wl_pointer, wl_registry, wl_seat, wl_touch, }; -use sctk::reexports::client::{ConnectError, Display, EventQueue, GlobalEvent}; -use sctk::Environment; +use smithay_client_toolkit::reexports::client::{ConnectError, Display, EventQueue, GlobalEvent}; +use smithay_client_toolkit::Environment; pub struct WindowEventsSink { - buffer: VecDeque<(::event::WindowEvent, ::window::WindowId)>, + buffer: VecDeque<(crate::event::WindowEvent, crate::window::WindowId)>, } impl WindowEventsSink { @@ -32,16 +32,16 @@ impl WindowEventsSink { } } - pub fn send_event(&mut self, evt: ::event::WindowEvent, wid: WindowId) { - self.buffer.push_back((evt, ::window::WindowId(::platform_impl::WindowId::Wayland(wid)))); + pub fn send_event(&mut self, evt: crate::event::WindowEvent, wid: WindowId) { + self.buffer.push_back((evt, crate::window::WindowId(crate::platform_impl::WindowId::Wayland(wid)))); } fn empty_with(&mut self, mut callback: F) where - F: FnMut(::event::Event), + F: FnMut(crate::event::Event), { for (evt, wid) in self.buffer.drain(..) { - callback(::event::Event::WindowEvent { event: evt, window_id: wid}) + callback(crate::event::Event::WindowEvent { event: evt, window_id: wid}) } } } @@ -58,7 +58,7 @@ pub struct EventLoop { pending_user_events: Rc>>, _user_source: ::calloop::Source<::calloop::channel::Channel>, user_sender: ::calloop::channel::Sender, - _kbd_source: ::calloop::Source<::calloop::channel::Channel<(::event::WindowEvent, super::WindowId)>>, + _kbd_source: ::calloop::Source<::calloop::channel::Channel<(crate::event::WindowEvent, super::WindowId)>>, window_target: RootELW } @@ -160,7 +160,7 @@ impl EventLoop { user_sender, _kbd_source: kbd_source, window_target: RootELW { - p: ::platform_impl::EventLoopWindowTarget::Wayland(EventLoopWindowTarget { + p: crate::platform_impl::EventLoopWindowTarget::Wayland(EventLoopWindowTarget { evq: RefCell::new(source), store, env, @@ -181,14 +181,14 @@ impl EventLoop { } pub fn run(mut self, callback: F) -> ! - where F: 'static + FnMut(::event::Event, &RootELW, &mut ControlFlow) + where F: 'static + FnMut(crate::event::Event, &RootELW, &mut ControlFlow) { self.run_return(callback); ::std::process::exit(0); } pub fn run_return(&mut self, mut callback: F) - where F: FnMut(::event::Event, &RootELW, &mut ControlFlow) + where F: FnMut(crate::event::Event, &RootELW, &mut ControlFlow) { // send pending events to the server self.display.flush().expect("Wayland connection lost."); @@ -198,7 +198,7 @@ impl EventLoop { let sink = self.sink.clone(); let user_events = self.pending_user_events.clone(); - callback(::event::Event::NewEvents(::event::StartCause::Init), &self.window_target, &mut control_flow); + callback(crate::event::Event::NewEvents(crate::event::StartCause::Init), &self.window_target, &mut control_flow); loop { self.post_dispatch_triggers(); @@ -215,7 +215,7 @@ impl EventLoop { let mut guard = user_events.borrow_mut(); for evt in guard.drain(..) { sticky_exit_callback( - ::event::Event::UserEvent(evt), + crate::event::Event::UserEvent(evt), &self.window_target, &mut control_flow, &mut callback @@ -234,7 +234,7 @@ impl EventLoop { // send Events cleared { sticky_exit_callback( - ::event::Event::EventsCleared, + crate::event::Event::EventsCleared, &self.window_target, &mut control_flow, &mut callback @@ -249,12 +249,12 @@ impl EventLoop { ControlFlow::Poll => { // non-blocking dispatch self.inner_loop.dispatch(Some(::std::time::Duration::from_millis(0)), &mut ()).unwrap(); - callback(::event::Event::NewEvents(::event::StartCause::Poll), &self.window_target, &mut control_flow); + callback(crate::event::Event::NewEvents(crate::event::StartCause::Poll), &self.window_target, &mut control_flow); }, ControlFlow::Wait => { self.inner_loop.dispatch(None, &mut ()).unwrap(); callback( - ::event::Event::NewEvents(::event::StartCause::WaitCancelled { + crate::event::Event::NewEvents(crate::event::StartCause::WaitCancelled { start: Instant::now(), requested_resume: None }), @@ -274,7 +274,7 @@ impl EventLoop { let now = Instant::now(); if now < deadline { callback( - ::event::Event::NewEvents(::event::StartCause::WaitCancelled { + crate::event::Event::NewEvents(crate::event::StartCause::WaitCancelled { start, requested_resume: Some(deadline) }), @@ -283,7 +283,7 @@ impl EventLoop { ); } else { callback( - ::event::Event::NewEvents(::event::StartCause::ResumeTimeReached { + crate::event::Event::NewEvents(crate::event::StartCause::ResumeTimeReached { start, requested_resume: deadline }), @@ -295,7 +295,7 @@ impl EventLoop { } } - callback(::event::Event::LoopDestroyed, &self.window_target, &mut control_flow); + callback(crate::event::Event::LoopDestroyed, &self.window_target, &mut control_flow); } pub fn primary_monitor(&self) -> MonitorHandle { @@ -323,7 +323,7 @@ impl EventLoop { fn post_dispatch_triggers(&mut self) { let mut sink = self.sink.lock().unwrap(); let window_target = match self.window_target.p { - ::platform_impl::EventLoopWindowTarget::Wayland(ref wt) => wt, + crate::platform_impl::EventLoopWindowTarget::Wayland(ref wt) => wt, _ => unreachable!() }; // prune possible dead windows @@ -333,7 +333,7 @@ impl EventLoop { let pruned = window_target.store.lock().unwrap().cleanup(); *cleanup_needed = false; for wid in pruned { - sink.send_event(::event::WindowEvent::Destroyed, wid); + sink.send_event(crate::event::WindowEvent::Destroyed, wid); } } } @@ -344,8 +344,8 @@ impl EventLoop { if let Some((w, h)) = newsize { frame.resize(w, h); frame.refresh(); - let logical_size = ::dpi::LogicalSize::new(w as f64, h as f64); - sink.send_event(::event::WindowEvent::Resized(logical_size), wid); + let logical_size = crate::dpi::LogicalSize::new(w as f64, h as f64); + sink.send_event(crate::event::WindowEvent::Resized(logical_size), wid); *size = (w, h); } else if frame_refresh { frame.refresh(); @@ -355,13 +355,13 @@ impl EventLoop { } } if let Some(dpi) = new_dpi { - sink.send_event(::event::WindowEvent::HiDpiFactorChanged(dpi as f64), wid); + sink.send_event(crate::event::WindowEvent::HiDpiFactorChanged(dpi as f64), wid); } if refresh { - sink.send_event(::event::WindowEvent::RedrawRequested, wid); + sink.send_event(crate::event::WindowEvent::RedrawRequested, wid); } if closed { - sink.send_event(::event::WindowEvent::CloseRequested, wid); + sink.send_event(crate::event::WindowEvent::CloseRequested, wid); } }, ) @@ -376,7 +376,7 @@ struct SeatManager { sink: Arc>, store: Arc>, seats: Arc>>, - kbd_sender: ::calloop::channel::Sender<(::event::WindowEvent, super::WindowId)> + kbd_sender: ::calloop::channel::Sender<(crate::event::WindowEvent, super::WindowId)> } impl SeatManager { @@ -417,7 +417,7 @@ impl SeatManager { struct SeatData { sink: Arc>, store: Arc>, - kbd_sender: ::calloop::channel::Sender<(::event::WindowEvent, super::WindowId)>, + kbd_sender: ::calloop::channel::Sender<(crate::event::WindowEvent, super::WindowId)>, pointer: Option, keyboard: Option, touch: Option, @@ -523,7 +523,7 @@ impl Clone for MonitorHandle { } impl fmt::Debug for MonitorHandle { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { #[derive(Debug)] struct MonitorHandle { name: Option, diff --git a/src/platform_impl/linux/wayland/keyboard.rs b/src/platform_impl/linux/wayland/keyboard.rs index d0930949..a03dcc2c 100644 --- a/src/platform_impl/linux/wayland/keyboard.rs +++ b/src/platform_impl/linux/wayland/keyboard.rs @@ -1,16 +1,16 @@ use std::sync::{Arc, Mutex}; use super::{make_wid, DeviceId}; -use sctk::keyboard::{ +use smithay_client_toolkit::keyboard::{ self, map_keyboard_auto_with_repeat, Event as KbEvent, KeyRepeatEvent, KeyRepeatKind, }; -use sctk::reexports::client::protocol::{wl_keyboard, wl_seat}; +use smithay_client_toolkit::reexports::client::protocol::{wl_keyboard, wl_seat}; -use event::{ElementState, KeyboardInput, ModifiersState, VirtualKeyCode, WindowEvent}; +use crate::event::{ElementState, KeyboardInput, ModifiersState, VirtualKeyCode, WindowEvent}; pub fn init_keyboard( seat: &wl_seat::WlSeat, - sink: ::calloop::channel::Sender<(::event::WindowEvent, super::WindowId)>, + sink: ::calloop::channel::Sender<(crate::event::WindowEvent, super::WindowId)>, modifiers_tracker: Arc>, ) -> wl_keyboard::WlKeyboard { // { variables to be captured by the closures @@ -23,7 +23,7 @@ pub fn init_keyboard( let ret = map_keyboard_auto_with_repeat( seat, KeyRepeatKind::System, - move |evt: KbEvent, _| match evt { + move |evt: KbEvent<'_>, _| match evt { KbEvent::Enter { surface, .. } => { let wid = make_wid(&surface); my_sink.send((WindowEvent::Focused(true), wid)).unwrap(); @@ -50,7 +50,7 @@ pub fn init_keyboard( let vkcode = key_to_vkey(rawkey, keysym); my_sink.send( (WindowEvent::KeyboardInput { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), input: KeyboardInput { state: state, scancode: rawkey, @@ -82,7 +82,7 @@ pub fn init_keyboard( let vkcode = key_to_vkey(repeat_event.rawkey, repeat_event.keysym); repeat_sink.send(( WindowEvent::KeyboardInput { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), input: KeyboardInput { state: state, scancode: repeat_event.rawkey, @@ -136,7 +136,7 @@ pub fn init_keyboard( }; my_sink.send(( WindowEvent::KeyboardInput { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), input: KeyboardInput { state: state, scancode: key, @@ -173,7 +173,7 @@ fn key_to_vkey(rawkey: u32, keysym: u32) -> Option { } fn keysym_to_vkey(keysym: u32) -> Option { - use sctk::keyboard::keysyms; + use smithay_client_toolkit::keyboard::keysyms; match keysym { // letters keysyms::XKB_KEY_A | keysyms::XKB_KEY_a => Some(VirtualKeyCode::A), diff --git a/src/platform_impl/linux/wayland/mod.rs b/src/platform_impl/linux/wayland/mod.rs index 44397ea2..da1f8d6b 100644 --- a/src/platform_impl/linux/wayland/mod.rs +++ b/src/platform_impl/linux/wayland/mod.rs @@ -4,7 +4,7 @@ pub use self::window::Window; pub use self::event_loop::{EventLoop, EventLoopWindowTarget, EventLoopProxy, WindowEventsSink, MonitorHandle}; -use sctk::reexports::client::protocol::wl_surface; +use smithay_client_toolkit::reexports::client::protocol::wl_surface; mod event_loop; mod pointer; diff --git a/src/platform_impl/linux/wayland/pointer.rs b/src/platform_impl/linux/wayland/pointer.rs index cbada78b..76976874 100644 --- a/src/platform_impl/linux/wayland/pointer.rs +++ b/src/platform_impl/linux/wayland/pointer.rs @@ -1,13 +1,13 @@ use std::sync::{Arc, Mutex}; -use event::{ElementState, MouseButton, MouseScrollDelta, TouchPhase, WindowEvent, ModifiersState}; +use crate::event::{ElementState, MouseButton, MouseScrollDelta, TouchPhase, WindowEvent, ModifiersState}; use super::DeviceId; use super::event_loop::WindowEventsSink; use super::window::WindowStore; -use sctk::reexports::client::protocol::wl_pointer::{self, Event as PtrEvent, WlPointer}; -use sctk::reexports::client::protocol::wl_seat; +use smithay_client_toolkit::reexports::client::protocol::wl_pointer::{self, Event as PtrEvent, WlPointer}; +use smithay_client_toolkit::reexports::client::protocol::wl_seat; pub fn implement_pointer( seat: &wl_seat::WlSeat, @@ -36,13 +36,13 @@ pub fn implement_pointer( mouse_focus = Some(wid); sink.send_event( WindowEvent::CursorEntered { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), }, wid, ); sink.send_event( WindowEvent::CursorMoved { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), position: (surface_x, surface_y).into(), modifiers: modifiers_tracker.lock().unwrap().clone(), }, @@ -56,7 +56,7 @@ pub fn implement_pointer( if let Some(wid) = wid { sink.send_event( WindowEvent::CursorLeft { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), }, wid, ); @@ -70,7 +70,7 @@ pub fn implement_pointer( if let Some(wid) = mouse_focus { sink.send_event( WindowEvent::CursorMoved { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), position: (surface_x, surface_y).into(), modifiers: modifiers_tracker.lock().unwrap().clone(), }, @@ -94,7 +94,7 @@ pub fn implement_pointer( }; sink.send_event( WindowEvent::MouseInput { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), state: state, button: button, modifiers: modifiers_tracker.lock().unwrap().clone(), @@ -116,7 +116,7 @@ pub fn implement_pointer( } sink.send_event( WindowEvent::MouseWheel { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), delta: MouseScrollDelta::PixelDelta((x as f64, y as f64).into()), phase: TouchPhase::Moved, modifiers: modifiers_tracker.lock().unwrap().clone(), @@ -146,7 +146,7 @@ pub fn implement_pointer( if let Some((x, y)) = axis_discrete_buffer { sink.send_event( WindowEvent::MouseWheel { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), delta: MouseScrollDelta::LineDelta(x as f32, y as f32), phase: axis_state, modifiers: modifiers_tracker.lock().unwrap().clone(), @@ -156,7 +156,7 @@ pub fn implement_pointer( } else if let Some((x, y)) = axis_buffer { sink.send_event( WindowEvent::MouseWheel { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), delta: MouseScrollDelta::PixelDelta((x as f64, y as f64).into()), phase: axis_state, modifiers: modifiers_tracker.lock().unwrap().clone(), diff --git a/src/platform_impl/linux/wayland/touch.rs b/src/platform_impl/linux/wayland/touch.rs index 765d524a..fd9f60fa 100644 --- a/src/platform_impl/linux/wayland/touch.rs +++ b/src/platform_impl/linux/wayland/touch.rs @@ -1,13 +1,13 @@ use std::sync::{Arc, Mutex}; -use event::{TouchPhase, WindowEvent}; +use crate::event::{TouchPhase, WindowEvent}; use super::{DeviceId, WindowId}; use super::event_loop::WindowEventsSink; use super::window::WindowStore; -use sctk::reexports::client::protocol::wl_touch::{Event as TouchEvent, WlTouch}; -use sctk::reexports::client::protocol::wl_seat; +use smithay_client_toolkit::reexports::client::protocol::wl_touch::{Event as TouchEvent, WlTouch}; +use smithay_client_toolkit::reexports::client::protocol::wl_seat; struct TouchPoint { wid: WindowId, @@ -32,8 +32,8 @@ pub(crate) fn implement_touch( let wid = store.find_wid(&surface); if let Some(wid) = wid { sink.send_event( - WindowEvent::Touch(::event::Touch { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + WindowEvent::Touch(crate::event::Touch { + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), phase: TouchPhase::Started, location: (x, y).into(), id: id as u64, @@ -52,8 +52,8 @@ pub(crate) fn implement_touch( if let Some(idx) = idx { let pt = pending_ids.remove(idx); sink.send_event( - WindowEvent::Touch(::event::Touch { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + WindowEvent::Touch(crate::event::Touch { + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), phase: TouchPhase::Ended, location: pt.location.into(), id: id as u64, @@ -67,8 +67,8 @@ pub(crate) fn implement_touch( if let Some(pt) = pt { pt.location = (x, y); sink.send_event( - WindowEvent::Touch(::event::Touch { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + WindowEvent::Touch(crate::event::Touch { + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), phase: TouchPhase::Moved, location: (x, y).into(), id: id as u64, @@ -80,8 +80,8 @@ pub(crate) fn implement_touch( TouchEvent::Frame => (), TouchEvent::Cancel => for pt in pending_ids.drain(..) { sink.send_event( - WindowEvent::Touch(::event::Touch { - device_id: ::event::DeviceId(::platform_impl::DeviceId::Wayland(DeviceId)), + WindowEvent::Touch(crate::event::Touch { + device_id: crate::event::DeviceId(crate::platform_impl::DeviceId::Wayland(DeviceId)), phase: TouchPhase::Cancelled, location: pt.location.into(), id: pt.id as u64, diff --git a/src/platform_impl/linux/wayland/window.rs b/src/platform_impl/linux/wayland/window.rs index c670ec93..d40e18a0 100644 --- a/src/platform_impl/linux/wayland/window.rs +++ b/src/platform_impl/linux/wayland/window.rs @@ -2,20 +2,20 @@ use std::collections::VecDeque; use std::io::{Seek, SeekFrom, Write}; use std::sync::{Arc, Mutex, Weak}; -use dpi::{LogicalPosition, LogicalSize}; -use error::{ExternalError, NotSupportedError, OsError as RootOsError}; -use platform_impl::{MonitorHandle as PlatformMonitorHandle, PlatformSpecificWindowBuilderAttributes as PlAttributes}; -use monitor::MonitorHandle as RootMonitorHandle; -use window::{WindowAttributes, CursorIcon}; +use crate::dpi::{LogicalPosition, LogicalSize}; +use crate::error::{ExternalError, NotSupportedError, OsError as RootOsError}; +use crate::platform_impl::{MonitorHandle as PlatformMonitorHandle, PlatformSpecificWindowBuilderAttributes as PlAttributes}; +use crate::monitor::MonitorHandle as RootMonitorHandle; +use crate::window::{WindowAttributes, CursorIcon}; -use sctk::surface::{get_dpi_factor, get_outputs}; -use sctk::window::{ConceptFrame, Event as WEvent, State as WState, Window as SWindow, Theme}; -use sctk::reexports::client::{Display, NewProxy}; -use sctk::reexports::client::protocol::{wl_seat, wl_surface, wl_subsurface, wl_shm}; -use sctk::output::OutputMgr; +use smithay_client_toolkit::surface::{get_dpi_factor, get_outputs}; +use smithay_client_toolkit::window::{ConceptFrame, Event as WEvent, State as WState, Window as SWindow, Theme}; +use smithay_client_toolkit::reexports::client::{Display, NewProxy}; +use smithay_client_toolkit::reexports::client::protocol::{wl_seat, wl_surface, wl_subsurface, wl_shm}; +use smithay_client_toolkit::output::OutputMgr; use super::{make_wid, EventLoopWindowTarget, MonitorHandle, WindowId}; -use platform_impl::platform::wayland::event_loop::{available_monitors, primary_monitor}; +use crate::platform_impl::platform::wayland::event_loop::{available_monitors, primary_monitor}; pub struct Window { _bg_surface: wl_surface::WlSurface, @@ -60,7 +60,7 @@ impl Window { let my_bg_surface = bg_surface.clone(); // prepare a 1px buffer to display on the root window - let mut pool = sctk::utils::MemPool::new(&evlp.env.shm, || {}).unwrap(); + let mut pool = smithay_client_toolkit::utils::MemPool::new(&evlp.env.shm, || {}).unwrap(); pool.resize(4).unwrap(); pool.seek(SeekFrom::Start(0)).unwrap(); pool.write(&[0, 0, 0, 0]).unwrap(); diff --git a/src/platform_impl/linux/x11/event_processor.rs b/src/platform_impl/linux/x11/event_processor.rs index 19332dc9..a710e4b6 100644 --- a/src/platform_impl/linux/x11/event_processor.rs +++ b/src/platform_impl/linux/x11/event_processor.rs @@ -12,9 +12,9 @@ use super::{ events, util, DndState, Dnd, DeviceInfo }; -use event_loop::EventLoopWindowTarget as RootELW; -use event::{DeviceEvent, Event, KeyboardInput, ModifiersState, WindowEvent}; -use dpi::{LogicalPosition,LogicalSize}; +use crate::event_loop::EventLoopWindowTarget as RootELW; +use crate::event::{DeviceEvent, Event, KeyboardInput, ModifiersState, WindowEvent}; +use crate::dpi::{LogicalPosition,LogicalSize}; pub(super) struct EventProcessor { pub(super) dnd: Dnd, @@ -440,7 +440,7 @@ impl EventProcessor { } ffi::KeyPress | ffi::KeyRelease => { - use event::ElementState::{Pressed, Released}; + use crate::event::ElementState::{Pressed, Released}; // Note that in compose/pre-edit sequences, this will always be Released. let state = if xev.get_type() == ffi::KeyPress { @@ -521,11 +521,11 @@ impl EventProcessor { return; } - use event::WindowEvent::{Focused, CursorEntered, MouseInput, CursorLeft, CursorMoved, MouseWheel, AxisMotion}; - use event::ElementState::{Pressed, Released}; - use event::MouseButton::{Left, Right, Middle, Other}; - use event::MouseScrollDelta::LineDelta; - use event::{Touch, TouchPhase}; + use crate::event::WindowEvent::{Focused, CursorEntered, MouseInput, CursorLeft, CursorMoved, MouseWheel, AxisMotion}; + use crate::event::ElementState::{Pressed, Released}; + use crate::event::MouseButton::{Left, Right, Middle, Other}; + use crate::event::MouseScrollDelta::LineDelta; + use crate::event::{Touch, TouchPhase}; match xev.evtype { ffi::XI_ButtonPress | ffi::XI_ButtonRelease => { diff --git a/src/platform_impl/linux/x11/events.rs b/src/platform_impl/linux/x11/events.rs index 254f04e1..bb511128 100644 --- a/src/platform_impl/linux/x11/events.rs +++ b/src/platform_impl/linux/x11/events.rs @@ -1,6 +1,6 @@ use libc; use super::ffi; -use event::VirtualKeyCode; +use crate::event::VirtualKeyCode; pub fn keysym_to_element(keysym: libc::c_uint) -> Option { Some(match keysym { diff --git a/src/platform_impl/linux/x11/ime/input_method.rs b/src/platform_impl/linux/x11/ime/input_method.rs index fee0a14f..13f6f75a 100644 --- a/src/platform_impl/linux/x11/ime/input_method.rs +++ b/src/platform_impl/linux/x11/ime/input_method.rs @@ -152,7 +152,7 @@ impl InputMethodName { } impl fmt::Debug for InputMethodName { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { self.string.fmt(f) } } @@ -254,7 +254,7 @@ impl PotentialInputMethods { pub fn open_im( &mut self, xconn: &Arc, - callback: Option<&Fn() -> ()>, + callback: Option<&dyn Fn() -> ()>, ) -> InputMethodResult { use self::InputMethodResult::*; diff --git a/src/platform_impl/linux/x11/mod.rs b/src/platform_impl/linux/x11/mod.rs index 6064a482..173dcad5 100644 --- a/src/platform_impl/linux/x11/mod.rs +++ b/src/platform_impl/linux/x11/mod.rs @@ -25,12 +25,12 @@ use std::sync::{Arc, mpsc, Weak, Mutex}; use libc::{self, setlocale, LC_CTYPE}; -use error::OsError as RootOsError; -use event_loop::{ControlFlow, EventLoopClosed, EventLoopWindowTarget as RootELW}; -use event::{WindowEvent, Event}; -use platform_impl::PlatformSpecificWindowBuilderAttributes; -use platform_impl::platform::sticky_exit_callback; -use window::{WindowAttributes}; +use crate::error::OsError as RootOsError; +use crate::event_loop::{ControlFlow, EventLoopClosed, EventLoopWindowTarget as RootELW}; +use crate::event::{WindowEvent, Event}; +use crate::platform_impl::PlatformSpecificWindowBuilderAttributes; +use crate::platform_impl::platform::sticky_exit_callback; +use crate::window::{WindowAttributes}; use self::dnd::{Dnd, DndState}; use self::ime::{ImeReceiver, ImeSender, ImeCreationError, Ime}; use self::event_processor::EventProcessor; @@ -243,7 +243,7 @@ impl EventLoop { let mut guard = self.pending_user_events.borrow_mut(); for evt in guard.drain(..) { sticky_exit_callback( - ::event::Event::UserEvent(evt), + crate::event::Event::UserEvent(evt), &self.target, &mut control_flow, &mut callback @@ -256,7 +256,7 @@ impl EventLoop { for wid in guard.drain() { sticky_exit_callback( Event::WindowEvent { - window_id: ::window::WindowId(super::WindowId::X(wid)), + window_id: crate::window::WindowId(super::WindowId::X(wid)), event: WindowEvent::RedrawRequested }, &self.target, @@ -268,7 +268,7 @@ impl EventLoop { // send Events cleared { sticky_exit_callback( - ::event::Event::EventsCleared, + crate::event::Event::EventsCleared, &self.target, &mut control_flow, &mut callback @@ -283,12 +283,12 @@ impl EventLoop { ControlFlow::Poll => { // non-blocking dispatch self.inner_loop.dispatch(Some(::std::time::Duration::from_millis(0)), &mut ()).unwrap(); - callback(::event::Event::NewEvents(::event::StartCause::Poll), &self.target, &mut control_flow); + callback(crate::event::Event::NewEvents(crate::event::StartCause::Poll), &self.target, &mut control_flow); }, ControlFlow::Wait => { self.inner_loop.dispatch(None, &mut ()).unwrap(); callback( - ::event::Event::NewEvents(::event::StartCause::WaitCancelled { + crate::event::Event::NewEvents(crate::event::StartCause::WaitCancelled { start: ::std::time::Instant::now(), requested_resume: None }), @@ -308,7 +308,7 @@ impl EventLoop { let now = std::time::Instant::now(); if now < deadline { callback( - ::event::Event::NewEvents(::event::StartCause::WaitCancelled { + crate::event::Event::NewEvents(crate::event::StartCause::WaitCancelled { start, requested_resume: Some(deadline) }), @@ -317,7 +317,7 @@ impl EventLoop { ); } else { callback( - ::event::Event::NewEvents(::event::StartCause::ResumeTimeReached { + crate::event::Event::NewEvents(crate::event::StartCause::ResumeTimeReached { start, requested_resume: deadline }), @@ -329,7 +329,7 @@ impl EventLoop { } } - callback(::event::Event::LoopDestroyed, &self.target, &mut control_flow); + callback(crate::event::Event::LoopDestroyed, &self.target, &mut control_flow); } pub fn run(mut self, callback: F) -> ! @@ -485,8 +485,8 @@ struct XExtension { first_error_id: c_int, } -fn mkwid(w: ffi::Window) -> ::window::WindowId { ::window::WindowId(::platform_impl::WindowId::X(WindowId(w))) } -fn mkdid(w: c_int) -> ::event::DeviceId { ::event::DeviceId(::platform_impl::DeviceId::X(DeviceId(w))) } +fn mkwid(w: ffi::Window) -> crate::window::WindowId { crate::window::WindowId(crate::platform_impl::WindowId::X(WindowId(w))) } +fn mkdid(w: c_int) -> crate::event::DeviceId { crate::event::DeviceId(crate::platform_impl::DeviceId::X(DeviceId(w))) } #[derive(Debug)] struct Device { diff --git a/src/platform_impl/linux/x11/monitor.rs b/src/platform_impl/linux/x11/monitor.rs index eb9b0ec2..3ab7387d 100644 --- a/src/platform_impl/linux/x11/monitor.rs +++ b/src/platform_impl/linux/x11/monitor.rs @@ -2,8 +2,8 @@ use std::os::raw::*; use parking_lot::Mutex; -use dpi::{PhysicalPosition, PhysicalSize}; -use monitor::VideoMode; +use crate::dpi::{PhysicalPosition, PhysicalSize}; +use crate::monitor::VideoMode; use super::{util, XConnection, XError}; use super::ffi::{ RRCrtcChangeNotifyMask, diff --git a/src/platform_impl/linux/x11/util/client_msg.rs b/src/platform_impl/linux/x11/util/client_msg.rs index 399db4f1..8e2d2314 100644 --- a/src/platform_impl/linux/x11/util/client_msg.rs +++ b/src/platform_impl/linux/x11/util/client_msg.rs @@ -8,7 +8,7 @@ impl XConnection { target_window: c_ulong, event_mask: Option, event: T, - ) -> Flusher { + ) -> Flusher<'_> { let event_mask = event_mask.unwrap_or(ffi::NoEventMask); unsafe { (self.xlib.XSendEvent)( @@ -29,7 +29,7 @@ impl XConnection { message_type: ffi::Atom, event_mask: Option, data: ClientMsgPayload, - ) -> Flusher { + ) -> Flusher<'_> { let mut event: ffi::XClientMessageEvent = unsafe { mem::uninitialized() }; event.type_ = ffi::ClientMessage; event.display = self.display; @@ -50,7 +50,7 @@ impl XConnection { message_type: ffi::Atom, event_mask: Option, data: &[T], - ) -> Flusher { + ) -> Flusher<'_> { let format = T::FORMAT; let size_of_t = mem::size_of::(); debug_assert_eq!(size_of_t, format.get_actual_size()); diff --git a/src/platform_impl/linux/x11/util/geometry.rs b/src/platform_impl/linux/x11/util/geometry.rs index f3bd1281..eef35479 100644 --- a/src/platform_impl/linux/x11/util/geometry.rs +++ b/src/platform_impl/linux/x11/util/geometry.rs @@ -1,7 +1,7 @@ use std::cmp; use super::*; -use dpi::{LogicalPosition, LogicalSize}; +use crate::dpi::{LogicalPosition, LogicalSize}; // Friendly neighborhood axis-aligned rectangle #[derive(Debug, Clone, PartialEq, Eq)] diff --git a/src/platform_impl/linux/x11/util/hint.rs b/src/platform_impl/linux/x11/util/hint.rs index 5405e5e5..3169abb7 100644 --- a/src/platform_impl/linux/x11/util/hint.rs +++ b/src/platform_impl/linux/x11/util/hint.rs @@ -187,7 +187,7 @@ impl<'a> NormalHints<'a> { } impl XConnection { - pub fn get_wm_hints(&self, window: ffi::Window) -> Result, XError> { + pub fn get_wm_hints(&self, window: ffi::Window) -> Result, XError> { let wm_hints = unsafe { (self.xlib.XGetWMHints)(self.display, window) }; self.check_errors()?; let wm_hints = if wm_hints.is_null() { @@ -198,7 +198,7 @@ impl XConnection { Ok(wm_hints) } - pub fn set_wm_hints(&self, window: ffi::Window, wm_hints: XSmartPointer) -> Flusher { + pub fn set_wm_hints(&self, window: ffi::Window, wm_hints: XSmartPointer<'_, ffi::XWMHints>) -> Flusher<'_> { unsafe { (self.xlib.XSetWMHints)( self.display, @@ -209,7 +209,7 @@ impl XConnection { Flusher::new(self) } - pub fn get_normal_hints(&self, window: ffi::Window) -> Result { + pub fn get_normal_hints(&self, window: ffi::Window) -> Result, XError> { let size_hints = self.alloc_size_hints(); let mut supplied_by_user: c_long = unsafe { mem::uninitialized() }; unsafe { @@ -223,7 +223,7 @@ impl XConnection { self.check_errors().map(|_| NormalHints { size_hints }) } - pub fn set_normal_hints(&self, window: ffi::Window, normal_hints: NormalHints) -> Flusher { + pub fn set_normal_hints(&self, window: ffi::Window, normal_hints: NormalHints<'_>) -> Flusher<'_> { unsafe { (self.xlib.XSetWMNormalHints)( self.display, diff --git a/src/platform_impl/linux/x11/util/icon.rs b/src/platform_impl/linux/x11/util/icon.rs index 9bcaf952..fa118ade 100644 --- a/src/platform_impl/linux/x11/util/icon.rs +++ b/src/platform_impl/linux/x11/util/icon.rs @@ -1,4 +1,4 @@ -use window::{Icon, Pixel, PIXEL_SIZE}; +use crate::window::{Icon, Pixel, PIXEL_SIZE}; use super::*; impl Pixel { diff --git a/src/platform_impl/linux/x11/util/input.rs b/src/platform_impl/linux/x11/util/input.rs index aa530e77..afb4e9f7 100644 --- a/src/platform_impl/linux/x11/util/input.rs +++ b/src/platform_impl/linux/x11/util/input.rs @@ -1,7 +1,7 @@ use std::str; use super::*; -use event::ModifiersState; +use crate::event::ModifiersState; pub const VIRTUAL_CORE_POINTER: c_int = 2; pub const VIRTUAL_CORE_KEYBOARD: c_int = 3; @@ -55,7 +55,7 @@ impl<'a> Drop for PointerState<'a> { } impl XConnection { - pub fn select_xinput_events(&self, window: c_ulong, device_id: c_int, mask: i32) -> Flusher { + pub fn select_xinput_events(&self, window: c_ulong, device_id: c_int, mask: i32) -> Flusher<'_> { let mut event_mask = ffi::XIEventMask { deviceid: device_id, mask: &mask as *const _ as *mut c_uchar, @@ -73,7 +73,7 @@ impl XConnection { } #[allow(dead_code)] - pub fn select_xkb_events(&self, device_id: c_uint, mask: c_ulong) -> Option { + pub fn select_xkb_events(&self, device_id: c_uint, mask: c_ulong) -> Option> { let status = unsafe { (self.xlib.XkbSelectEvents)( self.display, @@ -89,9 +89,9 @@ impl XConnection { } } - pub fn query_pointer(&self, window: ffi::Window, device_id: c_int) -> Result { + pub fn query_pointer(&self, window: ffi::Window, device_id: c_int) -> Result, XError> { unsafe { - let mut pointer_state: PointerState = mem::uninitialized(); + let mut pointer_state: PointerState<'_> = mem::uninitialized(); pointer_state.xconn = self; pointer_state.relative_to_window = (self.xinput2.XIQueryPointer)( self.display, diff --git a/src/platform_impl/linux/x11/util/memory.rs b/src/platform_impl/linux/x11/util/memory.rs index eef0bdc9..be9aeebd 100644 --- a/src/platform_impl/linux/x11/util/memory.rs +++ b/src/platform_impl/linux/x11/util/memory.rs @@ -45,17 +45,17 @@ impl<'a, T> Drop for XSmartPointer<'a, T> { } impl XConnection { - pub fn alloc_class_hint(&self) -> XSmartPointer { + pub fn alloc_class_hint(&self) -> XSmartPointer<'_, ffi::XClassHint> { XSmartPointer::new(self, unsafe { (self.xlib.XAllocClassHint)() }) .expect("`XAllocClassHint` returned null; out of memory") } - pub fn alloc_size_hints(&self) -> XSmartPointer { + pub fn alloc_size_hints(&self) -> XSmartPointer<'_, ffi::XSizeHints> { XSmartPointer::new(self, unsafe { (self.xlib.XAllocSizeHints)() }) .expect("`XAllocSizeHints` returned null; out of memory") } - pub fn alloc_wm_hints(&self) -> XSmartPointer { + pub fn alloc_wm_hints(&self) -> XSmartPointer<'_, ffi::XWMHints> { XSmartPointer::new(self, unsafe { (self.xlib.XAllocWMHints)() }) .expect("`XAllocWMHints` returned null; out of memory") } diff --git a/src/platform_impl/linux/x11/util/randr.rs b/src/platform_impl/linux/x11/util/randr.rs index 4513e77d..ddc261fe 100644 --- a/src/platform_impl/linux/x11/util/randr.rs +++ b/src/platform_impl/linux/x11/util/randr.rs @@ -1,8 +1,8 @@ use std::{env, slice}; use std::str::FromStr; -use monitor::VideoMode; -use dpi::validate_hidpi_factor; +use crate::monitor::VideoMode; +use crate::dpi::validate_hidpi_factor; use super::*; pub fn calc_dpi_factor( diff --git a/src/platform_impl/linux/x11/window.rs b/src/platform_impl/linux/x11/window.rs index 1e5330c7..78fa8fa7 100644 --- a/src/platform_impl/linux/x11/window.rs +++ b/src/platform_impl/linux/x11/window.rs @@ -8,14 +8,14 @@ use std::sync::Arc; use libc; use parking_lot::Mutex; -use error::{ExternalError, NotSupportedError, OsError as RootOsError}; -use window::{Icon, CursorIcon, WindowAttributes}; -use dpi::{LogicalPosition, LogicalSize}; -use platform_impl::MonitorHandle as PlatformMonitorHandle; -use platform_impl::{OsError, PlatformSpecificWindowBuilderAttributes}; -use platform_impl::x11::ime::ImeContextCreationError; -use platform_impl::x11::MonitorHandle as X11MonitorHandle; -use monitor::MonitorHandle as RootMonitorHandle; +use crate::error::{ExternalError, NotSupportedError, OsError as RootOsError}; +use crate::window::{Icon, CursorIcon, WindowAttributes}; +use crate::dpi::{LogicalPosition, LogicalSize}; +use crate::platform_impl::MonitorHandle as PlatformMonitorHandle; +use crate::platform_impl::{OsError, PlatformSpecificWindowBuilderAttributes}; +use crate::platform_impl::x11::ime::ImeContextCreationError; +use crate::platform_impl::x11::MonitorHandle as X11MonitorHandle; +use crate::monitor::MonitorHandle as RootMonitorHandle; use super::{ffi, util, ImeSender, XConnection, XError, WindowId, EventLoopWindowTarget}; @@ -429,7 +429,7 @@ impl UnownedWindow { LogicalSize::from_physical((width, height), dpi) } - fn set_pid(&self) -> Option { + fn set_pid(&self) -> Option> { let pid_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_PID\0") }; let client_machine_atom = unsafe { self.xconn.get_atom_unchecked(b"WM_CLIENT_MACHINE\0") }; unsafe { @@ -462,7 +462,7 @@ impl UnownedWindow { } } - fn set_window_type(&self, window_type: util::WindowType) -> util::Flusher { + fn set_window_type(&self, window_type: util::WindowType) -> util::Flusher<'_> { let hint_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_WINDOW_TYPE\0") }; let window_type_atom = window_type.as_atom(&self.xconn); self.xconn.change_property( @@ -474,7 +474,7 @@ impl UnownedWindow { ) } - fn set_gtk_theme_variant(&self, variant: String) -> util::Flusher { + fn set_gtk_theme_variant(&self, variant: String) -> util::Flusher<'_> { let hint_atom = unsafe { self.xconn.get_atom_unchecked(b"_GTK_THEME_VARIANT\0") }; let utf8_atom = unsafe { self.xconn.get_atom_unchecked(b"UTF8_STRING\0") }; let variant = CString::new(variant).expect("`_GTK_THEME_VARIANT` contained null byte"); @@ -502,7 +502,7 @@ impl UnownedWindow { &self, operation: util::StateOperation, properties: (c_long, c_long, c_long, c_long), - ) -> util::Flusher { + ) -> util::Flusher<'_> { let state_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_STATE\0") }; self.xconn.send_client_msg( self.xwindow, @@ -519,12 +519,12 @@ impl UnownedWindow { ) } - fn set_fullscreen_hint(&self, fullscreen: bool) -> util::Flusher { + fn set_fullscreen_hint(&self, fullscreen: bool) -> util::Flusher<'_> { let fullscreen_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_STATE_FULLSCREEN\0") }; self.set_netwm(fullscreen.into(), (fullscreen_atom as c_long, 0, 0, 0)) } - fn set_fullscreen_inner(&self, monitor: Option) -> util::Flusher { + fn set_fullscreen_inner(&self, monitor: Option) -> util::Flusher<'_> { match monitor { None => { let flusher = self.set_fullscreen_hint(false); @@ -588,7 +588,7 @@ impl UnownedWindow { self.xconn.primary_monitor() } - fn set_maximized_inner(&self, maximized: bool) -> util::Flusher { + fn set_maximized_inner(&self, maximized: bool) -> util::Flusher<'_> { let horz_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_STATE_MAXIMIZED_HORZ\0") }; let vert_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_STATE_MAXIMIZED_VERT\0") }; self.set_netwm(maximized.into(), (horz_atom as c_long, vert_atom as c_long, 0, 0)) @@ -602,7 +602,7 @@ impl UnownedWindow { self.invalidate_cached_frame_extents(); } - fn set_title_inner(&self, title: &str) -> util::Flusher { + fn set_title_inner(&self, title: &str) -> util::Flusher<'_> { let wm_name_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_NAME\0") }; let utf8_atom = unsafe { self.xconn.get_atom_unchecked(b"UTF8_STRING\0") }; let title = CString::new(title).expect("Window title contained null byte"); @@ -629,7 +629,7 @@ impl UnownedWindow { .expect("Failed to set window title"); } - fn set_decorations_inner(&self, decorations: bool) -> util::Flusher { + fn set_decorations_inner(&self, decorations: bool) -> util::Flusher<'_> { let wm_hints = unsafe { self.xconn.get_atom_unchecked(b"_MOTIF_WM_HINTS\0") }; self.xconn.change_property( self.xwindow, @@ -654,7 +654,7 @@ impl UnownedWindow { self.invalidate_cached_frame_extents(); } - fn set_always_on_top_inner(&self, always_on_top: bool) -> util::Flusher { + fn set_always_on_top_inner(&self, always_on_top: bool) -> util::Flusher<'_> { let above_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_STATE_ABOVE\0") }; self.set_netwm(always_on_top.into(), (above_atom as c_long, 0, 0, 0)) } @@ -666,7 +666,7 @@ impl UnownedWindow { .expect("Failed to set always-on-top state"); } - fn set_icon_inner(&self, icon: Icon) -> util::Flusher { + fn set_icon_inner(&self, icon: Icon) -> util::Flusher<'_> { let icon_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_ICON\0") }; let data = icon.to_cardinals(); self.xconn.change_property( @@ -678,7 +678,7 @@ impl UnownedWindow { ) } - fn unset_icon_inner(&self) -> util::Flusher { + fn unset_icon_inner(&self) -> util::Flusher<'_> { let icon_atom = unsafe { self.xconn.get_atom_unchecked(b"_NET_WM_ICON\0") }; let empty_data: [util::Cardinal; 0] = []; self.xconn.change_property( @@ -759,7 +759,7 @@ impl UnownedWindow { Ok(self.logicalize_coords(self.inner_position_physical())) } - pub(crate) fn set_position_inner(&self, mut x: i32, mut y: i32) -> util::Flusher { + pub(crate) fn set_position_inner(&self, mut x: i32, mut y: i32) -> util::Flusher<'_> { // There are a few WMs that set client area position rather than window position, so // we'll translate for consistency. if util::wm_name_is_one_of(&["Enlightenment", "FVWM"]) { @@ -851,7 +851,7 @@ impl UnownedWindow { } fn update_normal_hints(&self, callback: F) -> Result<(), XError> - where F: FnOnce(&mut util::NormalHints) -> () + where F: FnOnce(&mut util::NormalHints<'_>) -> () { let mut normal_hints = self.xconn.get_normal_hints(self.xwindow)?; callback(&mut normal_hints); @@ -892,7 +892,7 @@ impl UnownedWindow { new_dpi_factor: f64, width: f64, height: f64, - ) -> (f64, f64, util::Flusher) { + ) -> (f64, f64, util::Flusher<'_>) { let scale_factor = new_dpi_factor / old_dpi_factor; let new_width = width * scale_factor; let new_height = height * scale_factor; diff --git a/src/platform_impl/linux/x11/xdisplay.rs b/src/platform_impl/linux/x11/xdisplay.rs index 61e441bd..1e9d6e26 100644 --- a/src/platform_impl/linux/x11/xdisplay.rs +++ b/src/platform_impl/linux/x11/xdisplay.rs @@ -90,7 +90,7 @@ impl XConnection { } impl fmt::Debug for XConnection { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { self.display.fmt(f) } } @@ -119,7 +119,7 @@ impl Error for XError { } impl fmt::Display for XError { - fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { write!(formatter, "X error: {} (code: {}, request code: {}, minor code: {})", self.description, self.error_code, self.request_code, self.minor_code) } @@ -151,7 +151,7 @@ impl Error for XNotSupported { } #[inline] - fn cause(&self) -> Option<&Error> { + fn cause(&self) -> Option<&dyn Error> { match *self { XNotSupported::LibraryOpenError(ref err) => Some(err), _ => None @@ -160,7 +160,7 @@ impl Error for XNotSupported { } impl fmt::Display for XNotSupported { - fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { formatter.write_str(self.description()) } } diff --git a/src/platform_impl/macos/app.rs b/src/platform_impl/macos/app.rs index 2699eedc..576c6db7 100644 --- a/src/platform_impl/macos/app.rs +++ b/src/platform_impl/macos/app.rs @@ -3,8 +3,8 @@ use std::collections::VecDeque; use cocoa::{appkit::{self, NSEvent}, base::id}; use objc::{declare::ClassDecl, runtime::{Class, Object, Sel}}; -use event::{DeviceEvent, Event}; -use platform_impl::platform::{app_state::AppState, DEVICE_ID, util}; +use crate::event::{DeviceEvent, Event}; +use crate::platform_impl::platform::{app_state::AppState, DEVICE_ID, util}; pub struct AppClass(pub *const Class); unsafe impl Send for AppClass {} diff --git a/src/platform_impl/macos/app_delegate.rs b/src/platform_impl/macos/app_delegate.rs index 8e4ab19d..ead1619e 100644 --- a/src/platform_impl/macos/app_delegate.rs +++ b/src/platform_impl/macos/app_delegate.rs @@ -1,7 +1,7 @@ use cocoa::base::id; use objc::{runtime::{Class, Object, Sel, BOOL, YES}, declare::ClassDecl}; -use platform_impl::platform::app_state::AppState; +use crate::platform_impl::platform::app_state::AppState; pub struct AppDelegateClass(pub *const Class); unsafe impl Send for AppDelegateClass {} diff --git a/src/platform_impl/macos/app_state.rs b/src/platform_impl/macos/app_state.rs index cc9d4b22..354325bb 100644 --- a/src/platform_impl/macos/app_state.rs +++ b/src/platform_impl/macos/app_state.rs @@ -6,12 +6,12 @@ use std::{ use cocoa::{appkit::NSApp, base::nil}; -use { +use crate::{ event::{Event, StartCause, WindowEvent}, event_loop::{ControlFlow, EventLoopWindowTarget as RootWindowTarget}, window::WindowId, }; -use platform_impl::platform::{observer::EventLoopWaker, util::Never}; +use crate::platform_impl::platform::{observer::EventLoopWaker, util::Never}; lazy_static! { static ref HANDLER: Handler = Default::default(); @@ -38,7 +38,7 @@ struct EventLoopHandler { } impl Debug for EventLoopHandler { - fn fmt(&self, formatter: &mut Formatter) -> fmt::Result { + fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { formatter.debug_struct("EventLoopHandler") .field("window_target", &self.window_target) .finish() diff --git a/src/platform_impl/macos/event.rs b/src/platform_impl/macos/event.rs index c19c5300..73009e42 100644 --- a/src/platform_impl/macos/event.rs +++ b/src/platform_impl/macos/event.rs @@ -2,11 +2,11 @@ use std::os::raw::c_ushort; use cocoa::{appkit::{NSEvent, NSEventModifierFlags}, base::id}; -use event::{ +use crate::event::{ ElementState, KeyboardInput, ModifiersState, VirtualKeyCode, WindowEvent, }; -use platform_impl::platform::DEVICE_ID; +use crate::platform_impl::platform::DEVICE_ID; pub fn char_to_keycode(c: char) -> Option { // We only translate keys that are affected by keyboard layout. diff --git a/src/platform_impl/macos/event_loop.rs b/src/platform_impl/macos/event_loop.rs index 510dd84b..1a78033d 100644 --- a/src/platform_impl/macos/event_loop.rs +++ b/src/platform_impl/macos/event_loop.rs @@ -4,11 +4,11 @@ use std::{ use cocoa::{appkit::NSApp, base::{id, nil}, foundation::NSAutoreleasePool}; -use { +use crate::{ event::Event, event_loop::{ControlFlow, EventLoopClosed, EventLoopWindowTarget as RootWindowTarget}, }; -use platform_impl::platform::{ +use crate::platform_impl::platform::{ app::APP_CLASS, app_delegate::APP_DELEGATE_CLASS, app_state::AppState, monitor::{self, MonitorHandle}, observer::*, util::IdRef, diff --git a/src/platform_impl/macos/mod.rs b/src/platform_impl/macos/mod.rs index 2b5d9f5d..5efc9219 100644 --- a/src/platform_impl/macos/mod.rs +++ b/src/platform_impl/macos/mod.rs @@ -15,7 +15,7 @@ mod window_delegate; use std::{fmt, ops::Deref, sync::Arc}; -use { +use crate::{ event::DeviceId as RootDeviceId, window::WindowAttributes, error::OsError as RootOsError, }; @@ -74,7 +74,7 @@ impl Window { } impl fmt::Display for OsError { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { OsError::CGError(e) => f.pad(&format!("CGError {}", e)), OsError::CreationError(e) => f.pad(e), diff --git a/src/platform_impl/macos/monitor.rs b/src/platform_impl/macos/monitor.rs index 43cfe556..a80495c2 100644 --- a/src/platform_impl/macos/monitor.rs +++ b/src/platform_impl/macos/monitor.rs @@ -11,9 +11,9 @@ use core_video_sys::{ CVDisplayLinkGetNominalOutputVideoRefreshPeriod, CVDisplayLinkRelease, }; -use dpi::{PhysicalPosition, PhysicalSize}; -use monitor::VideoMode; -use platform_impl::platform::util::IdRef; +use crate::dpi::{PhysicalPosition, PhysicalSize}; +use crate::monitor::VideoMode; +use crate::platform_impl::platform::util::IdRef; #[derive(Clone, PartialEq)] pub struct MonitorHandle(CGDirectDisplayID); @@ -35,7 +35,7 @@ pub fn primary_monitor() -> MonitorHandle { } impl fmt::Debug for MonitorHandle { - fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { // TODO: Do this using the proper fmt API #[derive(Debug)] struct MonitorHandle { diff --git a/src/platform_impl/macos/observer.rs b/src/platform_impl/macos/observer.rs index 79b4c997..6289e914 100644 --- a/src/platform_impl/macos/observer.rs +++ b/src/platform_impl/macos/observer.rs @@ -1,6 +1,6 @@ use std::{self, ptr, os::raw::*, time::Instant}; -use platform_impl::platform::app_state::AppState; +use crate::platform_impl::platform::app_state::AppState; #[link(name = "CoreFoundation", kind = "framework")] extern { diff --git a/src/platform_impl/macos/util/async.rs b/src/platform_impl/macos/util/async.rs index 0f905bdd..9c972f81 100644 --- a/src/platform_impl/macos/util/async.rs +++ b/src/platform_impl/macos/util/async.rs @@ -7,8 +7,8 @@ use cocoa::{ }; use dispatch::ffi::{dispatch_async_f, dispatch_get_main_queue, dispatch_sync_f}; -use dpi::LogicalSize; -use platform_impl::platform::{ffi, window::SharedState}; +use crate::dpi::LogicalSize; +use crate::platform_impl::platform::{ffi, window::SharedState}; unsafe fn set_style_mask(ns_window: id, ns_view: id, mask: NSWindowStyleMask) { ns_window.setStyleMask_(mask); diff --git a/src/platform_impl/macos/util/cursor.rs b/src/platform_impl/macos/util/cursor.rs index 9d93762d..c6ad861b 100644 --- a/src/platform_impl/macos/util/cursor.rs +++ b/src/platform_impl/macos/util/cursor.rs @@ -4,7 +4,7 @@ use cocoa::{ }; use objc::runtime::Sel; -use window::CursorIcon; +use crate::window::CursorIcon; pub enum Cursor { Native(&'static str), diff --git a/src/platform_impl/macos/util/mod.rs b/src/platform_impl/macos/util/mod.rs index a8d6a83b..3bc0ad3b 100644 --- a/src/platform_impl/macos/util/mod.rs +++ b/src/platform_impl/macos/util/mod.rs @@ -1,7 +1,7 @@ -mod async; +mod r#async; mod cursor; -pub use self::{async::*, cursor::*}; +pub use self::{r#async::*, cursor::*}; use std::ops::Deref; use std::ops::BitAnd; @@ -14,7 +14,7 @@ use cocoa::{ use core_graphics::display::CGDisplay; use objc::runtime::{BOOL, Class, Object, Sel, YES}; -use platform_impl::platform::ffi; +use crate::platform_impl::platform::ffi; // Replace with `!` once stable #[derive(Debug)] diff --git a/src/platform_impl/macos/view.rs b/src/platform_impl/macos/view.rs index 891f181b..63275eb4 100644 --- a/src/platform_impl/macos/view.rs +++ b/src/platform_impl/macos/view.rs @@ -9,14 +9,14 @@ use cocoa::{ }; use objc::{declare::ClassDecl, runtime::{BOOL, Class, NO, Object, Protocol, Sel, YES}}; -use { +use crate::{ event::{ DeviceEvent, ElementState, Event, KeyboardInput, MouseButton, MouseScrollDelta, TouchPhase, VirtualKeyCode, WindowEvent, }, window::WindowId, }; -use platform_impl::platform::{ +use crate::platform_impl::platform::{ app_state::AppState, DEVICE_ID, event::{check_function_keys, event_mods, modifier_event, char_to_keycode, get_scancode, scancode_to_keycode}, util::{self, IdRef}, ffi::*, window::get_window_id, diff --git a/src/platform_impl/macos/window.rs b/src/platform_impl/macos/window.rs index 37abb20d..a7a9b4c1 100644 --- a/src/platform_impl/macos/window.rs +++ b/src/platform_impl/macos/window.rs @@ -15,7 +15,7 @@ use cocoa::{ use core_graphics::display::CGDisplay; use objc::{runtime::{Class, Object, Sel, BOOL, YES, NO}, declare::ClassDecl}; -use { +use crate::{ dpi::{LogicalPosition, LogicalSize}, icon::Icon, error::{ExternalError, NotSupportedError, OsError as RootOsError}, monitor::MonitorHandle as RootMonitorHandle, @@ -23,8 +23,8 @@ use { CursorIcon, WindowAttributes, WindowId as RootWindowId, }, }; -use platform::macos::{ActivationPolicy, WindowExtMacOS}; -use platform_impl::platform::{ +use crate::platform::macos::{ActivationPolicy, WindowExtMacOS}; +use crate::platform_impl::platform::{ OsError, app_state::AppState, ffi, monitor::{self, MonitorHandle}, util::{self, IdRef}, view::{self, new_view}, diff --git a/src/platform_impl/macos/window_delegate.rs b/src/platform_impl/macos/window_delegate.rs index 658f9d66..810c9788 100644 --- a/src/platform_impl/macos/window_delegate.rs +++ b/src/platform_impl/macos/window_delegate.rs @@ -6,8 +6,8 @@ use cocoa::{ }; use objc::{runtime::{Class, Object, Sel, BOOL, YES, NO}, declare::ClassDecl}; -use {dpi::LogicalSize, event::{Event, WindowEvent}, window::WindowId}; -use platform_impl::platform::{ +use crate::{dpi::LogicalSize, event::{Event, WindowEvent}, window::WindowId}; +use crate::platform_impl::platform::{ app_state::AppState, util::{self, IdRef}, window::{get_window_id, UnownedWindow}, }; diff --git a/src/platform_impl/windows/drop_handler.rs b/src/platform_impl/windows/drop_handler.rs index 6895bf30..66620c5a 100644 --- a/src/platform_impl/windows/drop_handler.rs +++ b/src/platform_impl/windows/drop_handler.rs @@ -14,17 +14,17 @@ use winapi::um::oleidl::{DROPEFFECT_COPY, DROPEFFECT_NONE, IDropTarget, IDropTar use winapi::um::winnt::HRESULT; use winapi::um::{shellapi, unknwnbase}; -use platform_impl::platform::WindowId; +use crate::platform_impl::platform::WindowId; -use event::Event; -use window::WindowId as SuperWindowId; +use crate::event::Event; +use crate::window::WindowId as SuperWindowId; #[repr(C)] pub struct FileDropHandlerData { pub interface: IDropTarget, refcount: AtomicUsize, window: HWND, - send_event: Box)>, + send_event: Box)>, cursor_effect: DWORD, hovered_is_valid: bool, // If the currently hovered item is not valid there must not be any `HoveredFileCancelled` emitted } @@ -35,7 +35,7 @@ pub struct FileDropHandler { #[allow(non_snake_case)] impl FileDropHandler { - pub fn new(window: HWND, send_event: Box)>) -> FileDropHandler { + pub fn new(window: HWND, send_event: Box)>) -> FileDropHandler { let data = Box::new(FileDropHandlerData { interface: IDropTarget { lpVtbl: &DROP_TARGET_VTBL as *const IDropTargetVtbl, @@ -85,7 +85,7 @@ impl FileDropHandler { _pt: *const POINTL, pdwEffect: *mut DWORD, ) -> HRESULT { - use event::WindowEvent::HoveredFile; + use crate::event::WindowEvent::HoveredFile; let drop_handler = Self::from_interface(this); let hdrop = Self::iterate_filenames(pDataObj, |filename| { drop_handler.send_event(Event::WindowEvent { @@ -117,7 +117,7 @@ impl FileDropHandler { } pub unsafe extern "system" fn DragLeave(this: *mut IDropTarget) -> HRESULT { - use event::WindowEvent::HoveredFileCancelled; + use crate::event::WindowEvent::HoveredFileCancelled; let drop_handler = Self::from_interface(this); if drop_handler.hovered_is_valid { drop_handler.send_event(Event::WindowEvent { @@ -136,7 +136,7 @@ impl FileDropHandler { _pt: *const POINTL, _pdwEffect: *mut DWORD, ) -> HRESULT { - use event::WindowEvent::DroppedFile; + use crate::event::WindowEvent::DroppedFile; let drop_handler = Self::from_interface(this); let hdrop = Self::iterate_filenames(pDataObj, |filename| { drop_handler.send_event(Event::WindowEvent { diff --git a/src/platform_impl/windows/event.rs b/src/platform_impl/windows/event.rs index a3d733d2..dee15c8c 100644 --- a/src/platform_impl/windows/event.rs +++ b/src/platform_impl/windows/event.rs @@ -2,7 +2,7 @@ use std::{char, ptr}; use std::os::raw::c_int; use std::sync::atomic::{AtomicBool, AtomicPtr, Ordering}; -use event::{ScanCode, ModifiersState, VirtualKeyCode}; +use crate::event::{ScanCode, ModifiersState, VirtualKeyCode}; use winapi::shared::minwindef::{WPARAM, LPARAM, UINT, HKL, HKL__}; use winapi::um::winuser; diff --git a/src/platform_impl/windows/event_loop.rs b/src/platform_impl/windows/event_loop.rs index 1d49060d..4c399386 100644 --- a/src/platform_impl/windows/event_loop.rs +++ b/src/platform_impl/windows/event_loop.rs @@ -43,22 +43,22 @@ use winapi::shared::{windowsx, winerror}; use winapi::um::{winuser, winbase, ole2, processthreadsapi, commctrl, libloaderapi}; use winapi::um::winnt::{LONG, LPCSTR, SHORT}; -use window::WindowId as RootWindowId; -use event_loop::{ControlFlow, EventLoopWindowTarget as RootELW, EventLoopClosed}; -use dpi::{LogicalPosition, LogicalSize, PhysicalSize}; -use event::{DeviceEvent, Touch, TouchPhase, StartCause, KeyboardInput, Event, WindowEvent}; -use platform_impl::platform::{event, WindowId, DEVICE_ID, wrap_device_id, util}; -use platform_impl::platform::dpi::{ +use crate::window::WindowId as RootWindowId; +use crate::event_loop::{ControlFlow, EventLoopWindowTarget as RootELW, EventLoopClosed}; +use crate::dpi::{LogicalPosition, LogicalSize, PhysicalSize}; +use crate::event::{DeviceEvent, Touch, TouchPhase, StartCause, KeyboardInput, Event, WindowEvent}; +use crate::platform_impl::platform::{event, WindowId, DEVICE_ID, wrap_device_id, util}; +use crate::platform_impl::platform::dpi::{ become_dpi_aware, dpi_to_scale_factor, enable_non_client_dpi_scaling, hwnd_scale_factor, }; -use platform_impl::platform::drop_handler::FileDropHandler; -use platform_impl::platform::event::{handle_extended_keys, process_key_params, vkey_to_winit_vkey}; -use platform_impl::platform::raw_input::{get_raw_input_data, get_raw_mouse_button_state}; -use platform_impl::platform::window::adjust_size; -use platform_impl::platform::window_state::{CursorFlags, WindowFlags, WindowState}; +use crate::platform_impl::platform::drop_handler::FileDropHandler; +use crate::platform_impl::platform::event::{handle_extended_keys, process_key_params, vkey_to_winit_vkey}; +use crate::platform_impl::platform::raw_input::{get_raw_input_data, get_raw_mouse_button_state}; +use crate::platform_impl::platform::window::adjust_size; +use crate::platform_impl::platform::window_state::{CursorFlags, WindowFlags, WindowState}; pub(crate) struct SubclassInput { pub window_state: Arc>, @@ -237,10 +237,10 @@ pub(crate) struct EventLoopRunner { runner_state: RunnerState, modal_redraw_window: HWND, in_modal_loop: bool, - event_handler: Box, &mut ControlFlow)>, + event_handler: Box, &mut ControlFlow)>, panic_error: Option, } -type PanicError = Box; +type PanicError = Box; impl ELRShared { pub(crate) unsafe fn send_event(&self, event: Event) { @@ -297,8 +297,8 @@ impl EventLoopRunner { in_modal_loop: false, modal_redraw_window: event_loop.window_target.p.thread_msg_target, event_handler: mem::transmute::< - Box, &mut ControlFlow)>, - Box, &mut ControlFlow)> + Box, &mut ControlFlow)>, + Box, &mut ControlFlow)> >(Box::new(f)), panic_error: None, } @@ -583,7 +583,7 @@ impl EventLoopThreadExecutor { function(); } else { // We double-box because the first box is a fat pointer. - let boxed = Box::new(function) as Box; + let boxed = Box::new(function) as Box; let boxed2: ThreadExecFn = Box::new(boxed); let raw = Box::into_raw(boxed2); @@ -598,7 +598,7 @@ impl EventLoopThreadExecutor { } } -type ThreadExecFn = Box>; +type ThreadExecFn = Box>; #[derive(Clone)] pub struct EventLoopProxy { @@ -629,7 +629,7 @@ lazy_static! { } }; // Message sent when we want to execute a closure in the thread. - // WPARAM contains a Box> that must be retrieved with `Box::from_raw`, + // WPARAM contains a Box> that must be retrieved with `Box::from_raw`, // and LPARAM is unused. static ref EXEC_MSG_ID: u32 = { unsafe { @@ -814,7 +814,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_CLOSE => { - use event::WindowEvent::CloseRequested; + use crate::event::WindowEvent::CloseRequested; subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), event: CloseRequested, @@ -823,7 +823,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_DESTROY => { - use event::WindowEvent::Destroyed; + use crate::event::WindowEvent::Destroyed; ole2::RevokeDragDrop(window); subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), @@ -836,7 +836,7 @@ unsafe extern "system" fn public_window_callback( }, _ if msg == *REQUEST_REDRAW_NO_NEWEVENTS_MSG_ID => { - use event::WindowEvent::RedrawRequested; + use crate::event::WindowEvent::RedrawRequested; let mut runner = subclass_input.event_loop_runner.runner.borrow_mut(); if let Some(ref mut runner) = *runner { // This check makes sure that calls to `request_redraw()` during `EventsCleared` @@ -871,7 +871,7 @@ unsafe extern "system" fn public_window_callback( 0 }, winuser::WM_PAINT => { - use event::WindowEvent::RedrawRequested; + use crate::event::WindowEvent::RedrawRequested; subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), event: RedrawRequested, @@ -881,7 +881,7 @@ unsafe extern "system" fn public_window_callback( // WM_MOVE supplies client area positions, so we send Moved here instead. winuser::WM_WINDOWPOSCHANGED => { - use event::WindowEvent::Moved; + use crate::event::WindowEvent::Moved; let windowpos = lparam as *const winuser::WINDOWPOS; if (*windowpos).flags & winuser::SWP_NOMOVE != winuser::SWP_NOMOVE { @@ -901,7 +901,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_SIZE => { - use event::WindowEvent::Resized; + use crate::event::WindowEvent::Resized; let w = LOWORD(lparam as DWORD) as u32; let h = HIWORD(lparam as DWORD) as u32; @@ -926,7 +926,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_CHAR => { - use event::WindowEvent::ReceivedCharacter; + use crate::event::WindowEvent::ReceivedCharacter; let chr: char = mem::transmute(wparam as u32); subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), @@ -944,7 +944,7 @@ unsafe extern "system" fn public_window_callback( } winuser::WM_MOUSEMOVE => { - use event::WindowEvent::{CursorEntered, CursorMoved}; + use crate::event::WindowEvent::{CursorEntered, CursorMoved}; let mouse_was_outside_window = { let mut w = subclass_input.window_state.lock(); @@ -982,7 +982,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_MOUSELEAVE => { - use event::WindowEvent::CursorLeft; + use crate::event::WindowEvent::CursorLeft; { let mut w = subclass_input.window_state.lock(); w.mouse.set_cursor_flags(window, |f| f.set(CursorFlags::IN_WINDOW, false)).ok(); @@ -997,7 +997,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_MOUSEWHEEL => { - use event::MouseScrollDelta::LineDelta; + use crate::event::MouseScrollDelta::LineDelta; let value = (wparam >> 16) as i16; let value = value as i32; @@ -1012,7 +1012,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_MOUSEHWHEEL => { - use event::MouseScrollDelta::LineDelta; + use crate::event::MouseScrollDelta::LineDelta; let value = (wparam >> 16) as i16; let value = value as i32; @@ -1027,8 +1027,8 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_KEYDOWN | winuser::WM_SYSKEYDOWN => { - use event::ElementState::Pressed; - use event::VirtualKeyCode; + use crate::event::ElementState::Pressed; + use crate::event::VirtualKeyCode; if msg == winuser::WM_SYSKEYDOWN && wparam as i32 == winuser::VK_F4 { commctrl::DefSubclassProc(window, msg, wparam, lparam) } else { @@ -1059,7 +1059,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_KEYUP | winuser::WM_SYSKEYUP => { - use event::ElementState::Released; + use crate::event::ElementState::Released; if let Some((scancode, vkey)) = process_key_params(wparam, lparam) { subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), @@ -1078,9 +1078,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_LBUTTONDOWN => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Left; - use event::ElementState::Pressed; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Left; + use crate::event::ElementState::Pressed; capture_mouse(window, &mut *subclass_input.window_state.lock()); @@ -1092,9 +1092,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_LBUTTONUP => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Left; - use event::ElementState::Released; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Left; + use crate::event::ElementState::Released; release_mouse(&mut *subclass_input.window_state.lock()); @@ -1106,9 +1106,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_RBUTTONDOWN => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Right; - use event::ElementState::Pressed; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Right; + use crate::event::ElementState::Pressed; capture_mouse(window, &mut *subclass_input.window_state.lock()); @@ -1120,9 +1120,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_RBUTTONUP => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Right; - use event::ElementState::Released; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Right; + use crate::event::ElementState::Released; release_mouse(&mut *subclass_input.window_state.lock()); @@ -1134,9 +1134,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_MBUTTONDOWN => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Middle; - use event::ElementState::Pressed; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Middle; + use crate::event::ElementState::Pressed; capture_mouse(window, &mut *subclass_input.window_state.lock()); @@ -1148,9 +1148,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_MBUTTONUP => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Middle; - use event::ElementState::Released; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Middle; + use crate::event::ElementState::Released; release_mouse(&mut *subclass_input.window_state.lock()); @@ -1162,9 +1162,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_XBUTTONDOWN => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Other; - use event::ElementState::Pressed; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Other; + use crate::event::ElementState::Pressed; let xbutton = winuser::GET_XBUTTON_WPARAM(wparam); capture_mouse(window, &mut *subclass_input.window_state.lock()); @@ -1177,9 +1177,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_XBUTTONUP => { - use event::WindowEvent::MouseInput; - use event::MouseButton::Other; - use event::ElementState::Released; + use crate::event::WindowEvent::MouseInput; + use crate::event::MouseButton::Other; + use crate::event::ElementState::Released; let xbutton = winuser::GET_XBUTTON_WPARAM(wparam); release_mouse(&mut *subclass_input.window_state.lock()); @@ -1207,9 +1207,9 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_INPUT => { - use event::DeviceEvent::{Motion, MouseMotion, MouseWheel, Button, Key}; - use event::MouseScrollDelta::LineDelta; - use event::ElementState::{Pressed, Released}; + use crate::event::DeviceEvent::{Motion, MouseMotion, MouseWheel, Button, Key}; + use crate::event::MouseScrollDelta::LineDelta; + use crate::event::ElementState::{Pressed, Released}; if let Some(data) = get_raw_input_data(lparam as _) { let device_id = wrap_device_id(data.header.hDevice as _); @@ -1351,7 +1351,7 @@ unsafe extern "system" fn public_window_callback( } winuser::WM_SETFOCUS => { - use event::WindowEvent::Focused; + use crate::event::WindowEvent::Focused; subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), event: Focused(true), @@ -1361,7 +1361,7 @@ unsafe extern "system" fn public_window_callback( }, winuser::WM_KILLFOCUS => { - use event::WindowEvent::Focused; + use crate::event::WindowEvent::Focused; subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), event: Focused(false), @@ -1423,7 +1423,7 @@ unsafe extern "system" fn public_window_callback( // Only sent on Windows 8.1 or newer. On Windows 7 and older user has to log out to change // DPI, therefore all applications are closed while DPI is changing. winuser::WM_DPICHANGED => { - use event::WindowEvent::HiDpiFactorChanged; + use crate::event::WindowEvent::HiDpiFactorChanged; // This message actually provides two DPI values - x and y. However MSDN says that // "you only need to use either the X-axis or the Y-axis value when scaling your @@ -1473,7 +1473,7 @@ unsafe extern "system" fn public_window_callback( window_state.set_window_flags_in_place(|f| f.set(WindowFlags::MARKER_RETAIN_STATE_ON_SIZE, wparam != 0)); 0 } else if msg == *INITIAL_DPI_MSG_ID { - use event::WindowEvent::HiDpiFactorChanged; + use crate::event::WindowEvent::HiDpiFactorChanged; let scale_factor = dpi_to_scale_factor(wparam as u32); subclass_input.send_event(Event::WindowEvent { window_id: RootWindowId(WindowId(window)), diff --git a/src/platform_impl/windows/icon.rs b/src/platform_impl/windows/icon.rs index 3a617ceb..e2700205 100644 --- a/src/platform_impl/windows/icon.rs +++ b/src/platform_impl/windows/icon.rs @@ -7,7 +7,7 @@ use winapi::shared::minwindef::{BYTE, LPARAM, WPARAM}; use winapi::shared::windef::{HICON, HWND}; use winapi::um::winuser; -use icon::{Pixel, PIXEL_SIZE, Icon}; +use crate::icon::{Pixel, PIXEL_SIZE, Icon}; impl Pixel { fn to_bgra(&mut self) { diff --git a/src/platform_impl/windows/mod.rs b/src/platform_impl/windows/mod.rs index 307423c3..c0a06c0b 100644 --- a/src/platform_impl/windows/mod.rs +++ b/src/platform_impl/windows/mod.rs @@ -7,8 +7,8 @@ pub use self::event_loop::{EventLoop, EventLoopWindowTarget, EventLoopProxy}; pub use self::monitor::MonitorHandle; pub use self::window::Window; -use window::Icon; -use event::DeviceId as RootDeviceId; +use crate::window::Icon; +use crate::event::DeviceId as RootDeviceId; #[derive(Clone, Default)] pub struct PlatformSpecificWindowBuilderAttributes { diff --git a/src/platform_impl/windows/monitor.rs b/src/platform_impl/windows/monitor.rs index d0781365..ec01b74c 100644 --- a/src/platform_impl/windows/monitor.rs +++ b/src/platform_impl/windows/monitor.rs @@ -7,10 +7,10 @@ use std::collections::{HashSet, VecDeque}; use std::{io, mem, ptr}; use super::{util, EventLoop}; -use dpi::{PhysicalPosition, PhysicalSize}; -use monitor::VideoMode; -use platform_impl::platform::dpi::{dpi_to_scale_factor, get_monitor_dpi}; -use platform_impl::platform::window::Window; +use crate::dpi::{PhysicalPosition, PhysicalSize}; +use crate::monitor::VideoMode; +use crate::platform_impl::platform::dpi::{dpi_to_scale_factor, get_monitor_dpi}; +use crate::platform_impl::platform::window::Window; /// Win32 implementation of the main `MonitorHandle` object. #[derive(Derivative)] diff --git a/src/platform_impl/windows/raw_input.rs b/src/platform_impl/windows/raw_input.rs index 03c26d11..c75bb757 100644 --- a/src/platform_impl/windows/raw_input.rs +++ b/src/platform_impl/windows/raw_input.rs @@ -31,8 +31,8 @@ use winapi::um::winuser::{ RID_INPUT, }; -use platform_impl::platform::util; -use event::ElementState; +use crate::platform_impl::platform::util; +use crate::event::ElementState; #[allow(dead_code)] pub fn get_raw_input_device_list() -> Option> { diff --git a/src/platform_impl/windows/util.rs b/src/platform_impl/windows/util.rs index a46c44bd..a8f30e22 100644 --- a/src/platform_impl/windows/util.rs +++ b/src/platform_impl/windows/util.rs @@ -2,7 +2,7 @@ use std::{mem, ptr, slice, io}; use std::ops::BitAnd; use std::sync::atomic::{AtomicBool, Ordering}; -use window::CursorIcon; +use crate::window::CursorIcon; use winapi::ctypes::wchar_t; use winapi::shared::minwindef::{BOOL, DWORD}; use winapi::shared::windef::{HWND, POINT, RECT}; diff --git a/src/platform_impl/windows/window.rs b/src/platform_impl/windows/window.rs index 1ccd5261..b16dd6f1 100644 --- a/src/platform_impl/windows/window.rs +++ b/src/platform_impl/windows/window.rs @@ -18,11 +18,11 @@ use winapi::um::wingdi::{CreateRectRgn, DeleteObject}; use winapi::um::oleidl::LPDROPTARGET; use winapi::um::winnt::{LONG, LPCWSTR}; -use window::{Icon, CursorIcon, WindowAttributes}; -use error::{ExternalError, NotSupportedError, OsError as RootOsError}; -use dpi::{LogicalPosition, LogicalSize, PhysicalSize}; -use monitor::MonitorHandle as RootMonitorHandle; -use platform_impl::platform::{ +use crate::window::{Icon, CursorIcon, WindowAttributes}; +use crate::error::{ExternalError, NotSupportedError, OsError as RootOsError}; +use crate::dpi::{LogicalPosition, LogicalSize, PhysicalSize}; +use crate::monitor::MonitorHandle as RootMonitorHandle; +use crate::platform_impl::platform::{ {PlatformSpecificWindowBuilderAttributes, WindowId}, dpi::{dpi_to_scale_factor, hwnd_dpi}, drop_handler::FileDropHandler, diff --git a/src/platform_impl/windows/window_state.rs b/src/platform_impl/windows/window_state.rs index 41dcb228..290c6eb3 100644 --- a/src/platform_impl/windows/window_state.rs +++ b/src/platform_impl/windows/window_state.rs @@ -1,10 +1,10 @@ -use monitor::MonitorHandle; -use window::{CursorIcon, WindowAttributes}; +use crate::monitor::MonitorHandle; +use crate::window::{CursorIcon, WindowAttributes}; use std::{io, ptr}; use parking_lot::MutexGuard; -use dpi::LogicalSize; -use platform_impl::platform::{util, event_loop}; -use platform_impl::platform::icon::WinIcon; +use crate::dpi::LogicalSize; +use crate::platform_impl::platform::{util, event_loop}; +use crate::platform_impl::platform::icon::WinIcon; use winapi::shared::windef::{RECT, HWND}; use winapi::shared::minwindef::DWORD; use winapi::um::winuser; @@ -113,7 +113,7 @@ impl WindowState { self.window_flags } - pub fn set_window_flags(mut this: MutexGuard, window: HWND, set_client_rect: Option, f: F) + pub fn set_window_flags(mut this: MutexGuard<'_, Self>, window: HWND, set_client_rect: Option, f: F) where F: FnOnce(&mut WindowFlags) { let old_flags = this.window_flags; @@ -127,7 +127,7 @@ impl WindowState { old_flags.apply_diff(window, new_flags, set_client_rect); } - pub fn refresh_window_state(this: MutexGuard, window: HWND, set_client_rect: Option) { + pub fn refresh_window_state(this: MutexGuard<'_, Self>, window: HWND, set_client_rect: Option) { Self::set_window_flags(this, window, set_client_rect, |_| ()); } diff --git a/src/window.rs b/src/window.rs index f2f246d2..e5747237 100644 --- a/src/window.rs +++ b/src/window.rs @@ -1,13 +1,13 @@ //! The `Window` struct and associated types. use std::fmt; -use platform_impl; -use error::{ExternalError, NotSupportedError, OsError}; -use event_loop::EventLoopWindowTarget; -use monitor::{AvailableMonitorsIter, MonitorHandle}; -use dpi::{LogicalPosition, LogicalSize}; +use crate::platform_impl; +use crate::error::{ExternalError, NotSupportedError, OsError}; +use crate::event_loop::EventLoopWindowTarget; +use crate::monitor::{AvailableMonitorsIter, MonitorHandle}; +use crate::dpi::{LogicalPosition, LogicalSize}; -pub use icon::*; +pub use crate::icon::*; /// Represents a window. /// @@ -35,7 +35,7 @@ pub struct Window { } impl fmt::Debug for Window { - fn fmt(&self, fmtr: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, fmtr: &mut fmt::Formatter<'_>) -> fmt::Result { fmtr.pad("Window { .. }") } } @@ -71,7 +71,7 @@ pub struct WindowBuilder { } impl fmt::Debug for WindowBuilder { - fn fmt(&self, fmtr: &mut fmt::Formatter) -> fmt::Result { + fn fmt(&self, fmtr: &mut fmt::Formatter<'_>) -> fmt::Result { fmtr.debug_struct("WindowBuilder") .field("window", &self.window) .finish() diff --git a/tests/send_objects.rs b/tests/send_objects.rs index ad1f248a..c06392c8 100644 --- a/tests/send_objects.rs +++ b/tests/send_objects.rs @@ -1,5 +1,5 @@ -extern crate winit; +#[allow(dead_code)] fn needs_send() {} #[test] diff --git a/tests/serde_objects.rs b/tests/serde_objects.rs index 00f30b8f..b2e94a42 100644 --- a/tests/serde_objects.rs +++ b/tests/serde_objects.rs @@ -1,8 +1,5 @@ #![cfg(feature = "serde")] -extern crate serde; -extern crate winit; - use winit::window::{CursorIcon}; use winit::event::{ KeyboardInput, TouchPhase, ElementState, MouseButton, MouseScrollDelta, VirtualKeyCode, @@ -11,6 +8,7 @@ use winit::event::{ use winit::dpi::{LogicalPosition, PhysicalPosition, LogicalSize, PhysicalSize}; use serde::{Serialize, Deserialize}; +#[allow(dead_code)] fn needs_serde>() {} #[test] diff --git a/tests/sync_object.rs b/tests/sync_object.rs index c59cc077..073f2a89 100644 --- a/tests/sync_object.rs +++ b/tests/sync_object.rs @@ -1,5 +1,5 @@ -extern crate winit; +#[allow(dead_code)] fn needs_sync() {} #[test]