3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
6 * \author Angus Leeming
7 * \author Lars Gullik Bjønnes
9 * Full author contact details are available in file CREDITS.
14 #include "insetcommand.h"
16 #include "BufferView.h"
17 #include "dispatchresult.h"
18 #include "funcrequest.h"
19 #include "FuncStatus.h"
21 #include "metricsinfo.h"
27 using std::istringstream;
29 using std::ostringstream;
32 InsetCommand::InsetCommand(InsetCommandParams const & p,
33 string const & mailer_name)
34 : p_(p.getCmdName(), p.getContents(), p.getOptions(), p.getSecOptions()),
35 mailer_name_(mailer_name),
36 updateButtonLabel_(true)
40 InsetCommand::~InsetCommand()
42 if (!mailer_name_.empty())
43 InsetCommandMailer(mailer_name_, *this).hideDialog();
47 void InsetCommand::metrics(MetricsInfo & mi, Dimension & dim) const
49 if (updateButtonLabel_) {
50 updateButtonLabel_ = false;
51 button_.update(getScreenLabel(*mi.base.bv->buffer()),
52 editable() != NOT_EDITABLE);
54 button_.metrics(mi, dim);
59 void InsetCommand::draw(PainterInfo & pi, int x, int y) const
61 setPosCache(pi, x, y);
62 button_.draw(pi, x, y);
66 void InsetCommand::setParams(InsetCommandParams const & p)
69 updateButtonLabel_ = true;
73 int InsetCommand::latex(Buffer const &, ostream & os,
74 OutputParams const &) const
81 int InsetCommand::plaintext(Buffer const &, ostream &,
82 OutputParams const &) const
88 int InsetCommand::linuxdoc(Buffer const &, ostream &,
89 OutputParams const &) const
95 int InsetCommand::docbook(Buffer const &, ostream &,
96 OutputParams const &) const
102 void InsetCommand::doDispatch(LCursor & cur, FuncRequest & cmd)
104 switch (cmd.action) {
105 case LFUN_INSET_REFRESH:
106 updateButtonLabel_ = true;
109 case LFUN_INSET_MODIFY: {
110 InsetCommandParams p;
111 InsetCommandMailer::string2params(mailer_name_, cmd.argument, p);
112 if (p.getCmdName().empty())
119 case LFUN_INSET_DIALOG_UPDATE:
120 InsetCommandMailer(cmd.argument, *this).updateDialog(&cur.bv());
123 case LFUN_MOUSE_RELEASE: {
124 if (!mailer_name_.empty())
125 InsetCommandMailer(mailer_name_, *this).showDialog(&cur.bv());
130 InsetBase::doDispatch(cur, cmd);
137 bool InsetCommand::getStatus(LCursor & cur, FuncRequest const & cmd,
138 FuncStatus & status) const
140 switch (cmd.action) {
142 case LFUN_ERT_INSERT:
143 status.enabled(false);
146 case LFUN_INSET_REFRESH:
147 case LFUN_INSET_MODIFY:
148 case LFUN_INSET_DIALOG_UPDATE:
149 status.enabled(true);
152 return InsetBase::getStatus(cur, cmd, status);
157 InsetCommandMailer::InsetCommandMailer(string const & name,
158 InsetCommand & inset)
159 : name_(name), inset_(inset)
163 string const InsetCommandMailer::inset2string(Buffer const &) const
165 return params2string(name(), inset_.params());
169 void InsetCommandMailer::string2params(string const & name,
171 InsetCommandParams & params)
173 params = InsetCommandParams();
177 istringstream data(in);
183 if (!lex || n != name)
184 return print_mailer_error("InsetCommandMailer", in, 1, name);
186 // This is part of the inset proper that is usually swallowed
187 // by LyXText::readInset
190 if (!lex || id != "LatexCommand")
191 return print_mailer_error("InsetCommandMailer", in, 2, "LatexCommand");
198 InsetCommandMailer::params2string(string const & name,
199 InsetCommandParams const & params)
204 data << "\\end_inset\n";