[Libreoffice-commits] core.git: starmath/source

Caolán McNamara caolanm at redhat.com
Sun Dec 10 20:04:53 UTC 2017


 starmath/source/mathmlattr.cxx |    8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)

New commits:
commit cd5a4971bb84bb588a990a252a84ed799fe1ebeb
Author: Caolán McNamara <caolanm at redhat.com>
Date:   Sun Dec 10 11:50:09 2017 +0000

    ofz#4578 Integer-overflow
    
    Change-Id: I2fcd530b3217c72385301b8f3456557c8c8cec13
    Reviewed-on: https://gerrit.libreoffice.org/46183
    Tested-by: Jenkins <ci at libreoffice.org>
    Reviewed-by: Caolán McNamara <caolanm at redhat.com>
    Tested-by: Caolán McNamara <caolanm at redhat.com>

diff --git a/starmath/source/mathmlattr.cxx b/starmath/source/mathmlattr.cxx
index f68bc003e4ff..2b0c70335430 100644
--- a/starmath/source/mathmlattr.cxx
+++ b/starmath/source/mathmlattr.cxx
@@ -62,8 +62,12 @@ sal_Int32 ParseMathMLUnsignedNumber(const OUString &rStr, Fraction *pUN)
     assert(nDecimalPoint < nIdx);
     *pUN = Fraction(rStr.copy(0, nDecimalPoint).toInt32(), 1);
     if (++nDecimalPoint < nIdx)
-        *pUN += Fraction(rStr.copy(nDecimalPoint, nIdx-nDecimalPoint).toInt32(),
-                         lcl_GetPowerOf10(nIdx-nDecimalPoint));
+    {
+        const sal_Int32 nDigits = nIdx - nDecimalPoint;
+        if (nDigits > 9)
+            return -1;
+        *pUN += Fraction(rStr.copy(nDecimalPoint, nDigits).toInt32(), lcl_GetPowerOf10(nDigits));
+    }
     return nIdx;
 }
 


More information about the Libreoffice-commits mailing list