diff --git a/examples/tao.rs b/examples/tao.rs index 6ad1c0b..d46a8b6 100644 --- a/examples/tao.rs +++ b/examples/tao.rs @@ -18,8 +18,8 @@ fn main() { let mut menu_bar = Menu::new(); let mut file_menu = menu_bar.add_submenu("&File", true); - let mut open_item = file_menu.add_text_item("&Open", true, None); - let mut save_item = file_menu.add_text_item("&Save", true, Some("CommandOrCtrl+S")); + let mut open_item = file_menu.add_item("&Open", true, None); + let mut save_item = file_menu.add_item("&Save", true, Some("CommandOrCtrl+S")); file_menu.add_native_item(NativeMenuItem::Minimize); file_menu.add_native_item(NativeMenuItem::CloseWindow); file_menu.add_native_item(NativeMenuItem::Quit); diff --git a/examples/winit.rs b/examples/winit.rs index c46eca3..29e865a 100644 --- a/examples/winit.rs +++ b/examples/winit.rs @@ -36,8 +36,8 @@ fn main() { let _window2 = WindowBuilder::new().build(&event_loop).unwrap(); let mut file_menu = menu_bar.add_submenu("&File", true); - let mut open_item = file_menu.add_text_item("&Open", true, None); - let mut save_item = file_menu.add_text_item("&Save", true, Some("CommandOrCtrl+S")); + let mut open_item = file_menu.add_item("&Open", true, None); + let mut save_item = file_menu.add_item("&Save", true, Some("CommandOrCtrl+S")); file_menu.add_native_item(NativeMenuItem::Minimize); file_menu.add_native_item(NativeMenuItem::CloseWindow); file_menu.add_native_item(NativeMenuItem::Quit); diff --git a/src/lib.rs b/src/lib.rs index cc7dd8f..63a71ed 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -17,7 +17,7 @@ //! //! # Aadding menu items and submenus within another submenu //! -//! Once you have a [`Submenu`] you can star creating more [`Submenu`]s or [`TextMenuItem`]s. +//! Once you have a [`Submenu`] you can star creating more [`Submenu`]s or [`MenuItem`]s. //! ```no_run //! let mut menu = Menu::new(); //! @@ -67,12 +67,9 @@ mod platform_impl; static MENU_CHANNEL: Lazy<(Sender, Receiver)> = Lazy::new(|| unbounded()); -/// A type alias to the receiver of the menu events channel. -pub type MenuEventReceiver = Receiver; - -/// Gets a reference to the event channel's [MenuEventReceiver] +/// Gets a reference to the event channel's [Receiver] /// which can be used to listen for menu events. -pub fn menu_event_receiver<'a>() -> &'a MenuEventReceiver { +pub fn menu_event_receiver<'a>() -> &'a Receiver { &MENU_CHANNEL.1 } @@ -269,7 +266,7 @@ impl Submenu { Submenu(self.0.add_submenu(label, enabled)) } - /// Creates a new [`TextMenuItem`] whithin this submenu. + /// Creates a new [`MenuItem`] whithin this submenu. /// /// ## Platform-specific: /// @@ -277,13 +274,13 @@ impl Submenu { /// For example, using `&Save` for the save menu item would result in the label gets an underline under the `S`, /// and the `&` character is not displayed on menu item label. /// Then the menu item can be activated by press `S` when its parent menu is active. - pub fn add_text_item>( + pub fn add_item>( &mut self, label: S, enabled: bool, accelerator: Option<&str>, - ) -> TextMenuItem { - TextMenuItem(self.0.add_text_item(label, enabled, accelerator)) + ) -> MenuItem { + MenuItem(self.0.add_item(label, enabled, accelerator)) } /// Creates a new [`NativeMenuItem`] within this submenu. @@ -303,11 +300,11 @@ impl Submenu { } } -/// This is a Text menu item within a [`Submenu`]. +/// This is a normal menu item within a [`Submenu`]. #[derive(Clone)] -pub struct TextMenuItem(platform_impl::TextMenuItem); +pub struct MenuItem(platform_impl::MenuItem); -impl TextMenuItem { +impl MenuItem { /// Gets the menu item's current label. pub fn label(&self) -> String { self.0.label() @@ -334,7 +331,7 @@ impl TextMenuItem { } } -/// This is a Check menu item within a [`Submenu`]. +/// This is a menu item with a checkmark icon within a [`Submenu`]. #[derive(Clone)] pub struct CheckMenuItem(platform_impl::CheckMenuItem); diff --git a/src/platform_impl/linux/mod.rs b/src/platform_impl/linux/mod.rs index c0ff9cf..b62777b 100644 --- a/src/platform_impl/linux/mod.rs +++ b/src/platform_impl/linux/mod.rs @@ -26,14 +26,14 @@ enum MenuEntryType { // keeps a vector of a [`gtk::MenuItem`] or a tuple of [`gtk::MenuItem`] and [`gtk::Menu`] if its a menu // and push to it every time [`Menu::init_for_gtk_window`] is called. Submenu(Vec<(gtk::MenuItem, gtk::Menu)>), - Text(Vec), - Check(Vec), - Native(NativeMenuItem), + MenuItem(Vec), + CheckMenuItem(Vec), + NativeMenuItem(NativeMenuItem), } impl Default for MenuEntryType { fn default() -> Self { - Self::Text(Default::default()) + Self::MenuItem(Default::default()) } } @@ -243,19 +243,19 @@ impl Submenu { Submenu(entry, Rc::clone(&self.1)) } - pub fn add_text_item>( + pub fn add_item>( &mut self, label: S, enabled: bool, accelerator: Option<&str>, - ) -> TextMenuItem { + ) -> MenuItem { let label = label.as_ref().to_string(); let id = COUNTER.next(); let entry = Rc::new(RefCell::new(MenuEntry { label: label.clone(), enabled, - r#type: MenuEntryType::Text(Vec::new()), + r#type: MenuEntryType::MenuItem(Vec::new()), id, accelerator: accelerator.map(|s| s.to_string()), ..Default::default() @@ -265,7 +265,7 @@ impl Submenu { if let MenuEntryType::Submenu(native_menus) = &mut inner.r#type { for (_, menu) in native_menus { - let item = create_gtk_text_menu_item( + let item = create_gtk_menu_item( &label, enabled, &accelerator.map(|s| s.to_string()), @@ -273,14 +273,14 @@ impl Submenu { &*self.1, ); menu.append(&item); - if let MenuEntryType::Text(native_items) = &mut entry.borrow_mut().r#type { + if let MenuEntryType::MenuItem(native_items) = &mut entry.borrow_mut().r#type { native_items.push(item); } } } inner.entries.as_mut().unwrap().push(entry.clone()); - TextMenuItem(entry) + MenuItem(entry) } pub fn add_native_item(&mut self, item: NativeMenuItem) { @@ -293,7 +293,7 @@ impl Submenu { } let entry = Rc::new(RefCell::new(MenuEntry { - r#type: MenuEntryType::Native(item), + r#type: MenuEntryType::NativeMenuItem(item), ..Default::default() })); inner.entries.as_mut().unwrap().push(entry); @@ -313,7 +313,7 @@ impl Submenu { label: label.clone(), enabled, checked, - r#type: MenuEntryType::Check(Vec::new()), + r#type: MenuEntryType::CheckMenuItem(Vec::new()), id, accelerator: accelerator.map(|s| s.to_string()), ..Default::default() @@ -332,7 +332,7 @@ impl Submenu { &*self.1, ); menu.append(&item); - if let MenuEntryType::Check(native_items) = &mut entry.borrow_mut().r#type { + if let MenuEntryType::CheckMenuItem(native_items) = &mut entry.borrow_mut().r#type { native_items.push(item); } } @@ -344,9 +344,9 @@ impl Submenu { } #[derive(Clone)] -pub struct TextMenuItem(Rc>); +pub struct MenuItem(Rc>); -impl TextMenuItem { +impl MenuItem { pub fn label(&self) -> String { self.0.borrow().label.clone() } @@ -354,7 +354,7 @@ impl TextMenuItem { pub fn set_label>(&mut self, label: S) { let label = label.as_ref().to_string(); let mut entry = self.0.borrow_mut(); - if let MenuEntryType::Text(native_items) = &mut entry.r#type { + if let MenuEntryType::MenuItem(native_items) = &mut entry.r#type { for item in native_items { item.set_label(&to_gtk_menemenoic(&label)); } @@ -368,7 +368,7 @@ impl TextMenuItem { pub fn set_enabled(&mut self, enabled: bool) { let mut entry = self.0.borrow_mut(); - if let MenuEntryType::Text(native_items) = &mut entry.r#type { + if let MenuEntryType::MenuItem(native_items) = &mut entry.r#type { for item in native_items { item.set_sensitive(enabled); } @@ -392,7 +392,7 @@ impl CheckMenuItem { pub fn set_label>(&mut self, label: S) { let label = label.as_ref().to_string(); let mut entry = self.0.borrow_mut(); - if let MenuEntryType::Text(native_items) = &mut entry.r#type { + if let MenuEntryType::CheckMenuItem(native_items) = &mut entry.r#type { for item in native_items { item.set_label(&to_gtk_menemenoic(&label)); } @@ -406,7 +406,7 @@ impl CheckMenuItem { pub fn set_enabled(&mut self, enabled: bool) { let mut entry = self.0.borrow_mut(); - if let MenuEntryType::Check(native_items) = &mut entry.r#type { + if let MenuEntryType::CheckMenuItem(native_items) = &mut entry.r#type { for item in native_items { item.set_sensitive(enabled); } @@ -417,19 +417,18 @@ impl CheckMenuItem { pub fn checked(&self) -> bool { let entry = self.0.borrow(); let mut checked = entry.checked; - if let MenuEntryType::Check(native_items) = &entry.r#type { + if let MenuEntryType::CheckMenuItem(native_items) = &entry.r#type { if let Some(item) = native_items.get(0) { - checked = item.is_active(); + checked = item.is_active(); } } checked - } pub fn set_checked(&mut self, checked: bool) { let mut entry = self.0.borrow_mut(); - if let MenuEntryType::Check(native_items) = &mut entry.r#type { + if let MenuEntryType::CheckMenuItem(native_items) = &mut entry.r#type { for item in native_items { item.set_active(checked); } @@ -456,8 +455,8 @@ fn add_entries_to_menu>( add_entries_to_menu(&submenu, entry.entries.as_ref().unwrap(), accel_group); (Some(item), Some(submenu)) } - MenuEntryType::Text(_) => { - let item = create_gtk_text_menu_item( + MenuEntryType::MenuItem(_) => { + let item = create_gtk_menu_item( &entry.label, entry.enabled, &entry.accelerator, @@ -467,7 +466,7 @@ fn add_entries_to_menu>( gtk_menu.append(&item); (Some(item), None) } - MenuEntryType::Check(_) => { + MenuEntryType::CheckMenuItem(_) => { let item = create_gtk_check_menu_item( &entry.label, entry.enabled, @@ -479,7 +478,7 @@ fn add_entries_to_menu>( gtk_menu.append(&item); (Some(item.upcast::()), None) } - MenuEntryType::Native(native_menu_item) => { + MenuEntryType::NativeMenuItem(native_menu_item) => { native_menu_item.add_to_gtk_menu(gtk_menu); (None, None) } @@ -489,13 +488,13 @@ fn add_entries_to_menu>( MenuEntryType::Submenu(native_menus) => { native_menus.push((item.unwrap(), submenu.unwrap())); } - MenuEntryType::Text(native_items) => { + MenuEntryType::MenuItem(native_items) => { native_items.push(item.unwrap()); } - MenuEntryType::Check(native_items) => { + MenuEntryType::CheckMenuItem(native_items) => { native_items.push(item.unwrap().downcast().unwrap()); } - MenuEntryType::Native(_) => {} + MenuEntryType::NativeMenuItem(_) => {} }; } } @@ -509,7 +508,7 @@ fn create_gtk_submenu(label: &str, enabled: bool) -> (gtk::MenuItem, gtk::Menu) (item, menu) } -fn create_gtk_text_menu_item( +fn create_gtk_menu_item( label: &str, enabled: bool, accelerator: &Option, diff --git a/src/platform_impl/macos/menu_item.rs b/src/platform_impl/macos/menu_item.rs index 39dd990..5e5bbdd 100644 --- a/src/platform_impl/macos/menu_item.rs +++ b/src/platform_impl/macos/menu_item.rs @@ -18,13 +18,13 @@ use std::sync::Once; static COUNTER: Counter = Counter::new(); #[derive(Debug, Clone)] -pub struct TextMenuItem { +pub struct MenuItem { pub(crate) id: u64, pub(crate) ns_menu_item: id, label: Rc, } -impl TextMenuItem { +impl MenuItem { pub fn new>( label: S, enabled: bool, diff --git a/src/platform_impl/macos/mod.rs b/src/platform_impl/macos/mod.rs index e7ff1c1..bedb43a 100644 --- a/src/platform_impl/macos/mod.rs +++ b/src/platform_impl/macos/mod.rs @@ -9,7 +9,7 @@ use cocoa::{ }; use objc::{msg_send, sel, sel_impl}; -pub use menu_item::TextMenuItem; +pub use menu_item::MenuItem; use self::accelerator::remove_mnemonic; @@ -27,7 +27,7 @@ impl Menu { pub fn add_submenu>(&mut self, label: S, enabled: bool) -> Submenu { let menu = Menu::new(); - let menu_item = TextMenuItem::new("", enabled, sel!(fireMenubarAction:), None); + let menu_item = MenuItem::new("", enabled, sel!(fireMenubarAction:), None); unsafe { menu_item.ns_menu_item.setSubmenu_(menu.0); @@ -56,7 +56,7 @@ impl Menu { #[derive(Debug, Clone)] pub struct Submenu { pub(crate) menu: Menu, - pub(crate) menu_item: TextMenuItem, + pub(crate) menu_item: MenuItem, } impl Submenu { @@ -85,13 +85,13 @@ impl Submenu { self.menu.add_submenu(label, enabled) } - pub fn add_text_item>( + pub fn add_item>( &mut self, label: S, enabled: bool, accelerator: Option<&str>, - ) -> TextMenuItem { - let item = TextMenuItem::new(label, enabled, sel!(fireMenubarAction:), accelerator); + ) -> MenuItem { + let item = MenuItem::new(label, enabled, sel!(fireMenubarAction:), accelerator); unsafe { self.menu.0.addItem_(item.ns_menu_item); } diff --git a/src/platform_impl/windows/mod.rs b/src/platform_impl/windows/mod.rs index c3e8bf3..4cfc964 100644 --- a/src/platform_impl/windows/mod.rs +++ b/src/platform_impl/windows/mod.rs @@ -191,12 +191,12 @@ impl Submenu { } } - pub fn add_text_item>( + pub fn add_item>( &mut self, label: S, enabled: bool, accelerator: Option<&str>, - ) -> TextMenuItem { + ) -> MenuItem { let id = COUNTER.next(); let mut flags = MF_STRING; if !enabled { @@ -222,7 +222,7 @@ impl Submenu { } unsafe { AppendMenuW(self.hmenu, flags, id as _, encode_wide(label).as_ptr()) }; - TextMenuItem { + MenuItem { id, parent_hmenu: self.hmenu, } @@ -270,7 +270,7 @@ impl Submenu { checked: bool, accelerator: Option<&str>, ) -> CheckMenuItem { - let mut item = CheckMenuItem(self.add_text_item(label, enabled, accelerator)); + let mut item = CheckMenuItem(self.add_item(label, enabled, accelerator)); item.set_checked(checked); unsafe { CHECK_MENU_ITEMS.push(item.clone()) }; item @@ -278,12 +278,12 @@ impl Submenu { } #[derive(Clone)] -pub struct TextMenuItem { +pub struct MenuItem { id: u64, parent_hmenu: HMENU, } -impl TextMenuItem { +impl MenuItem { pub fn label(&self) -> String { self.label_with_accel() .split("\t") @@ -352,7 +352,7 @@ impl TextMenuItem { } #[derive(Clone)] -pub struct CheckMenuItem(TextMenuItem); +pub struct CheckMenuItem(MenuItem); impl CheckMenuItem { pub fn label(&self) -> String {