2003-05-22 10:40:57 +00:00
|
|
|
|
// -*- C++ -*-
|
|
|
|
|
/**
|
|
|
|
|
* \file InsetSpace.h
|
|
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
|
* Licence details can be found in the file COPYING.
|
|
|
|
|
*
|
|
|
|
|
* \author Asger Alstrup Nielsen
|
|
|
|
|
* \author Jean-Marc Lasgouttes
|
|
|
|
|
* \author Lars Gullik Bj<EFBFBD>nnes
|
|
|
|
|
* \author Juergen Spitzmueller
|
|
|
|
|
*
|
|
|
|
|
* Full author contact details are available in file CREDITS
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef INSET_SPACE_H
|
|
|
|
|
#define INSET_SPACE_H
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "inset.h"
|
|
|
|
|
#include "LString.h"
|
|
|
|
|
|
|
|
|
|
struct LaTeXFeatures;
|
|
|
|
|
|
|
|
|
|
/// Used to insert different kinds of spaces
|
|
|
|
|
class InsetSpace : public Inset {
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
/// The different kinds of spaces we support
|
|
|
|
|
enum Kind {
|
|
|
|
|
/// Normal space ('\ ')
|
|
|
|
|
NORMAL,
|
|
|
|
|
/// Protected (no break) space ('~')
|
|
|
|
|
PROTECTED,
|
|
|
|
|
/// Thin space ('\,')
|
|
|
|
|
THIN,
|
|
|
|
|
/// \quad (1em)
|
|
|
|
|
QUAD,
|
|
|
|
|
/// \qquad (2em)
|
|
|
|
|
QQUAD,
|
|
|
|
|
/// \enspace (0.5em unbreakable)
|
|
|
|
|
ENSPACE,
|
|
|
|
|
/// \enspace (0.5em breakable)
|
|
|
|
|
ENSKIP,
|
|
|
|
|
/// Negative thin space ('\negthinspace')
|
|
|
|
|
NEGTHIN
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
///
|
|
|
|
|
InsetSpace() {}
|
|
|
|
|
///
|
|
|
|
|
explicit
|
|
|
|
|
InsetSpace(Kind k);
|
|
|
|
|
///
|
|
|
|
|
Kind kind() const;
|
|
|
|
|
///
|
|
|
|
|
void dimension(BufferView *, LyXFont const &, Dimension &) const;
|
|
|
|
|
///
|
|
|
|
|
void draw(BufferView *, LyXFont const &, int, float &) const;
|
|
|
|
|
///
|
|
|
|
|
void write(Buffer const *, std::ostream &) const;
|
|
|
|
|
/// Will not be used when lyxf3
|
|
|
|
|
void read(Buffer const *, LyXLex & lex);
|
|
|
|
|
///
|
2003-05-23 08:59:47 +00:00
|
|
|
|
int latex(Buffer const *, std::ostream &,
|
|
|
|
|
LatexRunParams const &) const;
|
2003-05-22 10:40:57 +00:00
|
|
|
|
///
|
|
|
|
|
int ascii(Buffer const *, std::ostream &, int linelen) const;
|
|
|
|
|
///
|
|
|
|
|
int linuxdoc(Buffer const *, std::ostream &) const;
|
|
|
|
|
///
|
|
|
|
|
int docbook(Buffer const *, std::ostream &, bool mixcont) const;
|
|
|
|
|
///
|
|
|
|
|
virtual Inset * clone(Buffer const &, bool same_id = false) 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;
|
|
|
|
|
/// is this equivalent to a letter?
|
|
|
|
|
bool isLetter() const;
|
|
|
|
|
/// is this equivalent to a space (which is BTW different from
|
|
|
|
|
// a line separator)?
|
|
|
|
|
bool isSpace() const;
|
|
|
|
|
// should we break lines after this inset?
|
|
|
|
|
bool isLineSeparator() const;
|
|
|
|
|
private:
|
|
|
|
|
/// And which kind is this?
|
|
|
|
|
Kind kind_;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#endif // INSET_SPACE_H
|