less: further tweaks to regular file detection
authorRon Yorston <rmy@pobox.com>
Fri, 31 Jul 2015 16:33:24 +0000 (17:33 +0100)
committerDenys Vlasenko <vda.linux@googlemail.com>
Mon, 3 Aug 2015 14:41:19 +0000 (16:41 +0200)
Test explicitly for REOPEN flags:  update_num_lines is called
unconditionally so (num_lines != NOT_REGULAR_FILE) is also true when
num_lines contains a valid number of lines.

The call to fstat doesn't need to be in #if ENABLE_FEATURE_LESS_FLAGS:
the whole function is already in such a test.

Signed-off-by: Ron Yorston <rmy@pobox.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
miscutils/less.c

index be8d20e66a1120648e55d5ac7b2b0376d27aedab..7a441bf7eb6e8a11dd9b73e23784223dc284d86e 100644 (file)
@@ -615,11 +615,12 @@ static int safe_lineno(int fline)
 static void update_num_lines(void)
 {
        int count, fd;
+       struct stat stbuf;
        ssize_t len, i;
        char buf[4096];
 
        /* only do this for regular files */
-       if (num_lines != NOT_REGULAR_FILE) {
+       if (num_lines == REOPEN_AND_COUNT || num_lines == REOPEN_STDIN) {
                count = 0;
                fd = open("/proc/self/fd/0", O_RDONLY);
                if (fd < 0 && num_lines == REOPEN_AND_COUNT) {
@@ -631,17 +632,10 @@ static void update_num_lines(void)
                        num_lines = NOT_REGULAR_FILE;
                        return;
                }
-#if ENABLE_FEATURE_LESS_FLAGS
-               {
-                       struct stat stbuf;
-                       if (fstat(fd, &stbuf) != 0
-                        || !S_ISREG(stbuf.st_mode)
-                       ) {
-                               num_lines = NOT_REGULAR_FILE;
-                               goto do_close;
-                       }
+               if (fstat(fd, &stbuf) != 0 || !S_ISREG(stbuf.st_mode)) {
+                       num_lines = NOT_REGULAR_FILE;
+                       goto do_close;
                }
-#endif
                while ((len = safe_read(fd, buf, sizeof(buf))) > 0) {
                        for (i = 0; i < len; ++i) {
                                if (buf[i] == '\n' && ++count == MAXLINES)