* \author Angus Leeming
* \author Lars Gullik Bjønnes
*
- * Full author contact details are available in file CREDITS
+ * Full author contact details are available in file CREDITS.
*/
#include <config.h>
#include "insetcommand.h"
+
#include "BufferView.h"
-#include "debug.h"
+#include "dispatchresult.h"
#include "funcrequest.h"
#include "lyxlex.h"
#include "metricsinfo.h"
-#include "frontends/Painter.h"
-
-#include "support/lstrings.h"
+#include <sstream>
-#include "Lsstream.h"
+using std::string;
+using std::istringstream;
using std::ostream;
+using std::ostringstream;
-InsetCommand::InsetCommand(InsetCommandParams const & p)
- : p_(p.getCmdName(), p.getContents(), p.getOptions()),
+InsetCommand::InsetCommand(InsetCommandParams const & p,
+ string const & mailer_name)
+ : p_(p.getCmdName(), p.getContents(), p.getOptions(), p.getSecOptions()),
+ mailer_name_(mailer_name),
set_label_(false)
{}
-BufferView * InsetCommand::view() const
+InsetCommand::~InsetCommand()
{
- return button_.view();
+ if (!mailer_name_.empty())
+ InsetCommandMailer(mailer_name_, *this).hideDialog();
}
{
if (!set_label_) {
set_label_ = true;
- button_.update(getScreenLabel(mi.base.bv->buffer()),
+ button_.update(getScreenLabel(*mi.base.bv->buffer()),
editable() != NOT_EDITABLE);
}
button_.metrics(mi, dim);
void InsetCommand::draw(PainterInfo & pi, int x, int y) const
{
+ setPosCache(pi, x, y);
button_.draw(pi, x, y);
}
void InsetCommand::setParams(InsetCommandParams const & p)
{
- p_.setCmdName(p.getCmdName());
- p_.setContents(p.getContents());
- p_.setOptions(p.getOptions());
+ p_ = p;
set_label_ = false;
}
-int InsetCommand::latex(Buffer const *, ostream & os,
- LatexRunParams const &) const
+int InsetCommand::latex(Buffer const &, ostream & os,
+ OutputParams const &) const
{
os << getCommand();
return 0;
}
-int InsetCommand::ascii(Buffer const *, ostream &, int) const
+int InsetCommand::plaintext(Buffer const &, ostream &,
+ OutputParams const &) const
{
return 0;
}
-int InsetCommand::linuxdoc(Buffer const *, ostream &) const
+int InsetCommand::linuxdoc(Buffer const &, ostream &,
+ OutputParams const &) const
{
return 0;
}
-int InsetCommand::docbook(Buffer const *, ostream &, bool) const
+int InsetCommand::docbook(Buffer const &, ostream &,
+ OutputParams const &) const
{
return 0;
}
-dispatch_result InsetCommand::localDispatch(FuncRequest const & cmd)
+void InsetCommand::priv_dispatch(LCursor & cur, FuncRequest & cmd)
{
switch (cmd.action) {
+ case LFUN_INSET_REFRESH:
+ set_label_ = false;
+ break;
+
case LFUN_INSET_MODIFY: {
InsetCommandParams p;
- InsetCommandMailer::string2params(cmd.argument, p);
- if (p.getCmdName().empty())
- return UNDISPATCHED;
-
- setParams(p);
- cmd.view()->updateInset(this);
- return DISPATCHED;
+ InsetCommandMailer::string2params(mailer_name_, cmd.argument, p);
+ if (p.getCmdName().empty()) {
+ cur.undispatched();
+ } else {
+ setParams(p);
+ cur.bv().update();
+ }
+ break;
}
case LFUN_INSET_DIALOG_UPDATE:
- InsetCommandMailer(cmd.argument, *this).updateDialog(cmd.view());
- return DISPATCHED;
-
- case LFUN_MOUSE_RELEASE:
- return localDispatch(FuncRequest(cmd.view(), LFUN_INSET_EDIT));
+ InsetCommandMailer(cmd.argument, *this).updateDialog(&cur.bv());
+ break;
+
+ case LFUN_INSET_DIALOG_SHOW:
+ case LFUN_MOUSE_RELEASE: {
+ if (!mailer_name_.empty())
+ InsetCommandMailer(mailer_name_, *this).showDialog(&cur.bv());
+ break;
+ }
default:
- return UNDISPATCHED;
+ InsetOld::priv_dispatch(cur, cmd);
+ break;
}
}
{}
-string const InsetCommandMailer::inset2string() const
+string const InsetCommandMailer::inset2string(Buffer const &) const
{
return params2string(name(), inset_.params());
}
-void InsetCommandMailer::string2params(string const & in,
+void InsetCommandMailer::string2params(string const & name,
+ string const & in,
InsetCommandParams & params)
{
- params.setCmdName(string());
- params.setContents(string());
- params.setOptions(string());
-
+ params = InsetCommandParams();
if (in.empty())
return;
- istringstream data(STRCONV(in));
+ istringstream data(in);
LyXLex lex(0,0);
lex.setStream(data);
- if (lex.isOK()) {
- lex.next();
- string const name = lex.getString();
- }
+ string n;
+ lex >> n;
+ if (!lex || n != name)
+ return print_mailer_error("InsetCommandMailer", in, 1, name);
// This is part of the inset proper that is usually swallowed
- // by Buffer::readInset
- if (lex.isOK()) {
- lex.next();
- string const token = lex.getString();
- if (token != "LatexCommand")
- return;
- }
- if (lex.isOK()) {
- params.read(lex);
- }
+ // by LyXText::readInset
+ string id;
+ lex >> id;
+ if (!lex || id != "LatexCommand")
+ return print_mailer_error("InsetCommandMailer", in, 2, "LatexCommand");
+
+ params.read(lex);
}
-string const InsetCommandMailer::params2string(string const & name,
+string const
+InsetCommandMailer::params2string(string const & name,
InsetCommandParams const & params)
{
ostringstream data;
data << name << ' ';
params.write(data);
data << "\\end_inset\n";
- return STRCONV(data.str());
+ return data.str();
}