This commit is contained in:
peterl 1998-04-30 19:52:46 +00:00
Родитель bd7c900947
Коммит 8007d1ba75
1 изменённых файлов: 50 добавлений и 16 удалений

Просмотреть файл

@ -20,14 +20,18 @@
#include "nsString.h"
#include "nsCRT.h"
nsStyleCoord::nsStyleCoord(void)
: mUnit(eStyleUnit_Twips)
nsStyleCoord::nsStyleCoord(nsStyleUnit aUnit)
: mUnit(aUnit)
{
NS_ASSERTION(aUnit < eStyleUnit_Percent, "not a valueless unit");
if (aUnit >= eStyleUnit_Percent) {
mUnit = eStyleUnit_Null;
}
mValue.mInt = 0;
}
nsStyleCoord::nsStyleCoord(nscoord aValue)
: mUnit(eStyleUnit_Twips)
: mUnit(eStyleUnit_Coord)
{
mValue.mInt = aValue;
}
@ -35,7 +39,18 @@ nsStyleCoord::nsStyleCoord(nscoord aValue)
nsStyleCoord::nsStyleCoord(PRInt32 aValue, nsStyleUnit aUnit)
: mUnit(aUnit)
{
mValue.mInt = aValue;
NS_ASSERTION((aUnit == eStyleUnit_Proportional) ||
(aUnit == eStyleUnit_Enumerated) ||
(aUnit == eStyleUnit_Integer), "not an int value");
if ((aUnit == eStyleUnit_Proportional) ||
(aUnit == eStyleUnit_Enumerated) ||
(aUnit == eStyleUnit_Integer)) {
mValue.mInt = aValue;
}
else {
mUnit = eStyleUnit_Null;
mValue.mInt = 0;
}
}
nsStyleCoord::nsStyleCoord(float aValue)
@ -80,37 +95,53 @@ PRBool nsStyleCoord::operator==(const nsStyleCoord& aOther) const
return PR_FALSE;
}
void nsStyleCoord::Set(nscoord aValue)
void nsStyleCoord::Reset(void)
{
mUnit = eStyleUnit_Twips;
mUnit = eStyleUnit_Null;
mValue.mInt = 0;
}
void nsStyleCoord::SetCoordValue(nscoord aValue)
{
mUnit = eStyleUnit_Coord;
mValue.mInt = aValue;
}
void nsStyleCoord::Set(PRInt32 aValue, nsStyleUnit aUnit)
void nsStyleCoord::SetIntValue(PRInt32 aValue, nsStyleUnit aUnit)
{
mUnit = aUnit;
mValue.mInt = aValue;
NS_ASSERTION((aUnit == eStyleUnit_Proportional) ||
(aUnit == eStyleUnit_Enumerated) ||
(aUnit == eStyleUnit_Integer), "not an int value");
if ((aUnit == eStyleUnit_Proportional) ||
(aUnit == eStyleUnit_Enumerated) ||
(aUnit == eStyleUnit_Integer)) {
mUnit = aUnit;
mValue.mInt = aValue;
}
else {
Reset();
}
}
void nsStyleCoord::Set(float aValue)
void nsStyleCoord::SetPercentValue(float aValue)
{
mUnit = eStyleUnit_Percent;
mValue.mFloat = aValue;
}
void nsStyleCoord::SetNormal(void)
void nsStyleCoord::SetNormalValue(void)
{
mUnit = eStyleUnit_Normal;
mValue.mInt = 0;
}
void nsStyleCoord::SetAuto(void)
void nsStyleCoord::SetAutoValue(void)
{
mUnit = eStyleUnit_Auto;
mValue.mInt = 0;
}
void nsStyleCoord::SetInherit(void)
void nsStyleCoord::SetInheritValue(void)
{
mUnit = eStyleUnit_Inherit;
mValue.mInt = 0;
@ -121,9 +152,10 @@ void nsStyleCoord::AppendToString(nsString& aBuffer) const
if (eStyleUnit_Percent == mUnit) {
aBuffer.Append(mValue.mFloat);
}
else if ((eStyleUnit_Twips == mUnit) ||
else if ((eStyleUnit_Coord == mUnit) ||
(eStyleUnit_Proportional == mUnit) ||
(eStyleUnit_Enumerated == mUnit)) {
(eStyleUnit_Enumerated == mUnit) ||
(eStyleUnit_Integer == mUnit)) {
aBuffer.Append(mValue.mInt, 10);
aBuffer.Append("[0x");
aBuffer.Append(mValue.mInt, 16);
@ -131,13 +163,15 @@ void nsStyleCoord::AppendToString(nsString& aBuffer) const
}
switch (mUnit) {
case eStyleUnit_Twips: aBuffer.Append("tw"); break;
case eStyleUnit_Null: aBuffer.Append("Null"); break;
case eStyleUnit_Coord: aBuffer.Append("tw"); break;
case eStyleUnit_Percent: aBuffer.Append("%"); break;
case eStyleUnit_Normal: aBuffer.Append("Normal"); break;
case eStyleUnit_Auto: aBuffer.Append("Auto"); break;
case eStyleUnit_Inherit: aBuffer.Append("Inherit"); break;
case eStyleUnit_Proportional: aBuffer.Append("*"); break;
case eStyleUnit_Enumerated: aBuffer.Append("enum"); break;
case eStyleUnit_Integer: aBuffer.Append("int"); break;
}
aBuffer.Append(' ');
}