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

Diff for /mandoc/main.c between version 1.280 and 1.284

version 1.280, 2017/01/27 13:47:10 version 1.284, 2017/02/22 14:58:48
Line 100  static void    parse(struct curparse *, int, const cha
Line 100  static void    parse(struct curparse *, int, const cha
 static  void              passthrough(const char *, int, int);  static  void              passthrough(const char *, int, int);
 static  pid_t             spawn_pager(struct tag_files *);  static  pid_t             spawn_pager(struct tag_files *);
 static  int               toptions(struct curparse *, char *);  static  int               toptions(struct curparse *, char *);
 static  void              usage(enum argmode) __attribute__((noreturn));  static  void              usage(enum argmode) __attribute__((__noreturn__));
 static  int               woptions(struct curparse *, char *);  static  int               woptions(struct curparse *, char *);
   
 static  const int sec_prios[] = {1, 4, 5, 8, 6, 3, 7, 2, 9};  static  const int sec_prios[] = {1, 4, 5, 8, 6, 3, 7, 2, 9};
Line 113  int
Line 113  int
 main(int argc, char *argv[])  main(int argc, char *argv[])
 {  {
         struct manconf   conf;          struct manconf   conf;
         struct curparse  curp;  
         struct mansearch search;          struct mansearch search;
           struct curparse  curp;
         struct tag_files *tag_files;          struct tag_files *tag_files;
         const char      *progname;  
         char            *auxpaths;  
         char            *defos;  
         unsigned char   *uc;  
         struct manpage  *res, *resp;          struct manpage  *res, *resp;
         char            *conf_file, *defpaths;          const char      *progname, *sec, *thisarg;
         const char      *sec;          char            *conf_file, *defpaths, *auxpaths;
         const char      *thisarg;          char            *defos, *oarg;
           unsigned char   *uc;
         size_t           i, sz;          size_t           i, sz;
         int              prio, best_prio;          int              prio, best_prio;
         enum outmode     outmode;          enum outmode     outmode;
Line 152  main(int argc, char *argv[])
Line 149  main(int argc, char *argv[])
                 return mandocdb(argc, argv);                  return mandocdb(argc, argv);
   
 #if HAVE_PLEDGE  #if HAVE_PLEDGE
         if (pledge("stdio rpath tmppath tty proc exec flock", NULL) == -1)          if (pledge("stdio rpath tmppath tty proc exec", NULL) == -1)
                 err((int)MANDOCLEVEL_SYSERR, "pledge");                  err((int)MANDOCLEVEL_SYSERR, "pledge");
 #endif  #endif
   
Line 169  main(int argc, char *argv[])
Line 166  main(int argc, char *argv[])
   
         memset(&search, 0, sizeof(struct mansearch));          memset(&search, 0, sizeof(struct mansearch));
         search.outkey = "Nd";          search.outkey = "Nd";
           oarg = NULL;
   
         if (strcmp(progname, BINM_MAN) == 0)          if (strcmp(progname, BINM_MAN) == 0)
                 search.argmode = ARG_NAME;                  search.argmode = ARG_NAME;
Line 247  main(int argc, char *argv[])
Line 245  main(int argc, char *argv[])
                         auxpaths = optarg;                          auxpaths = optarg;
                         break;                          break;
                 case 'O':                  case 'O':
                         search.outkey = optarg;                          oarg = optarg;
                         while (optarg != NULL) {  
                                 thisarg = optarg;  
                                 if (manconf_output(&conf.output,  
                                     strsep(&optarg, ","), 0) == 0)  
                                         continue;  
                                 warnx("-O %s: Bad argument", thisarg);  
                                 return (int)MANDOCLEVEL_BADARG;  
                         }  
                         break;                          break;
                 case 'S':                  case 'S':
                         search.arch = optarg;                          search.arch = optarg;
Line 300  main(int argc, char *argv[])
Line 290  main(int argc, char *argv[])
                 }                  }
         }          }
   
           if (oarg != NULL) {
                   if (outmode == OUTMODE_LST)
                           search.outkey = oarg;
                   else {
                           while (oarg != NULL) {
                                   thisarg = oarg;
                                   if (manconf_output(&conf.output,
                                       strsep(&oarg, ","), 0) == 0)
                                           continue;
                                   warnx("-O %s: Bad argument", thisarg);
                                   return (int)MANDOCLEVEL_BADARG;
                           }
                   }
           }
   
         if (outmode == OUTMODE_FLN ||          if (outmode == OUTMODE_FLN ||
             outmode == OUTMODE_LST ||              outmode == OUTMODE_LST ||
             !isatty(STDOUT_FILENO))              !isatty(STDOUT_FILENO))
Line 307  main(int argc, char *argv[])
Line 312  main(int argc, char *argv[])
   
 #if HAVE_PLEDGE  #if HAVE_PLEDGE
         if (!use_pager)          if (!use_pager)
                 if (pledge("stdio rpath flock", NULL) == -1)                  if (pledge("stdio rpath", NULL) == -1)
                         err((int)MANDOCLEVEL_SYSERR, "pledge");                          err((int)MANDOCLEVEL_SYSERR, "pledge");
 #endif  #endif
   
Line 742  parse(struct curparse *curp, int fd, const char *file)
Line 747  parse(struct curparse *curp, int fd, const char *file)
         if (man == NULL)          if (man == NULL)
                 return;                  return;
         if (man->macroset == MACROSET_MDOC) {          if (man->macroset == MACROSET_MDOC) {
                 mdoc_validate(man);                  if (curp->outtype != OUTT_TREE || !curp->outopts->noval)
                           mdoc_validate(man);
                 switch (curp->outtype) {                  switch (curp->outtype) {
                 case OUTT_HTML:                  case OUTT_HTML:
                         html_mdoc(curp->outdata, man);                          html_mdoc(curp->outdata, man);
Line 765  parse(struct curparse *curp, int fd, const char *file)
Line 771  parse(struct curparse *curp, int fd, const char *file)
                 }                  }
         }          }
         if (man->macroset == MACROSET_MAN) {          if (man->macroset == MACROSET_MAN) {
                 man_validate(man);                  if (curp->outtype != OUTT_TREE || !curp->outopts->noval)
                           man_validate(man);
                 switch (curp->outtype) {                  switch (curp->outtype) {
                 case OUTT_HTML:                  case OUTT_HTML:
                         html_man(curp->outdata, man);                          html_man(curp->outdata, man);

Legend:
Removed from v.1.280  
changed lines
  Added in v.1.284

CVSweb