diff options
author | Noel Power <noel.power@novell.com> | 2010-12-21 15:04:14 +0000 |
---|---|---|
committer | Noel Power <noel.power@novell.com> | 2010-12-21 15:04:14 +0000 |
commit | 9cc9b6dccbdecfe2877a5735672d7f9bb38d0235 (patch) | |
tree | 9f3af00f8d61a6cbaf825ed64ec67d785b5eef03 /basic/source/sbx/sbxuint.cxx | |
parent | 7f2458dec64aec8a2462f1e6adeabcf27120c857 (diff) |
revert Merge remote branch origin/feature/currency-64bit
Diffstat (limited to 'basic/source/sbx/sbxuint.cxx')
-rw-r--r-- | basic/source/sbx/sbxuint.cxx | 43 |
1 files changed, 26 insertions, 17 deletions
diff --git a/basic/source/sbx/sbxuint.cxx b/basic/source/sbx/sbxuint.cxx index 3115fd850f89..e20abbb3c0c0 100644 --- a/basic/source/sbx/sbxuint.cxx +++ b/basic/source/sbx/sbxuint.cxx @@ -81,18 +81,6 @@ start: else nRes = (UINT16) p->nULong; break; - case SbxCURRENCY: - if( p->nInt64 / CURRENCY_FACTOR > SbxMAXUINT ) - { - SbxBase::SetError( SbxERR_OVERFLOW ); nRes = SbxMAXUINT; - } - else if( p->nInt64 < 0 ) - { - SbxBase::SetError( SbxERR_OVERFLOW ); nRes = 0; - } - else - nRes = (UINT16) (p->nInt64 / CURRENCY_FACTOR); - break; case SbxSALINT64: if( p->nInt64 > SbxMAXUINT ) { @@ -127,11 +115,20 @@ start: break; case SbxDATE: case SbxDOUBLE: + case SbxLONG64: + case SbxULONG64: + case SbxCURRENCY: case SbxDECIMAL: case SbxBYREF | SbxDECIMAL: { double dVal; - if( p->eType == SbxDECIMAL ) + if( p->eType == SbxCURRENCY ) + dVal = ImpCurrencyToDouble( p->nLong64 ); + else if( p->eType == SbxLONG64 ) + dVal = ImpINT64ToDouble( p->nLong64 ); + else if( p->eType == SbxULONG64 ) + dVal = ImpUINT64ToDouble( p->nULong64 ); + else if( p->eType == SbxDECIMAL ) { dVal = 0.0; if( p->pDecimal ) @@ -208,7 +205,11 @@ start: case SbxBYREF | SbxDATE: case SbxBYREF | SbxDOUBLE: aTmp.nDouble = *p->pDouble; goto ref; + case SbxBYREF | SbxULONG64: + aTmp.nULong64 = *p->pULong64; goto ref; + case SbxBYREF | SbxLONG64: case SbxBYREF | SbxCURRENCY: + aTmp.nLong64 = *p->pLong64; goto ref; case SbxBYREF | SbxSALINT64: aTmp.nInt64 = *p->pnInt64; goto ref; case SbxBYREF | SbxSALUINT64: @@ -242,12 +243,16 @@ start: case SbxDATE: case SbxDOUBLE: p->nDouble = n; break; - case SbxCURRENCY: - p->nInt64 = n * CURRENCY_FACTOR; break; case SbxSALINT64: p->nInt64 = n; break; case SbxSALUINT64: p->uInt64 = n; break; + case SbxULONG64: + p->nULong64 = ImpDoubleToUINT64( (double)n ); break; + case SbxLONG64: + p->nLong64 = ImpDoubleToINT64( (double)n ); break; + case SbxCURRENCY: + p->nLong64 = ImpDoubleToCurrency( (double)n ); break; case SbxDECIMAL: case SbxBYREF | SbxDECIMAL: ImpCreateDecimal( p )->setUInt( n ); @@ -309,12 +314,16 @@ start: case SbxBYREF | SbxDATE: case SbxBYREF | SbxDOUBLE: *p->pDouble = n; break; - case SbxBYREF | SbxCURRENCY: - *p->pnInt64 = n * CURRENCY_FACTOR; break; case SbxBYREF | SbxSALINT64: *p->pnInt64 = n; break; case SbxBYREF | SbxSALUINT64: *p->puInt64 = n; break; + case SbxBYREF | SbxULONG64: + *p->pULong64 = ImpDoubleToUINT64( (double)n ); break; + case SbxBYREF | SbxLONG64: + *p->pLong64 = ImpDoubleToINT64( (double)n ); break; + case SbxBYREF | SbxCURRENCY: + *p->pLong64 = ImpDoubleToCurrency( (double)n ); break; default: SbxBase::SetError( SbxERR_CONVERSION ); |