X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FSpacing.h;h=274cfc20f220ef5682da932170af294f750ecc1d;hb=268ae66e3c7df04effc329373dc887715d9c6f06;hp=f3e27123f4a41d205057f4ecbc314bf9969cf359;hpb=d0950acedaa91320340af398bb06d790486a2207;p=lyx.git diff --git a/src/Spacing.h b/src/Spacing.h index f3e27123f4..274cfc20f2 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,41 +35,60 @@ 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) { - if (a.space == b.space && a.getValue() == b.getValue()) - return true; - return false; - } + void set(Spacing::Space sp, std::string const & val); /// - friend bool operator!=(Spacing const & a, Spacing const & b) { - if (a.space == b.space && a.getValue() == b.getValue()) - return false; - return true; - } + 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 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