X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FFloatList.C;h=81f7a6e99b1b72691130a3476dae34c2296ae921;hb=35204f8f33d7400a5fefeffea533fb4cb4097211;hp=77a885a2bf358804eb119f05043157eaca54ec8a;hpb=ee72ce87743857b4317da00e6e09cb6842095664;p=lyx.git diff --git a/src/FloatList.C b/src/FloatList.C index 77a885a2bf..81f7a6e99b 100644 --- a/src/FloatList.C +++ b/src/FloatList.C @@ -1,5 +1,104 @@ +/** + * \file FloatList.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. + */ + #include #include "FloatList.h" +#include "Floating.h" + + +namespace lyx { + +using std::string; + +// 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() +{ +} + + +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; +} + + +string const FloatList::defaultPlacement(string const & t) const +{ + List::const_iterator cit = list.find(t); + if (cit != list.end()) + return cit->second.placement(); + return string(); +} + + +bool FloatList::typeExist(string const & t) const +{ + List::const_iterator cit = list.find(t); + return cit != list.end(); +} + + +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; +#ifdef HAVE_EXCEPTIONS + throw UnknownFloatType(t); +#else + static Floating empty_float; + return empty_float; +#endif +} + + +void FloatList::erase(string const & t) +{ + list.erase(t); +} + + +FloatList::const_iterator FloatList::operator[](string const & t) const +{ + return list.find(t); +} + -FloatList floatList; +} // namespace lyx