#include "output_xhtml.h"
#include "ParIterator.h"
#include "sgml.h"
+#include "texstream.h"
#include "TocBackend.h"
#include "support/debug.h"
// FIXME What we'd really like to do is to be able to output some
// appropriate sort of text here. But to do that, we need to associate
// some sort of counter with the label, and we don't have that yet.
- string const attr = "href=\"#" + html::cleanAttr(to_utf8(ref)) + "\"";
- xs << html::StartTag("a", attr);
+ docstring const attr = "href=\"#" + html::cleanAttr(ref) + '"';
+ xs << html::StartTag("a", to_utf8(attr));
xs << display_string;
xs << html::EndTag("a");
return docstring();
}
-void InsetRef::forOutliner(docstring & os, size_t) const
+void InsetRef::forOutliner(docstring & os, size_t const, bool const) const
{
// There's no need for details in the TOC, and a long label
// will just get in the way.
label += getParam("name");
}
- screen_label_ = label;
- bool shortened = false;
unsigned int const maxLabelChars = 24;
- if (screen_label_.size() > maxLabelChars) {
- screen_label_.erase(maxLabelChars - 3);
- screen_label_ += "...";
- shortened = true;
- }
- if (shortened)
+ if (label.size() > maxLabelChars) {
tooltip_ = label;
- else
+ support::truncateWithEllipsis(label, maxLabelChars);
+ } else
tooltip_ = from_ascii("");
+ screen_label_ = label;
}
docstring const data = getEscapedLabel(features.runparams());
docstring label;
docstring prefix;
- string const fcmd = to_utf8(getFormattedCmd(data, label, prefix));
+ docstring const fcmd = getFormattedCmd(data, label, prefix);
if (buffer().params().use_refstyle) {
features.require("refstyle");
if (prefix == "cha")
- features.addPreambleSnippet("\\let\\charef=\\chapref");
+ features.addPreambleSnippet(from_ascii("\\let\\charef=\\chapref"));
else if (!prefix.empty()) {
- string lcmd = "\\AtBeginDocument{\\providecommand" +
- fcmd + "[1]{\\ref{" + to_utf8(prefix) + ":#1}}}";
+ docstring lcmd = "\\AtBeginDocument{\\providecommand" +
+ fcmd + "[1]{\\ref{" + prefix + ":#1}}}";
features.addPreambleSnippet(lcmd);
}
} else {
// prettyref uses "cha" for chapters, so we provide a kind of
// translation.
if (prefix == "chap")
- features.addPreambleSnippet("\\let\\pr@chap=\\pr@cha");
+ features.addPreambleSnippet(from_ascii("\\let\\pr@chap=\\pr@cha"));
}
} else if (cmd == "eqref" && !buffer().params().use_refstyle)
// with refstyle, we simply output "(\ref{label})"
{ "vpageref", N_("Textual Page Number"), N_("TextPage: ")},
{ "vref", N_("Standard+Textual Page"), N_("Ref+Text: ")},
{ "formatted", N_("Formatted"), N_("Format: ")},
- { "nameref", N_("Reference to Name"), N_("NameRef:")},
+ { "nameref", N_("Reference to Name"), N_("NameRef: ")},
{ "", "", "" }
};