#include "Lexer.h"
#include "MetricsInfo.h"
#include "output_xhtml.h"
+#include "xml.h"
#include "texstream.h"
#include "frontends/FontMetrics.h"
InsetSpecialChar::InsetSpecialChar(Kind k)
- : Inset(0), kind_(k)
+ : Inset(nullptr), kind_(k)
{}
}
-Inset::RowFlags InsetSpecialChar::rowFlags() const
+int InsetSpecialChar::rowFlags() const
{
switch (kind_) {
case ALLOWBREAK:
}
-int InsetSpecialChar::docbook(odocstream & os, OutputParams const &) const
+void InsetSpecialChar::docbook(XMLStream & xs, OutputParams const &) const
{
switch (kind_) {
- case HYPHENATION:
- break;
- case ALLOWBREAK:
- // U+200B ZERO WIDTH SPACE (ZWSP)
- os.put(0x200b);
- break;
+ case HYPHENATION:
+ // Soft hyphen.
+ xs << XMLStream::ESCAPE_NONE << "­";
+ break;
+ case ALLOWBREAK:
+ // Zero-width space
+ xs << XMLStream::ESCAPE_NONE << "​";
+ break;
case LIGATURE_BREAK:
+ // Zero width non-joiner
+ xs << XMLStream::ESCAPE_NONE << "‌";
break;
case END_OF_SENTENCE:
- os << '.';
+ xs << '.';
break;
case LDOTS:
- os << "…";
+ // …
+ xs << XMLStream::ESCAPE_NONE << "…";
break;
case MENU_SEPARATOR:
- os << "&lyxarrow;";
+ // ⇒, right arrow.
+ xs << XMLStream::ESCAPE_NONE << "⇒";
break;
case SLASH:
- os << '/';
+ // ⁄, fractional slash.
+ xs << XMLStream::ESCAPE_NONE << "⁄";
break;
+ // Non-breaking hyphen.
case NOBREAKDASH:
- os << '-';
+ xs << XMLStream::ESCAPE_NONE << "‑";
break;
case PHRASE_LYX:
- os << "LyX";
+ xs << "LyX";
break;
case PHRASE_TEX:
- os << "TeX";
+ xs << "TeX";
break;
case PHRASE_LATEX2E:
- os << "LaTeX2";
- // ε U+03B5 GREEK SMALL LETTER EPSILON
- os.put(0x03b5);
+ // Lower-case epsilon.
+ xs << "LaTeX2" << XMLStream::ESCAPE_NONE << "ε";
break;
case PHRASE_LATEX:
- os << "LaTeX";
+ xs << "LaTeX";
break;
}
- return 0;
}
bool InsetSpecialChar::isLetter() const
{
return kind_ == HYPHENATION || kind_ == LIGATURE_BREAK
- || kind_ == NOBREAKDASH;
+ || kind_ == NOBREAKDASH
+ || kind_ == PHRASE_LYX || kind_ == PHRASE_LATEX
+ || kind_ == PHRASE_TEX || kind_ == PHRASE_LATEX2E;
}