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

Diff for /mandoc/mandocdb.c between version 1.97 and 1.101

version 1.97, 2014/01/05 00:29:54 version 1.101, 2014/01/05 04:48:40
Line 114  struct mlink {
Line 114  struct mlink {
         struct mlink    *next;    /* singly linked list */          struct mlink    *next;    /* singly linked list */
 };  };
   
 struct  title {  
         char            *title; /* name(sec/arch) given inside the file */  
         char            *file; /* file name in case of mismatch */  
 };  
   
 enum    stmt {  enum    stmt {
         STMT_DELETE_PAGE = 0,   /* delete mpage */          STMT_DELETE_PAGE = 0,   /* delete mpage */
         STMT_INSERT_PAGE,       /* insert mpage */          STMT_INSERT_PAGE,       /* insert mpage */
Line 147  static int  mlink_check(struct mpage *, struct mlink *
Line 142  static int  mlink_check(struct mpage *, struct mlink *
 static  void     mlink_free(struct mlink *);  static  void     mlink_free(struct mlink *);
 static  void     mlinks_undupe(struct mpage *);  static  void     mlinks_undupe(struct mpage *);
 static  void     mpages_free(void);  static  void     mpages_free(void);
 static  void     mpages_merge(struct mchars *, struct mparse *, int);  static  void     mpages_merge(struct mchars *, struct mparse *);
 static  void     parse_cat(struct mpage *);  static  void     parse_cat(struct mpage *);
 static  void     parse_man(struct mpage *, const struct man_node *);  static  void     parse_man(struct mpage *, const struct man_node *);
 static  void     parse_mdoc(struct mpage *, const struct mdoc_node *);  static  void     parse_mdoc(struct mpage *, const struct mdoc_node *);
Line 435  main(int argc, char *argv[])
Line 430  main(int argc, char *argv[])
                 if (OP_TEST != op)                  if (OP_TEST != op)
                         dbprune();                          dbprune();
                 if (OP_DELETE != op)                  if (OP_DELETE != op)
                         mpages_merge(mc, mp, 0);                          mpages_merge(mc, mp);
                 dbclose(1);                  dbclose(1);
         } else {          } else {
                 /*                  /*
Line 479  main(int argc, char *argv[])
Line 474  main(int argc, char *argv[])
                         if (0 == dbopen(0))                          if (0 == dbopen(0))
                                 goto out;                                  goto out;
   
                         mpages_merge(mc, mp, warnings && !use_all);                          mpages_merge(mc, mp);
                         dbclose(0);                          dbclose(0);
   
                         if (j + 1 < dirs.sz) {                          if (j + 1 < dirs.sz) {
Line 945  mlink_check(struct mpage *mpage, struct mlink *mlink)
Line 940  mlink_check(struct mpage *mpage, struct mlink *mlink)
  * and filename to determine whether the file is parsable or not.   * and filename to determine whether the file is parsable or not.
  */   */
 static void  static void
 mpages_merge(struct mchars *mc, struct mparse *mp, int check_reachable)  mpages_merge(struct mchars *mc, struct mparse *mp)
 {  {
         struct ohash             title_table;          struct ohash_info        str_info;
         struct ohash_info        title_info, str_info;  
         struct mpage            *mpage;          struct mpage            *mpage;
         struct mlink            *mlink;          struct mlink            *mlink;
         struct mdoc             *mdoc;          struct mdoc             *mdoc;
         struct man              *man;          struct man              *man;
         struct title            *title_entry;  
         char                    *title_str;  
         const char              *cp;          const char              *cp;
         int                      match;          int                      match;
         unsigned int             pslot, tslot;          unsigned int             pslot;
         enum mandoclevel         lvl;          enum mandoclevel         lvl;
   
         str_info.alloc = hash_alloc;          str_info.alloc = hash_alloc;
Line 965  mpages_merge(struct mchars *mc, struct mparse *mp, int
Line 957  mpages_merge(struct mchars *mc, struct mparse *mp, int
         str_info.hfree = hash_free;          str_info.hfree = hash_free;
         str_info.key_offset = offsetof(struct str, key);          str_info.key_offset = offsetof(struct str, key);
   
         if (check_reachable) {  
                 title_info.alloc = hash_alloc;  
                 title_info.halloc = hash_halloc;  
                 title_info.hfree = hash_free;  
                 title_info.key_offset = offsetof(struct title, title);  
                 ohash_init(&title_table, 6, &title_info);  
         }  
   
         mpage = ohash_first(&mpages, &pslot);          mpage = ohash_first(&mpages, &pslot);
         while (NULL != mpage) {          while (NULL != mpage) {
                 mlinks_undupe(mpage);                  mlinks_undupe(mpage);
Line 1025  mpages_merge(struct mchars *mc, struct mparse *mp, int
Line 1009  mpages_merge(struct mchars *mc, struct mparse *mp, int
                             mandoc_strdup(mpage->mlinks->name);                              mandoc_strdup(mpage->mlinks->name);
                 }                  }
                 putkey(mpage, mpage->sec, TYPE_sec);                  putkey(mpage, mpage->sec, TYPE_sec);
                 putkey(mpage, mpage->arch, TYPE_arch);                  putkey(mpage, '\0' == *mpage->arch ?
                       "any" : mpage->arch, TYPE_arch);
   
                 for (mlink = mpage->mlinks; mlink; mlink = mlink->next) {                  for (mlink = mpage->mlinks; mlink; mlink = mlink->next) {
                         if ('\0' != *mlink->dsec)                          if ('\0' != *mlink->dsec)
                                 putkey(mpage, mlink->dsec, TYPE_sec);                                  putkey(mpage, mlink->dsec, TYPE_sec);
                         if ('\0' != *mlink->fsec)                          if ('\0' != *mlink->fsec)
                                 putkey(mpage, mlink->fsec, TYPE_sec);                                  putkey(mpage, mlink->fsec, TYPE_sec);
                         putkey(mpage, mlink->arch, TYPE_arch);                          putkey(mpage, '\0' == *mlink->arch ?
                               "any" : mlink->arch, TYPE_arch);
                         putkey(mpage, mlink->name, TYPE_Nm);                          putkey(mpage, mlink->name, TYPE_Nm);
                 }                  }
   
Line 1057  mpages_merge(struct mchars *mc, struct mparse *mp, int
Line 1043  mpages_merge(struct mchars *mc, struct mparse *mp, int
                 else                  else
                         parse_cat(mpage);                          parse_cat(mpage);
   
                 /*  
                  * Build a title string for the file.  If it matches  
                  * the location of the file, remember the title as  
                  * found; else, remember it as missing.  
                  */  
   
                 if (check_reachable) {  
                         if (-1 == asprintf(&title_str, "%s(%s%s%s)",  
                             mpage->title, mpage->sec,  
                             '\0' == *mpage->arch ? "" : "/",  
                             mpage->arch)) {  
                                 perror(NULL);  
                                 exit((int)MANDOCLEVEL_SYSERR);  
                         }  
                         tslot = ohash_qlookup(&title_table, title_str);  
                         title_entry = ohash_find(&title_table, tslot);  
                         if (NULL == title_entry) {  
                                 title_entry = mandoc_malloc(  
                                                 sizeof(struct title));  
                                 title_entry->title = title_str;  
                                 title_entry->file = mandoc_strdup(  
                                     match ? "" : mpage->mlinks->file);  
                                 ohash_insert(&title_table, tslot,  
                                                 title_entry);  
                         } else {  
                                 if (match)  
                                         *title_entry->file = '\0';  
                                 free(title_str);  
                         }  
                 }  
   
                 dbindex(mpage, mc);                  dbindex(mpage, mc);
                 ohash_delete(&strings);                  ohash_delete(&strings);
                 mpage = ohash_next(&mpages, &pslot);                  mpage = ohash_next(&mpages, &pslot);
         }          }
   
         if (check_reachable) {  
                 title_entry = ohash_first(&title_table, &tslot);  
                 while (NULL != title_entry) {  
                         if ('\0' != *title_entry->file)  
                                 say(title_entry->file,  
                                     "Probably unreachable, title is %s",  
                                     title_entry->title);  
                         free(title_entry->title);  
                         free(title_entry->file);  
                         free(title_entry);  
                         title_entry = ohash_next(&title_table, &tslot);  
                 }  
                 ohash_delete(&title_table);  
         }  
 }  }
   
 static void  static void
Line 1816  dbindex(const struct mpage *mpage, struct mchars *mc)
Line 1756  dbindex(const struct mpage *mpage, struct mchars *mc)
         SQL_EXEC("BEGIN TRANSACTION");          SQL_EXEC("BEGIN TRANSACTION");
   
         i = 1;          i = 1;
         /*  
          * XXX The following three lines are obsolete  
          * and only kept for backward compatibility  
          * until apropos(1) and friends have caught up.  
          */  
         SQL_BIND_TEXT(stmts[STMT_INSERT_PAGE], i, mpage->mlinks->file);  
         SQL_BIND_TEXT(stmts[STMT_INSERT_PAGE], i, mpage->mlinks->dsec);  
         SQL_BIND_TEXT(stmts[STMT_INSERT_PAGE], i, mpage->mlinks->arch);  
         SQL_BIND_TEXT(stmts[STMT_INSERT_PAGE], i, desc);          SQL_BIND_TEXT(stmts[STMT_INSERT_PAGE], i, desc);
         SQL_BIND_INT(stmts[STMT_INSERT_PAGE], i, FORM_SRC == mpage->form);          SQL_BIND_INT(stmts[STMT_INSERT_PAGE], i, FORM_SRC == mpage->form);
         SQL_STEP(stmts[STMT_INSERT_PAGE]);          SQL_STEP(stmts[STMT_INSERT_PAGE]);
Line 1960  dbopen(int real)
Line 1892  dbopen(int real)
                 return(0);                  return(0);
         }          }
   
         /*  
          * XXX The first three columns in table mpages are obsolete  
          * and only kept for backward compatibility  
          * until apropos(1) and friends have caught up.  
          */  
         sql = "CREATE TABLE \"mpages\" (\n"          sql = "CREATE TABLE \"mpages\" (\n"
               " \"file\" TEXT NOT NULL,\n"  
               " \"sec\" TEXT NOT NULL,\n"  
               " \"arch\" TEXT NOT NULL,\n"  
               " \"desc\" TEXT NOT NULL,\n"                " \"desc\" TEXT NOT NULL,\n"
               " \"form\" INTEGER NOT NULL,\n"                " \"form\" INTEGER NOT NULL,\n"
               " \"id\" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL\n"                " \"id\" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL\n"
Line 2005  prepare_statements:
Line 1929  prepare_statements:
         sql = "DELETE FROM mpages where file=?";          sql = "DELETE FROM mpages where file=?";
         sqlite3_prepare_v2(db, sql, -1, &stmts[STMT_DELETE_PAGE], NULL);          sqlite3_prepare_v2(db, sql, -1, &stmts[STMT_DELETE_PAGE], NULL);
         sql = "INSERT INTO mpages "          sql = "INSERT INTO mpages "
                 "(file,sec,arch,desc,form) VALUES (?,?,?,?,?)";                  "(desc,form) VALUES (?,?)";
         sqlite3_prepare_v2(db, sql, -1, &stmts[STMT_INSERT_PAGE], NULL);          sqlite3_prepare_v2(db, sql, -1, &stmts[STMT_INSERT_PAGE], NULL);
         sql = "INSERT INTO mlinks "          sql = "INSERT INTO mlinks "
                 "(file,sec,arch,name,pageid) VALUES (?,?,?,?,?)";                  "(file,sec,arch,name,pageid) VALUES (?,?,?,?,?)";

Legend:
Removed from v.1.97  
changed lines
  Added in v.1.101

CVSweb