aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2006-12-18 22:10:24 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2006-12-18 22:10:24 +0000
commitc8e6e35ba4095846121d5b5a3eee57caa5e8e0fb (patch)
treed310542c65bbfd183b50f156916ef3313721625f
parent83e5d6f77237b64853c194b0ce592e77ef677c4d (diff)
downloadbusybox-w32-c8e6e35ba4095846121d5b5a3eee57caa5e8e0fb.tar.gz
busybox-w32-c8e6e35ba4095846121d5b5a3eee57caa5e8e0fb.tar.bz2
busybox-w32-c8e6e35ba4095846121d5b5a3eee57caa5e8e0fb.zip
nc: add missing cast
xfuncs: add dprintf for dietlibc
-rw-r--r--include/platform.h3
-rw-r--r--libbb/xfuncs.c31
-rw-r--r--networking/nc.c2
3 files changed, 35 insertions, 1 deletions
diff --git a/include/platform.h b/include/platform.h
index a1ec17a7b..860143f7f 100644
--- a/include/platform.h
+++ b/include/platform.h
@@ -194,6 +194,9 @@ typedef unsigned long long int uintmax_t;
194 * libbb. This would require a platform.c. It's not going to be cleaned 194 * libbb. This would require a platform.c. It's not going to be cleaned
195 * out of the tree, so stop saying it should be. */ 195 * out of the tree, so stop saying it should be. */
196#define fdprintf dprintf 196#define fdprintf dprintf
197#ifdef __dietlibc__
198int dprintf(int fd, const char *format, ...);
199#endif
197 200
198/* Don't use lchown with glibc older than 2.1.x ... uC-libc lacks it */ 201/* Don't use lchown with glibc older than 2.1.x ... uC-libc lacks it */
199#if (defined __GLIBC__ && __GLIBC__ <= 2 && __GLIBC_MINOR__ < 1) || \ 202#if (defined __GLIBC__ && __GLIBC__ <= 2 && __GLIBC_MINOR__ < 1) || \
diff --git a/libbb/xfuncs.c b/libbb/xfuncs.c
index 313e32814..4790aa140 100644
--- a/libbb/xfuncs.c
+++ b/libbb/xfuncs.c
@@ -411,6 +411,37 @@ char *xasprintf(const char *format, ...)
411 return string_ptr; 411 return string_ptr;
412} 412}
413 413
414#ifdef __dietlibc__
415int dprintf(int fd, const char *format, ...)
416{
417 va_list p;
418 int r;
419 char *string_ptr;
420
421#if 1
422 // GNU extension
423 va_start(p, format);
424 r = vasprintf(&string_ptr, format, p);
425 va_end(p);
426#else
427 // Bloat for systems that haven't got the GNU extension.
428 va_start(p, format);
429 r = vsnprintf(NULL, 0, format, p);
430 va_end(p);
431 string_ptr = xmalloc(r+1);
432 va_start(p, format);
433 r = vsnprintf(string_ptr, r+1, format, p);
434 va_end(p);
435#endif
436
437 if (r >= 0) {
438 full_write(fd, string_ptr, r);
439 free(string_ptr);
440 }
441 return r;
442}
443#endif
444
414// Die with an error message if we can't copy an entire FILE * to stdout, then 445// Die with an error message if we can't copy an entire FILE * to stdout, then
415// close that file. 446// close that file.
416void xprint_and_close_file(FILE *file) 447void xprint_and_close_file(FILE *file)
diff --git a/networking/nc.c b/networking/nc.c
index 5fd9242cc..b2a4596d6 100644
--- a/networking/nc.c
+++ b/networking/nc.c
@@ -104,7 +104,7 @@ int nc_main(int argc, char **argv)
104 104
105 if (!lport) { 105 if (!lport) {
106 socklen_t len = sizeof(address); 106 socklen_t len = sizeof(address);
107 getsockname(sfd, &address, &len); 107 getsockname(sfd, (struct sockaddr *) &address, &len);
108 fdprintf(2, "%d\n", SWAP_BE16(address.sin_port)); 108 fdprintf(2, "%d\n", SWAP_BE16(address.sin_port));
109 } 109 }
110 repeatyness: 110 repeatyness: