init: fix logically inverted FEATURE_EXTRA_QUIET check
[oweals/busybox.git] / libbb / wfopen.c
index 26e6a13e2b1f825dc2928cc0e3f58d4821355178..deec79a280683d468f0ded2e3f4fee9eb7a38d81 100644 (file)
@@ -9,12 +9,48 @@
 
 #include "libbb.h"
 
-FILE *fopen_or_warn(const char *path, const char *mode)
+FILE* FAST_FUNC fopen_or_warn(const char *path, const char *mode)
 {
        FILE *fp = fopen(path, mode);
        if (!fp) {
-               bb_perror_msg("%s", path);
-               errno = 0;
+               bb_simple_perror_msg(path);
+               //errno = 0; /* why? */
        }
        return fp;
 }
+
+FILE* FAST_FUNC fopen_for_read(const char *path)
+{
+       return fopen(path, "r");
+}
+
+FILE* FAST_FUNC xfopen_for_read(const char *path)
+{
+       return xfopen(path, "r");
+}
+
+FILE* FAST_FUNC fopen_for_write(const char *path)
+{
+       return fopen(path, "w");
+}
+
+FILE* FAST_FUNC xfopen_for_write(const char *path)
+{
+       return xfopen(path, "w");
+}
+
+static FILE* xfdopen_helper(unsigned fd_and_rw_bit)
+{
+       FILE* fp = fdopen(fd_and_rw_bit >> 1, fd_and_rw_bit & 1 ? "w" : "r");
+       if (!fp)
+               bb_error_msg_and_die(bb_msg_memory_exhausted);
+       return fp;
+}
+FILE* FAST_FUNC xfdopen_for_read(int fd)
+{
+       return xfdopen_helper(fd << 1);
+}
+FILE* FAST_FUNC xfdopen_for_write(int fd)
+{
+       return xfdopen_helper((fd << 1) + 1);
+}