X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetfloatlist.C;h=6d11d93aa0b04536dff1d1ac6322ef0f12bc5ec1;hb=e28331ed63062dea10d0a21b9ec12034b4b17b9a;hp=ce9c6327050def0688817f201e8d9fafec4d1de2;hpb=44cd0fc9a1687cc63911c7f98d978594458e7813;p=lyx.git diff --git a/src/insets/insetfloatlist.C b/src/insets/insetfloatlist.C index ce9c632705..6d11d93aa0 100644 --- a/src/insets/insetfloatlist.C +++ b/src/insets/insetfloatlist.C @@ -15,6 +15,7 @@ #include "buffer.h" #include "bufferparams.h" #include "debug.h" +#include "dispatchresult.h" #include "Floating.h" #include "FloatList.h" #include "funcrequest.h" @@ -22,11 +23,14 @@ #include "LaTeXFeatures.h" #include "lyxlex.h" #include "metricsinfo.h" -#include "toc.h" +#include "TocBackend.h" #include "support/lstrings.h" -using lyx::support::bformat; + +namespace lyx { + +using support::bformat; using std::endl; using std::string; @@ -34,44 +38,37 @@ using std::ostream; InsetFloatList::InsetFloatList() - : InsetCommand(InsetCommandParams()) + : InsetCommand(InsetCommandParams("floatlist"), "toc") {} InsetFloatList::InsetFloatList(string const & type) - : InsetCommand(InsetCommandParams()) -{ - setCmdName(type); -} - - -InsetFloatList::~InsetFloatList() + : InsetCommand(InsetCommandParams("floatlist"), "toc") { - InsetCommandMailer mailer("toc", *this); - mailer.hideDialog(); + setParam("type", from_ascii(type)); } -string const InsetFloatList::getScreenLabel(Buffer const & buf) const +docstring const InsetFloatList::getScreenLabel(Buffer const & buf) const { FloatList const & floats = buf.params().getLyXTextClass().floats(); - FloatList::const_iterator it = floats[getCmdName()]; + FloatList::const_iterator it = floats[to_ascii(getParam("type"))]; if (it != floats.end()) - return _(it->second.listName()); + return buf.B_(it->second.listName()); else return _("ERROR: Nonexistent float type!"); } -InsetOld::Code InsetFloatList::lyxCode() const +InsetBase::Code InsetFloatList::lyxCode() const { - return InsetOld::FLOAT_LIST_CODE; + return InsetBase::FLOAT_LIST_CODE; } void InsetFloatList::write(Buffer const &, ostream & os) const { - os << "FloatList " << getCmdName() << "\n"; + os << "FloatList " << to_ascii(getParam("type")) << "\n"; } @@ -81,14 +78,15 @@ void InsetFloatList::read(Buffer const & buf, LyXLex & lex) string token; if (lex.eatLine()) { - setCmdName(lex.getString()); - lyxerr[Debug::INSETS] << "FloatList::float_type: " << getCmdName() << endl; - if (!floats.typeExist(getCmdName())) + setParam("type", lex.getDocString()); + lyxerr[Debug::INSETS] << "FloatList::float_type: " + << to_ascii(getParam("type")) << endl; + if (!floats.typeExist(to_ascii(getParam("type")))) lex.printError("InsetFloatList: Unknown float type: `$$Token'"); } else lex.printError("InsetFloatList: Parse error: `$$Token'"); while (lex.isOK()) { - lex.nextToken(); + lex.next(); token = lex.getString(); if (token == "\\end_inset") break; @@ -100,47 +98,11 @@ void InsetFloatList::read(Buffer const & buf, LyXLex & lex) } -void InsetFloatList::metrics(MetricsInfo & mi, Dimension & dim) const -{ - InsetCommand::metrics(mi, dim); - int center_indent = (mi.base.textwidth - dim.wid) / 2; - Box b(center_indent, center_indent + dim.wid, -dim.asc, dim.des); - button().setBox(b); - - dim.wid = mi.base.textwidth; - dim_ = dim; -} - - -void InsetFloatList::draw(PainterInfo & pi, int x, int y) const -{ - InsetCommand::draw(pi, x + button().box().x1, y); -} - - -dispatch_result InsetFloatList::localDispatch(FuncRequest const & cmd) -{ - switch (cmd.action) { - case LFUN_MOUSE_RELEASE: - if (button().box().contains(cmd.x, cmd.y)) - InsetCommandMailer("toc", *this).showDialog(cmd.view()); - return DISPATCHED; - - case LFUN_INSET_DIALOG_SHOW: - InsetCommandMailer("toc", *this).showDialog(cmd.view()); - return DISPATCHED; - - default: - return InsetCommand::localDispatch(cmd); - } -} - - -int InsetFloatList::latex(Buffer const & buf, ostream & os, - LatexRunParams const &) const +int InsetFloatList::latex(Buffer const & buf, odocstream & os, + OutputParams const &) const { FloatList const & floats = buf.params().getLyXTextClass().floats(); - FloatList::const_iterator cit = floats[getCmdName()]; + FloatList::const_iterator cit = floats[to_ascii(getParam("type"))]; if (cit != floats.end()) { if (cit->second.builtin()) { @@ -154,23 +116,24 @@ int InsetFloatList::latex(Buffer const & buf, ostream & os, os << "%% unknown builtin float\n"; } } else { - os << "\\listof{" << getCmdName() << "}{" - << cit->second.listName() << "}\n"; + os << "\\listof{" << getParam("type") << "}{" + << buf.B_(cit->second.listName()) << "}\n"; } } else { - os << "%%\\listof{" << getCmdName() << "}{" - << bformat(_("List of %1$s"), cit->second.name()) + os << "%%\\listof{" << getParam("type") << "}{" + << bformat(_("List of %1$s"), from_utf8(cit->second.name())) << "}\n"; } return 1; } -int InsetFloatList::ascii(Buffer const & buffer, ostream & os, int) const +int InsetFloatList::plaintext(Buffer const & buffer, odocstream & os, + OutputParams const &) const { os << getScreenLabel(buffer) << "\n\n"; - lyx::toc::asciiTocList(getCmdName(), buffer, os); + buffer.tocBackend().writePlaintextTocList(to_ascii(getParam("type")), os); os << "\n"; return 0; @@ -179,5 +142,8 @@ int InsetFloatList::ascii(Buffer const & buffer, ostream & os, int) const void InsetFloatList::validate(LaTeXFeatures & features) const { - features.useFloat(getCmdName()); + features.useFloat(to_ascii(getParam("type"))); } + + +} // namespace lyx