X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetfloatlist.C;h=6d11d93aa0b04536dff1d1ac6322ef0f12bc5ec1;hb=e28331ed63062dea10d0a21b9ec12034b4b17b9a;hp=579989b37822258ac8333289e388ed1df17c1e63;hpb=435d527581277fab8b1aa67888f17d8439d07693;p=lyx.git diff --git a/src/insets/insetfloatlist.C b/src/insets/insetfloatlist.C index 579989b378..6d11d93aa0 100644 --- a/src/insets/insetfloatlist.C +++ b/src/insets/insetfloatlist.C @@ -1,72 +1,92 @@ -#include +/** + * \file insetfloatlist.C + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. + * + * \author Lars Gullik Bjønnes + * + * Full author contact details are available in file CREDITS. + */ -#ifdef __GNUG__ -#pragma implementation -#endif +#include #include "insetfloatlist.h" -#include "FloatList.h" -#include "LaTeXFeatures.h" -#include "frontends/Dialogs.h" -#include "frontends/LyXView.h" -#include "BufferView.h" + #include "buffer.h" -#include "gettext.h" +#include "bufferparams.h" #include "debug.h" +#include "dispatchresult.h" +#include "Floating.h" +#include "FloatList.h" +#include "funcrequest.h" +#include "gettext.h" +#include "LaTeXFeatures.h" +#include "lyxlex.h" +#include "metricsinfo.h" +#include "TocBackend.h" +#include "support/lstrings.h" + + +namespace lyx { + +using support::bformat; -using std::ostream; using std::endl; +using std::string; +using std::ostream; InsetFloatList::InsetFloatList() - : InsetCommand(InsetCommandParams()) -{ -} + : InsetCommand(InsetCommandParams("floatlist"), "toc") +{} InsetFloatList::InsetFloatList(string const & type) - : InsetCommand(InsetCommandParams()) + : InsetCommand(InsetCommandParams("floatlist"), "toc") { - setCmdName(type); + setParam("type", from_ascii(type)); } -string const InsetFloatList::getScreenLabel(Buffer const *) const +docstring const InsetFloatList::getScreenLabel(Buffer const & buf) const { - FloatList::const_iterator it = floatList[getCmdName()]; - if (it != floatList.end()) - return _(it->second.listName()); + FloatList const & floats = buf.params().getLyXTextClass().floats(); + FloatList::const_iterator it = floats[to_ascii(getParam("type"))]; + if (it != floats.end()) + return buf.B_(it->second.listName()); else return _("ERROR: Nonexistent float type!"); } -Inset::Code InsetFloatList::lyxCode() const +InsetBase::Code InsetFloatList::lyxCode() const { - return Inset::FLOAT_LIST_CODE; + return InsetBase::FLOAT_LIST_CODE; } -void InsetFloatList::write(Buffer const *, ostream & os) const +void InsetFloatList::write(Buffer const &, ostream & os) const { - os << "FloatList " << getCmdName() << "\n"; + os << "FloatList " << to_ascii(getParam("type")) << "\n"; } -void InsetFloatList::read(Buffer const *, LyXLex & lex) +void InsetFloatList::read(Buffer const & buf, LyXLex & lex) { + FloatList const & floats = buf.params().getLyXTextClass().floats(); string token; if (lex.eatLine()) { - setCmdName(lex.getString()); - lyxerr[Debug::INSETS] << "FloatList::float_type: " << getCmdName() << endl; - if (!floatList.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; @@ -78,23 +98,13 @@ void InsetFloatList::read(Buffer const *, LyXLex & lex) } -void InsetFloatList::edit(BufferView * bv, int, int, unsigned int) +int InsetFloatList::latex(Buffer const & buf, odocstream & os, + OutputParams const &) const { - bv->owner()->getDialogs()->showTOC(this); -} - - -void InsetFloatList::edit(BufferView * bv, bool) -{ - edit(bv, 0, 0, 0); -} + FloatList const & floats = buf.params().getLyXTextClass().floats(); + FloatList::const_iterator cit = floats[to_ascii(getParam("type"))]; - -int InsetFloatList::latex(Buffer const *, ostream & os, bool, bool) const -{ - FloatList::const_iterator cit = floatList[getCmdName()]; - - if (cit != floatList.end()) { + if (cit != floats.end()) { if (cit->second.builtin()) { // Only two different types allowed here: string const type = cit->second.type(); @@ -106,31 +116,24 @@ int InsetFloatList::latex(Buffer const *, ostream & os, bool, bool) const 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() << "}{" - << _("List of ") << cit->second.name() << "}\n"; + 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"; - Buffer::Lists const toc_list = buffer->getLists(); - Buffer::Lists::const_iterator cit = - toc_list.find(getCmdName()); - if (cit != toc_list.end()) { - Buffer::SingleList::const_iterator ccit = cit->second.begin(); - Buffer::SingleList::const_iterator end = cit->second.end(); - for (; ccit != end; ++ccit) - os << string(4 * ccit->depth, ' ') - << ccit->str << "\n"; - } + buffer.tocBackend().writePlaintextTocList(to_ascii(getParam("type")), os); os << "\n"; return 0; @@ -139,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