X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fvspace.C;h=f62d348c10313cce41177e295d6544f8537fb751;hb=dad1fc66e44a4dad94eb1e9ffd5736bf8f59ae6d;hp=e65d4e8c213898927e5de7667f5d2970d4be1434;hpb=d5c4ecc548777daa7349df7a19edca8702dea19d;p=lyx.git diff --git a/src/vspace.C b/src/vspace.C index e65d4e8c21..f62d348c10 100644 --- a/src/vspace.C +++ b/src/vspace.C @@ -8,23 +8,21 @@ #include -#ifdef __GNUG__ -#pragma implementation -#endif - #include "vspace.h" #include "lengthcommon.h" -#include "lyx_main.h" #include "buffer.h" #include "lyxrc.h" -#include "lyxtext.h" #include "BufferView.h" +#include "lyxtext.h" #include "support/LAssert.h" #include "support/lstrings.h" #include +#ifndef CXX_GLOBAL_CSTD +using std::sscanf; +#endif namespace { @@ -52,7 +50,7 @@ void lyx_advance(string & data, string::size_type n) inline bool isEndOfData(string const & data) { - return frontStrip(data).empty(); + return ltrim(data).empty(); } /** @@ -60,8 +58,8 @@ bool isEndOfData(string const & data) * @param data input string * @return a char representing the type of token returned * - * The possible return values are : - * + stretch indicator for glue length + * The possible return values are : + * + stretch indicator for glue length * - shrink indicator for glue length * n a numeric value (stored in number array) * u a unit type (stored in unit array) @@ -69,7 +67,7 @@ bool isEndOfData(string const & data) */ char nextToken(string & data) { - data = frontStrip(data); + data = ltrim(data); if (data.empty()) return '\0'; else if (data[0] == '+') { @@ -91,7 +89,7 @@ char nextToken(string & data) if (number_index > 3) return 'E'; string buffer; - + // we have found some number if (i == string::npos) { buffer = data; @@ -107,13 +105,13 @@ char nextToken(string & data) return 'n'; } else return 'E'; } - + i = data.find_first_not_of("abcdefghijklmnopqrstuvwxyz%"); if (i != 0) { if (unit_index > 3) return 'E'; string buffer; - + // we have found some alphabetical string if (i == string::npos) { buffer = data; @@ -199,7 +197,7 @@ bool isValidGlueLength(string const & data, LyXGlueLength * result) if (data.empty()) return true; - string buffer = frontStrip(data); + string buffer = ltrim(data); // To make isValidGlueLength recognize negative values as // the first number this little hack is needed: @@ -217,7 +215,7 @@ bool isValidGlueLength(string const & data, LyXGlueLength * result) break; } // end of hack - + int pattern_index = 0; int table_index = 0; char pattern[20]; @@ -241,7 +239,7 @@ bool isValidGlueLength(string const & data, LyXGlueLength * result) if (!*table[table_index].pattern) return false; } - + // Get the values from the appropriate places. If an index // is zero, the corresponding array value is zero or UNIT_NONE, // so we needn't check this. @@ -286,7 +284,7 @@ bool isValidLength(string const & data, LyXLength * result) break; } // end of hack - + number_index = unit_index = 1; // entries at index 0 are sentinels // construct "pattern" from "data" @@ -301,8 +299,8 @@ bool isValidLength(string const & data, LyXLength * result) pattern[pattern_index] = '\0'; // only the most basic pattern is accepted here - if (compare(pattern, "nu") != 0) return false; - + if (compare(pattern, "nu") != 0) return false; + // It _was_ a correct length string. // Store away the values we found. if (result) { @@ -343,11 +341,11 @@ VSpace::VSpace(string const & data) if (data.empty()) return; double value; - string input = strip(data); + string input = rtrim(data); string::size_type const length = input.length(); - if (length > 1 && input[length-1] == '*') { + if (length > 1 && input[length - 1] == '*') { keep_ = true; input.erase(length - 1); } @@ -452,42 +450,48 @@ string const VSpace::asLatexCommand(BufferParams const & params) const : "\\vfill{}"; break; case LENGTH: - ret = keep_ ? "\\vspace*{" + len_.asLatexString() + '}' - : "\\vspace{" + len_.asLatexString() + '}'; - break; + { + string const lenstr = len_.asLatexString(); + + ret = keep_ ? "\\vspace*{" + lenstr + '}' + : "\\vspace{" + lenstr + '}'; } - + break; + + } + return ret; } -int VSpace::inPixels(BufferView * bv) const +int VSpace::inPixels(BufferView const * bv) const { // Height of a normal line in pixels (zoom factor considered) - int const default_height = bv->text->defaultHeight(); // [pixels] + int const default_height = defaultRowHeight(); // [pixels] int retval = 0; - + switch (kind_) { + case NONE: - // Value for this is already set + // value for this is already set break; + case DEFSKIP: retval = bv->buffer()->params.getDefSkip().inPixels(bv); break; - - // This is how the skips are normally defined by - // LateX. But there should be some way to change - // this per document. + + // This is how the skips are normally defined by LateX. + // But there should be some way to change this per document. case SMALLSKIP: retval = default_height / 4; break; - + case MEDSKIP: retval = default_height / 2; break; - + case BIGSKIP: retval = default_height; break; @@ -496,13 +500,11 @@ int VSpace::inPixels(BufferView * bv) const // leave space for the vfill symbol retval = 3 * default_height; break; - - case LENGTH: { - int const default_width = bv->workWidth(); - retval = len_.len().inPixels(default_width, default_height); + + case LENGTH: + retval = len_.len().inPixels(bv->workWidth()); break; - } - + } return retval; }