-#include <config.h>
+/**
+ * \file inseturl.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
+ *
+ * \author José Matos
+ *
+ * Full author contact details are available in file CREDITS
+ */
-#ifdef __GNUG__
-#pragma implementation
-#endif
+#include <config.h>
#include "inseturl.h"
+#include "funcrequest.h"
#include "BufferView.h"
#include "LaTeXFeatures.h"
-#include "LyXView.h"
+#include "frontends/LyXView.h"
#include "debug.h"
#include "frontends/Dialogs.h"
+#include "support/lstrings.h"
+#include "gettext.h"
using std::ostream;
-InsetUrl::InsetUrl(InsetCommandParams const & p)
+InsetUrl::InsetUrl(InsetCommandParams const & p, bool)
: InsetCommand(p)
{}
-void InsetUrl::Edit(BufferView * bv, int, int, unsigned int)
+InsetUrl::~InsetUrl()
+{
+ InsetCommandMailer("url", *this).hideDialog();
+}
+
+
+dispatch_result InsetUrl::localDispatch(FuncRequest const & cmd)
{
- bv->owner()->getDialogs()->showUrl( this );
+ switch (cmd.action) {
+ case LFUN_INSET_EDIT:
+ InsetCommandMailer("url", *this).showDialog(cmd.view());
+ return DISPATCHED;
+ default:
+ return InsetCommand::localDispatch(cmd);
+ }
}
-string const InsetUrl::getScreenLabel() const
+string const InsetUrl::getScreenLabel(Buffer const *) const
{
string temp;
- if( getCmdName() == "url" )
+ if (getCmdName() == "url")
temp = _("Url: ");
- else
+ else
temp = _("HtmlUrl: ");
- if(!getOptions().empty())
- temp += getOptions();
- else
- temp += getContents();
+ string url;
- return temp;
+ if (!getOptions().empty())
+ url += getOptions();
+ else
+ url += getContents();
+
+ // elide if long
+ if (url.length() > 30) {
+ url = url.substr(0, 10) + "..."
+ + url.substr(url.length() - 17, url.length());
+ }
+ return temp + url;
}
-int InsetUrl::Latex(Buffer const *, ostream & os,
+int InsetUrl::latex(Buffer const *, ostream & os,
bool fragile, bool /*free_spc*/) const
{
if (!getOptions().empty())
}
-int InsetUrl::Ascii(Buffer const *, ostream & os, int linelen) const
+int InsetUrl::ascii(Buffer const *, ostream & os, int) const
{
if (getOptions().empty())
- os << "[" << getContents() << "]";
+ os << '[' << getContents() << ']';
else
- os << "[" << getContents() << "||" << getOptions() << "]";
+ os << '[' << getContents() << "||" << getOptions() << ']';
return 0;
}
-int InsetUrl::Linuxdoc(Buffer const *, ostream & os) const
+int InsetUrl::linuxdoc(Buffer const *, ostream & os) const
{
- os << "<" << getCmdName()
+ os << '<' << getCmdName()
<< " url=\"" << getContents() << "\""
<< " name=\"" << getOptions() << "\">";
}
-int InsetUrl::DocBook(Buffer const *, ostream & os) const
+int InsetUrl::docbook(Buffer const *, ostream & os, bool) const
{
- os << "<ulink url=\"" << getContents() << "\">"
- << getOptions() << "</ulink>";
+ os << "<ulink url=\"" << subst(getContents(),"&","&")
+ << "\">" << getOptions() << "</ulink>";
return 0;
}
-void InsetUrl::Validate(LaTeXFeatures & features) const
+void InsetUrl::validate(LaTeXFeatures & features) const
{
- features.url = true;
+ features.require("url");
}