diff --git a/.changes/menu-rc.md b/.changes/menu-rc.md new file mode 100644 index 0000000..98c8ef2 --- /dev/null +++ b/.changes/menu-rc.md @@ -0,0 +1,5 @@ +--- +"muda": "patch" +--- + +Wrapped the `id` field of the `Menu` struct in an `Rc` to be consistent with other menu structs and make it cheaper to clone. diff --git a/src/menu.rs b/src/menu.rs index 1067919..9b0042e 100644 --- a/src/menu.rs +++ b/src/menu.rs @@ -10,7 +10,7 @@ use crate::{util::AddOp, ContextMenu, IsMenuItem, MenuId, MenuItemKind, Position /// and used as the app global menu on macOS. #[derive(Clone)] pub struct Menu { - id: MenuId, + id: Rc, inner: Rc>, } @@ -25,7 +25,7 @@ impl Menu { pub fn new() -> Self { let menu = crate::platform_impl::Menu::new(None); Self { - id: menu.id().clone(), + id: Rc::new(menu.id().clone()), inner: Rc::new(RefCell::new(menu)), } } @@ -34,7 +34,7 @@ impl Menu { pub fn with_id>(id: I) -> Self { let id = id.into(); Self { - id: id.clone(), + id: Rc::new(id.clone()), inner: Rc::new(RefCell::new(crate::platform_impl::Menu::new(Some(id)))), } }