summaryrefslogtreecommitdiffstats
path: root/native/src/widget/id.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2023-03-09 19:05:38 +0100
committerLibravatar GitHub <noreply@github.com>2023-03-09 19:05:38 +0100
commitcaf2836b1b15bff6e8a2ea72441d67f297eb8707 (patch)
tree0ffa0d1d604780999892b88de85ee93e3ed7d539 /native/src/widget/id.rs
parent11b2c3bbe31a43e73a61b9bd9f022233f302ae27 (diff)
parent424ac8177309440bbd8efe0dd9f7622cb10807ce (diff)
downloadiced-caf2836b1b15bff6e8a2ea72441d67f297eb8707.tar.gz
iced-caf2836b1b15bff6e8a2ea72441d67f297eb8707.tar.bz2
iced-caf2836b1b15bff6e8a2ea72441d67f297eb8707.zip
Merge pull request #1748 from iced-rs/feature/software-renderer
Software renderer, runtime renderer fallback, and core consolidation
Diffstat (limited to 'native/src/widget/id.rs')
-rw-r--r--native/src/widget/id.rs43
1 files changed, 0 insertions, 43 deletions
diff --git a/native/src/widget/id.rs b/native/src/widget/id.rs
deleted file mode 100644
index 4b8fedf1..00000000
--- a/native/src/widget/id.rs
+++ /dev/null
@@ -1,43 +0,0 @@
-use std::borrow;
-use std::sync::atomic::{self, AtomicUsize};
-
-static NEXT_ID: AtomicUsize = AtomicUsize::new(0);
-
-/// The identifier of a generic widget.
-#[derive(Debug, Clone, PartialEq, Eq, Hash)]
-pub struct Id(Internal);
-
-impl Id {
- /// Creates a custom [`Id`].
- pub fn new(id: impl Into<borrow::Cow<'static, str>>) -> Self {
- Self(Internal::Custom(id.into()))
- }
-
- /// Creates a unique [`Id`].
- ///
- /// This function produces a different [`Id`] every time it is called.
- pub fn unique() -> Self {
- let id = NEXT_ID.fetch_add(1, atomic::Ordering::Relaxed);
-
- Self(Internal::Unique(id))
- }
-}
-
-#[derive(Debug, Clone, PartialEq, Eq, Hash)]
-pub enum Internal {
- Unique(usize),
- Custom(borrow::Cow<'static, str>),
-}
-
-#[cfg(test)]
-mod tests {
- use super::Id;
-
- #[test]
- fn unique_generates_different_ids() {
- let a = Id::unique();
- let b = Id::unique();
-
- assert_ne!(a, b);
- }
-}