#include "support/lstrings.h"
-using lyx::docstring;
-using lyx::support::escape;
+namespace lyx {
+
+using support::escape;
using std::string;
using std::ostream;
case LFUN_MOUSE_PRESS:
// Eventually trigger dialog with button 3 not 1
if (cmd.button() == mouse_button::button3)
- lyx::dispatch(FuncRequest(LFUN_LABEL_GOTO, getContents()));
+ lyx::dispatch(FuncRequest(LFUN_LABEL_GOTO, getParam("reference")));
else {
InsetCommandMailer("ref", *this).showDialog(&cur.bv());
cur.undispatched();
break;
}
}
- // FIXME UNICODE
- temp += lyx::from_utf8(getContents());
+ temp += getParam("reference");
- if (!isLatex && !getOptions().empty()) {
+ if (!isLatex && !getParam("name").empty()) {
temp += "||";
- // FIXME UNICODE
- temp += lyx::from_utf8(getOptions());
+ temp += getParam("name");
}
return temp;
}
-int InsetRef::latex(Buffer const &, ostream & os,
+int InsetRef::latex(Buffer const &, odocstream & os,
OutputParams const &) const
{
- if (getOptions().empty())
- os << escape(getCommand());
- else {
- InsetCommandParams p(getCmdName(), getContents(), "");
- os << escape(p.getCommand());
- }
+ // Don't output p_["name"], this is only used in docbook
+ InsetCommandParams p(getCmdName());
+ p["reference"] = getParam("reference");
+ os << escape(p.getCommand());
return 0;
}
-int InsetRef::plaintext(Buffer const &, lyx::odocstream & os,
+int InsetRef::plaintext(Buffer const &, odocstream & os,
OutputParams const &) const
{
- // FIXME UNICODE
- os << '[' << lyx::from_utf8(getContents()) << ']';
+ os << '[' << getParam("reference") << ']';
return 0;
}
-int InsetRef::docbook(Buffer const & buf, ostream & os,
+int InsetRef::docbook(Buffer const & buf, odocstream & os,
OutputParams const & runparams) const
{
- if (getOptions().empty() && runparams.flavor == OutputParams::XML) {
- os << "<xref linkend=\"" << sgml::cleanID(buf, runparams, getContents()) << "\" />";
- } else if (getOptions().empty()) {
- os << "<xref linkend=\"" << sgml::cleanID(buf, runparams, getContents()) << "\">";
+ docstring const & name = getParam("name");
+ if (name.empty()) {
+ if (runparams.flavor == OutputParams::XML) {
+ os << "<xref linkend=\""
+ << sgml::cleanID(buf, runparams, getParam("reference"))
+ << "\" />";
+ } else {
+ os << "<xref linkend=\""
+ << sgml::cleanID(buf, runparams, getParam("reference"))
+ << "\">";
+ }
} else {
- os << "<link linkend=\"" << sgml::cleanID(buf, runparams, getContents())
- << "\">" << getOptions() << "</link>";
+ os << "<link linkend=\""
+ << sgml::cleanID(buf, runparams, getParam("reference"))
+ << "\">"
+ << getParam("name")
+ << "</link>";
}
return 0;
}
-int InsetRef::textString(Buffer const & buf, lyx::odocstream & os,
+int InsetRef::textString(Buffer const & buf, odocstream & os,
OutputParams const & op) const
{
return plaintext(buf, os, op);
{
return types[type].latex_name;
}
+
+
+} // namespace lyx