#include "GuiView.h"
#include "Action.h"
+#include "GuiApplication.h"
#include "GuiPopupMenu.h"
#include "qt_helpers.h"
+
#include "LyXFunc.h"
#include "MenuBackend.h"
-#include "support/lstrings.h"
#include "support/debug.h"
-
-#include <QMenuBar>
+#include "support/lstrings.h"
namespace lyx {
namespace frontend {
// Here, We make sure that theLyXFunc points to the correct LyXView.
theLyXFunc().setLyXView(owner_);
+ MenuBackend const & menubackend = guiApp->menuBackend();
Menu const & fromLyxMenu = menubackend.getMenu(name_);
menubackend.expand(fromLyxMenu, topLevelMenu_, owner_->buffer());
LYXERR(Debug::GUI, "creating Menu Item "
<< to_utf8(m->label()));
- docstring label = getLabel(*m);
- addBinding(label, *m);
+ docstring const label = getLabel(*m);
Action * action = new Action(*(owner_),
QIcon(), toqstr(label), m->func(), QString());
docstring const GuiPopupMenu::getLabel(MenuItem const & mi)
{
- docstring const shortcut = mi.shortcut();
- docstring label = support::subst(mi.label(),
- from_ascii("&"), from_ascii("&&"));
+ docstring label = support::subst(mi.label(),
+ from_ascii("&"), from_ascii("&&"));
+ docstring const shortcut = mi.shortcut();
if (!shortcut.empty()) {
size_t pos = label.find(shortcut);
if (pos != docstring::npos)
label.insert(pos, 1, char_type('&'));
}
- return label;
-}
-
-
-void GuiPopupMenu::addBinding(docstring & label, MenuItem const & mi)
-{
-#ifdef Q_WS_MACX
- docstring const binding = mi.binding(false);
-#else
- docstring const binding = mi.binding(true);
-#endif
+ docstring const binding = mi.binding();
if (!binding.empty())
label += '\t' + binding;
+
+ return label;
}