The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

96 lines
2.9KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2017 - ROLI Ltd.
  5. JUCE is an open source library subject to commercial or open-source
  6. licensing.
  7. By using JUCE, you agree to the terms of both the JUCE 5 End-User License
  8. Agreement and JUCE 5 Privacy Policy (both updated and effective as of the
  9. 27th April 2017).
  10. End User License Agreement: www.juce.com/juce-5-licence
  11. Privacy Policy: www.juce.com/juce-5-privacy-policy
  12. Or: You may also use this code under the terms of the GPL v3 (see
  13. www.gnu.org/licenses).
  14. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  15. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  16. DISCLAIMED.
  17. ==============================================================================
  18. */
  19. MenuBarModel::MenuBarModel() noexcept
  20. : manager (nullptr)
  21. {
  22. }
  23. MenuBarModel::~MenuBarModel()
  24. {
  25. setApplicationCommandManagerToWatch (nullptr);
  26. }
  27. //==============================================================================
  28. void MenuBarModel::menuItemsChanged()
  29. {
  30. triggerAsyncUpdate();
  31. }
  32. void MenuBarModel::setApplicationCommandManagerToWatch (ApplicationCommandManager* const newManager) noexcept
  33. {
  34. if (manager != newManager)
  35. {
  36. if (manager != nullptr)
  37. manager->removeListener (this);
  38. manager = newManager;
  39. if (manager != nullptr)
  40. manager->addListener (this);
  41. }
  42. }
  43. void MenuBarModel::addListener (Listener* const newListener) noexcept
  44. {
  45. listeners.add (newListener);
  46. }
  47. void MenuBarModel::removeListener (Listener* const listenerToRemove) noexcept
  48. {
  49. // Trying to remove a listener that isn't on the list!
  50. // If this assertion happens because this object is a dangling pointer, make sure you've not
  51. // deleted this menu model while it's still being used by something (e.g. by a MenuBarComponent)
  52. jassert (listeners.contains (listenerToRemove));
  53. listeners.remove (listenerToRemove);
  54. }
  55. //==============================================================================
  56. void MenuBarModel::handleAsyncUpdate()
  57. {
  58. listeners.call (&MenuBarModel::Listener::menuBarItemsChanged, this);
  59. }
  60. void MenuBarModel::applicationCommandInvoked (const ApplicationCommandTarget::InvocationInfo& info)
  61. {
  62. listeners.call (&MenuBarModel::Listener::menuCommandInvoked, this, info);
  63. }
  64. void MenuBarModel::applicationCommandListChanged()
  65. {
  66. menuItemsChanged();
  67. }
  68. void MenuBarModel::handleMenuBarActivate (bool isActive)
  69. {
  70. menuBarActivated (isActive);
  71. listeners.call (&MenuBarModel::Listener::menuBarActivated, this, isActive);
  72. }
  73. void MenuBarModel::menuBarActivated (bool) {}
  74. void MenuBarModel::Listener::menuBarActivated (MenuBarModel*, bool) {}