[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.15

version 1.14, 2011/11/18 07:02:19 version 1.15, 2011/11/20 15:43:14
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 28 
Line 29 
 #include "apropos_db.h"  #include "apropos_db.h"
 #include "mandoc.h"  #include "mandoc.h"
   
   /*
    * List of paths to be searched for manual databases.
    */
   struct  manpaths {
           int       sz;
           char    **paths;
   };
   
 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 *);
   static  int      manpath_add(struct manpaths *, const char *);
   static  int      manpath_parse(struct manpaths *, char *);
 static  void     usage(void);  static  void     usage(void);
   
 static  char    *progname;  static  char    *progname;
Line 37  static char *progname;
Line 48  static char *progname;
 int  int
 main(int argc, char *argv[])  main(int argc, char *argv[])
 {  {
         int              ch;          int              i, ch, rc;
           struct manpaths  paths;
         size_t           terms;          size_t           terms;
         struct opts      opts;          struct opts      opts;
         struct expr     *e;          struct expr     *e;
         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:")))          memset(&paths, 0, sizeof(struct manpaths));
           memset(&opts, 0, sizeof(struct opts));
   
           e = NULL;
           rc = 0;
   
           while (-1 != (ch = getopt(argc, argv, "m:S:s:")))
                 switch (ch) {                  switch (ch) {
                   case ('m'):
                           if ( ! manpath_parse(&paths, optarg))
                                   goto out;
                           break;
                 case ('S'):                  case ('S'):
                         opts.arch = optarg;                          opts.arch = optarg;
                         break;                          break;
Line 62  main(int argc, char *argv[])
Line 82  main(int argc, char *argv[])
                         break;                          break;
                 default:                  default:
                         usage();                          usage();
                         return(EXIT_FAILURE);                          goto out;
                 }                  }
   
         argc -= optind;          argc -= optind;
         argv += optind;          argv += optind;
   
         if (0 == argc)          if (0 == argc) {
                 return(EXIT_SUCCESS);                  rc = 1;
                   goto out;
           }
   
           if (0 == paths.sz && ! manpath_add(&paths, "."))
                   goto out;
   
         if (NULL == (e = exprcomp(argc, argv, &terms))) {          if (NULL == (e = exprcomp(argc, argv, &terms))) {
                   /* FIXME: be more specific about this. */
                 fprintf(stderr, "Bad expression\n");                  fprintf(stderr, "Bad expression\n");
                 return(EXIT_FAILURE);                  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);          /* FIXME: report an error based on ch. */
   
   out:
           for (i = 0; i < paths.sz; i++)
                   free(paths.paths[i]);
   
           free(paths.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 118  static void
Line 146  static void
 usage(void)  usage(void)
 {  {
   
         fprintf(stderr, "usage: %s [-S arch] [-s section] "          fprintf(stderr, "usage: %s "
                           "[-m dirs] "
                           "[-S arch] "
                           "[-s section] "
                         "expression...\n", progname);                          "expression...\n", progname);
   }
   
   /*
    * Parse a FULL pathname from a colon-separated list of arrays.
    */
   static int
   manpath_parse(struct manpaths *dirs, char *path)
   {
           char    *dir;
   
           for (dir = strtok(path, ":"); dir; dir = strtok(NULL, ":"))
                   if ( ! manpath_add(dirs, dir))
                           return(0);
   
           return(1);
   }
   
   /*
    * Add a directory to the array.
    * Grow the array one-by-one for simplicity's sake.
    * Return 0 if the directory is not a real path.
    */
   static int
   manpath_add(struct manpaths *dirs, const char *dir)
   {
           char             buf[PATH_MAX];
           char            *cp;
   
           if (NULL == (cp = realpath(dir, buf))) {
                   fprintf(stderr, "%s: Invalid path\n", dir);
                   return(0);
           }
   
           dirs->paths = mandoc_realloc
                   (dirs->paths,
                    ((size_t)dirs->sz + 1) * sizeof(char *));
   
           dirs->paths[dirs->sz++] = mandoc_strdup(cp);
           return(1);
 }  }

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

CVSweb