1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <sal/config.h>
22 #include <o3tl/float_int_conversion.hxx>
23 #include <vcl/errcode.hxx>
24 #include <basic/sberrors.hxx>
25 #include "sbxconv.hxx"
27 sal_uInt16
ImpGetUShort( const SbxValues
* p
)
35 SbxBase::SetError( ERRCODE_BASIC_CONVERSION
);
43 nRes
= p
->nByte
; break;
48 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= 0;
58 if( p
->nLong
> SbxMAXUINT
)
60 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
62 else if( p
->nLong
< 0 )
64 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= 0;
67 nRes
= static_cast<sal_uInt16
>(p
->nLong
);
70 if( p
->nULong
> SbxMAXUINT
)
72 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
75 nRes
= static_cast<sal_uInt16
>(p
->nULong
);
78 if( p
->nInt64
/ CURRENCY_FACTOR
> SbxMAXUINT
)
80 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
82 else if( p
->nInt64
< 0 )
84 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= 0;
87 nRes
= static_cast<sal_uInt16
>(p
->nInt64
/ CURRENCY_FACTOR
);
90 if( p
->nInt64
> SbxMAXUINT
)
92 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
94 else if( p
->nInt64
< 0 )
96 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= 0;
99 nRes
= static_cast<sal_uInt16
>(p
->nInt64
);
102 if( p
->uInt64
> SbxMAXUINT
)
104 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
107 nRes
= static_cast<sal_uInt16
>(p
->uInt64
);
110 if( !o3tl::convertsToAtMost(o3tl::roundAway(p
->nSingle
), SbxMAXUINT
) )
112 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
114 else if( p
->nSingle
< 0 )
116 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= 0;
119 nRes
= static_cast<sal_uInt16
>( p
->nSingle
+ 0.5 );
124 case SbxBYREF
| SbxDECIMAL
:
127 if( p
->eType
== SbxDECIMAL
)
131 p
->pDecimal
->getDouble( dVal
);
136 if( !o3tl::convertsToAtMost(o3tl::roundAway(dVal
), SbxMAXUINT
) )
138 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
142 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= 0;
145 nRes
= static_cast<sal_uInt16
>( dVal
+ 0.5 );
148 case SbxBYREF
| SbxSTRING
:
157 if( ImpScan( *p
->pOUString
, d
, t
, nullptr, false ) != ERRCODE_NONE
)
159 else if( !o3tl::convertsToAtMost(o3tl::roundAway(d
), SbxMAXUINT
) )
161 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= SbxMAXUINT
;
165 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); nRes
= 0;
168 nRes
= static_cast<sal_uInt16
>( d
+ 0.5 );
173 SbxValue
* pVal
= dynamic_cast<SbxValue
*>( p
->pObj
);
175 nRes
= pVal
->GetUShort();
178 SbxBase::SetError( ERRCODE_BASIC_NO_OBJECT
); nRes
= 0;
183 case SbxBYREF
| SbxBYTE
:
184 nRes
= *p
->pByte
; break;
185 case SbxBYREF
| SbxERROR
:
186 case SbxBYREF
| SbxUSHORT
:
187 nRes
= *p
->pUShort
; break;
189 // from here on will be tested
190 case SbxBYREF
| SbxCHAR
:
191 aTmp
.nChar
= *p
->pChar
; goto ref
;
192 case SbxBYREF
| SbxINTEGER
:
193 case SbxBYREF
| SbxBOOL
:
194 aTmp
.nInteger
= *p
->pInteger
; goto ref
;
195 case SbxBYREF
| SbxLONG
:
196 aTmp
.nLong
= *p
->pLong
; goto ref
;
197 case SbxBYREF
| SbxULONG
:
198 aTmp
.nULong
= *p
->pULong
; goto ref
;
199 case SbxBYREF
| SbxSINGLE
:
200 aTmp
.nSingle
= *p
->pSingle
; goto ref
;
201 case SbxBYREF
| SbxDATE
:
202 case SbxBYREF
| SbxDOUBLE
:
203 aTmp
.nDouble
= *p
->pDouble
; goto ref
;
204 case SbxBYREF
| SbxCURRENCY
:
205 case SbxBYREF
| SbxSALINT64
:
206 aTmp
.nInt64
= *p
->pnInt64
; goto ref
;
207 case SbxBYREF
| SbxSALUINT64
:
208 aTmp
.uInt64
= *p
->puInt64
; goto ref
;
210 aTmp
.eType
= SbxDataType( p
->eType
& 0x0FFF );
211 p
= &aTmp
; goto start
;
214 SbxBase::SetError( ERRCODE_BASIC_CONVERSION
); nRes
= 0;
219 void ImpPutUShort( SbxValues
* p
, sal_uInt16 n
)
228 p
->nUShort
= n
; break;
232 p
->nULong
= n
; break;
234 p
->nSingle
= n
; break;
237 p
->nDouble
= n
; break;
239 p
->nInt64
= n
* CURRENCY_FACTOR
; break;
241 p
->nInt64
= n
; break;
243 p
->uInt64
= n
; break;
245 case SbxBYREF
| SbxDECIMAL
:
246 ImpCreateDecimal( p
)->setUInt( n
);
249 // from here on tests
251 aTmp
.pChar
= &p
->nChar
; goto direct
;
253 aTmp
.pByte
= &p
->nByte
; goto direct
;
256 aTmp
.pInteger
= &p
->nInteger
;
258 aTmp
.eType
= SbxDataType( p
->eType
| SbxBYREF
);
259 p
= &aTmp
; goto start
;
261 case SbxBYREF
| SbxSTRING
:
265 p
->pOUString
= new OUString
;
266 ImpCvtNum( static_cast<double>(n
), 0, *p
->pOUString
);
270 SbxValue
* pVal
= dynamic_cast<SbxValue
*>( p
->pObj
);
272 pVal
->PutUShort( n
);
274 SbxBase::SetError( ERRCODE_BASIC_NO_OBJECT
);
278 case SbxBYREF
| SbxCHAR
:
279 *p
->pChar
= static_cast<sal_Unicode
>(n
); break;
280 case SbxBYREF
| SbxBYTE
:
283 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); n
= SbxMAXBYTE
;
285 *p
->pByte
= static_cast<sal_uInt8
>(n
); break;
286 case SbxBYREF
| SbxINTEGER
:
287 case SbxBYREF
| SbxBOOL
:
290 SbxBase::SetError( ERRCODE_BASIC_MATH_OVERFLOW
); n
= SbxMAXINT
;
292 *p
->pInteger
= static_cast<sal_Int16
>(n
); break;
293 case SbxBYREF
| SbxERROR
:
294 case SbxBYREF
| SbxUSHORT
:
295 *p
->pUShort
= n
; break;
296 case SbxBYREF
| SbxLONG
:
297 *p
->pLong
= n
; break;
298 case SbxBYREF
| SbxULONG
:
299 *p
->pULong
= n
; break;
300 case SbxBYREF
| SbxSINGLE
:
301 *p
->pSingle
= n
; break;
302 case SbxBYREF
| SbxDATE
:
303 case SbxBYREF
| SbxDOUBLE
:
304 *p
->pDouble
= n
; break;
305 case SbxBYREF
| SbxCURRENCY
:
306 *p
->pnInt64
= n
* CURRENCY_FACTOR
; break;
307 case SbxBYREF
| SbxSALINT64
:
308 *p
->pnInt64
= n
; break;
309 case SbxBYREF
| SbxSALUINT64
:
310 *p
->puInt64
= n
; break;
313 SbxBase::SetError( ERRCODE_BASIC_CONVERSION
);
317 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */