Add more compat code for non GNU environments
Signed-off-by: Dan Fandrich <dan@coneharvesters.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
95a036e125
commit
fe4e23f9de
7
TODO
7
TODO
@ -6,11 +6,8 @@ do one of these bounce an email off the person it's listed under to see if they
|
|||||||
have any suggestions how they plan to go about it, and to minimize conflicts
|
have any suggestions how they plan to go about it, and to minimize conflicts
|
||||||
between your work and theirs. But otherwise, all of these are fair game.
|
between your work and theirs. But otherwise, all of these are fair game.
|
||||||
|
|
||||||
Rob Landley suggested these:
|
Rob Landley suggested this:
|
||||||
Add a libbb/platform.c
|
Implement bb_realpath() that can handle NULL on non-glibc.
|
||||||
Implement fdprintf() for platforms that haven't got one.
|
|
||||||
Implement bb_realpath() that can handle NULL on non-glibc.
|
|
||||||
Cleanup bb_asprintf()
|
|
||||||
|
|
||||||
Remove obsolete _() wrapper crud for internationalization we don't do.
|
Remove obsolete _() wrapper crud for internationalization we don't do.
|
||||||
Figure out where we need utf8 support, and add it.
|
Figure out where we need utf8 support, and add it.
|
||||||
|
@ -11,7 +11,12 @@
|
|||||||
* true will #undef them below.
|
* true will #undef them below.
|
||||||
*/
|
*/
|
||||||
#define HAVE_FDPRINTF 1
|
#define HAVE_FDPRINTF 1
|
||||||
|
#define HAVE_MEMRCHR 1
|
||||||
|
#define HAVE_MKDTEMP 1
|
||||||
|
#define HAVE_SETBIT 1
|
||||||
|
#define HAVE_STRCASESTR 1
|
||||||
#define HAVE_STRCHRNUL 1
|
#define HAVE_STRCHRNUL 1
|
||||||
|
#define HAVE_STRSIGNAL 1
|
||||||
#define HAVE_VASPRINTF 1
|
#define HAVE_VASPRINTF 1
|
||||||
|
|
||||||
/* Convenience macros to test the version of gcc. */
|
/* Convenience macros to test the version of gcc. */
|
||||||
@ -335,17 +340,22 @@ typedef unsigned smalluint;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__dietlibc__)
|
#if defined(__dietlibc__)
|
||||||
#undef HAVE_STRCHRNUL
|
# undef HAVE_STRCHRNUL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__WATCOMC__)
|
#if defined(__WATCOMC__)
|
||||||
#undef HAVE_FDPRINTF
|
# undef HAVE_FDPRINTF
|
||||||
#undef HAVE_STRCHRNUL
|
# undef HAVE_MEMRCHR
|
||||||
#undef HAVE_VASPRINTF
|
# undef HAVE_MKDTEMP
|
||||||
|
# undef HAVE_SETBIT
|
||||||
|
# undef HAVE_STRCASESTR
|
||||||
|
# undef HAVE_STRCHRNUL
|
||||||
|
# undef HAVE_STRSIGNAL
|
||||||
|
# undef HAVE_VASPRINTF
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__FreeBSD__)
|
#if defined(__FreeBSD__)
|
||||||
#undef HAVE_STRCHRNUL
|
# undef HAVE_STRCHRNUL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -353,16 +363,38 @@ typedef unsigned smalluint;
|
|||||||
* These must come after all the HAVE_* macros are defined (or not)
|
* These must come after all the HAVE_* macros are defined (or not)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef HAVE_FDPRINTF
|
||||||
|
extern int fdprintf(int fd, const char *format, ...);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_MEMRCHR
|
||||||
|
extern void *memrchr(const void *s, int c, size_t n) FAST_FUNC;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_MKDTEMP
|
||||||
|
extern char *mkdtemp(char *template) FAST_FUNC;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_SETBIT
|
||||||
|
# define setbit(a, b) ((a)[(b) >> 3] |= 1 << ((b) & 7))
|
||||||
|
# define clrbit(a, b) ((a)[(b) >> 3] &= ~(1 << ((b) & 7)))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_STRCASESTR
|
||||||
|
extern char *strcasestr(const char *s, const char *pattern) FAST_FUNC;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef HAVE_STRCHRNUL
|
#ifndef HAVE_STRCHRNUL
|
||||||
extern char *strchrnul(const char *s, int c) FAST_FUNC;
|
extern char *strchrnul(const char *s, int c) FAST_FUNC;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_STRSIGNAL
|
||||||
|
/* Not exactly the same: instead of "Stopped" it shows "STOP" etc */
|
||||||
|
# define strsignal(sig) get_signame(sig)
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef HAVE_VASPRINTF
|
#ifndef HAVE_VASPRINTF
|
||||||
extern int vasprintf(char **string_ptr, const char *format, va_list p) FAST_FUNC;
|
extern int vasprintf(char **string_ptr, const char *format, va_list p) FAST_FUNC;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef HAVE_FDPRINTF
|
|
||||||
extern int fdprintf(int fd, const char *format, ...);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -6,13 +6,13 @@
|
|||||||
*
|
*
|
||||||
* Licensed under the GPL version 2, see the file LICENSE in this tarball.
|
* Licensed under the GPL version 2, see the file LICENSE in this tarball.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "libbb.h"
|
#include "libbb.h"
|
||||||
|
|
||||||
#ifndef HAVE_STRCHRNUL
|
#ifndef HAVE_STRCHRNUL
|
||||||
char * FAST_FUNC strchrnul(const char *s, int c)
|
char* FAST_FUNC strchrnul(const char *s, int c)
|
||||||
{
|
{
|
||||||
while (*s && *s != c) ++s;
|
while (*s != '\0' && *s != c)
|
||||||
|
s++;
|
||||||
return (char*)s;
|
return (char*)s;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -22,15 +22,19 @@ int FAST_FUNC vasprintf(char **string_ptr, const char *format, va_list p)
|
|||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
va_list p2;
|
va_list p2;
|
||||||
|
char buf[128];
|
||||||
|
|
||||||
va_copy(p2, p);
|
va_copy(p2, p);
|
||||||
r = vsnprintf(NULL, 0, format, p);
|
r = vsnprintf(buf, 128, format, p);
|
||||||
va_end(p);
|
va_end(p);
|
||||||
|
|
||||||
|
if (r < 128) {
|
||||||
|
va_end(p2);
|
||||||
|
return xstrdup(buf);
|
||||||
|
}
|
||||||
|
|
||||||
*string_ptr = xmalloc(r+1);
|
*string_ptr = xmalloc(r+1);
|
||||||
if (!*string_ptr)
|
r = vsnprintf(*string_ptr, r+1, format, p2);
|
||||||
r = -1;
|
|
||||||
else
|
|
||||||
r = vsnprintf(*string_ptr, r+1, format, p2);
|
|
||||||
va_end(p2);
|
va_end(p2);
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
@ -38,6 +42,7 @@ int FAST_FUNC vasprintf(char **string_ptr, const char *format, va_list p)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef HAVE_FDPRINTF
|
#ifndef HAVE_FDPRINTF
|
||||||
|
/* dprintf is now actually part of POSIX.1, but was only added in 2008 */
|
||||||
int fdprintf(int fd, const char *format, ...)
|
int fdprintf(int fd, const char *format, ...)
|
||||||
{
|
{
|
||||||
va_list p;
|
va_list p;
|
||||||
@ -55,3 +60,49 @@ int fdprintf(int fd, const char *format, ...)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_MEMRCHR
|
||||||
|
/* Copyright (C) 2005 Free Software Foundation, Inc.
|
||||||
|
* memrchr() is a GNU function that might not be available everywhere.
|
||||||
|
* It's basically the inverse of memchr() - search backwards in a
|
||||||
|
* memory block for a particular character.
|
||||||
|
*/
|
||||||
|
void* FAST_FUNC memrchr(const void *s, int c, size_t n)
|
||||||
|
{
|
||||||
|
const char *start = s, *end = s;
|
||||||
|
|
||||||
|
end += n - 1;
|
||||||
|
|
||||||
|
while (end >= start) {
|
||||||
|
if (*end == (char)c)
|
||||||
|
return (void *) end;
|
||||||
|
end--;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_MKDTEMP
|
||||||
|
/* This is now actually part of POSIX.1, but was only added in 2008 */
|
||||||
|
char* FAST_FUNC mkdtemp(char *template)
|
||||||
|
{
|
||||||
|
if (mktemp(template) == NULL || mkdir(template, 0700) != 0)
|
||||||
|
return NULL;
|
||||||
|
return template;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_STRCASESTR
|
||||||
|
/* Copyright (c) 1999, 2000 The ht://Dig Group */
|
||||||
|
char* FAST_FUNC strcasestr(const char *s, const char *pattern)
|
||||||
|
{
|
||||||
|
int length = strlen(pattern);
|
||||||
|
|
||||||
|
while (*s) {
|
||||||
|
if (strncasecmp(s, pattern, length) == 0)
|
||||||
|
return (char *)s;
|
||||||
|
s++;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user