#include "output_xhtml.h"
#include "OutputParams.h"
#include "Paragraph.h"
+#include "ParIterator.h"
#include "TextClass.h"
#include "TextMetrics.h"
#include "TocBackend.h"
}
-void InsetCaption::addToToc(DocIterator const & cpit) const
+void InsetCaption::addToToc(DocIterator const & cpit, bool output_active) const
{
if (floattype_.empty())
return;
Toc & toc = buffer().tocBackend().toc(floattype_);
docstring str = full_label_;
- text().forToc(str, TOC_ENTRY_LENGTH);
- toc.push_back(TocItem(pit, 0, str));
+ int length = output_active ? INT_MAX : TOC_ENTRY_LENGTH;
+ text().forToc(str, length);
+ toc.push_back(TocItem(pit, 0, str, output_active));
// Proceed with the rest of the inset.
- InsetText::addToToc(cpit);
+ InsetText::addToToc(cpit, output_active);
}
if (first_arg == "changetype") {
string const type = cmd.getArg(1);
status.setOnOff(type == type_);
- bool varia = true;
+ bool varia = type != "LongTableNoNumber";
// check if the immediate parent inset allows caption variation
if (cur.depth() > 1) {
- if (&cur[cur.depth() - 2].inset()
- && !cur[cur.depth() - 2].inset().allowsCaptionVariation())
- varia = false;
+ if (&cur[cur.depth() - 2].inset())
+ varia = cur[cur.depth() - 2].inset().allowsCaptionVariation(type);
}
status.setEnabled(varia
&& buffer().params().documentClass().hasInsetLayout(
// optional argument.
runparams.moving_arg = !runparams.inTableCell;
InsetText::latex(os, runparams);
+ // Backwards compatibility: We always had a linebreak after
+ // the caption (see #8514)
+ os << breakln;
runparams_in.encoding = runparams.encoding;
}
string const our_class = "float-caption-" + type_;
size_t const loc = attr.find("class='");
if (loc != string::npos)
- attr.insert(loc + 1, our_class);
+ attr.insert(loc + 7, our_class+ " ");
+ else
+ attr = attr + " class='" + our_class + "'";
}
xs << html::StartTag(tag, attr);
docstring def = getCaptionAsHTML(xs, rp);
{
os << full_label_ << ' ';
odocstringstream ods;
- return InsetText::plaintext(ods, runparams);
+ int const retval = InsetText::plaintext(ods, runparams);
os << ods.str();
+ return retval;
}