]> git.cameronkatri.com Git - mandoc.git/commitdiff
do not spawn a pager when there is no output; issue pointed out by deraadt@
authorIngo Schwarze <schwarze@openbsd.org>
Tue, 13 Jan 2015 13:22:22 +0000 (13:22 +0000)
committerIngo Schwarze <schwarze@openbsd.org>
Tue, 13 Jan 2015 13:22:22 +0000 (13:22 +0000)
main.c

diff --git a/main.c b/main.c
index 5f8e2680e6650b1733ea28a45b179a33fbb5c0b8..24e3537c81bf0173f47daba30b1ccdf88e3a5097 100644 (file)
--- a/main.c
+++ b/main.c
@@ -1,7 +1,7 @@
-/*     $Id: main.c,v 1.211 2015/01/01 13:20:38 schwarze Exp $ */
+/*     $Id: main.c,v 1.212 2015/01/13 13:22:22 schwarze Exp $ */
 /*
  * Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2010, 2011, 2012, 2014 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2010-2012, 2014, 2015 Ingo Schwarze <schwarze@openbsd.org>
  * Copyright (c) 2010 Joerg Sonnenberger <joerg@netbsd.org>
  *
  * Permission to use, copy, modify, and distribute this software for any
@@ -405,9 +405,6 @@ main(int argc, char *argv[])
        if (search.argmode == ARG_FILE && ! moptions(&options, auxpaths))
                return((int)MANDOCLEVEL_BADARG);
 
-       if (use_pager && isatty(STDOUT_FILENO))
-               spawn_pager();
-
        curp.mchars = mchars_alloc();
        curp.mp = mparse_alloc(options, curp.wlevel, mmsg,
            curp.mchars, defos);
@@ -418,15 +415,29 @@ main(int argc, char *argv[])
        if (OUTT_MAN == curp.outtype)
                mparse_keep(curp.mp);
 
-       if (argc == 0)
+       if (argc == 0) {
+               if (use_pager && isatty(STDOUT_FILENO))
+                       spawn_pager();
                parse(&curp, STDIN_FILENO, "<stdin>", &rc);
+       }
 
        while (argc) {
+               rc = mparse_open(curp.mp, &fd,
+#if HAVE_SQLITE3
+                   resp != NULL ? resp->file :
+#endif
+                   *argv);
+
+               if (fd != -1) {
+                       if (use_pager && isatty(STDOUT_FILENO))
+                               spawn_pager();
+                       use_pager = 0;
+
+#if HAVE_SQLITE3
+                       if (resp == NULL)
+#endif
+                               parse(&curp, fd, *argv, &rc);
 #if HAVE_SQLITE3
-               if (resp != NULL) {
-                       rc = mparse_open(curp.mp, &fd, resp->file);
-                       if (fd == -1)
-                               /* nothing */;
                        else if (resp->form & FORM_SRC) {
                                /* For .so only; ignore failure. */
                                chdir(paths.paths[resp->ipath]);
@@ -434,23 +445,26 @@ main(int argc, char *argv[])
                        } else
                                rc = passthrough(resp->file, fd,
                                    synopsis_only);
-                       resp++;
-               } else
 #endif
-               {
-                       rc = mparse_open(curp.mp, &fd, *argv++);
-                       if (fd != -1)
-                               parse(&curp, fd, argv[-1], &rc);
-               }
 
-               if (mparse_wait(curp.mp) != MANDOCLEVEL_OK)
-                       rc = MANDOCLEVEL_SYSERR;
+                       if (mparse_wait(curp.mp) != MANDOCLEVEL_OK)
+                               rc = MANDOCLEVEL_SYSERR;
+
+                       if (argc > 1 && curp.outtype <= OUTT_UTF8)
+                               ascii_sepline(curp.outdata);
+               }
 
                if (MANDOCLEVEL_OK != rc && curp.wstop)
                        break;
 
-               if (--argc && curp.outtype <= OUTT_UTF8)
-                       ascii_sepline(curp.outdata);
+#if HAVE_SQLITE3
+               if (resp != NULL)
+                       resp++;
+               else
+#endif
+                       argv++;
+               if (--argc)
+                       mparse_reset(curp.mp);
        }
 
        if (curp.outfree)
@@ -616,10 +630,7 @@ parse(struct curparse *curp, int fd, const char *file,
        if (mdoc && curp->outmdoc)
                (*curp->outmdoc)(curp->outdata, mdoc);
 
- cleanup:
-
-       mparse_reset(curp->mp);
-
+cleanup:
        if (*level < rc)
                *level = rc;
 }