mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
If the system has 64 bit "long", then "long long" does not add new
functionality. The existing code takes advantage of this when "typedef"ing 'longlong' in 'my_global.h'. This holds for Alpha CPUs. If the compiler then has prototypes for C99 functions 'strtoll()' and 'strtoull()' but no implementation, the existing code in 'strtoull.c' collides with that prototype. These collisions are avoided now. (backport from 4.1) include/m_string.h: Extend the "fake" approach from 'strtoull()' onto 'strtoll()' (backport from 4.1). strings/strto.c: Ensure that calling file has included necessary headers, as these are needed at the upper level already (backport from 4.1). strings/strtol.c: Cleanup/alignment with the "long long" functions. strings/strtoll.c: When "long" is 64 bit already, system function 'strtol()' can be used. Header files 'my_global.h' and 'm_string.h' will manage that, if they are included early enough (backport from 4.1). strings/strtoul.c: Cleanup/alignment with the "long long" functions. strings/strtoull.c: When "long" is 64 bit already, system function 'strtoul()' can be used. Header files 'my_global.h' and 'm_string.h' will manage that, if they are included early enough (backport from 4.1).
This commit is contained in:
@ -238,6 +238,9 @@ extern char *str2int(const char *src,int radix,long lower,long upper,
|
|||||||
#ifndef HAVE_STRTOULL
|
#ifndef HAVE_STRTOULL
|
||||||
#define HAVE_STRTOULL
|
#define HAVE_STRTOULL
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef HAVE_STRTOLL
|
||||||
|
#define HAVE_STRTOLL
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#ifdef HAVE_LONG_LONG
|
#ifdef HAVE_LONG_LONG
|
||||||
extern char *longlong2str(longlong val,char *dst,int radix);
|
extern char *longlong2str(longlong val,char *dst,int radix);
|
||||||
|
@ -35,8 +35,12 @@
|
|||||||
it can be compiled with the UNSIGNED and/or LONGLONG flag set
|
it can be compiled with the UNSIGNED and/or LONGLONG flag set
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <my_global.h>
|
|
||||||
#include "m_string.h"
|
#if !defined(_global_h) || !defined(_m_string_h)
|
||||||
|
# error Calling file must include 'my_global.h' and 'm_string.h'
|
||||||
|
/* see 'strtoll.c' and 'strtoull.c' for the reasons */
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "m_ctype.h"
|
#include "m_ctype.h"
|
||||||
#include "my_sys.h" /* defines errno */
|
#include "my_sys.h" /* defines errno */
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
@ -14,9 +14,16 @@
|
|||||||
along with this program; if not, write to the Free Software
|
along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
||||||
|
|
||||||
/* This defines strtol() if neaded */
|
/* This implements strtol() if needed */
|
||||||
|
|
||||||
|
/*
|
||||||
|
These includes are mandatory because they check for type sizes and
|
||||||
|
functions, especially they handle tricks for Tru64 where 'long' is
|
||||||
|
64 bit already and our 'longlong' is just a 'long'.
|
||||||
|
*/
|
||||||
#include <my_global.h>
|
#include <my_global.h>
|
||||||
|
#include <m_string.h>
|
||||||
|
|
||||||
#if !defined(MSDOS) && !defined(HAVE_STRTOL) && !defined(__WIN__)
|
#if !defined(MSDOS) && !defined(HAVE_STRTOL) && !defined(__WIN__)
|
||||||
#include "strto.c"
|
#include "strto.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -14,11 +14,20 @@
|
|||||||
along with this program; if not, write to the Free Software
|
along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
||||||
|
|
||||||
/* This is defines strtoll() if neaded */
|
/* This implements strtoll() if needed */
|
||||||
|
|
||||||
#define strtoll glob_strtoll /* Fix for True64 */
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
These includes are mandatory because they check for type sizes and
|
||||||
|
functions, especially they handle tricks for Tru64 where 'long' is
|
||||||
|
64 bit already and our 'longlong' is just a 'long'.
|
||||||
|
This solves a problem on Tru64 where the C99 compiler has a prototype
|
||||||
|
for 'strtoll()' but no implementation, see "6.1 New C99 library functions"
|
||||||
|
in file '/usr/share/doclib/cc.dtk/release_notes.txt'.
|
||||||
|
*/
|
||||||
#include <my_global.h>
|
#include <my_global.h>
|
||||||
|
#include <m_string.h>
|
||||||
|
|
||||||
#if !defined(HAVE_STRTOLL) && defined(HAVE_LONG_LONG)
|
#if !defined(HAVE_STRTOLL) && defined(HAVE_LONG_LONG)
|
||||||
#define USE_LONGLONG
|
#define USE_LONGLONG
|
||||||
#include "strto.c"
|
#include "strto.c"
|
||||||
|
@ -14,9 +14,16 @@
|
|||||||
along with this program; if not, write to the Free Software
|
along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
||||||
|
|
||||||
/* This is defines strtoul() if neaded */
|
/* This implements strtoul() if needed */
|
||||||
|
|
||||||
|
/*
|
||||||
|
These includes are mandatory because they check for type sizes and
|
||||||
|
functions, especially they handle tricks for Tru64 where 'long' is
|
||||||
|
64 bit already and our 'longlong' is just a 'long'.
|
||||||
|
*/
|
||||||
#include <my_global.h>
|
#include <my_global.h>
|
||||||
|
#include <m_string.h>
|
||||||
|
|
||||||
#if !defined(MSDOS) && !defined(HAVE_STRTOUL)
|
#if !defined(MSDOS) && !defined(HAVE_STRTOUL)
|
||||||
#define USE_UNSIGNED
|
#define USE_UNSIGNED
|
||||||
#include "strto.c"
|
#include "strto.c"
|
||||||
|
@ -14,9 +14,20 @@
|
|||||||
along with this program; if not, write to the Free Software
|
along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
||||||
|
|
||||||
/* This is defines strtoull() */
|
/* This implements strtoull() if needed */
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
These includes are mandatory because they check for type sizes and
|
||||||
|
functions, especially they handle tricks for Tru64 where 'long' is
|
||||||
|
64 bit already and our 'longlong' is just a 'long'.
|
||||||
|
This solves a problem on Tru64 where the C99 compiler has a prototype
|
||||||
|
for 'strtoull()' but no implementation, see "6.1 New C99 library functions"
|
||||||
|
in file '/usr/share/doclib/cc.dtk/release_notes.txt'.
|
||||||
|
*/
|
||||||
#include <my_global.h>
|
#include <my_global.h>
|
||||||
|
#include <m_string.h>
|
||||||
|
|
||||||
#if !defined(HAVE_STRTOULL) && defined(HAVE_LONG_LONG)
|
#if !defined(HAVE_STRTOULL) && defined(HAVE_LONG_LONG)
|
||||||
#define USE_UNSIGNED
|
#define USE_UNSIGNED
|
||||||
#define USE_LONGLONG
|
#define USE_LONGLONG
|
||||||
|
Reference in New Issue
Block a user