#include "Toolbar.h"
#include "ToolbarBackend.h"
-#include "Toolbar_pimpl.h"
#include "debug.h"
#include "LyXAction.h"
using std::endl;
-Toolbar::Toolbar(LyXView * o, int x, int y, ToolbarBackend const & backend)
+Toolbar::Toolbar()
: last_textclass_(-1)
{
- pimpl_ = new Pimpl(o, x, y);
-
- // extracts the toolbar actions from the backend
- for (ToolbarBackend::const_iterator cit = backend.begin();
- cit != backend.end(); ++cit) {
- pimpl_->add((*cit));
- lyxerr[Debug::GUI] << "tool action: " << (*cit) << endl;
- }
}
Toolbar::~Toolbar()
{
- delete pimpl_;
}
-void Toolbar::update()
+void Toolbar::init()
{
- pimpl_->update();
-}
+ // extracts the toolbars from the backend
+ ToolbarBackend::Toolbars::const_iterator cit = toolbarbackend.begin();
+ ToolbarBackend::Toolbars::const_iterator end = toolbarbackend.end();
+ for (; cit != end; ++cit)
+ add(*cit);
+}
-void Toolbar::setLayout(string const & layout)
+void Toolbar::update(bool in_math, bool in_table)
{
- pimpl_->setLayout(layout);
+ update();
+
+ // extracts the toolbars from the backend
+ ToolbarBackend::Toolbars::const_iterator cit = toolbarbackend.begin();
+ ToolbarBackend::Toolbars::const_iterator end = toolbarbackend.end();
+
+ for (; cit != end; ++cit) {
+ if (cit->flags & ToolbarBackend::MATH)
+ displayToolbar(*cit, in_math);
+ else if (cit->flags & ToolbarBackend::TABLE)
+ displayToolbar(*cit, in_table);
+ }
}
{
// update the layout display
if (last_textclass_ != textclass) {
- pimpl_->updateLayoutList(true);
+ updateLayoutList();
last_textclass_ = textclass;
return true;
- } else {
- pimpl_->updateLayoutList(false);
+ } else
return false;
- }
-}
-
-
-void Toolbar::openLayoutList()
-{
- pimpl_->openLayoutList();
-}
-
-
-void Toolbar::clearLayoutList()
-{
- pimpl_->clearLayoutList();
}