merge GuiView/Dialogs

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@21661 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
André Pönitz 2007-11-18 00:01:14 +00:00
parent ae4535adb3
commit 55b4fbcf21
11 changed files with 530 additions and 558 deletions

View File

@ -74,9 +74,8 @@
#include "insets/InsetVSpace.h" #include "insets/InsetVSpace.h"
#include "insets/InsetWrap.h" #include "insets/InsetWrap.h"
#include "frontends/Application.h"
#include "frontends/alert.h" #include "frontends/alert.h"
#include "frontends/Dialogs.h" #include "frontends/Application.h"
#include "frontends/FileDialog.h" #include "frontends/FileDialog.h"
#include "frontends/FontLoader.h" #include "frontends/FontLoader.h"
#include "frontends/KeySymbol.h" #include "frontends/KeySymbol.h"
@ -592,7 +591,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & cmd) const
break; break;
} }
string const name = cmd.getArg(0); string const name = cmd.getArg(0);
Inset * inset = lyx_view_->getDialogs().getOpenInset(name); Inset * inset = lyx_view_->getOpenInset(name);
if (inset) { if (inset) {
FuncRequest fr(LFUN_INSET_MODIFY, cmd.argument()); FuncRequest fr(LFUN_INSET_MODIFY, cmd.argument());
FuncStatus fs; FuncStatus fs;
@ -610,7 +609,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & cmd) const
} }
case LFUN_DIALOG_TOGGLE: case LFUN_DIALOG_TOGGLE:
flag.setOnOff(lyx_view_->getDialogs().visible(cmd.getArg(0))); flag.setOnOff(lyx_view_->isDialogVisible(cmd.getArg(0)));
// fall through to set "enable" // fall through to set "enable"
case LFUN_DIALOG_SHOW: { case LFUN_DIALOG_SHOW: {
string const name = cmd.getArg(0); string const name = cmd.getArg(0);
@ -1540,7 +1539,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
break; break;
} // end switch(code) } // end switch(code)
if (insetCodeOK) if (insetCodeOK)
lyx_view_->getDialogs().show(name, data, 0); lyx_view_->showDialog(name, data, 0);
break; break;
} }
@ -1548,7 +1547,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
BOOST_ASSERT(lyx_view_); BOOST_ASSERT(lyx_view_);
string const & name = argument; string const & name = argument;
// Can only update a dialog connected to an existing inset // Can only update a dialog connected to an existing inset
Inset * inset = lyx_view_->getDialogs().getOpenInset(name); Inset * inset = lyx_view_->getOpenInset(name);
if (inset) { if (inset) {
FuncRequest fr(LFUN_INSET_DIALOG_UPDATE, cmd.argument()); FuncRequest fr(LFUN_INSET_DIALOG_UPDATE, cmd.argument());
inset->dispatch(view()->cursor(), fr); inset->dispatch(view()->cursor(), fr);
@ -1569,7 +1568,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
case LFUN_DIALOG_TOGGLE: { case LFUN_DIALOG_TOGGLE: {
BOOST_ASSERT(lyx_view_); BOOST_ASSERT(lyx_view_);
if (lyx_view_->getDialogs().visible(cmd.getArg(0))) if (lyx_view_->isDialogVisible(cmd.getArg(0)))
dispatch(FuncRequest(LFUN_DIALOG_HIDE, argument)); dispatch(FuncRequest(LFUN_DIALOG_HIDE, argument));
else else
dispatch(FuncRequest(LFUN_DIALOG_SHOW, argument)); dispatch(FuncRequest(LFUN_DIALOG_SHOW, argument));
@ -1578,7 +1577,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
case LFUN_DIALOG_DISCONNECT_INSET: case LFUN_DIALOG_DISCONNECT_INSET:
BOOST_ASSERT(lyx_view_); BOOST_ASSERT(lyx_view_);
lyx_view_->getDialogs().disconnect(argument); lyx_view_->disconnectDialog(argument);
break; break;
@ -1785,7 +1784,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
case LFUN_INSET_APPLY: { case LFUN_INSET_APPLY: {
BOOST_ASSERT(lyx_view_); BOOST_ASSERT(lyx_view_);
string const name = cmd.getArg(0); string const name = cmd.getArg(0);
Inset * inset = lyx_view_->getDialogs().getOpenInset(name); Inset * inset = lyx_view_->getOpenInset(name);
if (inset) { if (inset) {
FuncRequest fr(LFUN_INSET_MODIFY, argument); FuncRequest fr(LFUN_INSET_MODIFY, argument);
inset->dispatch(view()->cursor(), fr); inset->dispatch(view()->cursor(), fr);

View File

@ -12,14 +12,12 @@
#include "Dialog.h" #include "Dialog.h"
#include "Buffer.h"
#include "FuncRequest.h" #include "FuncRequest.h"
#include "FuncStatus.h" #include "FuncStatus.h"
#include "LyXFunc.h" #include "LyXFunc.h"
#include "frontends/LyXView.h" #include "LyXView.h"
#include "frontends/Dialogs.h" // FIXME
#include "Buffer.h"
namespace lyx { namespace lyx {
@ -52,7 +50,7 @@ void Dialog::updateDialog(std::string const & name) const
void Dialog::disconnect(std::string const & name) const void Dialog::disconnect(std::string const & name) const
{ {
lyxview_->getDialogs().disconnect(name); lyxview_->disconnectDialog(name);
} }

View File

@ -1,125 +0,0 @@
// -*- C++ -*-
/**
* \file Dialogs.h
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Allan Rae
* \author Angus Leeming
*
* Full author contact details are available in file CREDITS.
*/
#ifndef DIALOGS_H
#define DIALOGS_H
#include <boost/shared_ptr.hpp>
#include <map>
#include <string>
namespace lyx {
class Inset;
namespace frontend {
class Dialog;
class LyXView;
/** Container of all dialogs.
*/
class Dialogs {
public:
///
Dialogs(LyXView &);
/** Check the status of all visible dialogs and disable or reenable
* them as appropriate.
*
* Disabling is needed for example when a dialog is open and the
* cursor moves to a position where the corresponding inset is not
* allowed.
*/
void checkStatus();
/// Are the tooltips on or off?
static bool tooltipsEnabled();
/// Hide all visible dialogs
void hideAll() const;
/// Hide any dialogs that require a buffer for them to operate
void hideBufferDependent() const;
/** Update visible, buffer-dependent dialogs
If the bool is true then a buffer change has occurred
else it is still the same buffer.
*/
void updateBufferDependent(bool) const;
/** \param name == "bibtex", "citation" etc; an identifier used to
launch a particular dialog.
\param data is a string representation of the Inset contents.
It is often little more than the output from Inset::write.
It is passed to, and parsed by, the frontend dialog.
Several of these dialogs do not need any data,
so it defaults to string().
\param inset ownership is _not_ passed to the frontend dialog.
It is stored internally and used by the kernel to ascertain
what to do with the FuncRequest dispatched from the frontend
dialog on 'Apply'; should it be used to create a new inset at
the current cursor position or modify an existing, 'open' inset?
*/
void show(std::string const & name,
std::string const & data = std::string(), Inset * inset = 0);
/** \param name == "citation", "bibtex" etc; an identifier used
to update the contents of a particular dialog with \param data.
See the comments to 'show', above.
*/
void update(std::string const & name, std::string const & data);
/// Is the dialog currently visible?
bool visible(std::string const & name) const;
/** All Dialogs of the given \param name will be closed if they are
connected to the given \param inset.
*/
void hide(std::string const & name, Inset * inset);
///
void disconnect(std::string const & name);
///
Inset * getOpenInset(std::string const & name) const;
private:
/// noncopyable
Dialogs(Dialogs const &);
void operator=(Dialogs const &);
///
void redraw() const;
///
bool isValidName(std::string const & name) const;
///
Dialog * find_or_build(std::string const & name);
///
typedef boost::shared_ptr<Dialog> DialogPtr;
///
Dialog * build(std::string const & name);
///
LyXView & lyxview_;
///
std::map<std::string, Inset *> open_insets_;
///
std::map<std::string, DialogPtr> dialogs_;
/// flag against a race condition due to multiclicks in Qt frontend,
/// see bug #1119
bool in_show_;
};
} // namespace frontend
} // namespace lyx
#endif

View File

@ -16,6 +16,8 @@
#include "frontends/Delegates.h" #include "frontends/Delegates.h"
#include "support/strfwd.h" #include "support/strfwd.h"
#include <string>
namespace lyx { namespace lyx {
namespace support { class FileName; } namespace support { class FileName; }
@ -81,11 +83,6 @@ public:
/// ///
virtual bool isToolbarVisible(std::string const & id) = 0; virtual bool isToolbarVisible(std::string const & id) = 0;
/// get access to the dialogs
virtual Dialogs & getDialogs() = 0;
///
virtual Dialogs const & getDialogs() const = 0;
//@} //@}
/// load a buffer into the current workarea. /// load a buffer into the current workarea.
@ -120,6 +117,67 @@ public:
// //
virtual void errors(std::string const &) = 0; virtual void errors(std::string const &) = 0;
//
// This View's Dialogs
//
/** Check the status of all visible dialogs and disable or reenable
* them as appropriate.
*
* Disabling is needed for example when a dialog is open and the
* cursor moves to a position where the corresponding inset is not
* allowed.
*/
virtual void checkStatus() = 0;
/// Are the tooltips on or off?
virtual bool tooltipsEnabled() = 0;
/// Hide all visible dialogs
virtual void hideAll() const = 0;
/// Hide any dialogs that require a buffer for them to operate
virtual void hideBufferDependent() const = 0;
/** Update visible, buffer-dependent dialogs
If the bool is true then a buffer change has occurred
else it is still the same buffer.
*/
virtual void updateBufferDependent(bool) const = 0;
/** \param name == "bibtex", "citation" etc; an identifier used to
launch a particular dialog.
\param data is a string representation of the Inset contents.
It is often little more than the output from Inset::write.
It is passed to, and parsed by, the frontend dialog.
Several of these dialogs do not need any data,
so it defaults to string().
\param inset ownership is _not_ passed to the frontend dialog.
It is stored internally and used by the kernel to ascertain
what to do with the FuncRequest dispatched from the frontend
dialog on 'Apply'; should it be used to create a new inset at
the current cursor position or modify an existing, 'open' inset?
*/
virtual void showDialog(std::string const & name,
std::string const & data = std::string(), Inset * inset = 0) = 0;
/** \param name == "citation", "bibtex" etc; an identifier used
to update the contents of a particular dialog with \param data.
See the comments to 'show', above.
*/
virtual void updateDialog(std::string const & name, std::string const & data) = 0;
/// Is the dialog currently visible?
virtual bool isDialogVisible(std::string const & name) const = 0;
/** All Dialogs of the given \param name will be closed if they are
connected to the given \param inset.
*/
virtual void hideDialog(std::string const & name, Inset * inset) = 0;
///
virtual void disconnectDialog(std::string const & name) = 0;
///
virtual Inset * getOpenInset(std::string const & name) const = 0;
private: private:
/// noncopyable /// noncopyable
LyXView(LyXView const &); LyXView(LyXView const &);

View File

@ -13,7 +13,6 @@ liblyxfrontends_la_SOURCES = \
Application.h \ Application.h \
NoGuiFontLoader.h \ NoGuiFontLoader.h \
NoGuiFontMetrics.h \ NoGuiFontMetrics.h \
Dialogs.h \
FileDialog.h \ FileDialog.h \
FontLoader.h \ FontLoader.h \
FontMetrics.h \ FontMetrics.h \

View File

@ -1,380 +0,0 @@
/**
* \file qt4/Dialogs.cpp
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Angus Leeming
*
* Full author contact details are available in file CREDITS.
*/
#include <config.h>
#include "Dialogs.h"
#include "Dialog.h"
#include <boost/assert.hpp>
using std::string;
namespace lyx {
extern bool quitting;
namespace frontend {
Dialogs::Dialogs(LyXView & lyxview)
: lyxview_(lyxview), in_show_(false)
{}
Dialog * Dialogs::find_or_build(string const & name)
{
if (!isValidName(name))
return 0;
std::map<string, DialogPtr>::iterator it =
dialogs_.find(name);
if (it != dialogs_.end())
return it->second.get();
dialogs_[name].reset(build(name));
return dialogs_[name].get();
}
void Dialogs::show(string const & name, string const & data, Inset * inset)
{
if (in_show_)
return;
in_show_ = true;
Dialog * dialog = find_or_build(name);
if (dialog) {
dialog->showData(data);
if (inset)
open_insets_[name] = inset;
}
in_show_ = false;
}
bool Dialogs::visible(string const & name) const
{
std::map<string, DialogPtr>::const_iterator it = dialogs_.find(name);
if (it == dialogs_.end())
return false;
return it->second.get()->isVisibleView();
}
void Dialogs::update(string const & name, string const & data)
{
std::map<string, DialogPtr>::const_iterator it = dialogs_.find(name);
if (it == dialogs_.end())
return;
Dialog * const dialog = it->second.get();
if (dialog->isVisibleView())
dialog->updateData(data);
}
void Dialogs::hide(string const & name, Inset* inset)
{
// Don't send the signal if we are quitting, because on MSVC it is
// destructed before the cut stack in CutAndPaste.cpp, and this method
// is called from some inset destructor if the cut stack is not empty
// on exit.
if (quitting)
return;
std::map<string, DialogPtr>::const_iterator it =
dialogs_.find(name);
if (it == dialogs_.end())
return;
if (inset && inset != getOpenInset(name))
return;
Dialog * const dialog = it->second.get();
if (dialog->isVisibleView())
dialog->hide();
open_insets_[name] = 0;
}
void Dialogs::disconnect(string const & name)
{
if (!isValidName(name))
return;
if (open_insets_.find(name) != open_insets_.end())
open_insets_[name] = 0;
}
Inset * Dialogs::getOpenInset(string const & name) const
{
if (!isValidName(name))
return 0;
std::map<string, Inset *>::const_iterator it =
open_insets_.find(name);
return it == open_insets_.end() ? 0 : it->second;
}
void Dialogs::hideAll() const
{
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
for(; it != end; ++it)
it->second->hide();
}
void Dialogs::hideBufferDependent() const
{
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
for(; it != end; ++it) {
Dialog * dialog = it->second.get();
if (dialog->isBufferDependent())
dialog->hide();
}
}
void Dialogs::updateBufferDependent(bool switched) const
{
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
for(; it != end; ++it) {
Dialog * dialog = it->second.get();
if (switched && dialog->isBufferDependent()) {
if (dialog->isVisibleView() && dialog->initialiseParams(""))
dialog->updateView();
else
dialog->hide();
} else {
// A bit clunky, but the dialog will request
// that the kernel provides it with the necessary
// data.
dialog->slotRestore();
}
}
}
void Dialogs::redraw() const
{
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
for(; it != end; ++it)
it->second->redraw();
}
void Dialogs::checkStatus()
{
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
for(; it != end; ++it) {
Dialog * const dialog = it->second.get();
if (dialog && dialog->isVisibleView())
dialog->checkStatus();
}
}
namespace {
// This list should be kept in sync with the list of insets in
// src/insets/Inset.cpp. I.e., if a dialog goes with an inset, the
// dialog should have the same name as the inset.
char const * const dialognames[] = {
"aboutlyx", "bibitem", "bibtex", "box", "branch", "changes", "character",
"citation", "document", "embedding", "errorlist", "ert", "external", "file",
"findreplace", "float", "graphics", "include", "index", "nomenclature", "label", "log",
"mathdelimiter", "mathmatrix", "note", "paragraph",
"prefs", "print", "ref", "sendto", "spellchecker","tabular", "tabularcreate",
#ifdef HAVE_LIBAIKSAURUS
"thesaurus",
#endif
"texinfo", "toc", "href", "view-source", "vspace", "wrap", "listings" };
char const * const * const end_dialognames =
dialognames + (sizeof(dialognames) / sizeof(char *));
class cmpCStr {
public:
cmpCStr(char const * name) : name_(name) {}
bool operator()(char const * other) {
return strcmp(other, name_) == 0;
}
private:
char const * name_;
};
} // namespace anon
// will be replaced by a proper factory...
Dialog * createGuiAbout(LyXView & lv);
Dialog * createGuiBibitem(LyXView & lv);
Dialog * createGuiBibtex(LyXView & lv);
Dialog * createGuiBox(LyXView & lv);
Dialog * createGuiBranch(LyXView & lv);
Dialog * createGuiChanges(LyXView & lv);
Dialog * createGuiCharacter(LyXView & lv);
Dialog * createGuiCitation(LyXView & lv);
Dialog * createGuiDelimiter(LyXView & lv);
Dialog * createGuiDocument(LyXView & lv);
Dialog * createGuiErrorList(LyXView & lv);
Dialog * createGuiERT(LyXView & lv);
Dialog * createGuiExternal(LyXView & lv);
Dialog * createGuiFloat(LyXView & lv);
Dialog * createGuiGraphics(LyXView & lv);
Dialog * createGuiInclude(LyXView & lv);
Dialog * createGuiIndex(LyXView & lv);
Dialog * createGuiLabel(LyXView & lv);
Dialog * createGuiListings(LyXView & lv);
Dialog * createGuiLog(LyXView & lv);
Dialog * createGuiMathMatrix(LyXView & lv);
Dialog * createGuiNomenclature(LyXView & lv);
Dialog * createGuiNote(LyXView & lv);
Dialog * createGuiParagraph(LyXView & lv);
Dialog * createGuiPreferences(LyXView & lv);
Dialog * createGuiPrint(LyXView & lv);
Dialog * createGuiRef(LyXView & lv);
Dialog * createGuiSearch(LyXView & lv);
Dialog * createGuiSendTo(LyXView & lv);
Dialog * createGuiShowFile(LyXView & lv);
Dialog * createGuiSpellchecker(LyXView & lv);
Dialog * createGuiTabularCreate(LyXView & lv);
Dialog * createGuiTabular(LyXView & lv);
Dialog * createGuiTexInfo(LyXView & lv);
Dialog * createGuiToc(LyXView & lv);
Dialog * createGuiThesaurus(LyXView & lv);
Dialog * createGuiHyperlink(LyXView & lv);
Dialog * createGuiVSpace(LyXView & lv);
Dialog * createGuiViewSource(LyXView & lv);
Dialog * createGuiWrap(LyXView & lv);
bool Dialogs::isValidName(string const & name) const
{
return std::find_if(dialognames, end_dialognames,
cmpCStr(name.c_str())) != end_dialognames;
}
Dialog * Dialogs::build(string const & name)
{
BOOST_ASSERT(isValidName(name));
if (name == "aboutlyx")
return createGuiAbout(lyxview_);
if (name == "bibitem")
return createGuiBibitem(lyxview_);
if (name == "bibtex")
return createGuiBibtex(lyxview_);
if (name == "box")
return createGuiBox(lyxview_);
if (name == "branch")
return createGuiBranch(lyxview_);
if (name == "changes")
return createGuiChanges(lyxview_);
if (name == "character")
return createGuiCharacter(lyxview_);
if (name == "citation")
return createGuiCitation(lyxview_);
if (name == "document")
return createGuiDocument(lyxview_);
if (name == "errorlist")
return createGuiErrorList(lyxview_);
if (name == "ert")
return createGuiERT(lyxview_);
if (name == "external")
return createGuiExternal(lyxview_);
if (name == "file")
return createGuiShowFile(lyxview_);
if (name == "findreplace")
return createGuiSearch(lyxview_);
if (name == "float")
return createGuiFloat(lyxview_);
if (name == "graphics")
return createGuiGraphics(lyxview_);
if (name == "include")
return createGuiInclude(lyxview_);
if (name == "index")
return createGuiIndex(lyxview_);
if (name == "nomenclature")
return createGuiNomenclature(lyxview_);
if (name == "label")
return createGuiLabel(lyxview_);
if (name == "log")
return createGuiLog(lyxview_);
if (name == "view-source")
return createGuiViewSource(lyxview_);
if (name == "mathdelimiter")
return createGuiDelimiter(lyxview_);
if (name == "mathmatrix")
return createGuiMathMatrix(lyxview_);
if (name == "note")
return createGuiNote(lyxview_);
if (name == "paragraph")
return createGuiParagraph(lyxview_);
if (name == "prefs")
return createGuiPreferences(lyxview_);
if (name == "print")
return createGuiPrint(lyxview_);
if (name == "ref")
return createGuiRef(lyxview_);
if (name == "sendto")
return createGuiSendTo(lyxview_);
if (name == "spellchecker")
return createGuiSpellchecker(lyxview_);
if (name == "tabular")
return createGuiTabular(lyxview_);
if (name == "tabularcreate")
return createGuiTabularCreate(lyxview_);
if (name == "texinfo")
return createGuiTexInfo(lyxview_);
#ifdef HAVE_LIBAIKSAURUS
if (name == "thesaurus")
return createGuiThesaurus(lyxview_);
#endif
if (name == "toc")
return createGuiToc(lyxview_);
if (name == "href")
return createGuiHyperlink(lyxview_);
if (name == "vspace")
return createGuiVSpace(lyxview_);
if (name == "wrap")
return createGuiWrap(lyxview_);
if (name == "listings")
return createGuiListings(lyxview_);
return 0;
}
/// Are the tooltips on or off?
bool Dialogs::tooltipsEnabled()
{
return false;
}
} // namespace frontend
} // namespace lyx

View File

@ -17,7 +17,6 @@
#include "qt_helpers.h" #include "qt_helpers.h"
#include "GuiImage.h" #include "GuiImage.h"
#include "GuiView.h" #include "GuiView.h"
#include "Dialogs.h"
#include "frontends/alert.h" #include "frontends/alert.h"
#include "frontends/Application.h" #include "frontends/Application.h"
@ -515,7 +514,7 @@ void GuiApplication::hideDialogs(string const & name, Inset * inset) const
vector<int>::const_iterator it = view_ids_.begin(); vector<int>::const_iterator it = view_ids_.begin();
vector<int>::const_iterator const end = view_ids_.end(); vector<int>::const_iterator const end = view_ids_.end();
for (; it != end; ++it) for (; it != end; ++it)
view(*it).getDialogs().hide(name, inset); view(*it).hideDialog(name, inset);
} }

View File

@ -13,6 +13,13 @@
#include <config.h> #include <config.h>
#include "GuiView.h"
#include "Dialog.h"
#include <boost/assert.hpp>
using std::string;
#include "GuiView.h" #include "GuiView.h"
#include "GuiApplication.h" #include "GuiApplication.h"
@ -21,12 +28,9 @@
#include "GuiMenubar.h" #include "GuiMenubar.h"
#include "GuiToolbar.h" #include "GuiToolbar.h"
#include "GuiToolbars.h" #include "GuiToolbars.h"
#include "Dialogs.h"
#include "qt_helpers.h" #include "qt_helpers.h"
#include "frontends/Dialogs.h"
#include "support/filetools.h" #include "support/filetools.h"
#include "support/convert.h" #include "support/convert.h"
#include "support/lstrings.h" #include "support/lstrings.h"
@ -147,6 +151,8 @@ private:
} // namespace anon } // namespace anon
typedef boost::shared_ptr<Dialog> DialogPtr;
struct GuiView::GuiViewPrivate struct GuiView::GuiViewPrivate
{ {
GuiViewPrivate() GuiViewPrivate()
@ -261,6 +267,16 @@ public:
GuiToolbars * toolbars_; GuiToolbars * toolbars_;
/// ///
docstring current_layout; docstring current_layout;
///
std::map<std::string, Inset *> open_insets_;
///
std::map<std::string, DialogPtr> dialogs_;
///
/// flag against a race condition due to multiclicks
/// see bug #1119
bool in_show_;
}; };
@ -272,7 +288,7 @@ GuiView::GuiView(int id)
d(*new GuiViewPrivate), d(*new GuiViewPrivate),
quitting_by_menu_(false), quitting_by_menu_(false),
autosave_timeout_(new Timeout(5000)), autosave_timeout_(new Timeout(5000)),
dialogs_(new Dialogs(*this)) in_show_(false)
{ {
// Start autosave timer // Start autosave timer
if (lyxrc.autosave) { if (lyxrc.autosave) {
@ -296,7 +312,6 @@ GuiView::GuiView(int id)
setWindowIcon(QPixmap(":/images/lyx.png")); setWindowIcon(QPixmap(":/images/lyx.png"));
#endif #endif
d.splitter_ = new QSplitter; d.splitter_ = new QSplitter;
d.initBackground(); d.initBackground();
@ -313,7 +328,6 @@ GuiView::GuiView(int id)
GuiView::~GuiView() GuiView::~GuiView()
{ {
delete dialogs_;
delete autosave_timeout_; delete autosave_timeout_;
delete &d; delete &d;
} }
@ -532,7 +546,7 @@ void GuiView::on_currentWorkAreaChanged(GuiWorkArea * wa)
// Buffer-dependent dialogs should be updated or // Buffer-dependent dialogs should be updated or
// hidden. This should go here because some dialogs (eg ToC) // hidden. This should go here because some dialogs (eg ToC)
// require bv_->text. // require bv_->text.
dialogs_->updateBufferDependent(true); updateBufferDependent(true);
updateToolbars(); updateToolbars();
updateLayoutChoice(false); updateLayoutChoice(false);
updateStatusBar(); updateStatusBar();
@ -582,7 +596,7 @@ bool GuiView::event(QEvent * e)
connectBuffer(bv.buffer()); connectBuffer(bv.buffer());
// The document structure, name and dialogs might have // The document structure, name and dialogs might have
// changed in another view. // changed in another view.
dialogs_->updateBufferDependent(true); updateBufferDependent(true);
} else { } else {
setWindowTitle(qt_("LyX")); setWindowTitle(qt_("LyX"));
setWindowIconText(qt_("LyX")); setWindowIconText(qt_("LyX"));
@ -757,7 +771,7 @@ void GuiView::removeWorkArea(GuiWorkArea * work_area)
if (gwa == d.current_work_area_) { if (gwa == d.current_work_area_) {
disconnectBuffer(); disconnectBuffer();
disconnectBufferView(); disconnectBufferView();
dialogs_->hideBufferDependent(); hideBufferDependent();
d.current_work_area_ = 0; d.current_work_area_ = 0;
} }
@ -837,7 +851,7 @@ void GuiView::updateToolbars()
d.toolbars_->update(false, false, false); d.toolbars_->update(false, false, false);
// update read-only status of open dialogs. // update read-only status of open dialogs.
dialogs_->checkStatus(); checkStatus();
} }
@ -942,33 +956,40 @@ void GuiView::errors(string const & error_type)
{ {
ErrorList & el = buffer()->errorList(error_type); ErrorList & el = buffer()->errorList(error_type);
if (!el.empty()) if (!el.empty())
dialogs_->show("errorlist", error_type); showDialog("errorlist", error_type);
} }
void GuiView::showDialog(string const & name) void GuiView::showDialog(std::string const & name)
{ {
dialogs_->show(name); showDialog(name, string());
} }
void GuiView::showDialogWithData(string const & name, string const & data) void GuiView::showDialogWithData(string const & name, string const & data)
{ {
dialogs_->show(name, data); showDialog(name, data);
} }
void GuiView::showInsetDialog(string const & name, string const & data, void GuiView::showInsetDialog(string const & name, string const & data,
Inset * inset) Inset * inset)
{ {
dialogs_->show(name, data, inset); showDialog(name, data, inset);
} }
void GuiView::updateDialog(string const & name, string const & data) void GuiView::updateDialog(string const & name, string const & data)
{ {
if (dialogs_->visible(name)) if (!isDialogVisible(name))
dialogs_->update(name, data); return;
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.find(name);
if (it == d.dialogs_.end())
return;
Dialog * const dialog = it->second.get();
if (dialog->isVisibleView())
dialog->updateData(data);
} }
@ -1085,6 +1106,341 @@ void GuiView::restartCursor()
d.current_work_area_->startBlinkingCursor(); d.current_work_area_->startBlinkingCursor();
} }
Dialog * GuiView::find_or_build(string const & name)
{
if (!isValidName(name))
return 0;
std::map<string, DialogPtr>::iterator it = d.dialogs_.find(name);
if (it != d.dialogs_.end())
return it->second.get();
d.dialogs_[name].reset(build(name));
return d.dialogs_[name].get();
}
void GuiView::showDialog(string const & name, string const & data,
Inset * inset)
{
if (in_show_)
return;
in_show_ = true;
Dialog * dialog = find_or_build(name);
if (dialog) {
dialog->showData(data);
if (inset)
d.open_insets_[name] = inset;
}
in_show_ = false;
}
bool GuiView::isDialogVisible(string const & name) const
{
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.find(name);
if (it == d.dialogs_.end())
return false;
return it->second.get()->isVisibleView();
}
void GuiView::hideDialog(string const & name, Inset * inset)
{
// Don't send the signal if we are quitting, because on MSVC it is
// destructed before the cut stack in CutAndPaste.cpp, and this method
// is called from some inset destructor if the cut stack is not empty
// on exit.
if (quitting)
return;
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.find(name);
if (it == d.dialogs_.end())
return;
if (inset && inset != getOpenInset(name))
return;
Dialog * const dialog = it->second.get();
if (dialog->isVisibleView())
dialog->hide();
d.open_insets_[name] = 0;
}
void GuiView::disconnectDialog(string const & name)
{
if (!isValidName(name))
return;
if (d.open_insets_.find(name) != d.open_insets_.end())
d.open_insets_[name] = 0;
}
Inset * GuiView::getOpenInset(string const & name) const
{
if (!isValidName(name))
return 0;
std::map<string, Inset *>::const_iterator it = d.open_insets_.find(name);
return it == d.open_insets_.end() ? 0 : it->second;
}
void GuiView::hideAll() const
{
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
for(; it != end; ++it)
it->second->hide();
}
void GuiView::hideBufferDependent() const
{
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
for(; it != end; ++it) {
Dialog * dialog = it->second.get();
if (dialog->isBufferDependent())
dialog->hide();
}
}
void GuiView::updateBufferDependent(bool switched) const
{
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
for(; it != end; ++it) {
Dialog * dialog = it->second.get();
if (switched && dialog->isBufferDependent()) {
if (dialog->isVisibleView() && dialog->initialiseParams(""))
dialog->updateView();
else
dialog->hide();
} else {
// A bit clunky, but the dialog will request
// that the kernel provides it with the necessary
// data.
dialog->slotRestore();
}
}
}
void GuiView::redrawDialog() const
{
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
for(; it != end; ++it)
it->second->redraw();
}
void GuiView::checkStatus()
{
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
for(; it != end; ++it) {
Dialog * const dialog = it->second.get();
if (dialog && dialog->isVisibleView())
dialog->checkStatus();
}
}
namespace {
// This list should be kept in sync with the list of insets in
// src/insets/Inset.cpp. I.e., if a dialog goes with an inset, the
// dialog should have the same name as the inset.
char const * const dialognames[] = {
"aboutlyx", "bibitem", "bibtex", "box", "branch", "changes", "character",
"citation", "document", "embedding", "errorlist", "ert", "external", "file",
"findreplace", "float", "graphics", "include", "index", "nomenclature", "label", "log",
"mathdelimiter", "mathmatrix", "note", "paragraph",
"prefs", "print", "ref", "sendto", "spellchecker","tabular", "tabularcreate",
#ifdef HAVE_LIBAIKSAURUS
"thesaurus",
#endif
"texinfo", "toc", "href", "view-source", "vspace", "wrap", "listings" };
char const * const * const end_dialognames =
dialognames + (sizeof(dialognames) / sizeof(char *));
class cmpCStr {
public:
cmpCStr(char const * name) : name_(name) {}
bool operator()(char const * other) {
return strcmp(other, name_) == 0;
}
private:
char const * name_;
};
} // namespace anon
// will be replaced by a proper factory...
Dialog * createGuiAbout(LyXView & lv);
Dialog * createGuiBibitem(LyXView & lv);
Dialog * createGuiBibtex(LyXView & lv);
Dialog * createGuiBox(LyXView & lv);
Dialog * createGuiBranch(LyXView & lv);
Dialog * createGuiChanges(LyXView & lv);
Dialog * createGuiCharacter(LyXView & lv);
Dialog * createGuiCitation(LyXView & lv);
Dialog * createGuiDelimiter(LyXView & lv);
Dialog * createGuiDocument(LyXView & lv);
Dialog * createGuiErrorList(LyXView & lv);
Dialog * createGuiERT(LyXView & lv);
Dialog * createGuiExternal(LyXView & lv);
Dialog * createGuiFloat(LyXView & lv);
Dialog * createGuiGraphics(LyXView & lv);
Dialog * createGuiInclude(LyXView & lv);
Dialog * createGuiIndex(LyXView & lv);
Dialog * createGuiLabel(LyXView & lv);
Dialog * createGuiListings(LyXView & lv);
Dialog * createGuiLog(LyXView & lv);
Dialog * createGuiMathMatrix(LyXView & lv);
Dialog * createGuiNomenclature(LyXView & lv);
Dialog * createGuiNote(LyXView & lv);
Dialog * createGuiParagraph(LyXView & lv);
Dialog * createGuiPreferences(LyXView & lv);
Dialog * createGuiPrint(LyXView & lv);
Dialog * createGuiRef(LyXView & lv);
Dialog * createGuiSearch(LyXView & lv);
Dialog * createGuiSendTo(LyXView & lv);
Dialog * createGuiShowFile(LyXView & lv);
Dialog * createGuiSpellchecker(LyXView & lv);
Dialog * createGuiTabularCreate(LyXView & lv);
Dialog * createGuiTabular(LyXView & lv);
Dialog * createGuiTexInfo(LyXView & lv);
Dialog * createGuiToc(LyXView & lv);
Dialog * createGuiThesaurus(LyXView & lv);
Dialog * createGuiHyperlink(LyXView & lv);
Dialog * createGuiVSpace(LyXView & lv);
Dialog * createGuiViewSource(LyXView & lv);
Dialog * createGuiWrap(LyXView & lv);
bool GuiView::isValidName(string const & name) const
{
return std::find_if(dialognames, end_dialognames,
cmpCStr(name.c_str())) != end_dialognames;
}
Dialog * GuiView::build(string const & name)
{
BOOST_ASSERT(isValidName(name));
if (name == "aboutlyx")
return createGuiAbout(*this);
if (name == "bibitem")
return createGuiBibitem(*this);
if (name == "bibtex")
return createGuiBibtex(*this);
if (name == "box")
return createGuiBox(*this);
if (name == "branch")
return createGuiBranch(*this);
if (name == "changes")
return createGuiChanges(*this);
if (name == "character")
return createGuiCharacter(*this);
if (name == "citation")
return createGuiCitation(*this);
if (name == "document")
return createGuiDocument(*this);
if (name == "errorlist")
return createGuiErrorList(*this);
if (name == "ert")
return createGuiERT(*this);
if (name == "external")
return createGuiExternal(*this);
if (name == "file")
return createGuiShowFile(*this);
if (name == "findreplace")
return createGuiSearch(*this);
if (name == "float")
return createGuiFloat(*this);
if (name == "graphics")
return createGuiGraphics(*this);
if (name == "include")
return createGuiInclude(*this);
if (name == "index")
return createGuiIndex(*this);
if (name == "nomenclature")
return createGuiNomenclature(*this);
if (name == "label")
return createGuiLabel(*this);
if (name == "log")
return createGuiLog(*this);
if (name == "view-source")
return createGuiViewSource(*this);
if (name == "mathdelimiter")
return createGuiDelimiter(*this);
if (name == "mathmatrix")
return createGuiMathMatrix(*this);
if (name == "note")
return createGuiNote(*this);
if (name == "paragraph")
return createGuiParagraph(*this);
if (name == "prefs")
return createGuiPreferences(*this);
if (name == "print")
return createGuiPrint(*this);
if (name == "ref")
return createGuiRef(*this);
if (name == "sendto")
return createGuiSendTo(*this);
if (name == "spellchecker")
return createGuiSpellchecker(*this);
if (name == "tabular")
return createGuiTabular(*this);
if (name == "tabularcreate")
return createGuiTabularCreate(*this);
if (name == "texinfo")
return createGuiTexInfo(*this);
#ifdef HAVE_LIBAIKSAURUS
if (name == "thesaurus")
return createGuiThesaurus(*this);
#endif
if (name == "toc")
return createGuiToc(*this);
if (name == "href")
return createGuiHyperlink(*this);
if (name == "vspace")
return createGuiVSpace(*this);
if (name == "wrap")
return createGuiWrap(*this);
if (name == "listings")
return createGuiListings(*this);
return 0;
}
/// Are the tooltips on or off?
bool GuiView::tooltipsEnabled()
{
return false;
}
} // namespace frontend } // namespace frontend
} // namespace lyx } // namespace lyx

View File

@ -17,6 +17,9 @@
#include "frontends/LyXView.h" #include "frontends/LyXView.h"
#include <string>
#include <QMainWindow> #include <QMainWindow>
#include <QTimer> #include <QTimer>
@ -36,6 +39,7 @@ namespace frontend {
class GuiToolbar; class GuiToolbar;
class GuiWorkArea; class GuiWorkArea;
class Dialog;
QWidget * mainWindow(); QWidget * mainWindow();
@ -95,8 +99,6 @@ public:
std::string const & data); std::string const & data);
void showInsetDialog(std::string const & name, void showInsetDialog(std::string const & name,
std::string const & data, Inset * inset); std::string const & data, Inset * inset);
void updateDialog(std::string const & name,
std::string const & data);
/// called on timeout /// called on timeout
void autoSave(); void autoSave();
@ -106,11 +108,6 @@ public:
/// \return the current buffer view. /// \return the current buffer view.
BufferView * view(); BufferView * view();
/// get access to the dialogs
Dialogs & getDialogs() { return *dialogs_; }
///
Dialogs const & getDialogs() const { return *dialogs_; }
/// load a buffer into the current workarea. /// load a buffer into the current workarea.
Buffer * loadLyXFile(support::FileName const & name, ///< File to load. Buffer * loadLyXFile(support::FileName const & name, ///< File to load.
bool tolastfiles = true); ///< append to the "Open recent" menu? bool tolastfiles = true); ///< append to the "Open recent" menu?
@ -205,10 +202,83 @@ private:
/// auto-saving of buffers /// auto-saving of buffers
Timeout * const autosave_timeout_; Timeout * const autosave_timeout_;
/// dialogs for this view
Dialogs * dialogs_;
};
public:
///
/// dialogs for this view
///
/** Check the status of all visible dialogs and disable or reenable
* them as appropriate.
*
* Disabling is needed for example when a dialog is open and the
* cursor moves to a position where the corresponding inset is not
* allowed.
*/
void checkStatus();
/// Are the tooltips on or off?
bool tooltipsEnabled();
/// Hide all visible dialogs
void hideAll() const;
/// Hide any dialogs that require a buffer for them to operate
void hideBufferDependent() const;
/** Update visible, buffer-dependent dialogs
If the bool is true then a buffer change has occurred
else it is still the same buffer.
*/
void updateBufferDependent(bool) const;
/** \param name == "bibtex", "citation" etc; an identifier used to
launch a particular dialog.
\param data is a string representation of the Inset contents.
It is often little more than the output from Inset::write.
It is passed to, and parsed by, the frontend dialog.
Several of these dialogs do not need any data,
so it defaults to string().
\param inset ownership is _not_ passed to the frontend dialog.
It is stored internally and used by the kernel to ascertain
what to do with the FuncRequest dispatched from the frontend
dialog on 'Apply'; should it be used to create a new inset at
the current cursor position or modify an existing, 'open' inset?
*/
void showDialog(std::string const & name,
std::string const & data = std::string(), Inset * inset = 0);
/** \param name == "citation", "bibtex" etc; an identifier used
to update the contents of a particular dialog with \param data.
See the comments to 'show', above.
*/
void updateDialog(std::string const & name, std::string const & data);
/// Is the dialog currently visible?
bool isDialogVisible(std::string const & name) const;
/** All Dialogs of the given \param name will be closed if they are
connected to the given \param inset.
*/
void hideDialog(std::string const & name, Inset * inset);
///
void disconnectDialog(std::string const & name);
///
Inset * getOpenInset(std::string const & name) const;
private:
///
void redrawDialog() const;
///
bool isValidName(std::string const & name) const;
///
Dialog * find_or_build(std::string const & name);
///
Dialog * build(std::string const & name);
///
/// flag against a race condition due to multiclicks in Qt frontend,
/// see bug #1119
bool in_show_;
};
} // namespace frontend } // namespace frontend
} // namespace lyx } // namespace lyx

View File

@ -41,7 +41,6 @@
#include "support/ForkedcallsController.h" #include "support/ForkedcallsController.h"
#include "frontends/Application.h" #include "frontends/Application.h"
#include "frontends/Dialogs.h" // only used in setReadOnly
#include "frontends/FontMetrics.h" #include "frontends/FontMetrics.h"
#include "frontends/WorkAreaManager.h" #include "frontends/WorkAreaManager.h"
@ -961,7 +960,7 @@ void GuiWorkArea::setReadOnly(bool)
{ {
updateWindowTitle(); updateWindowTitle();
if (this == lyx_view_->currentWorkArea()) if (this == lyx_view_->currentWorkArea())
lyx_view_->getDialogs().updateBufferDependent(false); lyx_view_->updateBufferDependent(false);
} }

View File

@ -56,7 +56,6 @@ SOURCEFILES = \
ButtonController.cpp \ ButtonController.cpp \
ColorCache.cpp \ ColorCache.cpp \
CustomizedWidgets.cpp \ CustomizedWidgets.cpp \
Dialogs.cpp \
EmptyTable.cpp \ EmptyTable.cpp \
FileDialog.cpp \ FileDialog.cpp \
FloatPlacement.cpp \ FloatPlacement.cpp \