aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2016-04-14 20:40:33 +0000
committerIngo Schwarze <schwarze@openbsd.org>2016-04-14 20:40:33 +0000
commit60f3c419013efd374b4edb4e0accd134de5cd50e (patch)
tree3e8d75d5de6c02d58914457781667bac1dda2660
parent83a41f79faf4a55f59c7c9359f4f57ac0399b3b6 (diff)
downloadmandoc-60f3c419013efd374b4edb4e0accd134de5cd50e.tar.gz
mandoc-60f3c419013efd374b4edb4e0accd134de5cd50e.tar.zst
mandoc-60f3c419013efd374b4edb4e0accd134de5cd50e.zip
do not rewrite short queries
-rw-r--r--cgi.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/cgi.c b/cgi.c
index d90f493b..34ee4a99 100644
--- a/cgi.c
+++ b/cgi.c
@@ -1,4 +1,4 @@
-/* $Id: cgi.c,v 1.120 2016/04/13 15:38:45 schwarze Exp $ */
+/* $Id: cgi.c,v 1.121 2016/04/14 20:40:33 schwarze Exp $ */
/*
* Copyright (c) 2011, 2012 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2014, 2015, 2016 Ingo Schwarze <schwarze@usta.de>
@@ -55,6 +55,7 @@ struct req {
struct query q;
char **p; /* array of available manpaths */
size_t psz; /* number of available manpaths */
+ int isquery; /* QUERY_STRING used, not PATH_INFO */
};
static void catman(const struct req *, const char *);
@@ -188,6 +189,7 @@ http_parse(struct req *req, const char *qs)
char *key, *val;
size_t keysz, valsz;
+ req->isquery = 1;
req->q.manpath = NULL;
req->q.arch = NULL;
req->q.sec = NULL;
@@ -568,7 +570,7 @@ pg_searchres(const struct req *req, struct manpage *r, size_t sz)
return;
}
- if (1 == sz) {
+ if (req->isquery && sz == 1) {
/*
* If we have just one result, then jump there now
* without any delay.
@@ -1085,6 +1087,7 @@ path_parse(struct req *req, const char *path)
{
int dir_done;
+ req->isquery = 0;
req->q.equal = 1;
req->q.manpath = mandoc_strdup(path);