-/* This file is part of
- * ======================================================
+/**
+ * \file lyxlength.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- * LyX, The Document Processor
+ * \author Matthias Ettrich
+ * \author Lars Gullik Bjønnes
+ * \author Jean-Marc Lasgouttes
+ * \author Angus Leeming
+ * \author John Levon
+ * \author Dekel Tsur
*
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-2001 The LyX Team.
- *
- * ====================================================== */
+ * Full author contact details are available in file CREDITS.
+ */
#include <config.h>
-#ifdef __GNUG__
-#pragma implementation
-#endif
-
#include "lyxlength.h"
#include "lengthcommon.h"
#include "lyxrc.h"
-#include "support/lstrings.h"
+#include <sstream>
+#include <iomanip>
-#include "Lsstream.h"
-#include <cstdlib>
+using std::ostringstream;
+using std::setprecision;
+using std::string;
-using std::abs;
LyXLength::LyXLength()
- : val_(0), unit_(LyXLength::PT)
+ : val_(0), unit_(LyXLength::UNIT_NONE)
{}
string const LyXLength::asString() const
{
- ostringstream buffer;
- buffer << val_ << unit_name[unit_]; // setw?
- return buffer.str().c_str();
+ ostringstream os;
+ os << val_ << unit_name[unit_]; // setw?
+ return os.str();
}
string const LyXLength::asLatexString() const
{
- ostringstream buffer;
+ ostringstream os;
switch (unit_) {
case PTW:
- buffer << abs(static_cast<int>(val_/100)) << "."
- << abs(static_cast<int>(val_)%100) << "\\textwidth";
- break;
+ os << setprecision(2) << val_/100.0 << "\\textwidth";
+ break;
case PCW:
- buffer << abs(static_cast<int>(val_/100)) << "."
- << abs(static_cast<int>(val_)%100) << "\\columnwidth";
- break;
+ os << setprecision(2) << val_/100.0 << "\\columnwidth";
+ break;
case PPW:
- buffer << abs(static_cast<int>(val_/100)) << "."
- << abs(static_cast<int>(val_)%100) << "\\paperwidth";
- break;
+ os << setprecision(2) << val_/100.0 << "\\paperwidth";
+ break;
case PLW:
- buffer << abs(static_cast<int>(val_/100)) << "."
- << abs(static_cast<int>(val_)%100) << "\\linewidth";
- break;
+ os << setprecision(2) << val_/100.0 << "\\linewidth";
+ break;
case PPH:
- buffer << abs(static_cast<int>(val_/100)) << "."
- << abs(static_cast<int>(val_)%100) << "\\paperheight";
- break;
+ os << setprecision(2) << val_/100.0 << "\\paperheight";
+ break;
case PTH:
- buffer << abs(static_cast<int>(val_/100)) << "."
- << abs(static_cast<int>(val_)%100) << "\\textheight";
- break;
+ os << setprecision(2) << val_/100.0 << "\\textheight";
+ break;
default:
- buffer << val_ << unit_name[unit_]; // setw?
- break;
+ os << setprecision(2) << val_ << unit_name[unit_];
+ break;
}
- return buffer.str().c_str();
+ return os.str();
}
}
+bool LyXLength::empty() const
+{
+ return unit_ == LyXLength::UNIT_NONE;
+}
+
+
int LyXLength::inPixels(int text_width, int em_width_base) const
{
// Zoom factor specified by user in percent
double const em_width = (em_width_base > 0)
? em_width_base
: 10*(dpi/72.27)*zoom;
- // A different estimate for em_width is
+ // A different estimate for em_width is
// font_metrics::width('M', LyXFont(LyXFont::ALL_SANE))
// but this estimate might not be more accurate as the screen font
// is different then the latex font.
// between lengths and font sizes on the screen
// is the same as on paper.
-#ifdef WITH_WARNINGS
-#warning if you don't care than either call this function differently or let it return negative values and call abs() explicitly when needed (Andre')
-#endif
-
double result = 0.0;
switch (unit_) {