]> git.lyx.org Git - lyx.git/blobdiff - src/insets/inseturl.C
* src/LyXAction.C: mark goto-clear-bookmark as working without buffer
[lyx.git] / src / insets / inseturl.C
index 848584044fbc0508b1678230eac65aaeacd97637..4bd7f5765a8d581e512c828af431d7aafdd426ab 100644 (file)
-#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 "BufferView.h"
+
+#include "dispatchresult.h"
+#include "funcrequest.h"
 #include "LaTeXFeatures.h"
-#include "LyXView.h"
-#include "debug.h"
-#include "frontends/Dialogs.h"
-#include "support/lstrings.h"
 #include "gettext.h"
+#include "outputparams.h"
 
-using std::ostream;
+#include "support/lstrings.h"
 
+#include "support/std_ostream.h"
 
-InsetUrl::InsetUrl(InsetCommandParams const & p, bool)
-               : InsetCommand(p)
-{}
 
+namespace lyx {
 
-void InsetUrl::edit(BufferView * bv, int, int, unsigned int)
-{
-       bv->owner()->getDialogs()->showUrl(this);
-}
+using support::subst;
 
+using std::string;
+using std::ostream;
 
-void InsetUrl::edit(BufferView * bv, bool)
-{
-       edit(bv, 0, 0, 0);
-}
+
+InsetUrl::InsetUrl(InsetCommandParams const & p)
+       : InsetCommand(p, "url")
+{}
 
 
-string const InsetUrl::getScreenLabel(Buffer const *) const
+docstring const InsetUrl::getScreenLabel(Buffer const &) const
 {
-       string temp;
-       if (getCmdName() == "url")
-               temp = _("Url: ");
-       else 
-               temp = _("HtmlUrl: ");
-
-       if (!getOptions().empty())
-               temp += getOptions();
-       else
-               temp += getContents();
+       docstring const temp =
+               (getCmdName() == "url") ? _("Url: ") : _("HtmlUrl: ");
+
+       docstring url;
 
-       return temp;
+       if (!getParam("name").empty())
+               url += getParam("name");
+       else
+               url += getParam("target");
+
+       // 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,
-                   bool fragile, bool /*free_spc*/) const
+int InsetUrl::latex(Buffer const &, odocstream & os,
+                   OutputParams const & runparams) const
 {
-       if (!getOptions().empty())
-               os << getOptions() + ' ';
-       if (fragile)
+       docstring const & name = getParam("name");
+       if (!name.empty())
+               os << name + ' ';
+       if (runparams.moving_arg)
                os << "\\protect";
-       os << "\\url{" << getContents() << '}';
+       os << "\\url{" << getParam("target") << '}';
        return 0;
 }
 
 
-int InsetUrl::ascii(Buffer const *, ostream & os, int) const
+int InsetUrl::plaintext(Buffer const &, odocstream & os,
+                   OutputParams const &) const
 {
-       if (getOptions().empty())
-               os << "[" << getContents() << "]";
+       os << '[' << getParam("target");
+       if (getParam("name").empty())
+               os << ']';
        else
-               os << "[" << getContents() << "||" <<  getOptions() << "]";
+               os << "||" << getParam("name") << ']';
        return 0;
 }
 
 
-int InsetUrl::linuxdoc(Buffer const *, ostream & os) const
+int InsetUrl::docbook(Buffer const &, odocstream & os,
+                     OutputParams const &) const
 {
-       os << "<" << getCmdName()
-          << " url=\""  << getContents() << "\""
-          << " name=\"" << getOptions() << "\">";
-
+       os << "<ulink url=\"" 
+          << subst(getParam("target"), from_ascii("&"), from_ascii("&amp;"))
+          << "\">" 
+          << getParam("name")
+          << "</ulink>";
        return 0;
 }
 
 
-int InsetUrl::docbook(Buffer const *, ostream & os) const
+int InsetUrl::textString(Buffer const & buf, odocstream & os,
+                      OutputParams const & op) const
 {
-       os << "<ulink url=\"" << subst(getContents(),"&","&amp;")
-          << "\">" << getOptions() << "</ulink>";
-       return 0;
+       return plaintext(buf, os, op);
 }
 
 
@@ -94,3 +105,6 @@ void InsetUrl::validate(LaTeXFeatures & features) const
 {
        features.require("url");
 }
+
+
+} // namespace lyx