[BACK]Return to main.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Diff for /mandoc/main.c between version 1.315 and 1.318

version 1.315, 2018/12/30 00:49:55 version 1.318, 2019/01/11 17:04:44
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010-2012, 2014-2018 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2010-2012, 2014-2019 Ingo Schwarze <schwarze@openbsd.org>
  * Copyright (c) 2010 Joerg Sonnenberger <joerg@netbsd.org>   * Copyright (c) 2010 Joerg Sonnenberger <joerg@netbsd.org>
  *   *
  * Permission to use, copy, modify, and distribute this software for any   * Permission to use, copy, modify, and distribute this software for any
Line 123  main(int argc, char *argv[])
Line 123  main(int argc, char *argv[])
         struct manpage  *res, *resp;          struct manpage  *res, *resp;
         const char      *progname, *sec, *thisarg;          const char      *progname, *sec, *thisarg;
         char            *conf_file, *defpaths, *auxpaths;          char            *conf_file, *defpaths, *auxpaths;
         char            *oarg;          char            *oarg, *tagarg;
         unsigned char   *uc;          unsigned char   *uc;
         size_t           i, sz;          size_t           i, sz;
         int              prio, best_prio;          int              prio, best_prio;
Line 148  main(int argc, char *argv[])
Line 148  main(int argc, char *argv[])
         setprogname(progname);          setprogname(progname);
 #endif  #endif
   
           mandoc_msg_setoutfile(stderr);
         if (strncmp(progname, "mandocdb", 8) == 0 ||          if (strncmp(progname, "mandocdb", 8) == 0 ||
             strcmp(progname, BINM_MAKEWHATIS) == 0)              strcmp(progname, BINM_MAKEWHATIS) == 0)
                 return mandocdb(argc, argv);                  return mandocdb(argc, argv);
Line 368  main(int argc, char *argv[])
Line 369  main(int argc, char *argv[])
 #endif  #endif
         }          }
   
           /*
            * Use the first argument for -O tag in addition to
            * using it as a search term for man(1) or apropos(1).
            */
   
           if (conf.output.tag != NULL && *conf.output.tag == '\0') {
                   tagarg = argc > 0 && search.argmode == ARG_EXPR ?
                       strchr(*argv, '=') : NULL;
                   conf.output.tag = tagarg == NULL ? *argv : tagarg + 1;
           }
   
         /* man(1), whatis(1), apropos(1) */          /* man(1), whatis(1), apropos(1) */
   
         if (search.argmode != ARG_FILE) {          if (search.argmode != ARG_FILE) {
Line 480  main(int argc, char *argv[])
Line 492  main(int argc, char *argv[])
         curp.mp = mparse_alloc(options, curp.os_e, curp.os_s);          curp.mp = mparse_alloc(options, curp.os_e, curp.os_s);
   
         if (argc < 1) {          if (argc < 1) {
                 if (use_pager)                  if (use_pager) {
                         tag_files = tag_init();                          tag_files = tag_init();
                           tag_files->tagname = conf.output.tag;
                   }
                 thisarg = "<stdin>";                  thisarg = "<stdin>";
                 mandoc_msg_setinfilename(thisarg);                  mandoc_msg_setinfilename(thisarg);
                 parse(&curp, STDIN_FILENO, thisarg);                  parse(&curp, STDIN_FILENO, thisarg);
Line 518  main(int argc, char *argv[])
Line 532  main(int argc, char *argv[])
                         if (use_pager) {                          if (use_pager) {
                                 use_pager = 0;                                  use_pager = 0;
                                 tag_files = tag_init();                                  tag_files = tag_init();
                                 if (conf.output.tag != NULL &&                                  tag_files->tagname = conf.output.tag;
                                     tag_files->tagname == NULL)  
                                         tag_files->tagname =  
                                             *conf.output.tag != '\0' ?  
                                             conf.output.tag : *argv;  
                         }                          }
   
                         mandoc_msg_setinfilename(thisarg);                          mandoc_msg_setinfilename(thisarg);
Line 551  main(int argc, char *argv[])
Line 561  main(int argc, char *argv[])
                         }                          }
                 } else                  } else
                         mandoc_msg(MANDOCERR_FILE, 0, 0,                          mandoc_msg(MANDOCERR_FILE, 0, 0,
                             "%s", strerror(errno));                              "%s: %s", thisarg, strerror(errno));
   
                 if (curp.wstop && mandoc_msg_getrc() != MANDOCLEVEL_OK)                  if (curp.wstop && mandoc_msg_getrc() != MANDOCLEVEL_OK)
                         break;                          break;

Legend:
Removed from v.1.315  
changed lines
  Added in v.1.318

CVSweb