several menu improvements. JMarc, I get a crash in expand when I'm

trying to disable a submenu label ...

Still need to implement the "special" menu items


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@4739 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
John Levon 2002-07-22 01:53:26 +00:00
parent 4ef66c42fc
commit 63ae707688
5 changed files with 156 additions and 41 deletions

View File

@ -1,3 +1,8 @@
2002-07-22 John Levon <moz@compsoc.man.ac.uk>
* Menubar_pimpl.h:
* Menubar_pimpl.C: implement check/disable, submenus
2002-07-22 John Levon <moz@compsoc.man.ac.uk> 2002-07-22 John Levon <moz@compsoc.man.ac.uk>
* Toolbar_pimpl.h: * Toolbar_pimpl.h:

View File

@ -38,6 +38,28 @@ using std::max;
using std::min; using std::min;
using std::for_each; using std::for_each;
namespace {
string const getLabel(MenuItem const & mi)
{
string const shortcut = mi.shortcut();
string label = mi.label();
label = subst(label, "&", "&&");
if (shortcut.empty())
return label;
string::size_type pos = label.find(shortcut);
if (pos == string::npos)
return label;
label.insert(pos, "&");
return label;
}
};
typedef vector<int>::size_type size_type; typedef vector<int>::size_type size_type;
extern boost::scoped_ptr<kb_keymap> toplevel_keymap; extern boost::scoped_ptr<kb_keymap> toplevel_keymap;
@ -57,21 +79,85 @@ Menubar::Pimpl::Pimpl(LyXView * view, MenuBackend const & mbe)
void Menubar::Pimpl::makeMenu(QMenuData * parent, MenuItem const & menu) void Menubar::Pimpl::makeMenu(QMenuData * parent, MenuItem const & menu)
{ {
// FIXME: leak // FIXME: does this leak or not ?
QPopupMenu * pm = new QPopupMenu(); QPopupMenu * pm = new QPopupMenu();
parent->insertItem(menu.label().c_str(), pm); int const parentid = parent->insertItem(getLabel(menu).c_str(), pm);
Menu md; Menu md;
menubackend_.getMenu(menu.submenu()).expand(md, 0); menubackend_.getMenu(menu.submenu()).expand(md, 0);
Menu::const_iterator m = md.begin(); Menu::const_iterator m = md.begin();
Menu::const_iterator end = md.end(); Menu::const_iterator end = md.end();
for (; m != end; ++m) { for (; m != end; ++m) {
// FIXME: handle the special stuff here
if (m->kind() == MenuItem::Separator) { if (m->kind() == MenuItem::Separator) {
pm->insertSeparator(); pm->insertSeparator();
} else if (m->kind() == MenuItem::Submenu) {
makeMenu(pm, *m);
} else { } else {
pm->insertItem(m->label().c_str(), m->action()); pm->insertItem(getLabel(*m).c_str(), m->action());
MenuItemInfo const info(pm, m->action(), m);
items_[m->label()] = info;
updateItem(info);
} }
} }
MenuItemInfo const info(parent, parentid, &menu);
items_[menu.label()] = info;
updateSubmenu(info);
}
// FIXME: this is probably buggy with respect to enabling
// two-level submenus
void Menubar::Pimpl::updateSubmenu(MenuItemInfo const & i)
{
bool enable = true;
#if 0
bool enable = false;
Menu md;
// FIXME FIXME SEGFAULTS
menubackend_.getMenu(i.item_->submenu()).expand(md, 0);
Menu::const_iterator m = md.begin();
Menu::const_iterator end = md.end();
for (; m != end; ++m) {
if (m->action() > 0) {
FuncStatus const status =
owner_->getLyXFunc()->getStatus(m->action());
if (!status.disabled())
enable = true;
}
}
#endif
i.parent_->setItemEnabled(i.id_, enable);
}
void Menubar::Pimpl::updateItem(MenuItemInfo const & i)
{
if (i.item_->kind() == MenuItem::Submenu) {
updateSubmenu(i);
return;
}
// FIXME
if (i.id_ < 0)
return;
FuncStatus const status = owner_->getLyXFunc()->getStatus(i.id_);
i.parent_->setItemEnabled(i.id_, !status.disabled());
i.parent_->setItemChecked(i.id_, status.onoff(true));
}
void Menubar::Pimpl::update()
{
// FIXME: handle special stuff to be updated.
ItemMap::const_iterator cit = items_.begin();
ItemMap::const_iterator end = items_.end();
for (; cit != end; ++cit)
updateItem(cit->second);
} }
@ -79,15 +165,10 @@ void Menubar::Pimpl::openByName(string const & name)
{ {
lyxerr << "Menubar::Pimpl::openByName: menu " << name << endl; lyxerr << "Menubar::Pimpl::openByName: menu " << name << endl;
#if 0 ItemMap::iterator it = items_.find(name);
if (menubackend_->getMenu(current_menu_name_).hasSubmenu(name)) {
for (ButtonList::const_iterator cit = buttonlist_.begin(); if (it == items_.end())
cit != buttonlist_.end(); ++cit) { lyxerr << "NOT FOUND " << name << endl;
if ((*cit)->item_->submenu() == name) {
MenuCallback((*cit)->obj_, 1); // FIXME
return;
}
}
}
#endif
} }

View File

@ -14,7 +14,6 @@
#include <vector> #include <vector>
#include <map> #include <map>
#include <boost/smart_ptr.hpp>
#include <config.h> #include <config.h>
@ -25,7 +24,6 @@
#include "LString.h" #include "LString.h"
#include "frontends/Menubar.h" #include "frontends/Menubar.h"
#include "commandtags.h" #include "commandtags.h"
//#include "MenuBackend.h"
class LyXView; class LyXView;
class QtView; class QtView;
@ -34,22 +32,56 @@ class Menu;
class MenuItem; class MenuItem;
class MenuBackend; class MenuBackend;
/// stored state for menu items
struct MenuItemInfo {
// I REALLY hate this stupid requirement of std::map
MenuItemInfo::MenuItemInfo()
: parent_(0), id_(0), item_(0) {};
MenuItemInfo::MenuItemInfo(QMenuData * p, int id, MenuItem const * item)
: parent_(p), id_(id), item_(item) {};
/// menu containing item
QMenuData * parent_;
/// id in containing menu
int id_;
/// LyX info for item
MenuItem const * item_;
};
struct Menubar::Pimpl { struct Menubar::Pimpl {
public: public:
///
Pimpl(LyXView *, MenuBackend const &); Pimpl(LyXView *, MenuBackend const &);
/// Opens a top-level submenu given its name
/// opens a top-level submenu given its name
void openByName(string const &); void openByName(string const &);
/// update the state of the menuitems /// update the state of the menuitems
void update() {} void update();
private: private:
/// create a menu
void makeMenu(QMenuData * parent, MenuItem const & menu); void makeMenu(QMenuData * parent, MenuItem const & menu);
/// special handling updating a submenu label
void updateSubmenu(MenuItemInfo const & i);
/// update an individual item, returns true if enabled
void updateItem(MenuItemInfo const & i);
/// owning view
QtView * owner_; QtView * owner_;
/// menu controller
MenuBackend const & menubackend_; MenuBackend const & menubackend_;
typedef std::map<string, MenuItemInfo> ItemMap;
/// menu items
ItemMap items_;
}; };
#endif #endif // MENUBAR_PIMPL_H

View File

@ -53,6 +53,9 @@ QtView::QtView(unsigned int width, unsigned int height)
qApp->setMainWidget(this); qApp->setMainWidget(this);
bufferview_.reset(new BufferView(this, 0, 0, width, height));
::current_view = bufferview_.get();
menubar_.reset(new Menubar(this, menubackend)); menubar_.reset(new Menubar(this, menubackend));
connect(menuBar(), SIGNAL(activated(int)), connect(menuBar(), SIGNAL(activated(int)),
@ -63,9 +66,6 @@ QtView::QtView(unsigned int width, unsigned int height)
statusBar()->setSizeGripEnabled(false); statusBar()->setSizeGripEnabled(false);
bufferview_.reset(new BufferView(this, 0, 0, width, height));
::current_view = bufferview_.get();
view_state_changed.connect(boost::bind(&QtView::update_view_state, this)); view_state_changed.connect(boost::bind(&QtView::update_view_state, this));
connect(&idle_timer_, SIGNAL(timeout()), this, SLOT(update_view_state_qt())); connect(&idle_timer_, SIGNAL(timeout()), this, SLOT(update_view_state_qt()));

View File

@ -15,15 +15,12 @@ lyx_gui (qt)
Menubar_pimpl Menubar_pimpl
- remove menubar-switching as discussed - fix disabling submenu labels when appropriate
- implement menu key shortcuts
- implement on/off switches in menus, enable/disable
- parse the submenus (*)
- implement dynamic menus (may need serious backend changes) (*)(*) - implement dynamic menus (may need serious backend changes) (*)(*)
- dynamic last files - dynamic last files
- import/export/view/update - import/export/view/update
- navigate - navigate
- remove openByName - implement openByName
QAbout QAbout