diff --git a/libc/src/__support/str_to_float.h b/libc/src/__support/str_to_float.h --- a/libc/src/__support/str_to_float.h +++ b/libc/src/__support/str_to_float.h @@ -463,14 +463,15 @@ // This is the number of leading zeroes a properly normalized float of type T // should have. - constexpr uint32_t NORMALIZED_LEADING_ZEROES = + constexpr int32_t NORMALIZED_LEADING_ZEROES = (sizeof(BitsType) * 8) - fputil::FloatProperties::mantissaWidth - 1; constexpr BitsType OVERFLOWED_MANTISSA = BitsType(1) << (fputil::FloatProperties::mantissaWidth + 1); // Normalization int32_t amountToShift = - NORMALIZED_LEADING_ZEROES - leadingZeroes(mantissa); + NORMALIZED_LEADING_ZEROES - + static_cast(leadingZeroes(mantissa)); if (amountToShift < 0) { mantissa <<= -amountToShift; } else { @@ -568,56 +569,43 @@ // The first loop fills the mantissa with as many digits as it can hold const BitsType BITSTYPE_MAX_DIV_BY_BASE = __llvm_libc::cpp::NumericLimits::max() / BASE; - while ((isdigit(*src) || *src == DECIMAL_POINT) && - mantissa < BITSTYPE_MAX_DIV_BY_BASE) { - if (*src == DECIMAL_POINT) { - if (afterDecimal) { - break; // this means that *src points to a second decimal point, ending - // the number. + while (true) { + if (isdigit(*src)) { + uint32_t digit = *src - '0'; + seenDigit = true; + + if (mantissa < BITSTYPE_MAX_DIV_BY_BASE) { + mantissa = (mantissa * BASE) + digit; + if (afterDecimal) { + --exponent; + } } else { - afterDecimal = true; - ++src; - continue; + if (digit > 0) + truncated = true; + + if (!afterDecimal) + ++exponent; } - } - uint32_t digit = *src - '0'; - mantissa = (mantissa * BASE) + digit; - seenDigit = true; - if (afterDecimal) { - --exponent; + ++src; + continue; } - - ++src; - } - - if (!seenDigit) - return false; - - // The second loop is to run through the remaining digits after we've filled - // the mantissa. - while (isdigit(*src) || *src == DECIMAL_POINT) { if (*src == DECIMAL_POINT) { if (afterDecimal) { break; // this means that *src points to a second decimal point, ending // the number. - } else { - afterDecimal = true; - ++src; - continue; } + afterDecimal = true; + ++src; + continue; } - uint32_t digit = *src - '0'; - - if (digit > 0) - truncated = true; - - if (!afterDecimal) - ++exponent; - - ++src; + // The character is neither a digit nor a decimal point. + break; } + if (!seenDigit) + return false; + if ((*src | 32) == EXPONENT_MARKER) { if (*(src + 1) == '+' || *(src + 1) == '-' || isdigit(*(src + 1))) { ++src; @@ -672,59 +660,44 @@ // The first loop fills the mantissa with as many digits as it can hold const BitsType BITSTYPE_MAX_DIV_BY_BASE = __llvm_libc::cpp::NumericLimits::max() / BASE; - while ((isalnum(*src) || *src == DECIMAL_POINT) && - mantissa < BITSTYPE_MAX_DIV_BY_BASE) { - if (*src == DECIMAL_POINT) { - if (afterDecimal) { - break; // this means that *src points to a second decimal point, ending - // the number. + while (true) { + if (isalnum(*src)) { + uint32_t digit = b36_char_to_int(*src); + if (digit >= BASE) { + seenDigit = false; + break; + } + seenDigit = true; + + if (mantissa < BITSTYPE_MAX_DIV_BY_BASE) { + mantissa = (mantissa * BASE) + digit; + if (afterDecimal) + --exponent; } else { - afterDecimal = true; - ++src; - continue; + if (digit > 0) + truncated = true; + if (!afterDecimal) + ++exponent; } + ++src; + continue; } - uint32_t digit = b36_char_to_int(*src); - if (digit >= BASE) - break; - - mantissa = (mantissa * BASE) + digit; - seenDigit = true; - if (afterDecimal) - --exponent; - - ++src; - } - - if (!seenDigit) - return false; - - // The second loop is to run through the remaining digits after we've filled - // the mantissa. - while (isalnum(*src) || *src == DECIMAL_POINT) { if (*src == DECIMAL_POINT) { if (afterDecimal) { break; // this means that *src points to a second decimal point, ending // the number. - } else { - afterDecimal = true; - ++src; - continue; } + afterDecimal = true; + ++src; + continue; } - uint32_t digit = b36_char_to_int(*src); - if (digit >= BASE) - break; - - if (digit > 0) - truncated = true; - - if (!afterDecimal) - ++exponent; - - ++src; + // The character is neither a hexadecimal digit nor a decimal point. + break; } + if (!seenDigit) + return false; + // Convert the exponent from having a base of 16 to having a base of 2. exponent *= 4;