summaryrefslogtreecommitdiffstats
path: root/native/src/window
diff options
context:
space:
mode:
authorLibravatar bungoboingo <shankern@protonmail.com>2023-01-05 15:26:28 -0800
committerLibravatar bungoboingo <shankern@protonmail.com>2023-01-09 11:28:07 -0800
commitec41918ec40bddaba81235372f1566da59fd09f2 (patch)
treefb530943ccf14dfec3820bf65f71a9572fd3d8be /native/src/window
parent1944e98f82b7efd5b268e04ba5ced065e55a218e (diff)
downloadiced-ec41918ec40bddaba81235372f1566da59fd09f2.tar.gz
iced-ec41918ec40bddaba81235372f1566da59fd09f2.tar.bz2
iced-ec41918ec40bddaba81235372f1566da59fd09f2.zip
Implemented window title update functionality for multiwindow.
Diffstat (limited to 'native/src/window')
-rw-r--r--native/src/window/action.rs8
-rw-r--r--native/src/window/icon.rs6
-rw-r--r--native/src/window/id.rs13
3 files changed, 18 insertions, 9 deletions
diff --git a/native/src/window/action.rs b/native/src/window/action.rs
index 0587f25c..929663ec 100644
--- a/native/src/window/action.rs
+++ b/native/src/window/action.rs
@@ -1,4 +1,4 @@
-use crate::window::{self, Mode, UserAttention};
+use crate::window;
use iced_futures::MaybeSend;
use std::fmt;
@@ -13,9 +13,9 @@ pub enum Action<T> {
/// There’s no guarantee that this will work unless the left mouse
/// button was pressed immediately before this function is called.
Drag,
- /// TODO(derezzedex)
+ /// Spawns a new window with the provided [`window::Settings`].
Spawn {
- /// TODO(derezzedex)
+ /// The settings of the [`Window`].
settings: window::Settings,
},
/// Resize the window.
@@ -62,7 +62,7 @@ pub enum Action<T> {
/// - **macOS:** `None` has no effect.
/// - **X11:** Requests for user attention must be manually cleared.
/// - **Wayland:** Requires `xdg_activation_v1` protocol, `None` has no effect.
- RequestUserAttention(Option<UserAttention>),
+ RequestUserAttention(Option<window::UserAttention>),
/// Brings the window to the front and sets input focus. Has no effect if the window is
/// already in focus, minimized, or not visible.
///
diff --git a/native/src/window/icon.rs b/native/src/window/icon.rs
index e89baf03..08a6acfd 100644
--- a/native/src/window/icon.rs
+++ b/native/src/window/icon.rs
@@ -3,10 +3,10 @@
/// The icon of a window.
#[derive(Debug, Clone)]
pub struct Icon {
- /// TODO(derezzedex)
+ /// The __rgba__ color data of the window [`Icon`].
pub rgba: Vec<u8>,
- /// TODO(derezzedex)
+ /// The width of the window [`Icon`].
pub width: u32,
- /// TODO(derezzedex)
+ /// The height of the window [`Icon`].
pub height: u32,
}
diff --git a/native/src/window/id.rs b/native/src/window/id.rs
index 5060e162..fa9761f5 100644
--- a/native/src/window/id.rs
+++ b/native/src/window/id.rs
@@ -1,15 +1,18 @@
use std::collections::hash_map::DefaultHasher;
+use std::fmt::{Display, Formatter};
use std::hash::{Hash, Hasher};
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash, PartialOrd, Ord)]
-/// TODO(derezzedex)
+/// The ID of the window.
+///
+/// This is not necessarily the same as the window ID fetched from `winit::window::Window`.
pub struct Id(u64);
impl Id {
/// TODO(derezzedex): maybe change `u64` to an enum `Type::{Single, Multi(u64)}`
pub const MAIN: Self = Id(0);
- /// TODO(derezzedex)
+ /// Creates a new unique window ID.
pub fn new(id: impl Hash) -> Id {
let mut hasher = DefaultHasher::new();
id.hash(&mut hasher);
@@ -17,3 +20,9 @@ impl Id {
Id(hasher.finish())
}
}
+
+impl Display for Id {
+ fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
+ write!(f, "Id({})", self.0)
+ }
+}