]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetSpace.h
Merge branch 'master' into biblatex2
[lyx.git] / src / insets / InsetSpace.h
index b254556185e5377aa0eb83abe154f17390eeed3b..a4fd6151f90a458c9a8429573e6d0cdc735f03a1 100644 (file)
@@ -6,8 +6,8 @@
  *
  * \author Asger Alstrup Nielsen
  * \author Jean-Marc Lasgouttes
- * \author Lars Gullik Bjønnes
- * \author Jürgen Spitzmüller
+ * \author Lars Gullik Bjønnes
+ * \author Jürgen Spitzmüller
  *
  * Full author contact details are available in file CREDITS.
  */
 #ifndef INSET_SPACE_H
 #define INSET_SPACE_H
 
-
 #include "Inset.h"
+#include "Length.h"
 
 
 namespace lyx {
 
 class LaTeXFeatures;
 
-///  Used to insert different kinds of spaces
-class InsetSpace : public Inset {
-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 ('\:')
+               MEDIUM,
+               /// Thick space ('\;')
+               THICK,
                /// \quad (1em)
                QUAD,
                /// \qquad (2em)
                QQUAD,
-               /// \enspace (0.5em unbreakable)
+               /// \enskip (0.5em unbreakable)
                ENSPACE,
                /// \enspace (0.5em breakable)
                ENSKIP,
                /// Negative thin space ('\negthinspace')
-               NEGTHIN
+               NEGTHIN,
+               /// Negative medium space ('\negmedspace')
+               NEGMEDIUM,
+               /// Negative thick space ('\negthickspace')
+               NEGTHICK,
+               /// rubber length
+               HFILL,
+               /// \hspace*{\fill}
+               HFILL_PROTECTED,
+               /// rubber length, filled with dots
+               DOTFILL,
+               /// rubber length, filled with a rule
+               HRULEFILL,
+               /// rubber length, filled with a left arrow
+               LEFTARROWFILL,
+               /// rubber length, filled with a right arrow
+               RIGHTARROWFILL,
+               // rubber length, filled with an up brace
+               UPBRACEFILL,
+               // rubber length, filled with a down brace
+               DOWNBRACEFILL,
+               /// \hspace{length}
+               CUSTOM,
+               /// \hspace*{length}
+               CUSTOM_PROTECTED
        };
+       ///
+       InsetSpaceParams(bool m = false) : kind(NORMAL), math(m) {}
+       ///
+       void write(std::ostream & os) const;
+       ///
+       void read(Lexer & lex);
+       ///
+       Kind kind;
+       ///
+       GlueLength length;
+       /**
+        * Whether these params are to be used in mathed.
+        * This determines the set of valid kinds.
+        */
+       bool math;
+};
+
 
+///  Used to insert different kinds of spaces
+class InsetSpace : public Inset
+{
+public:
        ///
-       InsetSpace();
+       InsetSpace() : Inset(0) {}
+       ///
+       explicit InsetSpace(InsetSpaceParams const & par);
+       ///
+       InsetSpaceParams const & params() const { return params_; }
+       ///
+       InsetSpaceParams::Kind kind() const;
 
        ///
-       explicit
-       InsetSpace(Kind k);
+       static void string2params(std::string const &, InsetSpaceParams &);
+       ///
+       static std::string params2string(InsetSpaceParams const &);
        ///
-       Kind kind() const;
+       GlueLength length() const;
+
+       ///
+       docstring toolTip(BufferView const & bv, int x, int y) const;
        ///
        void metrics(MetricsInfo &, Dimension &) const;
        ///
        void draw(PainterInfo & pi, int x, int y) const;
        ///
-       void write(Buffer const &, std::ostream &) const;
+       void write(std::ostream &) const;
        /// Will not be used when lyxf3
-       void read(Buffer const &, Lexer & lex);
+       void read(Lexer & lex);
        ///
-       int latex(Buffer const &, odocstream &,
-                 OutputParams const &) const;
+       void latex(otexstream &, OutputParams const &) const;
        ///
-       int plaintext(Buffer const &, odocstream &,
-                     OutputParams const &) const;
+       int plaintext(odocstringstream & ods, OutputParams const & op,
+                     size_t max_length = INT_MAX) const;
        ///
-       int docbook(Buffer const &, odocstream &,
-                   OutputParams const &) const;
-       /// the string that is passed to the TOC
-       virtual int textString(Buffer const &, odocstream &,
-               OutputParams const &) const;
+       int docbook(odocstream &, OutputParams const &) const;
        ///
-       Inset::Code lyxCode() const { return Inset::SPACE_CODE; }
-       /// We don't need \begin_inset and \end_inset
-       bool directWrite() const { return true; }
-
-       // should this inset be handled like a normal charater
-       bool isChar() const;
+       docstring xhtml(XHTMLStream &, OutputParams const &) const;
+       ///
+       void validate(LaTeXFeatures & features) const;
+       ///
+       void toString(odocstream &) const;
+       ///
+       void forOutliner(docstring &, size_t const, bool const) const;
+       ///
+       bool hasSettings() const { return true; }
+       ///
+       bool clickable(BufferView const &, int, int) const { return true; }
+       ///
+       InsetCode lyxCode() const { return SPACE_CODE; }
+       /// 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;
+       bool isLetter() const { return false; }
        /// is this equivalent to a space (which is BTW different from
        // a line separator)?
-       bool isSpace() const;
-private:
-       virtual Inset * clone() const;
+       bool isSpace() const { return true; }
+       ///
+       std::string contextMenuName() const;
+protected:
+       ///
+       Inset * clone() const { return new InsetSpace(*this); }
+       ///
+       void doDispatch(Cursor & cur, FuncRequest & cmd);
+public:
+       ///
+       bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const;
 
-       /// And which kind is this?
-       Kind kind_;
+private:
+       ///
+       InsetSpaceParams params_;
 };