version 1.195, 2015/07/19 06:05:16 |
version 1.198, 2015/10/11 21:12:54 |
|
|
|
|
#include <assert.h> |
#include <assert.h> |
#include <ctype.h> |
#include <ctype.h> |
|
#include <err.h> |
#include <errno.h> |
#include <errno.h> |
#include <fcntl.h> |
#include <fcntl.h> |
#if HAVE_FTS |
#if HAVE_FTS |
Line 189 static int set_basedir(const char *, int); |
|
Line 190 static int set_basedir(const char *, int); |
|
static int treescan(void); |
static int treescan(void); |
static size_t utf8(unsigned int, char [7]); |
static size_t utf8(unsigned int, char [7]); |
|
|
|
extern char *__progname; |
|
|
static char tempfilename[32]; |
static char tempfilename[32]; |
static char *progname; |
|
static int nodb; /* no database changes */ |
static int nodb; /* no database changes */ |
static int mparse_options; /* abort the parse early */ |
static int mparse_options; /* abort the parse early */ |
static int use_all; /* use all found files */ |
static int use_all; /* use all found files */ |
Line 357 mandocdb(int argc, char *argv[]) |
|
Line 359 mandocdb(int argc, char *argv[]) |
|
mpages_info.key_offset = offsetof(struct mpage, inodev); |
mpages_info.key_offset = offsetof(struct mpage, inodev); |
mlinks_info.key_offset = offsetof(struct mlink, file); |
mlinks_info.key_offset = offsetof(struct mlink, file); |
|
|
progname = strrchr(argv[0], '/'); |
|
if (progname == NULL) |
|
progname = argv[0]; |
|
else |
|
++progname; |
|
|
|
/* |
/* |
* We accept a few different invocations. |
* We accept a few different invocations. |
* The CHECKOP macro makes sure that invocation styles don't |
* The CHECKOP macro makes sure that invocation styles don't |
Line 370 mandocdb(int argc, char *argv[]) |
|
Line 366 mandocdb(int argc, char *argv[]) |
|
*/ |
*/ |
#define CHECKOP(_op, _ch) do \ |
#define CHECKOP(_op, _ch) do \ |
if (OP_DEFAULT != (_op)) { \ |
if (OP_DEFAULT != (_op)) { \ |
fprintf(stderr, "%s: -%c: Conflicting option\n", \ |
warnx("-%c: Conflicting option", (_ch)); \ |
progname, (_ch)); \ |
|
goto usage; \ |
goto usage; \ |
} while (/*CONSTCOND*/0) |
} while (/*CONSTCOND*/0) |
|
|
Line 407 mandocdb(int argc, char *argv[]) |
|
Line 402 mandocdb(int argc, char *argv[]) |
|
break; |
break; |
case 'T': |
case 'T': |
if (strcmp(optarg, "utf8")) { |
if (strcmp(optarg, "utf8")) { |
fprintf(stderr, "%s: -T%s: " |
warnx("-T%s: Unsupported output format", |
"Unsupported output format\n", |
optarg); |
progname, optarg); |
|
goto usage; |
goto usage; |
} |
} |
write_utf8 = 1; |
write_utf8 = 1; |
Line 436 mandocdb(int argc, char *argv[]) |
|
Line 430 mandocdb(int argc, char *argv[]) |
|
argv += optind; |
argv += optind; |
|
|
if (OP_CONFFILE == op && argc > 0) { |
if (OP_CONFFILE == op && argc > 0) { |
fprintf(stderr, "%s: -C: Too many arguments\n", |
warnx("-C: Too many arguments"); |
progname); |
|
goto usage; |
goto usage; |
} |
} |
|
|
|
|
mpages_free(); |
mpages_free(); |
ohash_delete(&mpages); |
ohash_delete(&mpages); |
ohash_delete(&mlinks); |
ohash_delete(&mlinks); |
return(exitcode); |
return exitcode; |
usage: |
usage: |
fprintf(stderr, "usage: %s [-aDnpQ] [-C file] [-Tutf8]\n" |
fprintf(stderr, "usage: %s [-aDnpQ] [-C file] [-Tutf8]\n" |
" %s [-aDnpQ] [-Tutf8] dir ...\n" |
" %s [-aDnpQ] [-Tutf8] dir ...\n" |
" %s [-DnpQ] [-Tutf8] -d dir [file ...]\n" |
" %s [-DnpQ] [-Tutf8] -d dir [file ...]\n" |
" %s [-Dnp] -u dir [file ...]\n" |
" %s [-Dnp] -u dir [file ...]\n" |
" %s [-Q] -t file ...\n", |
" %s [-Q] -t file ...\n", |
progname, progname, progname, |
__progname, __progname, __progname, |
progname, progname); |
__progname, __progname); |
|
|
return((int)MANDOCLEVEL_BADARG); |
return (int)MANDOCLEVEL_BADARG; |
} |
} |
|
|
/* |
/* |
|
|
if (NULL == f) { |
if (NULL == f) { |
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say("", "&fts_open"); |
say("", "&fts_open"); |
return(0); |
return 0; |
} |
} |
|
|
dsec = arch = NULL; |
dsec = arch = NULL; |
|
|
} |
} |
|
|
fts_close(f); |
fts_close(f); |
return(1); |
return 1; |
} |
} |
|
|
/* |
/* |
Line 1604 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
Line 1597 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
if (SEC_SYNOPSIS != n->sec || |
if (SEC_SYNOPSIS != n->sec || |
NULL == (n = n->child) || |
NULL == (n = n->child) || |
n->type != ROFFT_TEXT) |
n->type != ROFFT_TEXT) |
return(0); |
return 0; |
|
|
/* |
/* |
* Only consider those `Fd' macro fields that begin with an |
* Only consider those `Fd' macro fields that begin with an |
Line 1612 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
Line 1605 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
*/ |
*/ |
|
|
if (strcmp("#include", n->string)) |
if (strcmp("#include", n->string)) |
return(0); |
return 0; |
|
|
if ((n = n->next) == NULL || n->type != ROFFT_TEXT) |
if ((n = n->next) == NULL || n->type != ROFFT_TEXT) |
return(0); |
return 0; |
|
|
/* |
/* |
* Strip away the enclosing angle brackets and make sure we're |
* Strip away the enclosing angle brackets and make sure we're |
Line 1627 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
Line 1620 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
start++; |
start++; |
|
|
if (0 == (sz = strlen(start))) |
if (0 == (sz = strlen(start))) |
return(0); |
return 0; |
|
|
end = &start[(int)sz - 1]; |
end = &start[(int)sz - 1]; |
if ('>' == *end || '"' == *end) |
if ('>' == *end || '"' == *end) |
Line 1635 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
Line 1628 parse_mdoc_Fd(struct mpage *mpage, const struct roff_m |
|
|
|
if (end > start) |
if (end > start) |
putkeys(mpage, start, end - start + 1, TYPE_In); |
putkeys(mpage, start, end - start + 1, TYPE_In); |
return(0); |
return 0; |
} |
} |
|
|
static void |
static void |
Line 1665 parse_mdoc_Fn(struct mpage *mpage, const struct roff_m |
|
Line 1658 parse_mdoc_Fn(struct mpage *mpage, const struct roff_m |
|
{ |
{ |
|
|
if (n->child == NULL) |
if (n->child == NULL) |
return(0); |
return 0; |
|
|
parse_mdoc_fname(mpage, n->child); |
parse_mdoc_fname(mpage, n->child); |
|
|
Line 1673 parse_mdoc_Fn(struct mpage *mpage, const struct roff_m |
|
Line 1666 parse_mdoc_Fn(struct mpage *mpage, const struct roff_m |
|
if (n->type == ROFFT_TEXT) |
if (n->type == ROFFT_TEXT) |
putkey(mpage, n->string, TYPE_Fa); |
putkey(mpage, n->string, TYPE_Fa); |
|
|
return(0); |
return 0; |
} |
} |
|
|
static int |
static int |
Line 1682 parse_mdoc_Fo(struct mpage *mpage, const struct roff_m |
|
Line 1675 parse_mdoc_Fo(struct mpage *mpage, const struct roff_m |
|
{ |
{ |
|
|
if (n->type != ROFFT_HEAD) |
if (n->type != ROFFT_HEAD) |
return(1); |
return 1; |
|
|
if (n->child != NULL) |
if (n->child != NULL) |
parse_mdoc_fname(mpage, n->child); |
parse_mdoc_fname(mpage, n->child); |
|
|
return(0); |
return 0; |
} |
} |
|
|
static int |
static int |
Line 1697 parse_mdoc_Xr(struct mpage *mpage, const struct roff_m |
|
Line 1690 parse_mdoc_Xr(struct mpage *mpage, const struct roff_m |
|
char *cp; |
char *cp; |
|
|
if (NULL == (n = n->child)) |
if (NULL == (n = n->child)) |
return(0); |
return 0; |
|
|
if (NULL == n->next) { |
if (NULL == n->next) { |
putkey(mpage, n->string, TYPE_Xr); |
putkey(mpage, n->string, TYPE_Xr); |
return(0); |
return 0; |
} |
} |
|
|
mandoc_asprintf(&cp, "%s(%s)", n->string, n->next->string); |
mandoc_asprintf(&cp, "%s(%s)", n->string, n->next->string); |
putkey(mpage, cp, TYPE_Xr); |
putkey(mpage, cp, TYPE_Xr); |
free(cp); |
free(cp); |
return(0); |
return 0; |
} |
} |
|
|
static int |
static int |
Line 1717 parse_mdoc_Nd(struct mpage *mpage, const struct roff_m |
|
Line 1710 parse_mdoc_Nd(struct mpage *mpage, const struct roff_m |
|
|
|
if (n->type == ROFFT_BODY) |
if (n->type == ROFFT_BODY) |
deroff(&mpage->desc, n); |
deroff(&mpage->desc, n); |
return(0); |
return 0; |
} |
} |
|
|
static int |
static int |
Line 1739 parse_mdoc_Nm(struct mpage *mpage, const struct roff_m |
|
Line 1732 parse_mdoc_Nm(struct mpage *mpage, const struct roff_m |
|
putkey(mpage, n->child->string, ROFFT_HEAD); |
putkey(mpage, n->child->string, ROFFT_HEAD); |
mpage->name_head_done = 1; |
mpage->name_head_done = 1; |
} |
} |
return(0); |
return 0; |
} |
} |
|
|
static int |
static int |
Line 1747 parse_mdoc_Sh(struct mpage *mpage, const struct roff_m |
|
Line 1740 parse_mdoc_Sh(struct mpage *mpage, const struct roff_m |
|
const struct roff_node *n) |
const struct roff_node *n) |
{ |
{ |
|
|
return(n->sec == SEC_CUSTOM && n->type == ROFFT_HEAD); |
return n->sec == SEC_CUSTOM && n->type == ROFFT_HEAD; |
} |
} |
|
|
static int |
static int |
Line 1755 parse_mdoc_head(struct mpage *mpage, const struct roff |
|
Line 1748 parse_mdoc_head(struct mpage *mpage, const struct roff |
|
const struct roff_node *n) |
const struct roff_node *n) |
{ |
{ |
|
|
return(n->type == ROFFT_HEAD); |
return n->type == ROFFT_HEAD; |
} |
} |
|
|
static int |
static int |
Line 1763 parse_mdoc_body(struct mpage *mpage, const struct roff |
|
Line 1756 parse_mdoc_body(struct mpage *mpage, const struct roff |
|
const struct roff_node *n) |
const struct roff_node *n) |
{ |
{ |
|
|
return(n->type == ROFFT_BODY); |
return n->type == ROFFT_BODY; |
} |
} |
|
|
/* |
/* |
Line 1868 utf8(unsigned int cp, char out[7]) |
|
Line 1861 utf8(unsigned int cp, char out[7]) |
|
out[4] = (cp >> 6 & 63) | 128; |
out[4] = (cp >> 6 & 63) | 128; |
out[5] = (cp & 63) | 128; |
out[5] = (cp & 63) | 128; |
} else |
} else |
return(0); |
return 0; |
|
|
out[rc] = '\0'; |
out[rc] = '\0'; |
return(rc); |
return rc; |
} |
} |
|
|
/* |
/* |
Line 1995 render_string(char **public, size_t *psz) |
|
Line 1988 render_string(char **public, size_t *psz) |
|
--*psz; |
--*psz; |
if (dst != NULL) { |
if (dst != NULL) { |
(*public)[*psz] = '\0'; |
(*public)[*psz] = '\0'; |
return(1); |
return 1; |
} else |
} else |
return(0); |
return 0; |
} |
} |
|
|
static void |
static void |
Line 2208 dbclose(int real) |
|
Line 2201 dbclose(int real) |
|
return; |
return; |
case 0: |
case 0: |
execlp("cmp", "cmp", "-s", |
execlp("cmp", "cmp", "-s", |
tempfilename, MANDOC_DB, NULL); |
tempfilename, MANDOC_DB, (char *)NULL); |
say("", "&exec cmp"); |
say("", "&exec cmp"); |
exit(0); |
exit(0); |
default: |
default: |
Line 2233 dbclose(int real) |
|
Line 2226 dbclose(int real) |
|
say("", "&fork rm"); |
say("", "&fork rm"); |
return; |
return; |
case 0: |
case 0: |
execlp("rm", "rm", "-rf", tempfilename, NULL); |
execlp("rm", "rm", "-rf", tempfilename, (char *)NULL); |
say("", "&exec rm"); |
say("", "&exec rm"); |
exit((int)MANDOCLEVEL_SYSERR); |
exit((int)MANDOCLEVEL_SYSERR); |
default: |
default: |
Line 2264 dbopen(int real) |
|
Line 2257 dbopen(int real) |
|
int rc, ofl; |
int rc, ofl; |
|
|
if (nodb) |
if (nodb) |
return(1); |
return 1; |
|
|
*tempfilename = '\0'; |
*tempfilename = '\0'; |
ofl = SQLITE_OPEN_READWRITE; |
ofl = SQLITE_OPEN_READWRITE; |
Line 2275 dbopen(int real) |
|
Line 2268 dbopen(int real) |
|
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
if (SQLITE_CANTOPEN != rc) |
if (SQLITE_CANTOPEN != rc) |
say(MANDOC_DB, "%s", sqlite3_errstr(rc)); |
say(MANDOC_DB, "%s", sqlite3_errstr(rc)); |
return(0); |
return 0; |
} |
} |
goto prepare_statements; |
goto prepare_statements; |
} |
} |
Line 2289 dbopen(int real) |
|
Line 2282 dbopen(int real) |
|
if (MPARSE_QUICK & mparse_options) { |
if (MPARSE_QUICK & mparse_options) { |
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say(MANDOC_DB "~", "%s", sqlite3_errstr(rc)); |
say(MANDOC_DB "~", "%s", sqlite3_errstr(rc)); |
return(0); |
return 0; |
} |
} |
|
|
(void)strlcpy(tempfilename, "/tmp/mandocdb.XXXXXX", |
(void)strlcpy(tempfilename, "/tmp/mandocdb.XXXXXX", |
Line 2297 dbopen(int real) |
|
Line 2290 dbopen(int real) |
|
if (NULL == mkdtemp(tempfilename)) { |
if (NULL == mkdtemp(tempfilename)) { |
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say("", "&%s", tempfilename); |
say("", "&%s", tempfilename); |
return(0); |
return 0; |
} |
} |
(void)strlcat(tempfilename, "/" MANDOC_DB, |
(void)strlcat(tempfilename, "/" MANDOC_DB, |
sizeof(tempfilename)); |
sizeof(tempfilename)); |
Line 2305 dbopen(int real) |
|
Line 2298 dbopen(int real) |
|
if (SQLITE_OK != rc) { |
if (SQLITE_OK != rc) { |
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say("", "%s: %s", tempfilename, sqlite3_errstr(rc)); |
say("", "%s: %s", tempfilename, sqlite3_errstr(rc)); |
return(0); |
return 0; |
} |
} |
|
|
create_tables: |
create_tables: |
|
|
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say(MANDOC_DB, "%s", sqlite3_errmsg(db)); |
say(MANDOC_DB, "%s", sqlite3_errmsg(db)); |
sqlite3_close(db); |
sqlite3_close(db); |
return(0); |
return 0; |
} |
} |
|
|
prepare_statements: |
prepare_statements: |
Line 2354 prepare_statements: |
|
Line 2347 prepare_statements: |
|
say(MANDOC_DB, "PRAGMA foreign_keys: %s", |
say(MANDOC_DB, "PRAGMA foreign_keys: %s", |
sqlite3_errmsg(db)); |
sqlite3_errmsg(db)); |
sqlite3_close(db); |
sqlite3_close(db); |
return(0); |
return 0; |
} |
} |
|
|
sql = "DELETE FROM mpages WHERE pageid IN " |
sql = "DELETE FROM mpages WHERE pageid IN " |
Line 2388 prepare_statements: |
|
Line 2381 prepare_statements: |
|
say(MANDOC_DB, "PRAGMA synchronous: %s", |
say(MANDOC_DB, "PRAGMA synchronous: %s", |
sqlite3_errmsg(db)); |
sqlite3_errmsg(db)); |
sqlite3_close(db); |
sqlite3_close(db); |
return(0); |
return 0; |
} |
} |
#endif |
#endif |
|
|
return(1); |
return 1; |
} |
} |
|
|
static void * |
static void * |
hash_calloc(size_t n, size_t sz, void *arg) |
hash_calloc(size_t n, size_t sz, void *arg) |
{ |
{ |
|
|
return(mandoc_calloc(n, sz)); |
return mandoc_calloc(n, sz); |
} |
} |
|
|
static void * |
static void * |
hash_alloc(size_t sz, void *arg) |
hash_alloc(size_t sz, void *arg) |
{ |
{ |
|
|
return(mandoc_malloc(sz)); |
return mandoc_malloc(sz); |
} |
} |
|
|
static void |
static void |
Line 2455 set_basedir(const char *targetdir, int report_baddir) |
|
Line 2448 set_basedir(const char *targetdir, int report_baddir) |
|
if (2 == getcwd_status) { |
if (2 == getcwd_status) { |
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say("", "getcwd: %s", startdir); |
say("", "getcwd: %s", startdir); |
return(0); |
return 0; |
} |
} |
if (-1 == chdir(startdir)) { |
if (-1 == chdir(startdir)) { |
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say("", "&chdir %s", startdir); |
say("", "&chdir %s", startdir); |
return(0); |
return 0; |
} |
} |
} |
} |
|
|
Line 2474 set_basedir(const char *targetdir, int report_baddir) |
|
Line 2467 set_basedir(const char *targetdir, int report_baddir) |
|
exitcode = (int)MANDOCLEVEL_BADARG; |
exitcode = (int)MANDOCLEVEL_BADARG; |
say("", "&%s: realpath", targetdir); |
say("", "&%s: realpath", targetdir); |
} |
} |
return(0); |
return 0; |
} else if (-1 == chdir(basedir)) { |
} else if (-1 == chdir(basedir)) { |
if (report_baddir || errno != ENOENT) { |
if (report_baddir || errno != ENOENT) { |
exitcode = (int)MANDOCLEVEL_BADARG; |
exitcode = (int)MANDOCLEVEL_BADARG; |
say("", "&chdir"); |
say("", "&chdir"); |
} |
} |
return(0); |
return 0; |
} |
} |
chdir_status = 1; |
chdir_status = 1; |
cp = strchr(basedir, '\0'); |
cp = strchr(basedir, '\0'); |
Line 2488 set_basedir(const char *targetdir, int report_baddir) |
|
Line 2481 set_basedir(const char *targetdir, int report_baddir) |
|
if (cp - basedir >= PATH_MAX - 1) { |
if (cp - basedir >= PATH_MAX - 1) { |
exitcode = (int)MANDOCLEVEL_SYSERR; |
exitcode = (int)MANDOCLEVEL_SYSERR; |
say("", "Filename too long"); |
say("", "Filename too long"); |
return(0); |
return 0; |
} |
} |
*cp++ = '/'; |
*cp++ = '/'; |
*cp = '\0'; |
*cp = '\0'; |
} |
} |
return(1); |
return 1; |
} |
} |
|
|
static void |
static void |