* ======================================================
*
* LyX, The Document Processor
- *
+ *
* Copyright 1995 Matthias Ettrich
* Copyright 1995-2001 The LyX Team.
*
#include "lengthcommon.h"
#include "lyxrc.h"
+#include "support/lstrings.h"
+
#include "Lsstream.h"
#include <cstdlib>
+using std::abs;
LyXLength::LyXLength()
: val_(0), unit_(LyXLength::PT)
: val_(0), unit_(LyXLength::PT)
{
LyXLength tmp;
-
- if (!isValidLength (data, &tmp))
+
+ if (!isValidLength(data, &tmp))
return; // should raise an exception
val_ = tmp.val_;
string const LyXLength::asLatexString() const
{
ostringstream buffer;
- switch(unit_) {
+ switch (unit_) {
case PW:
+ buffer << abs(static_cast<int>(val_/100)) << "."
+ << abs(static_cast<int>(val_)%100) << "\\textwidth";
+ break;
case PE:
buffer << abs(static_cast<int>(val_/100)) << "."
<< abs(static_cast<int>(val_)%100) << "\\columnwidth";
buffer << abs(static_cast<int>(val_/100)) << "."
<< abs(static_cast<int>(val_)%100) << "\\linewidth";
break;
+ case PH:
+ buffer << abs(static_cast<int>(val_/100)) << "."
+ << abs(static_cast<int>(val_)%100) << "\\paperheight";
+ break;
+ case TH:
+ buffer << abs(static_cast<int>(val_/100)) << "."
+ << abs(static_cast<int>(val_)%100) << "\\textheight";
+ break;
default:
buffer << val_ << unit_name[unit_]; // setw?
break;
}
-bool LyXLength::zero() const
+bool LyXLength::zero() const
{
return val_ == 0.0;
}
// we don't care about sign of value, we
// display negative space with text too
+#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;
int val_sign = val_ < 0.0 ? -1 : 1;
-
+
switch (unit_) {
case LyXLength::SP:
// Scaled point: sp = 1/65536 pt
case LyXLength::PL:
result = val_ * default_width / 100;
break;
+ case LyXLength::PH:
+ case LyXLength::TH:
+ result = val_ * default_height / 100;
+ break;
case LyXLength::UNIT_NONE:
result = 0; // this cannot happen
break;
}
+int LyXLength::inBP() const
+{
+ // return any LyXLength value as a one with
+ // the PostScript point, called bp (big points)
+ double result = 0.0;
+ switch (unit_) {
+ case LyXLength::CM:
+ // 1bp = 0.2835cm
+ result = val_ * 28.346;
+ break;
+ case LyXLength::MM:
+ // 1bp = 0.02835mm
+ result = val_ * 2.8346;
+ break;
+ case LyXLength::IN:
+ // 1pt = 1/72in
+ result = val_ * 72.0;
+ break;
+ default:
+ // no other than bp possible
+ result = val_;
+ break;
+ }
+ return static_cast<int>(result + 0.5);
+}
+
+
bool operator==(LyXLength const & l1, LyXLength const & l2)
{
return l1.value() == l2.value() && l1.unit() == l2.unit();
{
return !(l1 == l2);
}
-