X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetref.C;h=490d5e58090dd593c703c67336cbfda8328fb5d8;hb=357a3741c0655e174ad48ded68cca90b09a158e6;hp=3ac5351ac86e73957918a4b1feef1147329c20ad;hpb=ccce6b9662e3a753d8864b1832d766a8f4ceef02;p=lyx.git diff --git a/src/insets/insetref.C b/src/insets/insetref.C index 3ac5351ac8..490d5e5809 100644 --- a/src/insets/insetref.C +++ b/src/insets/insetref.C @@ -5,65 +5,73 @@ * * \author José Matos * - * Full author contact details are available in file CREDITS + * Full author contact details are available in file CREDITS. */ #include - #include "insetref.h" + #include "buffer.h" +#include "cursor.h" +#include "BufferView.h" +#include "dispatchresult.h" #include "funcrequest.h" -#include "debug.h" #include "gettext.h" #include "LaTeXFeatures.h" + #include "frontends/LyXView.h" -#include "frontends/Dialogs.h" -#include "BufferView.h" + #include "support/lstrings.h" + +using lyx::support::escape; + +using std::string; using std::ostream; -InsetRef::InsetRef(InsetCommandParams const & p, Buffer const & buf, bool) - : InsetCommand(p), isLatex(buf.isLatex()) + +InsetRef::InsetRef(InsetCommandParams const & p, Buffer const & buf) + : InsetCommand(p, "ref"), isLatex(buf.isLatex()) {} -InsetRef::~InsetRef() -{ - InsetCommandMailer("ref", *this).hideDialog(); -} +InsetRef::InsetRef(InsetRef const & ir) + : InsetCommand(ir), isLatex(ir.isLatex) +{} -dispatch_result InsetRef::localDispatch(FuncRequest const & cmd) +void InsetRef::priv_dispatch(LCursor & cur, FuncRequest const & cmd) { switch (cmd.action) { - case LFUN_INSET_EDIT: + case LFUN_MOUSE_PRESS: // Eventually trigger dialog with button 3 not 1 if (cmd.button() == mouse_button::button3) - cmd.view()->owner()-> - dispatch(FuncRequest(LFUN_REF_GOTO, getContents())); - if (cmd.button() == mouse_button::button1) - InsetCommandMailer("ref", *this).showDialog(cmd.view()); - return DISPATCHED; - + cur.bv().owner()->dispatch(FuncRequest(LFUN_REF_GOTO, getContents())); + else + InsetCommandMailer("ref", *this).showDialog(&cur.bv()); + return; + + case LFUN_MOUSE_RELEASE: + return; + default: - return UNDISPATCHED; + return InsetCommand::priv_dispatch(cur, cmd); } } -string const InsetRef::getScreenLabel(Buffer const *) const +string const InsetRef::getScreenLabel(Buffer const &) const { string temp; - for (int i = 0; !types[i].latex_name.empty(); ++ i) + for (int i = 0; !types[i].latex_name.empty(); ++i) { if (getCmdName() == types[i].latex_name) { temp = _(types[i].short_gui_name); break; } + } temp += getContents(); - if (!isLatex - && !getOptions().empty()) { + if (!isLatex && !getOptions().empty()) { temp += "||"; temp += getOptions(); } @@ -71,8 +79,8 @@ string const InsetRef::getScreenLabel(Buffer const *) const } -int InsetRef::latex(Buffer const *, ostream & os, LatexRunParams const &, - bool /*fragile*/, bool /*fs*/) const +int InsetRef::latex(Buffer const &, ostream & os, + OutputParams const &) const { if (getOptions().empty()) os << escape(getCommand()); @@ -84,14 +92,16 @@ int InsetRef::latex(Buffer const *, ostream & os, LatexRunParams const &, } -int InsetRef::ascii(Buffer const *, ostream & os, int) const +int InsetRef::plaintext(Buffer const &, ostream & os, + OutputParams const &) const { os << '[' << getContents() << ']'; return 0; } -int InsetRef::linuxdoc(Buffer const *, ostream & os) const +int InsetRef::linuxdoc(Buffer const &, ostream & os, + OutputParams const &) const { os << ""; @@ -99,7 +109,8 @@ int InsetRef::linuxdoc(Buffer const *, ostream & os) const } -int InsetRef::docbook(Buffer const *, ostream & os, bool) const +int InsetRef::docbook(Buffer const &, ostream & os, + OutputParams const &) const { if (getOptions().empty()) { os << ""; @@ -118,6 +129,8 @@ void InsetRef::validate(LaTeXFeatures & features) const features.require("varioref"); else if (getCmdName() == "prettyref") features.require("prettyref"); + else if (getCmdName() == "eqref") + features.require("amsmath"); }