aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2011-11-09 23:31:36 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2011-11-09 23:31:36 +0000
commit8f033b9ec35601ec57fb7ccde390d68c8a51165a (patch)
tree153118d1eee0a4fb62ca7a9a6f331d07e20cda94
parent53ecc54dbae535c524e2b4044ae5c358dcd67c30 (diff)
downloadmandoc-8f033b9ec35601ec57fb7ccde390d68c8a51165a.tar.gz
mandoc-8f033b9ec35601ec57fb7ccde390d68c8a51165a.tar.zst
mandoc-8f033b9ec35601ec57fb7ccde390d68c8a51165a.zip
Use proper infix expressions and provide a default. (Exact match.)
-rw-r--r--db.c37
1 files changed, 25 insertions, 12 deletions
diff --git a/db.c b/db.c
index 512c48aa..d7d08247 100644
--- a/db.c
+++ b/db.c
@@ -1,4 +1,4 @@
-/* $Id: db.c,v 1.2 2011/11/09 22:05:56 kristaps Exp $ */
+/* $Id: db.c,v 1.3 2011/11/09 23:31:36 kristaps Exp $ */
/*
* Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
*
@@ -462,30 +462,43 @@ exprcomp(int cs, char *argv[], int argc)
{
struct expr *p;
struct expr e;
- int i, ch;
+ int i, pos, ch;
- if (3 != argc)
+ pos = 0;
+
+ if (pos > argc)
+ return(NULL);
+
+ for (i = 0; 0 != types[i].mask; i++)
+ if (0 == strcmp(types[i].name, argv[pos]))
+ break;
+
+ if (0 == (e.mask = types[i].mask))
+ return(NULL);
+
+ if (++pos > argc--)
return(NULL);
- if (0 == strcmp("-eq", argv[0]))
+ if ('-' != *argv[pos])
+ e.match = cs ? MATCH_STRCASE : MATCH_STR;
+ else if (0 == strcmp("-eq", argv[pos]))
e.match = cs ? MATCH_STRCASE : MATCH_STR;
- else if (0 == strcmp("-ieq", argv[0]))
+ else if (0 == strcmp("-ieq", argv[pos]))
e.match = MATCH_STRCASE;
- else if (0 == strcmp("-re", argv[0]))
+ else if (0 == strcmp("-re", argv[pos]))
e.match = cs ? MATCH_REGEXCASE : MATCH_REGEX;
- else if (0 == strcmp("-ire", argv[0]))
+ else if (0 == strcmp("-ire", argv[pos]))
e.match = MATCH_REGEXCASE;
else
return(NULL);
- for (i = 0; 0 != types[i].mask; i++)
- if (0 == strcmp(types[i].name, argv[1]))
- break;
+ if ('-' == *argv[pos])
+ pos++;
- if (0 == (e.mask = types[i].mask))
+ if (pos > argc--)
return(NULL);
- e.v = mandoc_strdup(argv[2]);
+ e.v = mandoc_strdup(argv[pos]);
if (MATCH_REGEX == e.match || MATCH_REGEXCASE == e.match) {
ch = REG_EXTENDED | REG_NOSUB;