diff --git a/dlls/oleaut32/tests/vartest.c b/dlls/oleaut32/tests/vartest.c index 8b3e4827a0c..3c10ba4e034 100644 --- a/dlls/oleaut32/tests/vartest.c +++ b/dlls/oleaut32/tests/vartest.c @@ -1050,10 +1050,20 @@ static void test_VarParseNumFromStr(void) EXPECT2(5,1); /* Keep trailing zeros on whole number part of a decimal */ - CONVERT("40.1", NUMPRS_STD); + CONVERT("10.1", NUMPRS_STD); EXPECT(3,NUMPRS_STD,NUMPRS_DECIMAL,4,0,-1); - EXPECT2(4,0); + EXPECT2(1,0); EXPECTRGB(2,1); + + /* Zeros after decimal sign */ + CONVERT("0.01", NUMPRS_STD); + EXPECT(1,NUMPRS_STD,NUMPRS_DECIMAL,4,0,-2); + EXPECT2(1,FAILDIG); + + /* Trailing zeros after decimal part */ + CONVERT("0.10", NUMPRS_STD); + EXPECT(1,NUMPRS_STD,NUMPRS_DECIMAL,4,0,-1); + EXPECT2(1,0); } static HRESULT (WINAPI *pVarNumFromParseNum)(NUMPARSE*,BYTE*,ULONG,VARIANT*); @@ -1161,6 +1171,11 @@ static void test_VarNumFromParseNum(void) /* -0.5 */ SETRGB(0, 5); CONVERT(1,0,NUMPRS_NEG,1,0,~0u, VTBIT_UI1); EXPECT_UI1(0); + /* Floating point zero is OK */ + /* 0.00000000E0 */ + SETRGB(0, 0); CONVERT(1,0,NUMPRS_DECIMAL|NUMPRS_EXPONENT,12,0,-8, VTBIT_R8); + EXPECT_R8(0.0); + /* Float is acceptable for an integer input value */ SETRGB(0, 1); CONVERT(1,0,0,1,0,0, VTBIT_R4); EXPECT_R4(1.0f); /* As is double */ diff --git a/dlls/oleaut32/variant.c b/dlls/oleaut32/variant.c index 1fb24b8be2b..866ee1f1e0d 100644 --- a/dlls/oleaut32/variant.c +++ b/dlls/oleaut32/variant.c @@ -1743,6 +1743,7 @@ HRESULT WINAPI VarParseNumFromStr(OLECHAR *lpszStr, LCID lcid, ULONG dwFlags, dwState |= B_LEADING_ZERO; cchUsed++; lpszStr++; + pNumprs->nPwr10--; } } } @@ -1823,11 +1824,7 @@ HRESULT WINAPI VarParseNumFromStr(OLECHAR *lpszStr, LCID lcid, ULONG dwFlags, } else { while (pNumprs->cDig > 1 && !rgbTmp[pNumprs->cDig - 1]) { - if (pNumprs->dwOutFlags & NUMPRS_DECIMAL) - pNumprs->nPwr10--; - else - pNumprs->nPwr10++; - + pNumprs->nPwr10++; pNumprs->cDig--; } } @@ -1837,11 +1834,7 @@ HRESULT WINAPI VarParseNumFromStr(OLECHAR *lpszStr, LCID lcid, ULONG dwFlags, /* Remove trailing zeros from the last (whole number or decimal) part */ while (pNumprs->cDig > 1 && !rgbTmp[pNumprs->cDig - 1]) { - if (pNumprs->dwOutFlags & NUMPRS_DECIMAL) - pNumprs->nPwr10--; - else - pNumprs->nPwr10++; - + pNumprs->nPwr10++; pNumprs->cDig--; } } @@ -2339,7 +2332,7 @@ HRESULT WINAPI VarNumFromParseNum(NUMPARSE *pNumprs, BYTE *rgbDig, while (divisor10 > 10) { - if (whole < dblMinimums[10]) + if (whole < dblMinimums[10] && whole != 0) { dwVtBits &= ~(VTBIT_R4|VTBIT_R8|VTBIT_CY); /* Underflow */ bOverflow = TRUE; @@ -2350,7 +2343,7 @@ HRESULT WINAPI VarNumFromParseNum(NUMPARSE *pNumprs, BYTE *rgbDig, } if (divisor10) { - if (whole < dblMinimums[divisor10]) + if (whole < dblMinimums[divisor10] && whole != 0) { dwVtBits &= ~(VTBIT_R4|VTBIT_R8|VTBIT_CY); /* Underflow */ bOverflow = TRUE;