dos2unix: try to preserve ownership. closes 8311
authorDenys Vlasenko <vda.linux@googlemail.com>
Sun, 17 Jan 2016 02:50:36 +0000 (03:50 +0100)
committerDenys Vlasenko <vda.linux@googlemail.com>
Sun, 17 Jan 2016 02:50:36 +0000 (03:50 +0100)
function                                             old     new   delta
dos2unix_main                                        426     441     +15

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
coreutils/dos2unix.c

index 07398bdfa71f1926376cb7c0a65522523acc6f5e..ccb74a1132b99975fbd6622bb7b2a5bf52e9630d 100644 (file)
@@ -41,7 +41,7 @@ enum {
 static void convert(char *fn, int conv_type)
 {
        FILE *in, *out;
-       int i;
+       int ch;
        char *temp_fn = temp_fn; /* for compiler */
        char *resolved_fn = resolved_fn;
 
@@ -49,28 +49,30 @@ static void convert(char *fn, int conv_type)
        out = stdout;
        if (fn != NULL) {
                struct stat st;
+               int fd;
 
                resolved_fn = xmalloc_follow_symlinks(fn);
                if (resolved_fn == NULL)
                        bb_simple_perror_msg_and_die(fn);
                in = xfopen_for_read(resolved_fn);
-               fstat(fileno(in), &st);
+               xfstat(fileno(in), &st, resolved_fn);
 
                temp_fn = xasprintf("%sXXXXXX", resolved_fn);
-               i = xmkstemp(temp_fn);
-               if (fchmod(i, st.st_mode) == -1)
+               fd = xmkstemp(temp_fn);
+               if (fchmod(fd, st.st_mode) == -1)
                        bb_simple_perror_msg_and_die(temp_fn);
+               fchown(fd, st.st_uid, st.st_gid);
 
-               out = xfdopen_for_write(i);
+               out = xfdopen_for_write(fd);
        }
 
-       while ((i = fgetc(in)) != EOF) {
-               if (i == '\r')
+       while ((ch = fgetc(in)) != EOF) {
+               if (ch == '\r')
                        continue;
-               if (i == '\n')
+               if (ch == '\n')
                        if (conv_type == CT_UNIX2DOS)
                                fputc('\r', out);
-               fputc(i, out);
+               fputc(ch, out);
        }
 
        if (fn != NULL) {