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

Diff for /mandoc/main.c between version 1.294 and 1.295

version 1.294, 2017/07/01 09:47:30 version 1.295, 2017/07/01 12:02:31
Line 92  static int    fs_lookup(const struct manpaths *,
Line 92  static int    fs_lookup(const struct manpaths *,
                                 size_t ipath, const char *,                                  size_t ipath, const char *,
                                 const char *, const char *,                                  const char *, const char *,
                                 struct manpage **, size_t *);                                  struct manpage **, size_t *);
 static  void              fs_search(const struct mansearch *,  static  int               fs_search(const struct mansearch *,
                                 const struct manpaths *, int, char**,                                  const struct manpaths *, int, char**,
                                 struct manpage **, size_t *);                                  struct manpage **, size_t *);
 static  int               koptions(int *, char *);  static  int               koptions(int *, char *);
Line 669  fs_lookup(const struct manpaths *paths, size_t ipath,
Line 669  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)
                   return 1;
         *res = mandoc_reallocarray(*res, ++*ressz, sizeof(struct manpage));          *res = mandoc_reallocarray(*res, ++*ressz, sizeof(struct manpage));
         page = *res + (*ressz - 1);          page = *res + (*ressz - 1);
         page->file = file;          page->file = file;
Line 681  found:
Line 683  found:
         return 1;          return 1;
 }  }
   
 static void  static int
 fs_search(const struct mansearch *cfg, const struct manpaths *paths,  fs_search(const struct mansearch *cfg, const struct manpaths *paths,
         int argc, char **argv, struct manpage **res, size_t *ressz)          int argc, char **argv, struct manpage **res, size_t *ressz)
 {  {
Line 693  fs_search(const struct mansearch *cfg, const struct ma
Line 695  fs_search(const struct mansearch *cfg, const struct ma
   
         assert(cfg->argmode == ARG_NAME);          assert(cfg->argmode == ARG_NAME);
   
         *res = NULL;          if (res != NULL)
                   *res = NULL;
         *ressz = lastsz = 0;          *ressz = lastsz = 0;
         while (argc) {          while (argc) {
                 for (ipath = 0; ipath < paths->sz; ipath++) {                  for (ipath = 0; ipath < paths->sz; ipath++) {
Line 701  fs_search(const struct mansearch *cfg, const struct ma
Line 704  fs_search(const struct mansearch *cfg, const struct ma
                                 if (fs_lookup(paths, ipath, cfg->sec,                                  if (fs_lookup(paths, ipath, cfg->sec,
                                     cfg->arch, *argv, res, ressz) &&                                      cfg->arch, *argv, res, ressz) &&
                                     cfg->firstmatch)                                      cfg->firstmatch)
                                         return;                                          return 1;
                         } else for (isec = 0; isec < nsec; isec++)                          } else for (isec = 0; isec < nsec; isec++)
                                 if (fs_lookup(paths, ipath, sections[isec],                                  if (fs_lookup(paths, ipath, sections[isec],
                                     cfg->arch, *argv, res, ressz) &&                                      cfg->arch, *argv, res, ressz) &&
                                     cfg->firstmatch)                                      cfg->firstmatch)
                                         return;                                          return 1;
                 }                  }
                 if (*ressz == lastsz)                  if (res != NULL && *ressz == lastsz)
                         warnx("No entry for %s in the manual.", *argv);                          warnx("No entry for %s in the manual.", *argv);
                 lastsz = *ressz;                  lastsz = *ressz;
                 argv++;                  argv++;
                 argc--;                  argc--;
         }          }
           return 0;
 }  }
   
 static void  static void
Line 826  check_xr(const char *file)
Line 830  check_xr(const char *file)
                 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;
                   if (fs_search(&search, &paths, 1, &xr->name, NULL, &sz))
                         continue;                          continue;
                 mandoc_asprintf(&cp, "Xr %s %s", xr->name, xr->sec);                  mandoc_asprintf(&cp, "Xr %s %s", xr->name, xr->sec);
                 mmsg(MANDOCERR_XR_BAD, MANDOCLEVEL_STYLE,                  mmsg(MANDOCERR_XR_BAD, MANDOCLEVEL_STYLE,

Legend:
Removed from v.1.294  
changed lines
  Added in v.1.295

CVSweb