X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FFloatList.C;h=61d0aadff776e9877e5df150e046f9bf38d6ce55;hb=06f9f0ea08ddcf13e99ea02cff21471aa2020c9e;hp=fbbfa370a0caf7a0db3223272e3cfa40a3033da6;hpb=d59d3eb51af11e2146ac95ec58fc5677ea35386e;p=lyx.git diff --git a/src/FloatList.C b/src/FloatList.C index fbbfa370a0..61d0aadff7 100644 --- a/src/FloatList.C +++ b/src/FloatList.C @@ -5,53 +5,74 @@ #endif #include "FloatList.h" +#include "gettext.h" + +// This class is now mostly finished, except one thing, it is a global +// object. This will not do. The user (and layout files) are free to +// create floats and modify them to fit into a certain document. So it is +// pretty clear that each layout needs its own list, as do documents. +// However this is also not enough since we really want the user to be +// able to create "presistent" floats, in the sense that a user created +// float can be used across sessions and across documents. So we need a +// global¹ floatlist as well. The interaction between these are not quite +// clear, but it seems natural that the definition found in the document +// takes precedence. +// We also have the issue about what get stored _in_ the lyx file. +// +// ¹ not absolutely global but somewhere where documents,layouts and +// the bufferview can have access to it. +// +// Lgb FloatList::FloatList() { // Insert the latex builtin float-types - Floating table; - table.type = "table"; - table.placement = "htbp"; - table.ext = "lot"; - table.within = ""; - table.style = "plain"; - table.name = "Table"; - table.builtin = true; - list[table.type] = table; - Floating figure; - figure.type = "figure"; - figure.placement = "htbp"; - figure.ext = "lof"; - figure.within = ""; - figure.style = "plain"; - figure.name = "Figure"; - figure.builtin = true; - list[figure.type] = figure; + // (these will later be read from a layout file) + + // table + Floating table("table", "htbp", "lot", "", "plain", N_("Table"), + N_("List of Tables"), true); + newFloat(table); + + // figure + Floating figure("figure", "htbp", "lof", + "", "plain", N_("Figure"), + N_("List of Figures"), true); + newFloat(figure); + // And we add algorithm too since LyX has - // supported that for a long time - Floating algorithm; - algorithm.type = "algorithm"; - algorithm.placement = "htbp"; - algorithm.ext = "loa"; - algorithm.within = ""; - algorithm.style = "ruled"; - algorithm.name = "Algorithm"; - algorithm.builtin = false; - list[algorithm.type] = algorithm; + // supported that for a long time, + // but support for this should probably be moved to a layout file. + Floating algorithm("algorithm", "htbp", "loa", + "", "ruled", N_("Algorithm"), + N_("List of Algorithms")); + newFloat(algorithm); +} + + +FloatList::const_iterator FloatList::begin() const +{ + return list.begin(); +} + + +FloatList::const_iterator FloatList::end() const +{ + return list.end(); } void FloatList::newFloat(Floating const & fl) { - list[fl.type] = fl; + list[fl.type()] = fl; } -string FloatList::defaultPlacement(string const & t) const +string const FloatList::defaultPlacement(string const & t) const { List::const_iterator cit = list.find(t); if (cit != list.end()) - return (*cit).second.placement; + return cit->second.placement(); return string(); } @@ -68,7 +89,7 @@ Floating const & FloatList::getType(string const & t) const // I wish we could use exceptions List::const_iterator cit = list.find(t); if (cit != list.end()) - return (*cit).second; + return cit->second; #ifdef HAVE_EXCEPTIONS throw UnknownFloatType(t); #else @@ -77,5 +98,12 @@ Floating const & FloatList::getType(string const & t) const #endif } + +FloatList::const_iterator FloatList::operator[](string const & t) const +{ + return list.find(t); +} + + // The global floatlist FloatList floatList;