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"
15 #include "BufferView.h"
17 #include "funcrequest.h"
20 #include "frontends/Painter.h"
22 #include "support/lstrings.h"
29 InsetCommand::InsetCommand(InsetCommandParams const & p, bool)
30 : p_(p.getCmdName(), p.getContents(), p.getOptions())
34 void InsetCommand::setParams(InsetCommandParams const & p)
36 p_.setCmdName(p.getCmdName());
37 p_.setContents(p.getContents());
38 p_.setOptions(p.getOptions());
42 int InsetCommand::latex(Buffer const *, ostream & os,
43 bool /*fragile*/, bool/*fs*/) const
50 int InsetCommand::ascii(Buffer const *, ostream &, int) const
56 int InsetCommand::linuxdoc(Buffer const *, ostream &) const
62 int InsetCommand::docbook(Buffer const *, ostream &, bool) const
68 dispatch_result InsetCommand::localDispatch(FuncRequest const & cmd)
70 if (cmd.action != LFUN_INSET_APPLY)
74 InsetCommandMailer::string2params(cmd.argument, p);
75 if (p.getCmdName().empty())
80 view()->updateInset(this, true);
85 InsetCommandMailer::InsetCommandMailer(string const & name,
87 : name_(name), inset_(inset)
91 string const InsetCommandMailer::inset2string() const
93 return params2string(name(), inset_.params());
97 void InsetCommandMailer::string2params(string const & in,
98 InsetCommandParams & params)
100 params.setCmdName(string());
101 params.setContents(string());
102 params.setOptions(string());
105 string body = split(in, name, ' ');
110 istringstream data(body);
119 InsetCommandMailer::params2string(string const & name,
120 InsetCommandParams const & params)
125 data << "\\end_inset\n";