aboutsummaryrefslogtreecommitdiff
path: root/libbb
diff options
context:
space:
mode:
authorDan Fandrich <dan@coneharvesters.com>2009-10-27 11:05:00 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2009-10-27 11:05:00 +0100
commit21a542d7d732735a522c413c0c385e577528ec63 (patch)
treef0873e7eb57524ca9306d12b6dd2ecd5224f8a0a /libbb
parentd83bbf41934382631161845302f5d77027383aba (diff)
downloadbusybox-w32-21a542d7d732735a522c413c0c385e577528ec63.tar.gz
busybox-w32-21a542d7d732735a522c413c0c385e577528ec63.tar.bz2
busybox-w32-21a542d7d732735a522c413c0c385e577528ec63.zip
platform compatibility work (by Dan Fandrich)
Signed-off-by: Dan Fandrich <dan@coneharvesters.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'libbb')
-rw-r--r--libbb/Kbuild1
-rw-r--r--libbb/platform.c57
-rw-r--r--libbb/xfuncs_printf.c45
3 files changed, 58 insertions, 45 deletions
diff --git a/libbb/Kbuild b/libbb/Kbuild
index 8c7a189b4..c3c02b33e 100644
--- a/libbb/Kbuild
+++ b/libbb/Kbuild
@@ -71,6 +71,7 @@ lib-y += perror_msg_and_die.o
71lib-y += perror_nomsg.o 71lib-y += perror_nomsg.o
72lib-y += perror_nomsg_and_die.o 72lib-y += perror_nomsg_and_die.o
73lib-y += pidfile.o 73lib-y += pidfile.o
74lib-y += platform.o
74lib-y += printable.o 75lib-y += printable.o
75lib-y += print_flags.o 76lib-y += print_flags.o
76lib-y += process_escape_sequence.o 77lib-y += process_escape_sequence.o
diff --git a/libbb/platform.c b/libbb/platform.c
new file mode 100644
index 000000000..470185a68
--- /dev/null
+++ b/libbb/platform.c
@@ -0,0 +1,57 @@
1/*
2 * Replacements for common but usually nonstandard functions that aren't
3 * supplied by all platforms.
4 *
5 * Copyright (C) 2009 by Dan Fandrich <dan@coneharvesters.com>, et. al.
6 *
7 * Licensed under the GPL version 2, see the file LICENSE in this tarball.
8 */
9
10#include "libbb.h"
11
12#ifndef HAVE_STRCHRNUL
13char * FAST_FUNC strchrnul(const char *s, int c)
14{
15 while (*s && *s != c) ++s;
16 return (char*)s;
17}
18#endif
19
20#ifndef HAVE_VASPRINTF
21int FAST_FUNC vasprintf(char **string_ptr, const char *format, va_list p)
22{
23 int r;
24 va_list p2;
25
26 va_copy(p2, p);
27 r = vsnprintf(NULL, 0, format, p);
28 va_end(p);
29 *string_ptr = xmalloc(r+1);
30 if (!*string_ptr)
31 r = -1;
32 else
33 r = vsnprintf(*string_ptr, r+1, format, p2);
34 va_end(p2);
35
36 return r;
37}
38#endif
39
40#ifndef HAVE_FDPRINTF
41int fdprintf(int fd, const char *format, ...)
42{
43 va_list p;
44 int r;
45 char *string_ptr;
46
47 va_start(p, format);
48 r = vasprintf(&string_ptr, format, p);
49 va_end(p);
50 if (r >= 0) {
51 r = full_write(fd, string_ptr, r);
52 free(string_ptr);
53 }
54 return r;
55}
56#endif
57
diff --git a/libbb/xfuncs_printf.c b/libbb/xfuncs_printf.c
index aaf9989a0..345c84219 100644
--- a/libbb/xfuncs_printf.c
+++ b/libbb/xfuncs_printf.c
@@ -283,60 +283,15 @@ char* FAST_FUNC xasprintf(const char *format, ...)
283 int r; 283 int r;
284 char *string_ptr; 284 char *string_ptr;
285 285
286#if 1
287 // GNU extension
288 va_start(p, format); 286 va_start(p, format);
289 r = vasprintf(&string_ptr, format, p); 287 r = vasprintf(&string_ptr, format, p);
290 va_end(p); 288 va_end(p);
291#else
292 // Bloat for systems that haven't got the GNU extension.
293 va_start(p, format);
294 r = vsnprintf(NULL, 0, format, p);
295 va_end(p);
296 string_ptr = xmalloc(r+1);
297 va_start(p, format);
298 r = vsnprintf(string_ptr, r+1, format, p);
299 va_end(p);
300#endif
301 289
302 if (r < 0) 290 if (r < 0)
303 bb_error_msg_and_die(bb_msg_memory_exhausted); 291 bb_error_msg_and_die(bb_msg_memory_exhausted);
304 return string_ptr; 292 return string_ptr;
305} 293}
306 294
307#if 0 /* If we will ever meet a libc which hasn't [f]dprintf... */
308int FAST_FUNC fdprintf(int fd, const char *format, ...)
309{
310 va_list p;
311 int r;
312 char *string_ptr;
313
314#if 1
315 // GNU extension
316 va_start(p, format);
317 r = vasprintf(&string_ptr, format, p);
318 va_end(p);
319#else
320 // Bloat for systems that haven't got the GNU extension.
321 va_start(p, format);
322 r = vsnprintf(NULL, 0, format, p) + 1;
323 va_end(p);
324 string_ptr = malloc(r);
325 if (string_ptr) {
326 va_start(p, format);
327 r = vsnprintf(string_ptr, r, format, p);
328 va_end(p);
329 }
330#endif
331
332 if (r >= 0) {
333 full_write(fd, string_ptr, r);
334 free(string_ptr);
335 }
336 return r;
337}
338#endif
339
340void FAST_FUNC xsetenv(const char *key, const char *value) 295void FAST_FUNC xsetenv(const char *key, const char *value)
341{ 296{
342 if (setenv(key, value, 1)) 297 if (setenv(key, value, 1))