implement openByName

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@5280 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
John Levon 2002-09-12 02:10:19 +00:00
parent bcffabeb84
commit af5a63bc3e
5 changed files with 27 additions and 17 deletions

View File

@ -1,3 +1,10 @@
2002-09-12 John Levon <levon@movementarian.org>
* Menubar_pimpl.C:
* Menubar_pimpl.h:
* QtView.C: implement openByName(). Move activated
signal to per-menu
2002-09-12 John Levon <levon@movementarian.org> 2002-09-12 John Levon <levon@movementarian.org>
* QCommandBuffer.C: fix click * QCommandBuffer.C: fix click

View File

@ -30,13 +30,14 @@
#include "QLPopupMenu.h" #include "QLPopupMenu.h"
#include <qmenubar.h> #include <qmenubar.h>
#include <qcursor.h>
using std::endl; using std::endl;
using std::vector; using std::vector;
using std::max; using std::max;
using std::min; using std::min;
using std::for_each; using std::for_each;
using std::pair;
Menubar::Pimpl::Pimpl(LyXView * view, MenuBackend const & mbe) Menubar::Pimpl::Pimpl(LyXView * view, MenuBackend const & mbe)
: owner_(static_cast<QtView*>(view)), menubackend_(mbe) : owner_(static_cast<QtView*>(view)), menubackend_(mbe)
@ -44,12 +45,21 @@ Menubar::Pimpl::Pimpl(LyXView * view, MenuBackend const & mbe)
Menu::const_iterator m = mbe.getMenubar().begin(); Menu::const_iterator m = mbe.getMenubar().begin();
Menu::const_iterator end = mbe.getMenubar().end(); Menu::const_iterator end = mbe.getMenubar().end();
for (; m != end; ++m) { for (; m != end; ++m) {
pair<int, QLPopupMenu *> menu =
createMenu(owner_->menuBar(), &(*m), this, true); createMenu(owner_->menuBar(), &(*m), this, true);
name_map_[m->submenuname()] = menu.second;
QObject::connect(menu.second, SIGNAL(activated(int)),
owner_, SLOT(activated(int)));
} }
} }
void Menubar::Pimpl::openByName(string const &) void Menubar::Pimpl::openByName(string const & name)
{ {
// FIXME NameMap::const_iterator const cit = name_map_.find(name);
if (cit == name_map_.end())
return;
// this will have to do I'm afraid.
cit->second->exec(QCursor::pos());
} }

View File

@ -12,7 +12,6 @@
#ifndef MENUBAR_PIMPL_H #ifndef MENUBAR_PIMPL_H
#define MENUBAR_PIMPL_H #define MENUBAR_PIMPL_H
#include <vector>
#include <map> #include <map>
#include <config.h> #include <config.h>
@ -27,6 +26,7 @@
class LyXView; class LyXView;
class QtView; class QtView;
class MenuBackend; class MenuBackend;
class QLPopupMenu;
struct Menubar::Pimpl { struct Menubar::Pimpl {
public: public:
@ -49,6 +49,11 @@ private:
/// menu controller /// menu controller
MenuBackend const & menubackend_; MenuBackend const & menubackend_;
typedef std::map<string, QLPopupMenu *> NameMap;
/// name to menu for openByName
NameMap name_map_;
}; };
#endif // MENUBAR_PIMPL_H #endif // MENUBAR_PIMPL_H

View File

@ -61,10 +61,6 @@ QtView::QtView(unsigned int width, unsigned int height)
::current_view = bufferview_.get(); ::current_view = bufferview_.get();
menubar_.reset(new Menubar(this, menubackend)); menubar_.reset(new Menubar(this, menubackend));
connect(menuBar(), SIGNAL(activated(int)),
this, SLOT(activated(int)));
toolbar_.reset(new Toolbar(this, 0, 0, toolbardefaults)); toolbar_.reset(new Toolbar(this, 0, 0, toolbardefaults));
statusBar()->setSizeGripEnabled(false); statusBar()->setSizeGripEnabled(false);

View File

@ -9,14 +9,6 @@ lyx_gui (qt)
- move out lyxserver - move out lyxserver
- do dpi (cannot easily fix) - do dpi (cannot easily fix)
Menubar_pimpl
- implement openByName
QAbout
- give good default size
QDocument QDocument
- implement me. Need MVC (Edwin is on this) - implement me. Need MVC (Edwin is on this)