mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-11 03:03:06 +00:00
* MenuItem::submenu_: it seems that boost::shared_ptr() was necessary for std::vector purpose
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23570 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
999d69709f
commit
9991539819
@ -152,6 +152,8 @@ public:
|
||||
func_.origin = FuncRequest::MENU;
|
||||
}
|
||||
|
||||
~MenuItem() {}
|
||||
|
||||
/// The label of a given menuitem
|
||||
QString label() const { return label_.split('|')[0]; }
|
||||
|
||||
@ -197,9 +199,9 @@ public:
|
||||
/// set the description of the submenu
|
||||
void submenuname(QString const & name) { submenuname_ = name; }
|
||||
///
|
||||
Menu * submenu() const { return submenu_; }
|
||||
Menu * submenu() const { return submenu_.get(); }
|
||||
///
|
||||
void setSubmenu(Menu * menu) { submenu_ = menu; }
|
||||
void setSubmenu(Menu * menu) { submenu_.reset(menu); }
|
||||
|
||||
private:
|
||||
///
|
||||
@ -215,7 +217,7 @@ private:
|
||||
///
|
||||
FuncStatus status_;
|
||||
///
|
||||
Menu * submenu_;
|
||||
boost::shared_ptr<Menu> submenu_;
|
||||
};
|
||||
|
||||
///
|
||||
@ -289,6 +291,8 @@ public:
|
||||
setTitle(label(mi));
|
||||
}
|
||||
|
||||
~GuiPopupMenu() { delete top_level_menu; }
|
||||
|
||||
/// populates the menu or one of its submenu
|
||||
/// This is used as a recursive function
|
||||
void populate(QMenu * qMenu, Menu * menu);
|
||||
@ -970,12 +974,12 @@ void Menu::expandToc(Buffer const * buf)
|
||||
continue;
|
||||
|
||||
// All the rest is for floats
|
||||
auto_ptr<Menu> menu(new Menu);
|
||||
Menu * submenu = new Menu;
|
||||
TocIterator ccit = cit->second.begin();
|
||||
TocIterator eend = cit->second.end();
|
||||
for (; ccit != eend; ++ccit) {
|
||||
QString const label = limitStringLength(ccit->str());
|
||||
menu->add(MenuItem(MenuItem::Command, label,
|
||||
submenu->add(MenuItem(MenuItem::Command, label,
|
||||
FuncRequest(ccit->action())));
|
||||
}
|
||||
string const & floatName = floatlist.getType(cit->first).listName();
|
||||
@ -1005,7 +1009,7 @@ void Menu::expandToc(Buffer const * buf)
|
||||
else
|
||||
label = qt_("Other floats");
|
||||
MenuItem item(MenuItem::Submenu, label);
|
||||
item.setSubmenu(menu.release());
|
||||
item.setSubmenu(submenu);
|
||||
add(item);
|
||||
}
|
||||
|
||||
@ -1096,8 +1100,6 @@ void Menu::expandBranches(Buffer const * buf)
|
||||
|
||||
|
||||
struct Menus::Impl {
|
||||
///
|
||||
void add(Menu const &);
|
||||
///
|
||||
bool hasMenu(QString const &) const;
|
||||
///
|
||||
@ -1288,8 +1290,7 @@ void Menus::Impl::expand(Menu const & frommenu, Menu & tomenu,
|
||||
case MenuItem::Submenu: {
|
||||
MenuItem item(*cit);
|
||||
item.setSubmenu(new Menu(cit->submenuname()));
|
||||
expand(getMenu(cit->submenuname()),
|
||||
*item.submenu(), buf);
|
||||
expand(getMenu(cit->submenuname()), *item.submenu(), buf);
|
||||
tomenu.addWithStatusCheck(item);
|
||||
}
|
||||
break;
|
||||
@ -1313,12 +1314,6 @@ void Menus::Impl::expand(Menu const & frommenu, Menu & tomenu,
|
||||
}
|
||||
|
||||
|
||||
void Menus::Impl::add(Menu const & menu)
|
||||
{
|
||||
menulist_.push_back(menu);
|
||||
}
|
||||
|
||||
|
||||
bool Menus::Impl::hasMenu(QString const & name) const
|
||||
{
|
||||
return find_if(menulist_.begin(), menulist_.end(),
|
||||
@ -1394,7 +1389,7 @@ void Menus::read(Lexer & lex)
|
||||
else {
|
||||
Menu menu(name);
|
||||
menu.read(lex);
|
||||
d->add(menu);
|
||||
d->menulist_.push_back(menu);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user