[BACK]Return to cgi.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Diff for /mandoc/cgi.c between version 1.28 and 1.29

version 1.28, 2011/12/10 23:09:25 version 1.29, 2011/12/11 00:22:47
Line 103  static void   resp_index(const struct req *);
Line 103  static void   resp_index(const struct req *);
 static  void             resp_search(struct res *, size_t, void *);  static  void             resp_search(struct res *, size_t, void *);
 static  void             resp_searchform(const struct req *);  static  void             resp_searchform(const struct req *);
   
 static  const char       *progname;  static  const char       *progname; /* cgi script name */
 static  const char       *cache;  static  const char       *cache; /* cache directory */
 static  const char       *host;  static  const char       *css; /* css directory */
   static  const char       *host; /* hostname */
   
 static  const char * const pages[PAGE__MAX] = {  static  const char * const pages[PAGE__MAX] = {
         "index", /* PAGE_INDEX */          "index", /* PAGE_INDEX */
Line 338  resp_begin_html(int code, const char *msg)
Line 339  resp_begin_html(int code, const char *msg)
   
         resp_begin_http(code, msg);          resp_begin_http(code, msg);
   
         puts("<!DOCTYPE HTML PUBLIC "          printf("<!DOCTYPE HTML PUBLIC "
              " \"-//W3C//DTD HTML 4.01//EN\""                 " \"-//W3C//DTD HTML 4.01//EN\""
              " \"http://www.w3.org/TR/html4/strict.dtd\">\n"                 " \"http://www.w3.org/TR/html4/strict.dtd\">\n"
              "<HTML>\n"                 "<HTML>\n"
              "<HEAD>\n"                 "<HEAD>\n"
              "<META HTTP-EQUIV=\"Content-Type\""                 "<META HTTP-EQUIV=\"Content-Type\""
              " CONTENT=\"text/html; charset=utf-8\">\n"                 " CONTENT=\"text/html; charset=utf-8\">\n"
              "<LINK REL=\"stylesheet\" HREF=\"/man.cgi.css\""                 "<LINK REL=\"stylesheet\" HREF=\"%s/man.cgi.css\""
              " TYPE=\"text/css\" media=\"all\">\n"                 " TYPE=\"text/css\" media=\"all\">\n"
              "<TITLE>System Manpage Reference</TITLE>\n"                 "<TITLE>System Manpage Reference</TITLE>\n"
              "</HEAD>\n"                 "</HEAD>\n"
              "<BODY>\n"                 "<BODY>\n"
              "<!-- Begin page content. //-->");                 "<!-- Begin page content. //-->\n", css);
 }  }
   
 static void  static void
Line 367  resp_searchform(const struct req *req)
Line 368  resp_searchform(const struct req *req)
         int              i;          int              i;
   
         puts("<!-- Begin search form. //-->");          puts("<!-- Begin search form. //-->");
         printf("<FORM ACTION=\"");          printf("<FORM ACTION=\"%s/search.html\" METHOD=\"get\">\n"
         html_print(progname);                 "<FIELDSET>\n"
         printf("/search.html\" METHOD=\"get\">\n");  
         printf("<FIELDSET>\n"  
                "<LEGEND>Search Parameters</LEGEND>\n"                 "<LEGEND>Search Parameters</LEGEND>\n"
                "<INPUT TYPE=\"submit\" NAME=\"op\""                 "<INPUT TYPE=\"submit\" NAME=\"op\""
                " VALUE=\"Whatis\"> or \n"                 " VALUE=\"Whatis\"> or \n"
                "<INPUT TYPE=\"submit\" NAME=\"op\""                 "<INPUT TYPE=\"submit\" NAME=\"op\""
                " VALUE=\"apropos\"> for manuals satisfying \n"                 " VALUE=\"apropos\"> for manuals satisfying \n"
                "<INPUT TYPE=\"text\" NAME=\"expr\" VALUE=\"");                 "<INPUT TYPE=\"text\" NAME=\"expr\" VALUE=\"",
                  progname);
         html_print(req->q.expr ? req->q.expr : "");          html_print(req->q.expr ? req->q.expr : "");
         printf("\">, section "          printf("\">, section "
                "<INPUT TYPE=\"text\""                 "<INPUT TYPE=\"text\""
Line 472  resp_search(struct res *r, size_t sz, void *arg)
Line 472  resp_search(struct res *r, size_t sz, void *arg)
         int               i;          int               i;
         const struct req *req;          const struct req *req;
   
           req = (const struct req *)arg;
           assert(req->q.manroot >= 0);
   
         if (1 == sz) {          if (1 == sz) {
                 /*                  /*
                  * If we have just one result, then jump there now                   * If we have just one result, then jump there now
                  * without any delay.                   * without any delay.
                  */                   */
                 puts("Status: 303 See Other");                  puts("Status: 303 See Other");
                 printf("Location: http://%s%s/show/%u/%u.html\n",                  printf("Location: http://%s%s/show/%d/%u/%u.html\n",
                                 host, progname,                                  host, progname, req->q.manroot,
                                 r[0].volume, r[0].rec);                                  r[0].volume, r[0].rec);
                 puts("Content-Type: text/html; charset=utf-8\n");                  puts("Content-Type: text/html; charset=utf-8\n");
                 return;                  return;
Line 488  resp_search(struct res *r, size_t sz, void *arg)
Line 491  resp_search(struct res *r, size_t sz, void *arg)
         qsort(r, sz, sizeof(struct res), cmp);          qsort(r, sz, sizeof(struct res), cmp);
   
         resp_begin_html(200, NULL);          resp_begin_html(200, NULL);
   
         req = (const struct req *)arg;  
         resp_searchform(req);          resp_searchform(req);
   
         if (0 == sz) {          if (0 == sz) {
Line 497  resp_search(struct res *r, size_t sz, void *arg)
Line 498  resp_search(struct res *r, size_t sz, void *arg)
                        "No %s results found.\n",                         "No %s results found.\n",
                        req->q.whatis ? "whatis" : "apropos");                         req->q.whatis ? "whatis" : "apropos");
                 if (req->q.whatis) {                  if (req->q.whatis) {
                         printf("(Try <A HREF=\"");                          printf("(Try <A HREF=\"%s/search.html?"
                         html_print(progname);                                 "op=apropos&amp;expr=", progname);
                         printf("/search.html?op=apropos&amp;expr=");  
                         html_print(req->q.expr ? req->q.expr : "");                          html_print(req->q.expr ? req->q.expr : "");
                         printf("&amp;sec=");                          printf("&amp;sec=");
                         html_print(req->q.sec ? req->q.sec : "");                          html_print(req->q.sec ? req->q.sec : "");
Line 515  resp_search(struct res *r, size_t sz, void *arg)
Line 515  resp_search(struct res *r, size_t sz, void *arg)
         puts("<P></P>\n"          puts("<P></P>\n"
              "<TABLE>");               "<TABLE>");
   
         assert(req->q.manroot >= 0);  
         for (i = 0; i < (int)sz; i++) {          for (i = 0; i < (int)sz; i++) {
                 printf("<TR>\n"                  printf("<TR>\n"
                        "<TD CLASS=\"title\">\n"                         "<TD CLASS=\"title\">\n"
                        "<A HREF=\"");                         "<A HREF=\"%s/show/%d/%u/%u.html\">",
                 html_print(progname);                                  progname, req->q.manroot,
                 printf("/show/%d/%u/%u.html\">",  
                                 req->q.manroot,  
                                 r[i].volume, r[i].rec);                                  r[i].volume, r[i].rec);
                 html_print(r[i].title);                  html_print(r[i].title);
                 putchar('(');                  putchar('(');
Line 566  catman(const char *file)
Line 563  catman(const char *file)
         }          }
   
         resp_begin_http(200, NULL);          resp_begin_http(200, NULL);
         puts("<!DOCTYPE HTML PUBLIC "          printf("<!DOCTYPE HTML PUBLIC "
              " \"-//W3C//DTD HTML 4.01//EN\""                 " \"-//W3C//DTD HTML 4.01//EN\""
              " \"http://www.w3.org/TR/html4/strict.dtd\">\n"                 " \"http://www.w3.org/TR/html4/strict.dtd\">\n"
              "<HTML>\n"                 "<HTML>\n"
              "<HEAD>\n"                 "<HEAD>\n"
              "<META HTTP-EQUIV=\"Content-Type\""                 "<META HTTP-EQUIV=\"Content-Type\""
              " CONTENT=\"text/html; charset=utf-8\">\n"                 " CONTENT=\"text/html; charset=utf-8\">\n"
              "<LINK REL=\"stylesheet\" HREF=\"/catman.css\""                 "<LINK REL=\"stylesheet\" HREF=\"%s/catman.css\""
              " TYPE=\"text/css\" media=\"all\">\n"                 " TYPE=\"text/css\" media=\"all\">\n"
              "<TITLE>System Manpage Reference</TITLE>\n"                 "<TITLE>System Manpage Reference</TITLE>\n"
              "</HEAD>\n"                 "</HEAD>\n"
              "<BODY>\n"                 "<BODY>\n"
              "<!-- Begin page content. //-->\n"                 "<!-- Begin page content. //-->\n"
              "<PRE>");                 "<PRE>\n", css);
   
         while (NULL != (p = fgetln(f, &len))) {          while (NULL != (p = fgetln(f, &len))) {
                 bold = italic = 0;                  bold = italic = 0;
Line 722  format(const char *file)
Line 719  format(const char *file)
                 return;                  return;
         }          }
   
         snprintf(opts, sizeof(opts), "style=/man.css,"          snprintf(opts, sizeof(opts), "style=%s/man.css,"
                         "man=%s/search.html?sec=%%S&expr=%%N,"                          "man=%s/search.html?sec=%%S&expr=%%N,"
                         /*"includes=/cgi-bin/man.cgi/usr/include/%%I"*/,                          /*"includes=/cgi-bin/man.cgi/usr/include/%%I"*/,
                         progname);                          css, progname);
   
         mparse_result(mp, &mdoc, &man);          mparse_result(mp, &mdoc, &man);
         vp = html_alloc(opts);          vp = html_alloc(opts);
Line 942  main(void)
Line 939  main(void)
   
         /* Scan our run-time environment. */          /* Scan our run-time environment. */
   
         progname = getenv("SCRIPT_NAME");          if (NULL == (cache = getenv("CACHE_DIR")))
         if (NULL == progname)                  cache = "/cache/man.cgi";
   
           if (NULL == (progname = getenv("SCRIPT_NAME")))
                 progname = "";                  progname = "";
   
         cache = getenv("CACHE_DIR");          if (NULL == (css = getenv("CSS_DIR")))
         if (NULL == cache)                  css = "/";
                 cache = "/cache/man.cgi";  
   
         host = getenv("HTTP_HOST");          if (NULL == (host = getenv("HTTP_HOST")))
         if (NULL == host)  
                 host = "localhost";                  host = "localhost";
   
         /*          /*

Legend:
Removed from v.1.28  
changed lines
  Added in v.1.29

CVSweb