*
* \author Asger Alstrup Nielsen
* \author Jean-Marc Lasgouttes
- * \author Lars Gullik Bjønnes
+ * \author Lars Gullik Bjønnes
*
* Full author contact details are available in file CREDITS.
*/
enum Kind {
/// Optional hyphenation point (\-)
HYPHENATION,
+ /// Optional line wrap point without hyphen (ZWSP)
+ ALLOWBREAK,
/// Ligature break point (\textcompwordmark)
LIGATURE_BREAK,
/// ... (\ldots)
SLASH,
/// protected dash
NOBREAKDASH,
+ /// LyX logo
+ PHRASE_LYX,
+ /// TeX logo
+ PHRASE_TEX,
+ /// LaTeX2e logo
+ PHRASE_LATEX2E,
+ /// LaTeX logo
+ PHRASE_LATEX
};
///
- InsetSpecialChar() {}
+ InsetSpecialChar() : Inset(0), kind_(HYPHENATION) {}
///
explicit InsetSpecialChar(Kind k);
///
Kind kind() const;
///
- void metrics(MetricsInfo &, Dimension &) const;
+ docstring toolTip(BufferView const & bv, int x, int y) const override;
+ /// some special chars allow line breaking after them
+ int rowFlags() const override;
///
- void draw(PainterInfo & pi, int x, int y) const;
+ void metrics(MetricsInfo &, Dimension &) const override;
///
- void write(std::ostream &) const;
+ void draw(PainterInfo & pi, int x, int y) const override;
+ ///
+ void write(std::ostream &) const override;
/// Will not be used when lyxf3
- void read(Lexer & lex);
+ void read(Lexer & lex) override;
+ ///
+ void latex(otexstream &, OutputParams const &) const override;
+ ///
+ int plaintext(odocstringstream & ods, OutputParams const & op,
+ size_t max_length = INT_MAX) const override;
+ ///
+ void docbook(XMLStream &, OutputParams const &) const override;
+ ///
+ docstring xhtml(XMLStream &, OutputParams const &) const override;
///
- int latex(odocstream &, OutputParams const &) const;
+ void toString(odocstream &) const override;
///
- int plaintext(odocstream &, OutputParams const &) const;
+ bool isInToc() const override { return true; }
///
- int docbook(odocstream &, OutputParams const &) const;
- /// the string that is passed to the TOC
- void tocString(odocstream &) const;
+ void forOutliner(docstring &, size_t const, bool const) const override;
///
- InsetCode lyxCode() const { return SPECIALCHAR_CODE; }
+ InsetCode lyxCode() const override { return SPECIALCHAR_CODE; }
/// We don't need \begin_inset and \end_inset
- bool directWrite() const { return true; }
+ bool directWrite() const override { return true; }
///
- void validate(LaTeXFeatures &) const;
+ void validate(LaTeXFeatures &) const override;
- // should this inset be handled like a normal charater
- bool isChar() const;
+ /// should this inset be handled like a normal character?
+ bool isChar() const override;
/// is this equivalent to a letter?
- bool isLetter() const;
- // should we break lines after this inset?
- bool isLineSeparator() const;
+ bool isLetter() const override;
+ /// should we break lines after this inset?
+ bool isLineSeparator() const override;
+ /// Is the content of this inset part of the immediate (visible) text sequence?
+ bool isPartOfTextSequence() const override { return isChar(); }
private:
- Inset * clone() const { return new InsetSpecialChar(*this); };
+ Inset * clone() const override { return new InsetSpecialChar(*this); }
/// And which kind is this?
Kind kind_;