mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-11 19:14:51 +00:00
1a8665988f
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@7219 a592a061-630c-0410-9148-cb99ea01b6c8
95 lines
2.1 KiB
C++
95 lines
2.1 KiB
C++
// -*- 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ø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 metrics(MetricsInfo &, Dimension &) const;
|
|
///
|
|
void draw(PainterInfo & pi, int x, int y) const;
|
|
///
|
|
void write(Buffer const *, std::ostream &) const;
|
|
/// Will not be used when lyxf3
|
|
void read(Buffer const *, LyXLex & lex);
|
|
///
|
|
int latex(Buffer const *, std::ostream &,
|
|
LatexRunParams const &) const;
|
|
///
|
|
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 InsetBase * clone() 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
|