X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finseturl.C;h=4bd7f5765a8d581e512c828af431d7aafdd426ab;hb=e28331ed63062dea10d0a21b9ec12034b4b17b9a;hp=d73ccd377b2015334c4670382bd1f8b8b4af0a61;hpb=e91aba8dd07c8f8fafefa21f1e2dd7b10e3ccae0;p=lyx.git diff --git a/src/insets/inseturl.C b/src/insets/inseturl.C index d73ccd377b..4bd7f5765a 100644 --- a/src/insets/inseturl.C +++ b/src/insets/inseturl.C @@ -1,52 +1,52 @@ -#include +/** + * \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 #include "inseturl.h" -#include "BufferView.h" + +#include "dispatchresult.h" +#include "funcrequest.h" #include "LaTeXFeatures.h" -#include "frontends/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, mouse_button::state) -{ - bv->owner()->getDialogs().showUrl(this); -} +using support::subst; + +using std::string; +using std::ostream; -void InsetUrl::edit(BufferView * bv, bool) -{ - edit(bv, 0, 0, mouse_button::none); -} +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: "); + docstring const temp = + (getCmdName() == "url") ? _("Url: ") : _("HtmlUrl: "); - string url; - - if (!getOptions().empty()) - url += getOptions(); + docstring url; + + if (!getParam("name").empty()) + url += getParam("name"); else - url += getContents(); + url += getParam("target"); // elide if long if (url.length() > 30) { @@ -57,43 +57,47 @@ string const InsetUrl::getScreenLabel(Buffer const *) const } -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 << "" + << getParam("name") + << ""; return 0; } -int InsetUrl::docbook(Buffer const *, ostream & os, bool) const +int InsetUrl::textString(Buffer const & buf, odocstream & os, + OutputParams const & op) const { - os << "" << getOptions() << ""; - return 0; + return plaintext(buf, os, op); } @@ -101,3 +105,6 @@ void InsetUrl::validate(LaTeXFeatures & features) const { features.require("url"); } + + +} // namespace lyx