aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/main.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2014-08-20 21:04:35 +0000
committerIngo Schwarze <schwarze@openbsd.org>2014-08-20 21:04:35 +0000
commit62538d1a0002980ab3e87a0e27f4ee71043aa57a (patch)
treefe21643f7c7ff2ce6bf5ad286235a7050e01f1a6 /main.c
parentdbbe90e77ce844aa87521cef0cdc9152aa38381f (diff)
downloadmandoc-62538d1a0002980ab3e87a0e27f4ee71043aa57a.tar.gz
mandoc-62538d1a0002980ab3e87a0e27f4ee71043aa57a.tar.zst
mandoc-62538d1a0002980ab3e87a0e27f4ee71043aa57a.zip
Parse the new -a, -i, and -w options.
Implement -w (list manual page filenames).
Diffstat (limited to 'main.c')
-rw-r--r--main.c49
1 files changed, 44 insertions, 5 deletions
diff --git a/main.c b/main.c
index 213b6068..8a4e9fa9 100644
--- a/main.c
+++ b/main.c
@@ -1,4 +1,4 @@
-/* $Id: main.c,v 1.180 2014/08/17 03:24:47 schwarze Exp $ */
+/* $Id: main.c,v 1.181 2014/08/20 21:04:35 schwarze Exp $ */
/*
* Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2010, 2011, 2012, 2014 Ingo Schwarze <schwarze@openbsd.org>
@@ -41,6 +41,15 @@
# endif
#endif /* !defined(__GNUC__) || (__GNUC__ < 2) */
+enum outmode {
+ OUTMODE_DEF = 0,
+ OUTMODE_FLN,
+ OUTMODE_LST,
+ OUTMODE_ALL,
+ OUTMODE_INT,
+ OUTMODE_ONE
+};
+
typedef void (*out_mdoc)(void *, const struct mdoc *);
typedef void (*out_man)(void *, const struct man *);
typedef void (*out_free)(void *);
@@ -96,6 +105,7 @@ main(int argc, char *argv[])
size_t i, sz;
#endif
enum mandoclevel rc;
+ enum outmode outmode;
int show_usage;
int options;
int c;
@@ -132,8 +142,12 @@ main(int argc, char *argv[])
defos = NULL;
show_usage = 0;
- while (-1 != (c = getopt(argc, argv, "C:fI:kM:m:O:S:s:T:VW:"))) {
+ outmode = OUTMODE_DEF;
+ while (-1 != (c = getopt(argc, argv, "aC:fI:ikM:m:O:S:s:T:VW:w"))) {
switch (c) {
+ case 'a':
+ outmode = OUTMODE_ALL;
+ break;
case 'C':
conf_file = optarg;
break;
@@ -155,6 +169,9 @@ main(int argc, char *argv[])
}
defos = mandoc_strdup(optarg + 3);
break;
+ case 'i':
+ outmode = OUTMODE_INT;
+ break;
case 'k':
search.argmode = ARG_EXPR;
break;
@@ -183,6 +200,9 @@ main(int argc, char *argv[])
if ( ! woptions(&curp, optarg))
return((int)MANDOCLEVEL_BADARG);
break;
+ case 'w':
+ outmode = OUTMODE_FLN;
+ break;
case 'V':
version();
/* NOTREACHED */
@@ -195,6 +215,20 @@ main(int argc, char *argv[])
if (show_usage)
usage(search.argmode);
+ if (outmode == OUTMODE_DEF) {
+ switch (search.argmode) {
+ case ARG_FILE:
+ outmode = OUTMODE_ALL;
+ break;
+ case ARG_NAME:
+ outmode = OUTMODE_ONE;
+ break;
+ default:
+ outmode = OUTMODE_LST;
+ break;
+ }
+ }
+
argc -= optind;
argv += optind;
@@ -209,9 +243,14 @@ main(int argc, char *argv[])
if( ! mansearch(&search, &paths, argc, argv, &res, &sz))
usage(search.argmode);
manpath_free(&paths);
- for (i = 0; i < sz; i++)
- printf("%s - %s\n", res[i].names,
- res[i].output == NULL ? "" : res[i].output);
+ for (i = 0; i < sz; i++) {
+ if (outmode == OUTMODE_FLN)
+ puts(res[i].file);
+ else
+ printf("%s - %s\n", res[i].names,
+ res[i].output == NULL ? "" :
+ res[i].output);
+ }
mansearch_free(res, sz);
mansearch_setup(0);
return((int)MANDOCLEVEL_OK);