-/* $Id: apropos.c,v 1.12 2011/11/13 11:10:27 schwarze Exp $ */
+/* $Id: apropos.c,v 1.13 2011/11/14 10:07:06 kristaps Exp $ */
/*
* Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
*
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
#include <assert.h>
#include <getopt.h>
#include <limits.h>
main(int argc, char *argv[])
{
int ch;
+ size_t sz;
+ char *buf;
struct opts opts;
struct expr *e;
extern int optind;
if (0 == argc)
return(EXIT_SUCCESS);
- if (NULL == (e = exprcomp(argc, argv))) {
+ /*
+ * Collapse expressions into a single string.
+ * First count up the contained strings, adding a space at the
+ * end of each (plus nil-terminator). Then merge.
+ */
+
+ for (sz = 0, ch = 0; ch < argc; ch++)
+ sz += strlen(argv[ch]) + 1;
+
+ buf = mandoc_malloc(++sz);
+
+ for (*buf = '\0', ch = 0; ch < argc; ch++) {
+ strlcat(buf, argv[ch], sz);
+ strlcat(buf, " ", sz);
+ }
+
+ buf[sz - 2] = '\0';
+
+ if (NULL == (e = exprcomp(buf))) {
fprintf(stderr, "Bad expression\n");
+ free(buf);
return(EXIT_FAILURE);
}
+ free(buf);
+
/*
* Configure databases.
* The keyword database is a btree that allows for duplicate
-/* $Id: apropos_db.c,v 1.3 2011/11/13 11:10:27 schwarze Exp $ */
+/* $Id: apropos_db.c,v 1.4 2011/11/14 10:07:06 kristaps Exp $ */
/*
* Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2011 Ingo Schwarze <schwarze@openbsd.org>
}
struct expr *
-exprcomp(int argc, char *argv[])
+exprcomp(char *buf)
{
struct expr *p;
struct expr e;
char *key;
int i, icase;
- if (0 >= argc)
+ if ('\0' == *buf)
return(NULL);
/*
* Choose regex or substring match.
*/
- if (NULL == (e.v = strpbrk(*argv, "=~"))) {
+ if (NULL == (e.v = strpbrk(buf, "=~"))) {
e.regex = 0;
- e.v = *argv;
+ e.v = buf;
} else {
e.regex = '~' == *e.v;
*e.v++ = '\0';
icase = 0;
e.mask = 0;
- if (*argv < e.v) {
- while (NULL != (key = strsep(argv, ","))) {
+ if (buf < e.v) {
+ while (NULL != (key = strsep(&buf, ","))) {
if ('i' == key[0] && '\0' == key[1]) {
icase = REG_ICASE;
continue;
}
i = 0;
while (types[i].mask &&
- strcmp(types[i].name, key))
+ strcmp(types[i].name, key))
i++;
e.mask |= types[i].mask;
}
-/* $Id: apropos_db.h,v 1.3 2011/11/13 11:10:27 schwarze Exp $ */
+/* $Id: apropos_db.h,v 1.4 2011/11/14 10:07:06 kristaps Exp $ */
/*
* Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
*
const struct expr *, void *,
void (*)(struct rec *, size_t, void *));
-struct expr *exprcomp(int, char *[]);
+struct expr *exprcomp(char *);
void exprfree(struct expr *);
__END_DECLS