connectivity/source/drivers/firebird/PreparedStatement.cxx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-)
New commits: commit b9a0dc13a02e71dc680ad6b3d1d9f55ae27e3217 Author: Xisco Fauli <xiscofa...@libreoffice.org> AuthorDate: Tue Jul 16 15:34:53 2019 +0200 Commit: Thorsten Behrens <thorsten.behr...@cib.de> CommitDate: Wed Aug 7 23:27:37 2019 +0200 tdf#123591: truncate and round to 'scale' number of decimal places otherwise the number will be incorrectly converted to OUString if scale < number of decimals See https://bugs.documentfoundation.org/show_bug.cgi?id=123591#c25 Change-Id: Ie32c9c6ab339d6907e9a4e2645d6f19bad9e67c8 Reviewed-on: https://gerrit.libreoffice.org/75727 Tested-by: Jenkins Reviewed-by: Thorsten Behrens <thorsten.behr...@cib.de> Tested-by: Thorsten Behrens <thorsten.behr...@cib.de> (cherry picked from commit 54028dc503fc08eb12e287919d5e2850cff05b73) Reviewed-on: https://gerrit.libreoffice.org/76751 diff --git a/connectivity/source/drivers/firebird/PreparedStatement.cxx b/connectivity/source/drivers/firebird/PreparedStatement.cxx index 69ce91f42da1..71a43454f315 100644 --- a/connectivity/source/drivers/firebird/PreparedStatement.cxx +++ b/connectivity/source/drivers/firebird/PreparedStatement.cxx @@ -18,6 +18,7 @@ */ #include <sal/config.h> +#include <cmath> #include <string_view> @@ -729,7 +730,8 @@ void SAL_CALL OPreparedStatement::setObjectWithInfo( sal_Int32 parameterIndex, c OUString sValue; if( x >>= dbValue ) { - sValue = OUString::number( dbValue ); + // truncate and round to 'scale' number of decimal places + sValue = OUString::number( std::floor((dbValue * pow10Integer(scale)) + .5) / pow10Integer(scale) ); } else { _______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits