mirror of
https://github.com/bolero-MURAKAMI/Sprout
synced 2025-08-03 12:49:50 +00:00
fix char literal implementation
This commit is contained in:
parent
773855410b
commit
897d1e25b6
18 changed files with 325 additions and 95 deletions
|
@ -14,6 +14,8 @@
|
|||
#include <sprout/limits.hpp>
|
||||
#include <sprout/iterator/operation.hpp>
|
||||
#include <sprout/ctype/ascii.hpp>
|
||||
#include <sprout/detail/char_literal.hpp>
|
||||
#include <sprout/detail/char_type_of_consecutive.hpp>
|
||||
|
||||
namespace sprout {
|
||||
namespace detail {
|
||||
|
@ -22,13 +24,15 @@ namespace sprout {
|
|||
template<typename IntType, typename NullTerminatedIterator>
|
||||
inline SPROUT_CONSTEXPR IntType
|
||||
ascii_to_int_impl(NullTerminatedIterator str, IntType val, bool negative) {
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type value_type;
|
||||
SPROUT_STATIC_ASSERT(sprout::detail::is_char_type_of_consecutive_digits<value_type>::value);
|
||||
return !sprout::ascii::isdigit(*str)
|
||||
? negative ? -val : val
|
||||
: val > (sprout::numeric_limits<IntType>::max() - (*str - static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('0')) - (negative ? 1 : 0)) / 10
|
||||
: val > (sprout::numeric_limits<IntType>::max() - (*str - SPROUT_CHAR_LITERAL('0', value_type)) - (negative ? 1 : 0)) / 10
|
||||
? (negative ? sprout::numeric_limits<IntType>::min() : sprout::numeric_limits<IntType>::max())
|
||||
: sprout::detail::ascii_to_int_impl<IntType>(
|
||||
sprout::next(str),
|
||||
val * 10 + (*str - static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('0')),
|
||||
val * 10 + (*str - SPROUT_CHAR_LITERAL('0', value_type)),
|
||||
negative
|
||||
)
|
||||
;
|
||||
|
@ -39,9 +43,10 @@ namespace sprout {
|
|||
IntType
|
||||
>::type
|
||||
ascii_to_int(NullTerminatedIterator str) {
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type value_type;
|
||||
return sprout::ascii::isspace(*str)
|
||||
? sprout::detail::ascii_to_int<IntType>(sprout::next(str))
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('+')
|
||||
: *str == SPROUT_CHAR_LITERAL('+', value_type)
|
||||
? sprout::detail::ascii_to_int_impl<IntType>(sprout::next(str), IntType(), false)
|
||||
: sprout::detail::ascii_to_int_impl<IntType>(str, IntType(), false)
|
||||
;
|
||||
|
@ -52,11 +57,12 @@ namespace sprout {
|
|||
IntType
|
||||
>::type
|
||||
ascii_to_int(NullTerminatedIterator str) {
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type value_type;
|
||||
return sprout::ascii::isspace(*str)
|
||||
? sprout::detail::ascii_to_int<IntType>(sprout::next(str))
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('-')
|
||||
: *str == SPROUT_CHAR_LITERAL('-', value_type)
|
||||
? sprout::detail::ascii_to_int_impl<IntType>(sprout::next(str), IntType(), true)
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('+')
|
||||
: *str == SPROUT_CHAR_LITERAL('+', value_type)
|
||||
? sprout::detail::ascii_to_int_impl<IntType>(sprout::next(str), IntType(), false)
|
||||
: sprout::detail::ascii_to_int_impl<IntType>(str, IntType(), false)
|
||||
;
|
||||
|
|
|
@ -16,6 +16,8 @@
|
|||
#include <sprout/limits.hpp>
|
||||
#include <sprout/iterator/operation.hpp>
|
||||
#include <sprout/ctype/ascii.hpp>
|
||||
#include <sprout/detail/char_literal.hpp>
|
||||
#include <sprout/detail/char_type_of_consecutive.hpp>
|
||||
|
||||
namespace sprout {
|
||||
namespace detail {
|
||||
|
@ -83,6 +85,7 @@ namespace sprout {
|
|||
)
|
||||
{
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
SPROUT_STATIC_ASSERT(sprout::detail::is_char_type_of_consecutive_digits<char_type>::value);
|
||||
return sprout::ascii::isdigit(*str) ? sprout::detail::str_to_float_impl_exponent_1<FloatType>(
|
||||
sprout::next(str),
|
||||
negative,
|
||||
|
@ -90,7 +93,7 @@ namespace sprout {
|
|||
num_digits,
|
||||
num_decimals,
|
||||
exponent,
|
||||
n * 10 + (*str - static_cast<char_type>('0'))
|
||||
n * 10 + (*str - SPROUT_CHAR_LITERAL('0', char_type))
|
||||
)
|
||||
: sprout::detail::str_to_float_impl_exponent_2<FloatType>(
|
||||
str,
|
||||
|
@ -114,8 +117,8 @@ namespace sprout {
|
|||
)
|
||||
{
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
return (*str == static_cast<char_type>('e') || *str == static_cast<char_type>('E'))
|
||||
? *sprout::next(str) == static_cast<char_type>('-')
|
||||
return (*str == SPROUT_CHAR_LITERAL('e', char_type) || *str == SPROUT_CHAR_LITERAL('E', char_type))
|
||||
? *sprout::next(str) == SPROUT_CHAR_LITERAL('-', char_type)
|
||||
? sprout::detail::str_to_float_impl_exponent_1<FloatType>(
|
||||
sprout::next(str, 2),
|
||||
true,
|
||||
|
@ -176,10 +179,11 @@ namespace sprout {
|
|||
)
|
||||
{
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
SPROUT_STATIC_ASSERT(sprout::detail::is_char_type_of_consecutive_digits<char_type>::value);
|
||||
return sprout::ascii::isdigit(*str) ? sprout::detail::str_to_float_impl_decimal<FloatType>(
|
||||
sprout::next(str),
|
||||
negative,
|
||||
number * 10 + (*str - static_cast<char_type>('0')),
|
||||
number * 10 + (*str - SPROUT_CHAR_LITERAL('0', char_type)),
|
||||
num_digits + 1,
|
||||
num_decimals + 1,
|
||||
exponent
|
||||
|
@ -205,13 +209,14 @@ namespace sprout {
|
|||
)
|
||||
{
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
SPROUT_STATIC_ASSERT(sprout::detail::is_char_type_of_consecutive_digits<char_type>::value);
|
||||
return sprout::ascii::isdigit(*str) ? sprout::detail::str_to_float_impl<FloatType>(
|
||||
sprout::next(str),
|
||||
negative,
|
||||
number * 10 + (*str - static_cast<char_type>('0')),
|
||||
number * 10 + (*str - SPROUT_CHAR_LITERAL('0', char_type)),
|
||||
num_digits + 1
|
||||
)
|
||||
: *str == static_cast<char_type>('.') ? sprout::detail::str_to_float_impl_decimal<FloatType>(
|
||||
: *str == SPROUT_CHAR_LITERAL('.', char_type) ? sprout::detail::str_to_float_impl_decimal<FloatType>(
|
||||
sprout::next(str),
|
||||
negative,
|
||||
number,
|
||||
|
@ -228,11 +233,12 @@ namespace sprout {
|
|||
template<typename FloatType, typename NullTerminatedIterator>
|
||||
inline SPROUT_CONSTEXPR FloatType
|
||||
str_to_float(NullTerminatedIterator str) {
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
return sprout::ascii::isspace(*str)
|
||||
? sprout::detail::str_to_float<FloatType>(sprout::next(str))
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('-')
|
||||
: *str == SPROUT_CHAR_LITERAL('-', char_type)
|
||||
? sprout::detail::str_to_float_impl<FloatType>(sprout::next(str), true)
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('+')
|
||||
: *str == SPROUT_CHAR_LITERAL('+', char_type)
|
||||
? sprout::detail::str_to_float_impl<FloatType>(sprout::next(str), false)
|
||||
: sprout::detail::str_to_float_impl<FloatType>(str, false)
|
||||
;
|
||||
|
|
|
@ -15,6 +15,7 @@
|
|||
#include <sprout/limits.hpp>
|
||||
#include <sprout/iterator/operation.hpp>
|
||||
#include <sprout/ctype/ascii.hpp>
|
||||
#include <sprout/detail/char_literal.hpp>
|
||||
#include <sprout/detail/char_conversion.hpp>
|
||||
#if !defined(_MSC_VER)
|
||||
# include <cinttypes>
|
||||
|
@ -42,9 +43,10 @@ namespace sprout {
|
|||
template<typename IntType, typename NullTerminatedIterator>
|
||||
inline SPROUT_CONSTEXPR IntType
|
||||
str_to_int_impl(NullTerminatedIterator str, int base, bool negative) {
|
||||
return *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('0')
|
||||
? *sprout::next(str) == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('x')
|
||||
|| *sprout::next(str) == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('X')
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
return *str == SPROUT_CHAR_LITERAL('0', char_type)
|
||||
? *sprout::next(str) == SPROUT_CHAR_LITERAL('x', char_type)
|
||||
|| *sprout::next(str) == SPROUT_CHAR_LITERAL('X', char_type)
|
||||
? sprout::detail::str_to_int_impl_1<IntType>(
|
||||
sprout::next(str, 2),
|
||||
base ? base : 16,
|
||||
|
@ -74,9 +76,10 @@ namespace sprout {
|
|||
IntType
|
||||
>::type
|
||||
str_to_int(NullTerminatedIterator str, int base) {
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
return sprout::ascii::isspace(*str)
|
||||
? sprout::detail::str_to_int<IntType>(sprout::next(str), base)
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('+')
|
||||
: *str == SPROUT_CHAR_LITERAL('+', char_type)
|
||||
? sprout::detail::str_to_int_impl<IntType>(sprout::next(str), base, false)
|
||||
: sprout::detail::str_to_int_impl<IntType>(str, base, false)
|
||||
;
|
||||
|
@ -87,11 +90,12 @@ namespace sprout {
|
|||
IntType
|
||||
>::type
|
||||
str_to_int(NullTerminatedIterator str, int base) {
|
||||
typedef typename std::iterator_traits<NullTerminatedIterator>::value_type char_type;
|
||||
return sprout::ascii::isspace(*str)
|
||||
? sprout::detail::str_to_int<IntType>(sprout::next(str), base)
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('-')
|
||||
: *str == SPROUT_CHAR_LITERAL('-', char_type)
|
||||
? sprout::detail::str_to_int_impl<IntType>(sprout::next(str), base, true)
|
||||
: *str == static_cast<typename std::iterator_traits<NullTerminatedIterator>::value_type>('+')
|
||||
: *str == SPROUT_CHAR_LITERAL('+', char_type)
|
||||
? sprout::detail::str_to_int_impl<IntType>(sprout::next(str), base, false)
|
||||
: sprout::detail::str_to_int_impl<IntType>(str, base, false)
|
||||
;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue