mirror of
https://github.com/php/php-src.git
synced 2025-08-15 21:48:51 +02:00
generalize the zend_long stuff
This commit is contained in:
parent
59848e3fbb
commit
c429c74be9
3 changed files with 23 additions and 25 deletions
|
@ -61,12 +61,12 @@ typedef off_t zend_off_t;
|
||||||
# endif
|
# endif
|
||||||
# define SIZEOF_ZEND_LONG 8
|
# define SIZEOF_ZEND_LONG 8
|
||||||
#else
|
#else
|
||||||
typedef long zend_long;
|
typedef int32_t zend_long;
|
||||||
typedef unsigned long zend_ulong;
|
typedef uint32_t zend_ulong;
|
||||||
typedef long zend_off_t;
|
typedef int32_t zend_off_t;
|
||||||
# define ZEND_LONG_MAX LONG_MAX
|
# define ZEND_LONG_MAX INT32_MAX
|
||||||
# define ZEND_LONG_MIN LONG_MIN
|
# define ZEND_LONG_MIN INT32_MIN
|
||||||
# define ZEND_ULONG_MAX ULONG_MAX
|
# define ZEND_ULONG_MAX UINT32_MAX
|
||||||
# define Z_L(i) i##L
|
# define Z_L(i) i##L
|
||||||
# define Z_UL(i) i##UL
|
# define Z_UL(i) i##UL
|
||||||
# define SIZEOF_ZEND_LONG SIZEOF_LONG
|
# define SIZEOF_ZEND_LONG SIZEOF_LONG
|
||||||
|
@ -77,31 +77,27 @@ typedef long zend_off_t;
|
||||||
#define ZEND_LTOA_BUF_LEN 65
|
#define ZEND_LTOA_BUF_LEN 65
|
||||||
|
|
||||||
#ifdef ZEND_ENABLE_INT64
|
#ifdef ZEND_ENABLE_INT64
|
||||||
|
# define ZEND_LONG_FMT "%" PRId64
|
||||||
|
# define ZEND_ULONG_FMT "%" PRIu64
|
||||||
|
# define ZEND_LONG_FMT_SPEC PRId64
|
||||||
|
# define ZEND_ULONG_FMT_SPEC PRIu64
|
||||||
# ifdef PHP_WIN32
|
# ifdef PHP_WIN32
|
||||||
# define ZEND_LTOA(i, s, len) _i64toa_s((i), (s), (len), 10)
|
# define ZEND_LTOA(i, s, len) _i64toa_s((i), (s), (len), 10)
|
||||||
# define ZEND_ATOL(i, s) i = _atoi64((s))
|
# define ZEND_ATOL(i, s) i = _atoi64((s))
|
||||||
# define ZEND_STRTOL(s0, s1, base) _strtoi64((s0), (s1), (base))
|
# define ZEND_STRTOL(s0, s1, base) _strtoi64((s0), (s1), (base))
|
||||||
# define ZEND_STRTOUL(s0, s1, base) _strtoui64((s0), (s1), (base))
|
# define ZEND_STRTOUL(s0, s1, base) _strtoui64((s0), (s1), (base))
|
||||||
# define ZEND_LONG_FMT "%I64d"
|
|
||||||
# define ZEND_ULONG_FMT "%I64u"
|
|
||||||
# define ZEND_LONG_FMT_SPEC "I64d"
|
|
||||||
# define ZEND_ULONG_FMT_SPEC "I64u"
|
|
||||||
# define ZEND_STRTOL_PTR _strtoi64
|
# define ZEND_STRTOL_PTR _strtoi64
|
||||||
# define ZEND_STRTOUL_PTR _strtoui64
|
# define ZEND_STRTOUL_PTR _strtoui64
|
||||||
# define ZEND_ABS _abs64
|
# define ZEND_ABS _abs64
|
||||||
# else
|
# else
|
||||||
# define ZEND_LTOA(i, s, len) \
|
# define ZEND_LTOA(i, s, len) \
|
||||||
do { \
|
do { \
|
||||||
int st = snprintf((s), (len), "%lld", (i)); \
|
int st = snprintf((s), (len), ZEND_LONG_FMT, (i)); \
|
||||||
(s)[st] = '\0'; \
|
(s)[st] = '\0'; \
|
||||||
} while (0)
|
} while (0)
|
||||||
# define ZEND_ATOL(i, s) (i) = atoll((s))
|
# define ZEND_ATOL(i, s) (i) = atoll((s))
|
||||||
# define ZEND_STRTOL(s0, s1, base) strtoll((s0), (s1), (base))
|
# define ZEND_STRTOL(s0, s1, base) strtoll((s0), (s1), (base))
|
||||||
# define ZEND_STRTOUL(s0, s1, base) strtoull((s0), (s1), (base))
|
# define ZEND_STRTOUL(s0, s1, base) strtoull((s0), (s1), (base))
|
||||||
# define ZEND_LONG_FMT "%" PRId64
|
|
||||||
# define ZEND_ULONG_FMT "%" PRIu64
|
|
||||||
# define ZEND_LONG_FMT_SPEC PRId64
|
|
||||||
# define ZEND_ULONG_FMT_SPEC PRIu64
|
|
||||||
# define ZEND_STRTOL_PTR strtoll
|
# define ZEND_STRTOL_PTR strtoll
|
||||||
# define ZEND_STRTOUL_PTR strtoull
|
# define ZEND_STRTOUL_PTR strtoull
|
||||||
# define ZEND_ABS llabs
|
# define ZEND_ABS llabs
|
||||||
|
@ -109,21 +105,21 @@ typedef long zend_off_t;
|
||||||
#else
|
#else
|
||||||
# define ZEND_STRTOL(s0, s1, base) strtol((s0), (s1), (base))
|
# define ZEND_STRTOL(s0, s1, base) strtol((s0), (s1), (base))
|
||||||
# define ZEND_STRTOUL(s0, s1, base) strtoul((s0), (s1), (base))
|
# define ZEND_STRTOUL(s0, s1, base) strtoul((s0), (s1), (base))
|
||||||
|
# define ZEND_LONG_FMT "%" PRId32
|
||||||
|
# define ZEND_ULONG_FMT "%" PRIu32
|
||||||
|
# define ZEND_LONG_FMT_SPEC PRId32
|
||||||
|
# define ZEND_ULONG_FMT_SPEC PRIu32
|
||||||
# ifdef PHP_WIN32
|
# ifdef PHP_WIN32
|
||||||
# define ZEND_LTOA(i, s, len) _ltoa_s((i), (s), (len), 10)
|
# define ZEND_LTOA(i, s, len) _ltoa_s((i), (s), (len), 10)
|
||||||
# define ZEND_ATOL(i, s) i = atol((s))
|
# define ZEND_ATOL(i, s) i = atol((s))
|
||||||
# else
|
# else
|
||||||
# define ZEND_LTOA(i, s, len) \
|
# define ZEND_LTOA(i, s, len) \
|
||||||
do { \
|
do { \
|
||||||
int st = snprintf((s), (len), "%ld", (i)); \
|
int st = snprintf((s), (len), ZEND_LONG_FMT, (i)); \
|
||||||
(s)[st] = '\0'; \
|
(s)[st] = '\0'; \
|
||||||
} while (0)
|
} while (0)
|
||||||
# define ZEND_ATOL(i, s) (i) = atol((s))
|
# define ZEND_ATOL(i, s) (i) = atol((s))
|
||||||
# endif
|
# endif
|
||||||
# define ZEND_LONG_FMT "%ld"
|
|
||||||
# define ZEND_ULONG_FMT "%lu"
|
|
||||||
# define ZEND_LONG_FMT_SPEC "ld"
|
|
||||||
# define ZEND_ULONG_FMT_SPEC "lu"
|
|
||||||
# define ZEND_STRTOL_PTR strtol
|
# define ZEND_STRTOL_PTR strtol
|
||||||
# define ZEND_STRTOUL_PTR strtoul
|
# define ZEND_STRTOUL_PTR strtoul
|
||||||
# define ZEND_ABS abs
|
# define ZEND_ABS abs
|
||||||
|
|
|
@ -71,12 +71,13 @@ typedef unsigned long long zend_ulong64;
|
||||||
# undef HAVE_ZEND_LONG64
|
# undef HAVE_ZEND_LONG64
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _WIN64
|
/* XXX this won't work on X32 platform */
|
||||||
typedef __int64 zend_intptr_t;
|
#ifdef ZEND_ENABLE_INT64
|
||||||
typedef unsigned __int64 zend_uintptr_t;
|
typedef int64_t zend_intptr_t;
|
||||||
|
typedef uint64_t zend_uintptr_t;
|
||||||
#else
|
#else
|
||||||
typedef long zend_intptr_t;
|
typedef int32_t zend_intptr_t;
|
||||||
typedef unsigned long zend_uintptr_t;
|
typedef uint32_t zend_uintptr_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef struct _zend_object_handlers zend_object_handlers;
|
typedef struct _zend_object_handlers zend_object_handlers;
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
# if !defined(_STDINT)
|
# if !defined(_STDINT)
|
||||||
# define _STDINT
|
# define _STDINT
|
||||||
# include "win32/php_stdint.h"
|
# include "win32/php_stdint.h"
|
||||||
|
# include "win32/php_inttypes.h"
|
||||||
# endif
|
# endif
|
||||||
# define HAVE_INT8_T 1
|
# define HAVE_INT8_T 1
|
||||||
# define HAVE_UINT8_T 1
|
# define HAVE_UINT8_T 1
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue