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

Diff for /mandoc/main.c between version 1.186 and 1.191

version 1.186, 2014/08/23 00:34:59 version 1.191, 2014/09/03 18:09:14
Line 154  main(int argc, char *argv[])
Line 154  main(int argc, char *argv[])
         show_usage = 0;          show_usage = 0;
         outmode = OUTMODE_DEF;          outmode = OUTMODE_DEF;
   
         while (-1 != (c = getopt(argc, argv, "aC:cfI:ikM:m:O:S:s:T:VW:w"))) {          while (-1 != (c = getopt(argc, argv, "aC:cfhI:iklM:m:O:S:s:T:VW:w"))) {
                 switch (c) {                  switch (c) {
                 case 'a':                  case 'a':
                         outmode = OUTMODE_ALL;                          outmode = OUTMODE_ALL;
Line 168  main(int argc, char *argv[])
Line 168  main(int argc, char *argv[])
                 case 'f':                  case 'f':
                         search.argmode = ARG_WORD;                          search.argmode = ARG_WORD;
                         break;                          break;
                   case 'h':
                           (void)strlcat(curp.outopts, "synopsis,", BUFSIZ);
                           outmode = OUTMODE_ALL;
                           break;
                 case 'I':                  case 'I':
                         if (strncmp(optarg, "os=", 3)) {                          if (strncmp(optarg, "os=", 3)) {
                                 fprintf(stderr,                                  fprintf(stderr,
Line 189  main(int argc, char *argv[])
Line 193  main(int argc, char *argv[])
                 case 'k':                  case 'k':
                         search.argmode = ARG_EXPR;                          search.argmode = ARG_EXPR;
                         break;                          break;
                   case 'l':
                           search.argmode = ARG_FILE;
                           outmode = OUTMODE_ALL;
                           break;
                 case 'M':                  case 'M':
                         defpaths = optarg;                          defpaths = optarg;
                         break;                          break;
Line 280  main(int argc, char *argv[])
Line 288  main(int argc, char *argv[])
                 mansearch_setup(1);                  mansearch_setup(1);
                 if( ! mansearch(&search, &paths, argc, argv, &res, &sz))                  if( ! mansearch(&search, &paths, argc, argv, &res, &sz))
                         usage(search.argmode);                          usage(search.argmode);
                 manpath_free(&paths);  
                 resp = res;                  resp = res;
   
                   if (sz == 0) {
                           if (search.argmode == ARG_NAME)
                                   fprintf(stderr, "%s: No entry for %s "
                                       "in the manual.\n", progname, argv[0]);
                           rc = MANDOCLEVEL_BADARG;
                           goto out;
                   }
   
                 /*                  /*
                  * For standard man(1) and -a output mode,                   * For standard man(1) and -a output mode,
                  * prepare for copying filename pointers                   * prepare for copying filename pointers
Line 355  main(int argc, char *argv[])
Line 370  main(int argc, char *argv[])
         while (argc) {          while (argc) {
 #if HAVE_SQLITE3  #if HAVE_SQLITE3
                 if (resp != NULL) {                  if (resp != NULL) {
                         if (resp->form)                          if (resp->form & FORM_SRC) {
                                   /* For .so only; ignore failure. */
                                   chdir(paths.paths[resp->ipath]);
                                 parse(&curp, -1, resp->file, &rc);                                  parse(&curp, -1, resp->file, &rc);
                         else                          } else
                                 rc = passthrough(resp->file);                                  rc = passthrough(resp->file);
                         resp++;                          resp++;
                 } else                  } else
Line 376  main(int argc, char *argv[])
Line 393  main(int argc, char *argv[])
 #if HAVE_SQLITE3  #if HAVE_SQLITE3
 out:  out:
         if (search.argmode != ARG_FILE) {          if (search.argmode != ARG_FILE) {
                   manpath_free(&paths);
                 mansearch_free(res, sz);                  mansearch_free(res, sz);
                 mansearch_setup(0);                  mansearch_setup(0);
         }          }
Line 400  usage(enum argmode argmode)
Line 418  usage(enum argmode argmode)
   
         switch (argmode) {          switch (argmode) {
         case ARG_FILE:          case ARG_FILE:
                 fputs("usage: mandoc [-V] [-Ios=name] [-mformat]"                  fputs("usage: mandoc [-acfhklV] [-Ios=name] "
                     " [-Ooption] [-Toutput] [-Wlevel]\n"                      "[-mformat] [-Ooption] [-Toutput] [-Wlevel]\n"
                     "\t      [file ...]\n", stderr);                      "\t      [file ...]\n", stderr);
                 break;                  break;
         case ARG_NAME:          case ARG_NAME:
                 fputs("usage: man [-acfhkVw] [-C file] "                  fputs("usage: man [-acfhklVw] [-C file] "
                     "[-M path] [-m path] [-S arch] [-s section]\n"                      "[-M path] [-m path] [-S arch] [-s section]\n"
                     "\t   [section] name ...\n", stderr);                      "\t   [section] name ...\n", stderr);
                 break;                  break;
         case ARG_WORD:          case ARG_WORD:
                 fputs("usage: whatis [-V] [-C file] [-M path] [-m path] "                  fputs("usage: whatis [-acfhklVw] [-C file] "
                     "[-S arch] [-s section] name ...\n", stderr);                      "[-M path] [-m path] [-O outkey] [-S arch]\n"
                       "\t      [-s section] name ...\n", stderr);
                 break;                  break;
         case ARG_EXPR:          case ARG_EXPR:
                 fputs("usage: apropos [-V] [-C file] [-M path] [-m path] "                  fputs("usage: apropos [-acfhklVw] [-C file] "
                     "[-O outkey] [-S arch]\n"                      "[-M path] [-m path] [-O outkey] [-S arch]\n"
                     "\t       [-s section] expression ...\n", stderr);                      "\t       [-s section] expression ...\n", stderr);
                 break;                  break;
         }          }

Legend:
Removed from v.1.186  
changed lines
  Added in v.1.191

CVSweb