+2014-11-30 Keith Marshall <keithmarshall@users.sourceforge.net>
+
+ More JMPSTUB rationalization of inline functions.
+
+ * include/stdlib.h (_Exit, atoll, lltoa, ulltoa, wtoll, lltow)
+ (ulltow): Add __JMPSTUB__ declarations; each is REMAPPED to its
+ appropriate MSVCRT.DLL equivalent entry point.
+
+ * mingwex/_Exit.c: File is now redundant; delete it.
+ * mingwex/atoll.c mingwex/lltoa.c mingwex/ulltoa: Likewise.
+ * mingwex/wtoll.c mingwex/lltow.c mingwex/ulltow: Likewise.
+
+ * Makefile.in (jmpstub_awk_script): Add support for...
+ [__JMPSTUB__((REMAPPED))]: ...this stub function attribute.
+ (libmingwex.a): Remove dependencies on deleted files, namely...
+ (_Exit.$OBJEXT, atoll.$OBJEXT, lltoa.$OBJEXT, ulltoa.$OBJEXT)
+ (wtoll.$OBJEXT, lltow.$OBJEXT, ulltow.$OBJEXT): ...these.
+
2014-11-29 Keith Marshall <keithmarshall@users.sourceforge.net>
Correct omission of complex conjugate functions from libmingwex.a
libmingwex.a: $(addsuffix .$(OBJEXT), tdelete tfind tsearch twalk)
-libmingwex.a: $(addsuffix .$(OBJEXT), _Exit atoll lltoa lltow \
- ulltoa ulltow wtoll)
-
libmingwex.a: gettimeofday.$(OBJEXT)
libmingwex.a: $(addsuffix .$(OBJEXT), dirent wdirent dlfcn)
FUNCTION = gensub( ".*[ ,(:]FUNCTION *= *"symbol".*", "\\1", 1 ); \
OBJNAME = gensub( "_*(.*)_*", "\\1", 1, FUNCTION )".jmpstub.$$(OBJEXT)"; \
OBJNAME_CFLAGS = "-D FUNCTION="FUNCTION; \
+ if( match( $$0, ".*[ ,(:]REMAPPED *= *"symbol, alias ) ) \
+ OBJNAME_CFLAGS = OBJNAME_CFLAGS" -D REMAPPED="alias[1]; \
printf fmt, LIB, OBJNAME, OBJNAME, OBJNAME_CFLAGS; \
} \
END { \
#define __need_size_t
#define __need_wchar_t
#define __need_NULL
+
#ifndef RC_INVOKED
#include <stddef.h>
#endif /* RC_INVOKED */
#ifndef RC_INVOKED
-#ifdef __cplusplus
-extern "C" {
-#endif
+_BEGIN_C_DECLS
#if !defined (__STRICT_ANSI__)
/* C99 name for _exit */
void __cdecl __MINGW_NOTHROW _Exit(int) __MINGW_ATTRIB_NORETURN;
#if !defined __NO_INLINE__ && !defined __STRICT_ANSI__
-__CRT_INLINE void __cdecl __MINGW_NOTHROW _Exit(int __status)
- { _exit (__status); }
+__CRT_INLINE __JMPSTUB__(( FUNCTION = _Exit, REMAPPED = _exit ))
+void __cdecl __MINGW_NOTHROW _Exit( int __status ){ _exit (__status); }
#endif
typedef struct { long long quot, rem; } lldiv_t;
long long __cdecl __MINGW_NOTHROW llabs(long long);
#ifndef __NO_INLINE__
-__CRT_INLINE long long __cdecl __MINGW_NOTHROW llabs(long long _j)
- {return (_j >= 0 ? _j : -_j);}
+__CRT_INLINE
+/* No JMPSTUB or LIBIMPL reference here -- we provide a free-standing
+ * implementation, along with imaxabs(), in mingwex/imaxabs.c
+ */
+long long __cdecl __MINGW_NOTHROW llabs( long long __j )
+{ return __j >= 0 ? __j : -__j; }
#endif
long long __cdecl __MINGW_NOTHROW strtoll (const char* __restrict__, char** __restrict, int);
wchar_t* __cdecl __MINGW_NOTHROW lltow (long long, wchar_t *, int);
wchar_t* __cdecl __MINGW_NOTHROW ulltow (unsigned long long, wchar_t *, int);
- /* inline using non-ansi functions */
-#ifndef __NO_INLINE__
-__CRT_INLINE long long __cdecl __MINGW_NOTHROW atoll (const char * _c)
- { return _atoi64 (_c); }
-__CRT_INLINE char* __cdecl __MINGW_NOTHROW lltoa (long long _n, char * _c, int _i)
- { return _i64toa (_n, _c, _i); }
-__CRT_INLINE char* __cdecl __MINGW_NOTHROW ulltoa (unsigned long long _n, char * _c, int _i)
- { return _ui64toa (_n, _c, _i); }
-__CRT_INLINE long long __cdecl __MINGW_NOTHROW wtoll (const wchar_t * _w)
- { return _wtoi64 (_w); }
-__CRT_INLINE wchar_t* __cdecl __MINGW_NOTHROW lltow (long long _n, wchar_t * _w, int _i)
- { return _i64tow (_n, _w, _i); }
-__CRT_INLINE wchar_t* __cdecl __MINGW_NOTHROW ulltow (unsigned long long _n, wchar_t * _w, int _i)
- { return _ui64tow (_n, _w, _i); }
+#ifndef __NO_INLINE__ /* inline support for non-ansi functions */
+
+__CRT_INLINE __JMPSTUB__(( FUNCTION = atoll, REMAPPED = _atoi64 ))
+long long __cdecl __MINGW_NOTHROW atoll (const char * _c){ return _atoi64 (_c); }
+
+__CRT_INLINE __JMPSTUB__(( FUNCTION = lltoa, REMAPPED = _i64toa ))
+char* __cdecl __MINGW_NOTHROW lltoa (long long _n, char * _c, int _i)
+{ return _i64toa (_n, _c, _i); }
+
+__CRT_INLINE __JMPSTUB__(( FUNCTION = ulltoa, REMAPPED = _ui64toa ))
+char* __cdecl __MINGW_NOTHROW ulltoa (unsigned long long _n, char * _c, int _i)
+{ return _ui64toa (_n, _c, _i); }
+
+__CRT_INLINE __JMPSTUB__(( FUNCTION = wtoll, REMAPPED = _wtoi64 ))
+long long __cdecl __MINGW_NOTHROW wtoll (const wchar_t * _w){ return _wtoi64 (_w); }
+
+__CRT_INLINE __JMPSTUB__(( FUNCTION = lltow, REMAPPED = _i64tow ))
+wchar_t* __cdecl __MINGW_NOTHROW lltow (long long _n, wchar_t * _w, int _i)
+{ return _i64tow (_n, _w, _i); }
+
+__CRT_INLINE __JMPSTUB__(( FUNCTION = ulltow, REMAPPED = _ui64tow ))
+wchar_t* __cdecl __MINGW_NOTHROW ulltow (unsigned long long _n, wchar_t * _w, int _i)
+{ return _ui64tow (_n, _w, _i); }
+
#endif /* (__NO_INLINE__) */
#endif /* (__STRICT_ANSI__) */
#endif /* __MSVCRT__ */
-
#endif /* !__NO_ISOCEXT */
-#ifdef __cplusplus
-}
#endif
-#endif /* Not RC_INVOKED */
+_END_C_DECLS
+#endif /* Not RC_INVOKED */
#endif /* Not _STDLIB_H_ */
-