summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2012-04-20 18:36:16 +0200
committerDavid Tardon <dtardon@redhat.com>2012-04-23 07:28:38 +0200
commitcf12c5e164575935a30ce626e3b4ea59183980db (patch)
tree8784bbe4c148d0bca6fd215c21229c1138dd32ac
parent691325d67ef395ec9a758e5f8acc46767455ac98 (diff)
fdo#48969: GetConversionFactor: add inch as source unit
Also, add whole bunch of missing cases while at it. Signed-off-by: Fridrich Štrba <fridrich.strba@bluewin.ch> Signed-off-by: Miklos Vajna <vmiklos@suse.cz> Signed-off-by: David Tardon <dtardon@redhat.com>
-rw-r--r--sax/source/tools/converter.cxx152
1 files changed, 142 insertions, 10 deletions
diff --git a/sax/source/tools/converter.cxx b/sax/source/tools/converter.cxx
index cf5a5b50089f..51be183f5326 100644
--- a/sax/source/tools/converter.cxx
+++ b/sax/source/tools/converter.cxx
@@ -1820,9 +1820,16 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
switch(nTargetUnit)
{
case MeasureUnit::MM_100TH:
+ {
+ // 0.01mm = 0.57twip (exactly)
+ fRetval = ((25400.0 / 1440.0) / 10.0);
+ break;
+ }
case MeasureUnit::MM_10TH:
{
- OSL_ENSURE( MeasureUnit::INCH == nTargetUnit, "output unit not supported for twip values");
+ // 0.01mm = 0.57twip (exactly)
+ fRetval = ((25400.0 / 1440.0) / 100.0);
+ break;
}
case MeasureUnit::MM:
{
@@ -1861,31 +1868,49 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
{
switch(nTargetUnit)
{
+ case MeasureUnit::MM_100TH:
+ {
+ // 1mm = 72 / 25.4 pt (exactly)
+ fRetval = ( 2540.0 / 72.0 );
+ break;
+ }
+ case MeasureUnit::MM_10TH:
+ {
+ // 1mm = 72 / 25.4 pt (exactly)
+ fRetval = ( 254.0 / 72.0 );
+ break;
+ }
case MeasureUnit::MM:
+ {
// 1mm = 72 / 25.4 pt (exactly)
fRetval = ( 25.4 / 72.0 );
psUnit = gpsMM;
break;
+ }
case MeasureUnit::CM:
+ {
// 1cm = 72 / 2.54 pt (exactly)
fRetval = ( 2.54 / 72.0 );
psUnit = gpsCM;
break;
-
+ }
case MeasureUnit::TWIP:
+ {
// 1twip = 72 / 1440 pt (exactly)
fRetval = 20.0; // 1440.0 / 72.0
psUnit = gpsPC;
break;
-
+ }
case MeasureUnit::INCH:
default:
+ {
OSL_ENSURE( MeasureUnit::INCH == nTargetUnit, "output unit not supported for pt values");
// 1in = 72 pt (exactly)
fRetval = ( 1.0 / 72.0 );
psUnit = gpsINCH;
break;
+ }
}
break;
}
@@ -1894,9 +1919,9 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
switch(nTargetUnit)
{
case MeasureUnit::MM_100TH:
- case MeasureUnit::MM_10TH:
{
- OSL_ENSURE( MeasureUnit::INCH == nTargetUnit, "output unit not supported for 1/100mm values");
+ fRetval = 10.0;
+ break;
}
case MeasureUnit::MM:
{
@@ -1907,7 +1932,6 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
}
case MeasureUnit::CM:
{
- // 0.001mm = 1 mm/100 (exactly)
fRetval = ((10.0 / 1.0) / 1000.0);
psUnit = gpsCM;
break;
@@ -1919,10 +1943,16 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
psUnit = gpsPT;
break;
}
+ case MeasureUnit::TWIP:
+ {
+ fRetval = ((20.0 * 72000.0 / 2540.0) / 100.0);
+ psUnit = gpsPC;
+ break;
+ }
case MeasureUnit::INCH:
default:
{
- OSL_ENSURE( MeasureUnit::INCH == nTargetUnit, "output unit not supported for 1/100mm values");
+ OSL_ENSURE( MeasureUnit::INCH == nTargetUnit, "output unit not supported for 1/10mm values");
// 0.0001in = 0.254 mm/100 (exactly)
fRetval = ((100000.0 / 2540.0) / 10000.0);
psUnit = gpsINCH;
@@ -1935,10 +1965,10 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
{
switch(nTargetUnit)
{
- case MeasureUnit::MM_100TH:
case MeasureUnit::MM_10TH:
{
- OSL_ENSURE( MeasureUnit::INCH == nTargetUnit, "output unit not supported for 1/100mm values");
+ fRetval = ((10.0 / 1.0) / 100.0);
+ break;
}
case MeasureUnit::MM:
{
@@ -1949,7 +1979,6 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
}
case MeasureUnit::CM:
{
- // 0.001mm = 1 mm/100 (exactly)
fRetval = ((10.0 / 1.0) / 10000.0);
psUnit = gpsCM;
break;
@@ -1961,6 +1990,12 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
psUnit = gpsPT;
break;
}
+ case MeasureUnit::TWIP:
+ {
+ fRetval = ((20.0 * 72000.0 / 2540.0) / 1000.0);
+ psUnit = gpsPC;
+ break;
+ }
case MeasureUnit::INCH:
default:
{
@@ -1973,6 +2008,49 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
}
break;
}
+ case MeasureUnit::MM:
+ {
+ switch(nTargetUnit)
+ {
+ case MeasureUnit::MM_100TH:
+ {
+ fRetval = 100.0;
+ break;
+ }
+ case MeasureUnit::MM_10TH:
+ {
+ fRetval = 10.0;
+ break;
+ }
+ case MeasureUnit::CM:
+ {
+ fRetval = 0.1;
+ psUnit = gpsCM;
+ break;
+ }
+ case MeasureUnit::POINT:
+ {
+ fRetval = 72.0 / (2.54 * 10);
+ psUnit = gpsPT;
+ break;
+ }
+ case MeasureUnit::TWIP:
+ {
+ fRetval = (20.0 * 72.0) / (2.54 * 10);
+ psUnit = gpsPC;
+ break;
+ }
+ case MeasureUnit::INCH:
+ default:
+ {
+ OSL_ENSURE( MeasureUnit::INCH == nTargetUnit, "output unit not supported for cm values");
+ fRetval = 1 / (2.54 * 10);
+ psUnit = gpsINCH;
+ break;
+ }
+ }
+ break;
+ }
case MeasureUnit::CM:
{
switch(nTargetUnit)
@@ -2003,6 +2081,12 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
psUnit = gpsPT;
break;
}
+ case MeasureUnit::TWIP:
+ {
+ fRetval = (20.0 * 72.0) / 2.54;
+ psUnit = gpsPC;
+ break;
+ }
case MeasureUnit::INCH:
default:
{
@@ -2014,6 +2098,54 @@ double Converter::GetConversionFactor(::rtl::OUStringBuffer& rUnit, sal_Int16 nS
}
break;
}
+ case MeasureUnit::INCH:
+ {
+ switch (nTargetUnit)
+ {
+ case MeasureUnit::MM_100TH:
+ {
+ fRetval = 2540;
+ break;
+ }
+ case MeasureUnit::MM_10TH:
+ {
+ fRetval = 254;
+ break;
+ }
+ case MeasureUnit::MM:
+ {
+ fRetval = 25.4;
+ psUnit = gpsMM;
+ break;
+ }
+ case MeasureUnit::CM:
+ {
+ fRetval = 2.54;
+ psUnit = gpsCM;
+ break;
+ }
+ case MeasureUnit::POINT:
+ {
+ fRetval = 72.0;
+ psUnit = gpsPT;
+ break;
+ }
+ case MeasureUnit::TWIP:
+ {
+ fRetval = 72.0 * 20.0;
+ psUnit = gpsPC;
+ break;
+ }
+ default:
+ {
+ OSL_FAIL("output unit not supported for in values");
+ fRetval = 1;
+ psUnit = gpsINCH;
+ break;
+ }
+ }
+ break;
+ }
default:
OSL_ENSURE(false, "sax::Converter::GetConversionFactor(): "
"source unit not supported");