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

Diff for /mandoc/main.c between version 1.351 and 1.357

version 1.351, 2020/07/20 16:57:30 version 1.357, 2021/09/04 12:52:57
Line 1 
Line 1 
 /* $Id$ */  /* $Id$ */
 /*  /*
  * Copyright (c) 2010-2012, 2014-2020 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2010-2012, 2014-2021 Ingo Schwarze <schwarze@openbsd.org>
  * Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008-2012 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010 Joerg Sonnenberger <joerg@netbsd.org>   * Copyright (c) 2010 Joerg Sonnenberger <joerg@netbsd.org>
  *   *
Line 93  struct outstate {
Line 93  struct outstate {
   
 int                       mandocdb(int, char *[]);  int                       mandocdb(int, char *[]);
   
 static  void              check_xr(void);  static  void              check_xr(struct manpaths *);
 static  int               fs_lookup(const struct manpaths *,  static  void              fs_append(char **, size_t, int,
                                 size_t ipath, const char *,                                  size_t, const char *, enum form,
                                 const char *, const char *,  
                                 struct manpage **, size_t *);                                  struct manpage **, size_t *);
   static  int               fs_lookup(const struct manpaths *, size_t,
                                   const char *, const char *, const char *,
                                   struct manpage **, size_t *);
 static  int               fs_search(const struct mansearch *,  static  int               fs_search(const struct mansearch *,
                                 const struct manpaths *, const char *,                                  const struct manpaths *, const char *,
                                 struct manpage **, size_t *);                                  struct manpage **, size_t *);
 static  void              glob_esc(char **, const char *, const char *);  static  void              glob_esc(char **, const char *, const char *);
 static  void              outdata_alloc(struct outstate *, struct manoutput *);  static  void              outdata_alloc(struct outstate *, struct manoutput *);
 static  void              parse(struct mparse *, int, const char *,  static  void              parse(struct mparse *, int, const char *,
                                 struct outstate *, struct manoutput *);                                  struct outstate *, struct manconf *);
 static  void              passthrough(int, int);  static  void              passthrough(int, int);
 static  void              process_onefile(struct mparse *, struct manpage *,  static  void              process_onefile(struct mparse *, struct manpage *,
                                 int, struct outstate *, struct manconf *);                                  int, struct outstate *, struct manconf *);
Line 165  main(int argc, char *argv[])
Line 167  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", NULL) == -1) {          if (pledge("stdio rpath wpath cpath tmppath tty proc exec", NULL) == -1) {
                 mandoc_msg(MANDOCERR_PLEDGE, 0, 0, "%s", strerror(errno));                  mandoc_msg(MANDOCERR_PLEDGE, 0, 0, "%s", strerror(errno));
                 return mandoc_msg_getrc();                  return mandoc_msg_getrc();
         }          }
Line 373  main(int argc, char *argv[])
Line 375  main(int argc, char *argv[])
   
         if (outmode == OUTMODE_FLN ||          if (outmode == OUTMODE_FLN ||
             outmode == OUTMODE_LST ||              outmode == OUTMODE_LST ||
             !isatty(STDOUT_FILENO))              (conf.output.outfilename == NULL &&
                conf.output.tagfilename == NULL &&
                isatty(STDOUT_FILENO) == 0))
                 outst.use_pager = 0;                  outst.use_pager = 0;
   
         if (outst.use_pager &&          if (outst.use_pager &&
Line 387  main(int argc, char *argv[])
Line 391  main(int argc, char *argv[])
         }          }
   
 #if HAVE_PLEDGE  #if HAVE_PLEDGE
         if (outst.use_pager == 0) {          if (outst.use_pager == 0)
                 if (pledge("stdio rpath", NULL) == -1) {                  c = pledge("stdio rpath", NULL);
                         mandoc_msg(MANDOCERR_PLEDGE, 0, 0,          else if (conf.output.outfilename != NULL ||
                             "%s", strerror(errno));              conf.output.tagfilename != NULL)
                         return mandoc_msg_getrc();                  c = pledge("stdio rpath wpath cpath", NULL);
                 }          else
                   c = pledge("stdio rpath tmppath tty proc exec", NULL);
           if (c == -1) {
                   mandoc_msg(MANDOCERR_PLEDGE, 0, 0, "%s", strerror(errno));
                   return mandoc_msg_getrc();
         }          }
 #endif  #endif
   
Line 446  main(int argc, char *argv[])
Line 454  main(int argc, char *argv[])
   
         /* Read the configuration file. */          /* Read the configuration file. */
   
         if (search.argmode != ARG_FILE)          if (search.argmode != ARG_FILE ||
               mandoc_msg_getmin() == MANDOCERR_STYLE)
                 manconf_parse(&conf, conf_file, defpaths, auxpaths);                  manconf_parse(&conf, conf_file, defpaths, auxpaths);
   
         /* man(1): Resolve each name individually. */          /* man(1): Resolve each name individually. */
Line 642  out:
Line 651  out:
                 manconf_free(&conf);                  manconf_free(&conf);
   
         if (outst.tag_files != NULL) {          if (outst.tag_files != NULL) {
                 if (term_tag_close() != -1)                  if (term_tag_close() != -1 &&
                       conf.output.outfilename == NULL &&
                       conf.output.tagfilename == NULL)
                         run_pager(&outst, conf.output.tag);                          run_pager(&outst, conf.output.tag);
                 term_tag_unlink();                  term_tag_unlink();
         } else if (outst.had_output && outst.outtype != OUTT_LINT)          } else if (outst.had_output && outst.outtype != OUTT_LINT)
Line 691  glob_esc(char **dst, const char *src, const char *suff
Line 702  glob_esc(char **dst, const char *src, const char *suff
                 *(*dst)++ = *suffix++;                  *(*dst)++ = *suffix++;
 }  }
   
   static void
   fs_append(char **file, size_t filesz, int copy, size_t ipath,
       const char *sec, enum form form, struct manpage **res, size_t *ressz)
   {
           struct manpage  *page;
   
           *res = mandoc_reallocarray(*res, *ressz + filesz, sizeof(**res));
           page = *res + *ressz;
           *ressz += filesz;
           for (;;) {
                   page->file = copy ? mandoc_strdup(*file) : *file;
                   page->names = NULL;
                   page->output = NULL;
                   page->bits = NAME_FILE & NAME_MASK;
                   page->ipath = ipath;
                   page->sec = (*sec >= '1' && *sec <= '9') ? *sec - '1' + 1 : 10;
                   page->form = form;
                   if (--filesz == 0)
                           break;
                   file++;
                   page++;
           }
   }
   
 static int  static int
 fs_lookup(const struct manpaths *paths, size_t ipath,  fs_lookup(const struct manpaths *paths, size_t ipath,
         const char *sec, const char *arch, const char *name,          const char *sec, const char *arch, const char *name,
Line 698  fs_lookup(const struct manpaths *paths, size_t ipath,
Line 733  fs_lookup(const struct manpaths *paths, size_t ipath,
 {  {
         struct stat      sb;          struct stat      sb;
         glob_t           globinfo;          glob_t           globinfo;
         struct manpage  *page;          char            *file, *cp, secnum[2];
         char            *file, *cp;  
         int              globres;          int              globres;
         enum form        form;          enum form        form;
   
         const char *const slman = "/man";          const char *const slman = "/man";
         const char *const slash = "/";          const char *const slash = "/";
         const char *const sglob = ".[01-9]*";          const char *const sglob = ".[01-9]*";
           const char *const dot   = ".";
           const char *const aster = "*";
   
           memset(&globinfo, 0, sizeof(globinfo));
         form = FORM_SRC;          form = FORM_SRC;
   
         mandoc_asprintf(&file, "%s/man%s/%s.%s",          mandoc_asprintf(&file, "%s/man%s/%s.%s",
             paths->paths[ipath], sec, name, sec);              paths->paths[ipath], sec, name, sec);
         if (stat(file, &sb) != -1)          if (stat(file, &sb) != -1)
Line 742  fs_lookup(const struct manpaths *paths, size_t ipath,
Line 780  fs_lookup(const struct manpaths *paths, size_t ipath,
                 mandoc_msg(MANDOCERR_GLOB, 0, 0,                  mandoc_msg(MANDOCERR_GLOB, 0, 0,
                     "%s: %s", file, strerror(errno));                      "%s: %s", file, strerror(errno));
         free(file);          free(file);
           file = NULL;
         if (globres == 0)          if (globres == 0)
                 file = mandoc_strdup(*globinfo.gl_pathv);                  goto found;
         globfree(&globinfo);          globfree(&globinfo);
         if (globres == 0) {  
                 if (stat(file, &sb) != -1)          if (sec[1] != '\0' && *ressz == 0) {
                         goto found;                  secnum[0] = sec[0];
                   secnum[1] = '\0';
                   cp = file = mandoc_malloc(strlen(paths->paths[ipath]) * 2 +
                       strlen(slman) + strlen(secnum) * 2 + strlen(slash) +
                       strlen(name) * 2 + strlen(dot) +
                       strlen(sec) * 2 + strlen(aster) + 1);
                   glob_esc(&cp, paths->paths[ipath], slman);
                   glob_esc(&cp, secnum, slash);
                   glob_esc(&cp, name, dot);
                   glob_esc(&cp, sec, aster);
                   *cp = '\0';
                   globres = glob(file, 0, NULL, &globinfo);
                   if (globres != 0 && globres != GLOB_NOMATCH)
                           mandoc_msg(MANDOCERR_GLOB, 0, 0,
                               "%s: %s", file, strerror(errno));
                 free(file);                  free(file);
                   file = NULL;
                   if (globres == 0)
                           goto found;
                   globfree(&globinfo);
         }          }
   
         if (res != NULL || ipath + 1 != paths->sz)          if (res != NULL || ipath + 1 != paths->sz)
                 return -1;                  return -1;
   
Line 761  fs_lookup(const struct manpaths *paths, size_t ipath,
Line 819  fs_lookup(const struct manpaths *paths, size_t ipath,
 found:  found:
         warnx("outdated mandoc.db lacks %s(%s) entry, run %s %s",          warnx("outdated mandoc.db lacks %s(%s) entry, run %s %s",
             name, sec, BINM_MAKEWHATIS, paths->paths[ipath]);              name, sec, BINM_MAKEWHATIS, paths->paths[ipath]);
         if (res == NULL) {          if (res == NULL)
                 free(file);                  free(file);
                 return 0;          else if (file == NULL)
         }                  fs_append(globinfo.gl_pathv, globinfo.gl_pathc, 1,
         *res = mandoc_reallocarray(*res, ++*ressz, sizeof(**res));                      ipath, sec, form, res, ressz);
         page = *res + (*ressz - 1);          else
         page->file = file;                  fs_append(&file, 1, 0, ipath, sec, form, res, ressz);
         page->names = NULL;          globfree(&globinfo);
         page->output = NULL;  
         page->bits = NAME_FILE & NAME_MASK;  
         page->ipath = ipath;  
         page->sec = (*sec >= '1' && *sec <= '9') ? *sec - '1' + 1 : 10;  
         page->form = form;  
         return 0;          return 0;
 }  }
   
Line 837  process_onefile(struct mparse *mp, struct manpage *res
Line 890  process_onefile(struct mparse *mp, struct manpage *res
   
         if (outst->use_pager) {          if (outst->use_pager) {
                 outst->use_pager = 0;                  outst->use_pager = 0;
                 outst->tag_files = term_tag_init();                  outst->tag_files = term_tag_init(conf->output.outfilename,
                       outst->outtype == OUTT_HTML ? ".html" : "",
                       conf->output.tagfilename);
   #if HAVE_PLEDGE
                   if ((conf->output.outfilename != NULL ||
                        conf->output.tagfilename != NULL) &&
                       pledge("stdio rpath cpath", NULL) == -1) {
                           mandoc_msg(MANDOCERR_PLEDGE, 0, 0,
                               "%s", strerror(errno));
                           exit(mandoc_msg_getrc());
                   }
   #endif
         }          }
         if (outst->had_output && outst->outtype <= OUTT_UTF8) {          if (outst->had_output && outst->outtype <= OUTT_UTF8) {
                 if (outst->outdata == NULL)                  if (outst->outdata == NULL)
Line 846  process_onefile(struct mparse *mp, struct manpage *res
Line 910  process_onefile(struct mparse *mp, struct manpage *res
         }          }
   
         if (resp->form == FORM_SRC)          if (resp->form == FORM_SRC)
                 parse(mp, fd, resp->file, outst, &conf->output);                  parse(mp, fd, resp->file, outst, conf);
         else {          else {
                 passthrough(fd, conf->output.synopsisonly);                  passthrough(fd, conf->output.synopsisonly);
                 outst->had_output = 1;                  outst->had_output = 1;
Line 867  process_onefile(struct mparse *mp, struct manpage *res
Line 931  process_onefile(struct mparse *mp, struct manpage *res
   
 static void  static void
 parse(struct mparse *mp, int fd, const char *file,  parse(struct mparse *mp, int fd, const char *file,
     struct outstate *outst, struct manoutput *outconf)      struct outstate *outst, struct manconf *conf)
 {  {
           static struct manpaths   basepaths;
         static int               previous;          static int               previous;
         struct roff_meta        *meta;          struct roff_meta        *meta;
   
Line 894  parse(struct mparse *mp, int fd, const char *file,
Line 959  parse(struct mparse *mp, int fd, const char *file,
                 return;                  return;
   
         if (outst->outdata == NULL)          if (outst->outdata == NULL)
                 outdata_alloc(outst, outconf);                  outdata_alloc(outst, &conf->output);
         else if (outst->outtype == OUTT_HTML)          else if (outst->outtype == OUTT_HTML)
                 html_reset(outst->outdata);                  html_reset(outst->outdata);
   
Line 947  parse(struct mparse *mp, int fd, const char *file,
Line 1012  parse(struct mparse *mp, int fd, const char *file,
                 case OUTT_PS:                  case OUTT_PS:
                         terminal_man(outst->outdata, meta);                          terminal_man(outst->outdata, meta);
                         break;                          break;
                   case OUTT_MARKDOWN:
                           mandoc_msg(MANDOCERR_MAN_TMARKDOWN, 0, 0, NULL);
                           break;
                 default:                  default:
                         break;                          break;
                 }                  }
         }          }
         if (outconf->tag != NULL && outconf->tag_found == 0 &&          if (conf->output.tag != NULL && conf->output.tag_found == 0 &&
             tag_exists(outconf->tag))              tag_exists(conf->output.tag))
                 outconf->tag_found = 1;                  conf->output.tag_found = 1;
         if (mandoc_msg_getmin() < MANDOCERR_STYLE)  
                 check_xr();          if (mandoc_msg_getmin() < MANDOCERR_STYLE) {
                   if (basepaths.sz == 0)
                           manpath_base(&basepaths);
                   check_xr(&basepaths);
           } else if (mandoc_msg_getmin() < MANDOCERR_WARNING)
                   check_xr(&conf->manpath);
 }  }
   
 static void  static void
 check_xr(void)  check_xr(struct manpaths *paths)
 {  {
         static struct manpaths   paths;  
         struct mansearch         search;          struct mansearch         search;
         struct mandoc_xr        *xr;          struct mandoc_xr        *xr;
         size_t                   sz;          size_t                   sz;
   
         if (paths.sz == 0)  
                 manpath_base(&paths);  
   
         for (xr = mandoc_xr_get(); xr != NULL; xr = xr->next) {          for (xr = mandoc_xr_get(); xr != NULL; xr = xr->next) {
                 if (xr->line == -1)                  if (xr->line == -1)
                         continue;                          continue;
Line 977  check_xr(void)
Line 1046  check_xr(void)
                 search.outkey = NULL;                  search.outkey = NULL;
                 search.argmode = ARG_NAME;                  search.argmode = ARG_NAME;
                 search.firstmatch = 1;                  search.firstmatch = 1;
                 if (mansearch(&search, &paths, 1, &xr->name, NULL, &sz))                  if (mansearch(&search, paths, 1, &xr->name, NULL, &sz))
                         continue;                          continue;
                 if (fs_search(&search, &paths, xr->name, NULL, &sz) != -1)                  if (fs_search(&search, paths, xr->name, NULL, &sz) != -1)
                         continue;                          continue;
                 if (xr->count == 1)                  if (xr->count == 1)
                         mandoc_msg(MANDOCERR_XR_BAD, xr->line,                          mandoc_msg(MANDOCERR_XR_BAD, xr->line,

Legend:
Removed from v.1.351  
changed lines
  Added in v.1.357

CVSweb