* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
- * \author Jürgen Vigna
- * \author Lars Gullik Bjønnes
+ * \author Jürgen Vigna
+ * \author Lars Gullik Bjønnes
*
* Full author contact details are available in file CREDITS.
*/
#include "Buffer.h"
#include "BufferParams.h"
#include "Counters.h"
-#include "support/gettext.h"
+#include "Language.h"
#include "Layout.h"
-// FIXME: the following is needed just to get the layout of the enclosing
-// paragraph. This seems a bit too much to me (JMarc)
#include "OutputParams.h"
#include "ParIterator.h"
#include "TextClass.h"
#include "TocBackend.h"
#include "support/debug.h"
-#include "support/lstrings.h"
-
-#include <ostream>
+#include "support/docstream.h"
+#include "support/gettext.h"
using namespace std;
namespace lyx {
-
-InsetFoot::InsetFoot(Buffer const & buf)
+InsetFoot::InsetFoot(Buffer * buf)
: InsetFootlike(buf)
{}
-InsetFoot::InsetFoot(InsetFoot const & in)
- : InsetFootlike(in)
-{}
-
-
-docstring InsetFoot::editMessage() const
-{
- return _("Opened Footnote Inset");
-}
-
-
-void InsetFoot::updateLabels(ParIterator const & it)
+void InsetFoot::updateLabels(ParIterator const & it, bool out)
{
- DocumentClass const & tclass = buffer().params().documentClass();
- Counters & cnts = tclass.counters();
- docstring const foot = from_ascii("footnote");
- Paragraph const & outer = it.paragraph();
- if (!outer.layout()->intitle && cnts.hasCounter(foot)) {
- cnts.step(foot);
- // FIXME: the counter should format itself.
- setLabel(support::bformat(from_ascii("%1$s %2$s"),
- getLayout(buffer().params()).labelstring(),
- cnts.theCounter(foot)));
-
+ BufferParams const & bp = buffer().masterBuffer()->params();
+ Counters & cnts = bp.documentClass().counters();
+ Paragraph const & outer = it.paragraph();
+ InsetLayout const & il = getLayout();
+ docstring const & count = il.counter();
+ if (!outer.layout().intitle && cnts.hasCounter(count)) {
+ cnts.step(count);
+ custom_label_= translateIfPossible(il.labelstring())
+ + ' ' + cnts.theCounter(count, outer.getParLanguage(bp)->code());
+ setLabel(custom_label_);
}
- InsetCollapsable::updateLabels(it);
+ InsetCollapsable::updateLabels(it, out);
}
-void InsetFoot::addToToc(ParConstIterator const & cpit) const
+void InsetFoot::addToToc(DocIterator const & cpit)
{
- ParConstIterator pit = cpit;
- pit.push_back(*this);
+ DocIterator pit = cpit;
+ pit.push_back(CursorSlice(*this));
Toc & toc = buffer().tocBackend().toc("footnote");
- // FIXME: we probably want the footnote number too.
docstring str;
- str = getNewLabel(str);
+ str = custom_label_ + ": " + getNewLabel(str);
toc.push_back(TocItem(pit, 0, str));
+ // Proceed with the rest of the inset.
+ InsetFootlike::addToToc(cpit);
+}
+
+
+docstring InsetFoot::toolTip(BufferView const & bv, int x, int y) const
+{
+ docstring default_tip = InsetCollapsable::toolTip(bv, x, y);
+ if (!isOpen(bv))
+ return custom_label_ + "\n" + default_tip;
+ return default_tip;
}
return i;
}
-
} // namespace lyx