class LaTeXFeatures;
-class InsetSpaceParams {
-public:
+struct InsetSpaceParams {
/// The different kinds of spaces we support
enum Kind {
/// Normal space ('\ ')
NORMAL,
/// Protected (no break) space ('~')
PROTECTED,
+ /// Visible ("open box") space ('\textvisiblespace')
+ VISIBLE,
/// Thin space ('\,')
THIN,
/// Medium space ('\:')
QUAD,
/// \qquad (2em)
QQUAD,
- /// \enskip (0.5em unbreakable)
+ /// \enspace (0.5em unbreakable)
ENSPACE,
- /// \enspace (0.5em breakable)
+ /// \enskip (0.5em breakable)
ENSKIP,
/// Negative thin space ('\negthinspace')
NEGTHIN,
CUSTOM_PROTECTED
};
///
- InsetSpaceParams(bool m = false) : kind(NORMAL), math(m) {}
+ explicit InsetSpaceParams(bool m = false) : kind(NORMAL), math(m) {}
///
void write(std::ostream & os) const;
///
///
Kind kind;
///
- Length length;
+ GlueLength length;
/**
* Whether these params are to be used in mathed.
* This determines the set of valid kinds.
{
public:
///
- InsetSpace() {}
+ InsetSpace() : Inset(0) {}
///
explicit InsetSpace(InsetSpaceParams const & par);
///
- InsetSpaceParams params() const { return params_; }
+ InsetSpaceParams const & params() const { return params_; }
///
InsetSpaceParams::Kind kind() const;
- ///
- ~InsetSpace();
///
static void string2params(std::string const &, InsetSpaceParams &);
///
static std::string params2string(InsetSpaceParams const &);
///
- Length length() const;
+ GlueLength length() const;
///
docstring toolTip(BufferView const & bv, int x, int y) const;
+ /// unprotected spaces allow line breaking after them
+ RowFlags rowFlags() const;
///
void metrics(MetricsInfo &, Dimension &) const;
///
/// Will not be used when lyxf3
void read(Lexer & lex);
///
- int latex(odocstream &, OutputParams const &) const;
+ void latex(otexstream &, OutputParams const &) const;
///
- int plaintext(odocstream &, OutputParams const &) const;
+ int plaintext(odocstringstream & ods, OutputParams const & op,
+ size_t max_length = INT_MAX) const;
///
- int docbook(odocstream &, OutputParams const &) const;
+ void docbook(XMLStream &, OutputParams const &) const;
+ ///
+ docstring xhtml(XMLStream &, OutputParams const &) const;
///
void validate(LaTeXFeatures & features) const;
- /// the string that is passed to the TOC
- void tocString(odocstream &) const;
///
- void edit(Cursor & cur, bool front,
- EntryDirection entry_from = ENTRY_DIRECTION_IGNORE);
+ void toString(odocstream &) const;
+ ///
+ void forOutliner(docstring &, size_t const, bool const) const;
///
- EDITABLE editable() const { return IS_EDITABLE; }
+ bool hasSettings() const { return true; }
+ ///
+ bool clickable(BufferView const &, int, int) const { return true; }
///
InsetCode lyxCode() const { return SPACE_CODE; }
- /// is this an expandible space (rubber length)?
- bool isStretchableSpace() const;
-
- // should this inset be handled like a normal charater
+ /// does this inset try to use all available space (like \\hfill does)?
+ bool isHfill() const;
+ /// should this inset be handled like a normal character?
bool isChar() const { return true; }
/// is this equivalent to a letter?
bool isLetter() const { return false; }
// a line separator)?
bool isSpace() const { return true; }
///
- docstring contextMenu(BufferView const & bv, int x, int y) const;
+ std::string contextMenuName() const;
protected:
///
Inset * clone() const { return new InsetSpace(*this); }
bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const;
private:
- ///
- bool showInsetDialog(BufferView * bv) const;
///
InsetSpaceParams params_;
};