aboutsummaryrefslogtreecommitdiff
path: root/libbb
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2009-11-15 23:28:11 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2009-11-15 23:28:11 +0100
commita7ccdeef396700d1ed78b9f97de0d10c706b169f (patch)
tree4ef45efdaaac81d2a4c31b16d9cc36ba2d3a22e1 /libbb
parent647553a4fcbbc169b4390d9ef8e4657f0ffe1a5f (diff)
downloadbusybox-w32-a7ccdeef396700d1ed78b9f97de0d10c706b169f.tar.gz
busybox-w32-a7ccdeef396700d1ed78b9f97de0d10c706b169f.tar.bz2
busybox-w32-a7ccdeef396700d1ed78b9f97de0d10c706b169f.zip
libbb: added xfdopen_for_read/write
function old new delta xfdopen_helper - 40 +40 logdir_open 1163 1184 +21 process_stdin 433 443 +10 xfdopen_for_write - 9 +9 doCommands 2465 2474 +9 patch_main 1214 1222 +8 bbunpack 457 465 +8 xfdopen_for_read - 7 +7 scan_tree 258 262 +4 xstrtoul_range_sfx 230 231 +1 sendmail_main 957 955 -2 passwd_main 1027 1023 -4 parse 969 964 -5 test_main 253 247 -6 sed_main 655 649 -6 dos2unix_main 437 429 -8 fbsplash_main 950 938 -12 handle_dir_common 371 354 -17 expand_vars_to_list 2197 2169 -28 update_passwd 1275 1246 -29 ------------------------------------------------------------------------------ (add/remove: 3/0 grow/shrink: 7/10 up/down: 117/-117) Total: 0 bytes Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'libbb')
-rw-r--r--libbb/update_passwd.c7
-rw-r--r--libbb/wfopen.c16
2 files changed, 17 insertions, 6 deletions
diff --git a/libbb/update_passwd.c b/libbb/update_passwd.c
index ba773fcb2..301893be1 100644
--- a/libbb/update_passwd.c
+++ b/libbb/update_passwd.c
@@ -137,12 +137,7 @@ int FAST_FUNC update_passwd(const char *filename,
137 fchown(new_fd, sb.st_uid, sb.st_gid); 137 fchown(new_fd, sb.st_uid, sb.st_gid);
138 } 138 }
139 errno = 0; 139 errno = 0;
140 new_fp = fdopen(new_fd, "w"); 140 new_fp = xfdopen_for_write(new_fd);
141 if (!new_fp) {
142 bb_perror_nomsg();
143 close(new_fd);
144 goto unlink_new;
145 }
146 141
147 /* Backup file is "/etc/passwd-" */ 142 /* Backup file is "/etc/passwd-" */
148 *sfx_char = '-'; 143 *sfx_char = '-';
diff --git a/libbb/wfopen.c b/libbb/wfopen.c
index 1cb871ef5..deec79a28 100644
--- a/libbb/wfopen.c
+++ b/libbb/wfopen.c
@@ -38,3 +38,19 @@ FILE* FAST_FUNC xfopen_for_write(const char *path)
38{ 38{
39 return xfopen(path, "w"); 39 return xfopen(path, "w");
40} 40}
41
42static FILE* xfdopen_helper(unsigned fd_and_rw_bit)
43{
44 FILE* fp = fdopen(fd_and_rw_bit >> 1, fd_and_rw_bit & 1 ? "w" : "r");
45 if (!fp)
46 bb_error_msg_and_die(bb_msg_memory_exhausted);
47 return fp;
48}
49FILE* FAST_FUNC xfdopen_for_read(int fd)
50{
51 return xfdopen_helper(fd << 1);
52}
53FILE* FAST_FUNC xfdopen_for_write(int fd)
54{
55 return xfdopen_helper((fd << 1) + 1);
56}