X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FSpacing.h;h=7311f792b5a3b5ae7ec98e90430db607a30ac52c;hb=ac59b049229053a2e5ebb4911d2540a3f88ea6a8;hp=8d466864a24dfa1a42d6d42e6ba8fbfa94abb652;hpb=2889b5fd3e8987d0c265ff4726a7fb6c6cb6c034;p=lyx.git diff --git a/src/Spacing.h b/src/Spacing.h index 8d466864a2..7311f792b5 100644 --- a/src/Spacing.h +++ b/src/Spacing.h @@ -1,20 +1,22 @@ // -*- C++ -*- -/* This file is part of - * ====================================================== - * - * LyX, The Document Processor - * - * Copyright 1995 Matthias Ettrich - * Copyright 1995-2000 The LyX Team. +/** + * \file src/Spacing.h + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. * - * ====================================================== */ + * \author Lars Gullik Bjønnes + * + * Full author contact details are available in file CREDITS. + */ #ifndef SPACING_H #define SPACING_H -#include +#include "support/strfwd.h" + +#include -#include "LString.h" +namespace lyx { /// class Spacing { @@ -33,37 +35,63 @@ public: Default }; /// - Spacing() : space(Single), value(1.0) {} + Spacing() : space(Default), value("1.0") {} /// - bool isDefault() const { - return space == Default; - } + Spacing(Spacing::Space sp, double val = 1.0) { set(sp, val); } /// - float getValue() const; - /// - Spacing::Space getSpace() const { return space; } + Spacing(Spacing::Space sp, std::string const & val) { set(sp, val); } /// - void set(Spacing::Space sp, float val = 1.0); + bool isDefault() const { return space == Default; } /// - void set(Spacing::Space sp, char const * val) ; + std::string const getValueAsString() const; /// - void writeFile(std::ostream &, bool para = false) const; + double getValue() const; /// - string writeEnvirBegin() const; + Spacing::Space getSpace() const { return space; } /// - string writeEnvirEnd() const; + void set(Spacing::Space sp, double val = 1.0); /// - friend bool operator==(Spacing const & a, Spacing const & b) { - return a.space == b.space && a.getValue() == b.getValue(); - } + void set(Spacing::Space sp, std::string const & val); /// - friend bool operator!=(Spacing const & a, Spacing const & b) { - return !(a == b); - } + void writeFile(std::ostream &, bool para = false) const; + /// useSetSpace is true when using the variant supported by + /// the memoir class. + std::string const writeEnvirBegin(bool useSetSpace) const; + /// useSetSpace is true when using the variant supported by + /// the memoir class. + std::string const writeEnvirEnd(bool useSetSpace) const; + /// useSetSpace is true when using the variant supported by + /// the memoir class. + std::string const writeCmd(bool useSetSpace) const; + /// useSetSpace is true when using the variant supported by + /// the memoir class. + std::string const writePreamble(bool useSetSpace) const; + private: /// Space space; /// - float value; + std::string value; + /// names of line spacing + static std::string const spacing_string[]; }; -#endif + + +/// +inline +bool operator==(Spacing const & a, Spacing const & b) +{ + return a.getSpace() == b.getSpace() + && a.getValueAsString() == b.getValueAsString(); +} + +/// +inline +bool operator!=(Spacing const & a, Spacing const & b) +{ + return !(a == b); +} + +} // namespace lyx + +#endif // SPACING_H