=================================================================== RCS file: /cvs/mandoc/cgi.c,v retrieving revision 1.85 retrieving revision 1.92 diff -u -p -r1.85 -r1.92 --- mandoc/cgi.c 2014/07/25 16:56:06 1.85 +++ mandoc/cgi.c 2014/08/05 15:29:30 1.92 @@ -1,4 +1,4 @@ -/* $Id: cgi.c,v 1.85 2014/07/25 16:56:06 schwarze Exp $ */ +/* $Id: cgi.c,v 1.92 2014/08/05 15:29:30 schwarze Exp $ */ /* * Copyright (c) 2011, 2012 Kristaps Dzonsons * Copyright (c) 2014 Ingo Schwarze @@ -23,6 +23,7 @@ #include #include #include +#include #include #include #include @@ -55,13 +56,12 @@ struct req { static void catman(const struct req *, const char *); static void format(const struct req *, const char *); static void html_print(const char *); -static void html_printquery(const struct req *); static void html_putchar(char); static int http_decode(char *); static void http_parse(struct req *, const char *); static void http_print(const char *); static void http_putchar(char); -static void http_printquery(const struct req *); +static void http_printquery(const struct req *, const char *); static void pathgen(struct req *); static void pg_error_badrequest(const char *); static void pg_error_internal(void); @@ -145,51 +145,28 @@ html_putchar(char c) } static void -http_printquery(const struct req *req) +http_printquery(const struct req *req, const char *sep) { - if (NULL != req->q.manpath) { - printf("&manpath="); - http_print(req->q.manpath); - } - if (NULL != req->q.sec) { - printf("&sec="); - http_print(req->q.sec); - } - if (NULL != req->q.arch) { - printf("&arch="); - http_print(req->q.arch); - } if (NULL != req->q.query) { - printf("&query="); + printf("query="); http_print(req->q.query); } if (0 == req->q.equal) - printf("&apropos=1"); -} - -static void -html_printquery(const struct req *req) -{ - - if (NULL != req->q.manpath) { - printf("&manpath="); - html_print(req->q.manpath); - } + printf("%sapropos=1", sep); if (NULL != req->q.sec) { - printf("&sec="); - html_print(req->q.sec); + printf("%ssec=", sep); + http_print(req->q.sec); } if (NULL != req->q.arch) { - printf("&arch="); - html_print(req->q.arch); + printf("%sarch=", sep); + http_print(req->q.arch); } - if (NULL != req->q.query) { - printf("&query="); - html_print(req->q.query); + if (NULL != req->q.manpath && + strcmp(req->q.manpath, req->p[0])) { + printf("%smanpath=", sep); + http_print(req->q.manpath); } - if (0 == req->q.equal) - printf("&apropos=1"); } static void @@ -455,19 +432,19 @@ resp_searchform(const struct req *req) printf( "\n" "q.equal) - printf("CHECKED "); + printf("CHECKED=\"checked\" "); printf( "NAME=\"apropos\" ID=\"show\" VALUE=\"0\">\n" "\n"); /* Write section selector. */ - printf( "\n" + puts( "\n" ""); @@ -477,13 +454,13 @@ resp_searchform(const struct req *req) printf( ""); @@ -496,7 +473,7 @@ resp_searchform(const struct req *req) printf("