diff options
author | Dan Fandrich <dan@coneharvesters.com> | 2009-10-27 11:05:00 +0100 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2009-10-27 11:05:00 +0100 |
commit | 21a542d7d732735a522c413c0c385e577528ec63 (patch) | |
tree | f0873e7eb57524ca9306d12b6dd2ecd5224f8a0a /libbb | |
parent | d83bbf41934382631161845302f5d77027383aba (diff) | |
download | busybox-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/Kbuild | 1 | ||||
-rw-r--r-- | libbb/platform.c | 57 | ||||
-rw-r--r-- | libbb/xfuncs_printf.c | 45 |
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 | |||
71 | lib-y += perror_nomsg.o | 71 | lib-y += perror_nomsg.o |
72 | lib-y += perror_nomsg_and_die.o | 72 | lib-y += perror_nomsg_and_die.o |
73 | lib-y += pidfile.o | 73 | lib-y += pidfile.o |
74 | lib-y += platform.o | ||
74 | lib-y += printable.o | 75 | lib-y += printable.o |
75 | lib-y += print_flags.o | 76 | lib-y += print_flags.o |
76 | lib-y += process_escape_sequence.o | 77 | lib-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 | ||
13 | char * 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 | ||
21 | int 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 | ||
41 | int 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... */ | ||
308 | int 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 | |||
340 | void FAST_FUNC xsetenv(const char *key, const char *value) | 295 | void FAST_FUNC xsetenv(const char *key, const char *value) |
341 | { | 296 | { |
342 | if (setenv(key, value, 1)) | 297 | if (setenv(key, value, 1)) |