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

Diff for /mandoc/Attic/apropos.c between version 1.14 and 1.20

version 1.14, 2011/11/18 07:02:19 version 1.20, 2011/11/27 18:54:01
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
    * Copyright (c) 2011 Ingo Schwarze <schwarze@openbsd.org>
  *   *
  * Permission to use, copy, modify, and distribute this software for any   * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above   * purpose with or without fee is hereby granted, provided that the above
Line 20 
Line 21 
   
 #include <assert.h>  #include <assert.h>
 #include <getopt.h>  #include <getopt.h>
 #include <limits.h>  
 #include <stdio.h>  #include <stdio.h>
 #include <stdlib.h>  #include <stdlib.h>
 #include <string.h>  #include <string.h>
   
 #include "apropos_db.h"  #include "apropos_db.h"
 #include "mandoc.h"  #include "mandoc.h"
   #include "manpath.h"
   
 static  int      cmp(const void *, const void *);  static  int      cmp(const void *, const void *);
 static  void     list(struct res *, size_t, void *);  static  void     list(struct res *, size_t, void *);
Line 37  static char *progname;
Line 38  static char *progname;
 int  int
 main(int argc, char *argv[])  main(int argc, char *argv[])
 {  {
         int              ch;          int              ch, rc, whatis;
           struct manpaths  paths;
         size_t           terms;          size_t           terms;
         struct opts      opts;          struct opts      opts;
         struct expr     *e;          struct expr     *e;
           char            *defpaths, *auxpaths;
         extern int       optind;          extern int       optind;
         extern char     *optarg;          extern char     *optarg;
   
         memset(&opts, 0, sizeof(struct opts));  
   
         progname = strrchr(argv[0], '/');          progname = strrchr(argv[0], '/');
         if (progname == NULL)          if (progname == NULL)
                 progname = argv[0];                  progname = argv[0];
         else          else
                 ++progname;                  ++progname;
   
         while (-1 != (ch = getopt(argc, argv, "S:s:")))          whatis = 0 == strcmp(progname, "whatis");
   
           memset(&paths, 0, sizeof(struct manpaths));
           memset(&opts, 0, sizeof(struct opts));
   
           auxpaths = defpaths = NULL;
           e = NULL;
   
           while (-1 != (ch = getopt(argc, argv, "M:m:S:s:")))
                 switch (ch) {                  switch (ch) {
                   case ('M'):
                           defpaths = optarg;
                           break;
                   case ('m'):
                           auxpaths = optarg;
                           break;
                 case ('S'):                  case ('S'):
                         opts.arch = optarg;                          opts.arch = optarg;
                         break;                          break;
Line 71  main(int argc, char *argv[])
Line 86  main(int argc, char *argv[])
         if (0 == argc)          if (0 == argc)
                 return(EXIT_SUCCESS);                  return(EXIT_SUCCESS);
   
         if (NULL == (e = exprcomp(argc, argv, &terms))) {          rc = 0;
                 fprintf(stderr, "Bad expression\n");  
                 return(EXIT_FAILURE);          manpath_parse(&paths, defpaths, auxpaths);
   
           e = whatis ? termcomp(argc, argv, &terms) :
                        exprcomp(argc, argv, &terms);
   
           if (NULL == e) {
                   fprintf(stderr, "%s: Bad expression\n", progname);
                   goto out;
         }          }
   
         /*          rc = apropos_search
          * Configure databases.                  (paths.sz, paths.paths,
          * The keyword database is a btree that allows for duplicate                   &opts, e, terms, NULL, list);
          * entries.  
          * The index database is a recno.  
          */  
   
         ch = apropos_search(&opts, e, terms, NULL, list);          if (0 == rc)
                   fprintf(stderr, "%s: Error reading "
                                   "manual database\n", progname);
   
   out:
           manpath_free(&paths);
         exprfree(e);          exprfree(e);
         if (0 == ch)  
                 fprintf(stderr, "%s: Database error\n", progname);          return(rc ? EXIT_SUCCESS : EXIT_FAILURE);
         return(ch ? EXIT_SUCCESS : EXIT_FAILURE);  
 }  }
   
 /* ARGSUSED */  /* ARGSUSED */
Line 99  list(struct res *res, size_t sz, void *arg)
Line 122  list(struct res *res, size_t sz, void *arg)
         qsort(res, sz, sizeof(struct res), cmp);          qsort(res, sz, sizeof(struct res), cmp);
   
         for (i = 0; i < (int)sz; i++)          for (i = 0; i < (int)sz; i++)
                 printf("%s(%s%s%s) - %s\n", res[i].title,                  printf("%s(%s%s%s) - %s\n", res[i].title,
                                 res[i].cat,                                  res[i].cat,
                                 *res[i].arch ? "/" : "",                                  *res[i].arch ? "/" : "",
                                 *res[i].arch ? res[i].arch : "",                                  *res[i].arch ? res[i].arch : "",
                                 res[i].desc);                                  res[i].desc);
Line 118  static void
Line 141  static void
 usage(void)  usage(void)
 {  {
   
         fprintf(stderr, "usage: %s [-S arch] [-s section] "          fprintf(stderr, "usage: %s "
                         "expression...\n", progname);                          "[-M path] "
                           "[-m path] "
                           "[-S arch] "
                           "[-s section] "
                           "expression...\n",
                           progname);
 }  }

Legend:
Removed from v.1.14  
changed lines
  Added in v.1.20

CVSweb