#include <config.h>
#include "InsetFoot.h"
+#include "InsetBox.h"
#include "Buffer.h"
#include "BufferParams.h"
#include "Counters.h"
#include "Language.h"
+#include "LaTeXFeatures.h"
#include "Layout.h"
#include "OutputParams.h"
+#include "output_docbook.h"
#include "ParIterator.h"
#include "TextClass.h"
#include "TocBackend.h"
#include "support/debug.h"
#include "support/docstream.h"
#include "support/gettext.h"
+#include "support/lstrings.h"
using namespace std;
namespace lyx {
InsetFoot::InsetFoot(Buffer * buf)
- : InsetFootlike(buf)
+ : InsetFootlike(buf), intitle_(false), infloattable_(false)
{}
-void InsetFoot::updateLabels(ParIterator const & it, bool out)
+docstring InsetFoot::layoutName() const
{
- 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, out);
+ if (intitle_)
+ return from_ascii("Foot:InTitle");
+ else if (infloattable_)
+ return from_ascii("Foot:InFloatTable");
+ return from_ascii("Foot");
}
-void InsetFoot::addToToc(DocIterator const & cpit)
+void InsetFoot::updateBuffer(ParIterator const & it, UpdateType utype, bool const deleted)
{
- DocIterator pit = cpit;
- pit.push_back(CursorSlice(*this));
-
- Toc & toc = buffer().tocBackend().toc("footnote");
- docstring str;
- str = custom_label_ + ": " + getNewLabel(str);
- toc.push_back(TocItem(pit, 0, str));
- // Proceed with the rest of the inset.
- InsetFootlike::addToToc(cpit);
-}
+ BufferParams const & bp = buffer().masterBuffer()->params();
+ Counters & cnts = bp.documentClass().counters();
+ if (utype == OutputUpdate) {
+ // the footnote counter is local to this inset
+ cnts.saveLastCounter();
+ }
+ intitle_ = false;
+ infloattable_ = false;
+ bool intable = false;
+ if (it.innerInsetOfType(TABULAR_CODE) != 0)
+ intable = true;
+ if (it.innerInsetOfType(FLOAT_CODE) != 0)
+ infloattable_ = intable;
+ // If we are in a table in a float, but the table is also in a minipage,
+ // we do not use tablefootnote, since minipages provide their own footnotes.
+ if (intable && infloattable_ && it.innerInsetOfType(BOX_CODE) != 0) {
+ InsetBoxParams const & boxp =
+ static_cast<InsetBox*>(it.innerInsetOfType(BOX_CODE))->params();
+ if (boxp.inner_box && !boxp.use_parbox && !boxp.use_makebox)
+ infloattable_ = false;
+ }
+ for (size_type sl = 0 ; sl < it.depth() ; ++sl) {
+ if (it[sl].text() && it[sl].paragraph().layout().intitle) {
+ intitle_ = true;
+ break;
+ }
+ }
-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;
+ Language const * lang = it.paragraph().getParLanguage(bp);
+ InsetLayout const & il = getLayout();
+ docstring const & count = il.counter();
+ custom_label_ = translateIfPossible(il.labelstring());
+
+ int val = cnts.value(count);
+ if (cnts.hasCounter(count)) {
+ cnts.step(count, utype);
+ custom_label_ += ' ' + cnts.theCounter(count, lang->code());
+ if (deleted)
+ // un-step after deleted counter
+ cnts.set(count, val);
+ } else
+ custom_label_ += ' ' + from_ascii("#");
+ setLabel(custom_label_);
+
+ InsetCollapsible::updateBuffer(it, utype, deleted);
+ if (utype == OutputUpdate)
+ cnts.restoreLastCounter();
}
-int InsetFoot::latex(odocstream & os, OutputParams const & runparams_in) const
+docstring InsetFoot::toolTip(BufferView const & bv, int x, int y) const
{
- OutputParams runparams = runparams_in;
- // footnotes in titling commands like \title have moving arguments
- runparams.moving_arg |= runparams_in.intitle;
-
- // in titling commands, \thanks should be used instead of \footnote.
- // some classes (e.g. memoir) do not understand \footnote.
- if (runparams_in.intitle)
- os << "%\n\\thanks{";
- else
- os << "%\n\\footnote{";
-
- int const i = InsetText::latex(os, runparams);
- os << "%\n}";
- runparams_in.encoding = runparams.encoding;
-
- return i + 2;
+ if (isOpen(bv))
+ // this will give us something useful if there is no button
+ return InsetCollapsible::toolTip(bv, x, y);
+ return toolTipText(custom_label_+ ": ");
}
-int InsetFoot::plaintext(odocstream & os, OutputParams const & runparams) const
+int InsetFoot::plaintext(odocstringstream & os,
+ OutputParams const & runparams, size_t max_length) const
{
os << '[' << buffer().B_("footnote") << ":\n";
- InsetText::plaintext(os, runparams);
+ InsetText::plaintext(os, runparams, max_length);
os << "\n]";
return PLAINTEXT_NEWLINE + 1; // one char on a separate line
}
-int InsetFoot::docbook(odocstream & os, OutputParams const & runparams) const
+void InsetFoot::docbook(XMLStream & xs, OutputParams const & runparams) const
{
- os << "<footnote>";
- int const i = InsetText::docbook(os, runparams);
- os << "</footnote>";
+ OutputParams rp = runparams;
+ rp.docbook_force_pars = true;
+ rp.docbook_in_par = false;
+ InsetText::docbook(xs, rp);
+}
+
+
+void InsetFoot::validate(LaTeXFeatures & features) const
+{
+ // Use footnote package to provide footnotes in tables
+ // unless an alternative approach is built in the class.
+ if (!features.saveNoteEnv().empty()
+ && !features.isProvided("footnote-alternative")) {
+ features.require("footnote");
+ features.addPreambleSnippet(
+ from_ascii("\\makesavenoteenv{"
+ + features.saveNoteEnv()
+ + "}\n"));
+ }
- return i;
+ InsetText::validate(features);
}
} // namespace lyx