]> git.cameronkatri.com Git - mandoc.git/commitdiff
Fix parsing of PATH_INFO if both a section directory and an
authorIngo Schwarze <schwarze@openbsd.org>
Fri, 15 Apr 2016 15:13:07 +0000 (15:13 +0000)
committerIngo Schwarze <schwarze@openbsd.org>
Fri, 15 Apr 2016 15:13:07 +0000 (15:13 +0000)
architecture subdirectory are specified.  Issue reported by tb@.

cgi.c

diff --git a/cgi.c b/cgi.c
index dee2ad7c7366de309cc289d941385af8d1cbf7d5..2b521e21a2063c2d5b6d7d2a5029ff083ba3ce9a 100644 (file)
--- a/cgi.c
+++ b/cgi.c
@@ -1,4 +1,4 @@
-/*     $Id: cgi.c,v 1.126 2016/04/15 01:34:51 schwarze Exp $ */
+/*     $Id: cgi.c,v 1.127 2016/04/15 15:13:07 schwarze Exp $ */
 /*
  * Copyright (c) 2011, 2012 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2014, 2015, 2016 Ingo Schwarze <schwarze@usta.de>
@@ -1085,7 +1085,7 @@ main(void)
 static void
 path_parse(struct req *req, const char *path)
 {
-       int      dir_done;
+       char    *dir;
 
        req->isquery = 0;
        req->q.equal = 1;
@@ -1115,23 +1115,19 @@ path_parse(struct req *req, const char *path)
        req->q.query = mandoc_strdup(req->q.query);
 
        /* Optional architecture. */
-       dir_done = 0;
-       for (;;) {
-               if ((req->q.arch = strrchr(req->q.manpath, '/')) == NULL)
-                       break;
-               *req->q.arch++ = '\0';
-               if (dir_done || strncmp(req->q.arch, "man", 3)) {
-                       req->q.arch = mandoc_strdup(req->q.arch);
-                       break;
-               }
+       dir = strrchr(req->q.manpath, '/');
+       if (dir != NULL && strncmp(dir + 1, "man", 3) != 0) {
+               *dir++ = '\0';
+               req->q.arch = mandoc_strdup(dir);
+               dir = strrchr(req->q.manpath, '/');
+       } else
+               req->q.arch = NULL;
 
-               /* Optional directory name. */
-               req->q.arch += 3;
-               if (*req->q.arch != '\0') {
-                       free(req->q.sec);
-                       req->q.sec = mandoc_strdup(req->q.arch);
-               }
-               dir_done = 1;
+       /* Optional directory name. */
+       if (dir != NULL && strncmp(dir + 1, "man", 3) == 0) {
+               *dir++ = '\0';
+               free(req->q.sec);
+               req->q.sec = mandoc_strdup(dir + 3);
        }
 }