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

Diff for /mandoc/cgi.c between version 1.112 and 1.115

version 1.112, 2015/10/22 22:06:43 version 1.115, 2015/11/07 17:58:55
Line 77  static void   pg_searchres(const struct req *,
Line 77  static void   pg_searchres(const struct req *,
 static  void             pg_show(struct req *, const char *);  static  void             pg_show(struct req *, const char *);
 static  void             resp_begin_html(int, const char *);  static  void             resp_begin_html(int, const char *);
 static  void             resp_begin_http(int, const char *);  static  void             resp_begin_http(int, const char *);
   static  void             resp_copy(const char *);
 static  void             resp_end_html(void);  static  void             resp_end_html(void);
 static  void             resp_searchform(const struct req *);  static  void             resp_searchform(const struct req *);
 static  void             resp_show(const struct req *, const char *);  static  void             resp_show(const struct req *, const char *);
Line 368  resp_begin_http(int code, const char *msg)
Line 369  resp_begin_http(int code, const char *msg)
 }  }
   
 static void  static void
   resp_copy(const char *filename)
   {
           char     buf[4096];
           ssize_t  sz;
           int      fd;
   
           if ((fd = open(filename, O_RDONLY)) != -1) {
                   fflush(stdout);
                   while ((sz = read(fd, buf, sizeof(buf))) > 0)
                           write(STDOUT_FILENO, buf, sz);
           }
   }
   
   static void
 resp_begin_html(int code, const char *msg)  resp_begin_html(int code, const char *msg)
 {  {
   
Line 377  resp_begin_html(int code, const char *msg)
Line 392  resp_begin_html(int code, const char *msg)
                "<HTML>\n"                 "<HTML>\n"
                "<HEAD>\n"                 "<HEAD>\n"
                "<META CHARSET=\"UTF-8\" />\n"                 "<META CHARSET=\"UTF-8\" />\n"
                "<LINK REL=\"stylesheet\" HREF=\"%s/man-cgi.css\""                 "<LINK REL=\"stylesheet\" HREF=\"%s/mandoc.css\""
                " TYPE=\"text/css\" media=\"all\">\n"                 " TYPE=\"text/css\" media=\"all\">\n"
                "<LINK REL=\"stylesheet\" HREF=\"%s/man.css\""  
                " TYPE=\"text/css\" media=\"all\">\n"  
                "<TITLE>%s</TITLE>\n"                 "<TITLE>%s</TITLE>\n"
                "</HEAD>\n"                 "</HEAD>\n"
                "<BODY>\n"                 "<BODY>\n"
                "<!-- Begin page content. //-->\n",                 "<!-- Begin page content. //-->\n",
                CSS_DIR, CSS_DIR, CUSTOMIZE_TITLE);                 CSS_DIR, CUSTOMIZE_TITLE);
   
           resp_copy(MAN_DIR "/header.html");
 }  }
   
 static void  static void
 resp_end_html(void)  resp_end_html(void)
 {  {
   
           resp_copy(MAN_DIR "/footer.html");
   
         puts("</BODY>\n"          puts("</BODY>\n"
              "</HTML>");               "</HTML>");
 }  }
Line 401  resp_searchform(const struct req *req)
Line 418  resp_searchform(const struct req *req)
 {  {
         int              i;          int              i;
   
         puts(CUSTOMIZE_BEGIN);  
         puts("<!-- Begin search form. //-->");          puts("<!-- Begin search form. //-->");
         printf("<DIV ID=\"mancgi\">\n"          printf("<DIV ID=\"mancgi\">\n"
                "<FORM ACTION=\"%s\" METHOD=\"get\">\n"                 "<FORM ACTION=\"%s\" METHOD=\"get\">\n"
Line 688  static void
Line 704  static void
 catman(const struct req *req, const char *file)  catman(const struct req *req, const char *file)
 {  {
         FILE            *f;          FILE            *f;
         size_t           len;  
         int              i;  
         char            *p;          char            *p;
           size_t           sz;
           ssize_t          len;
           int              i;
         int              italic, bold;          int              italic, bold;
   
         if (NULL == (f = fopen(file, "r"))) {          if ((f = fopen(file, "r")) == NULL) {
                 puts("<P>You specified an invalid manual file.</P>");                  puts("<P>You specified an invalid manual file.</P>");
                 return;                  return;
         }          }
Line 701  catman(const struct req *req, const char *file)
Line 718  catman(const struct req *req, const char *file)
         puts("<DIV CLASS=\"catman\">\n"          puts("<DIV CLASS=\"catman\">\n"
              "<PRE>");               "<PRE>");
   
         while (NULL != (p = fgetln(f, &len))) {          p = NULL;
           sz = 0;
   
           while ((len = getline(&p, &sz, f)) != -1) {
                 bold = italic = 0;                  bold = italic = 0;
                 for (i = 0; i < (int)len - 1; i++) {                  for (i = 0; i < len - 1; i++) {
                         /*                          /*
                          * This means that the catpage is out of state.                           * This means that the catpage is out of state.
                          * Ignore it and keep going (although the                           * Ignore it and keep going (although the
Line 728  catman(const struct req *req, const char *file)
Line 748  catman(const struct req *req, const char *file)
                                 italic = bold = 0;                                  italic = bold = 0;
                                 html_putchar(p[i]);                                  html_putchar(p[i]);
                                 continue;                                  continue;
                         } else if (i + 2 >= (int)len)                          } else if (i + 2 >= len)
                                 continue;                                  continue;
   
                         /* Italic mode. */                          /* Italic mode. */
Line 804  catman(const struct req *req, const char *file)
Line 824  catman(const struct req *req, const char *file)
                 if (bold)                  if (bold)
                         printf("</B>");                          printf("</B>");
   
                 if (i == (int)len - 1 && '\n' != p[i])                  if (i == len - 1 && p[i] != '\n')
                         html_putchar(p[i]);                          html_putchar(p[i]);
   
                 putchar('\n');                  putchar('\n');
         }          }
           free(p);
   
         puts("</PRE>\n"          puts("</PRE>\n"
              "</DIV>");               "</DIV>");
Line 1118  pathgen(struct req *req)
Line 1139  pathgen(struct req *req)
         FILE    *fp;          FILE    *fp;
         char    *dp;          char    *dp;
         size_t   dpsz;          size_t   dpsz;
           ssize_t  len;
   
         if (NULL == (fp = fopen("manpath.conf", "r"))) {          if (NULL == (fp = fopen("manpath.conf", "r"))) {
                 fprintf(stderr, "%s/manpath.conf: %s\n",                  fprintf(stderr, "%s/manpath.conf: %s\n",
Line 1126  pathgen(struct req *req)
Line 1148  pathgen(struct req *req)
                 exit(EXIT_FAILURE);                  exit(EXIT_FAILURE);
         }          }
   
         while (NULL != (dp = fgetln(fp, &dpsz))) {          dp = NULL;
                 if ('\n' == dp[dpsz - 1])          dpsz = 0;
                         dpsz--;  
           while ((len = getline(&dp, &dpsz, fp)) != -1) {
                   if (dp[len - 1] == '\n')
                           dp[--len] = '\0';
                 req->p = mandoc_realloc(req->p,                  req->p = mandoc_realloc(req->p,
                     (req->psz + 1) * sizeof(char *));                      (req->psz + 1) * sizeof(char *));
                 dp = mandoc_strndup(dp, dpsz);  
                 if ( ! validate_urifrag(dp)) {                  if ( ! validate_urifrag(dp)) {
                         fprintf(stderr, "%s/manpath.conf contains "                          fprintf(stderr, "%s/manpath.conf contains "
                             "unsafe path \"%s\"\n", MAN_DIR, dp);                              "unsafe path \"%s\"\n", MAN_DIR, dp);
Line 1145  pathgen(struct req *req)
Line 1169  pathgen(struct req *req)
                         exit(EXIT_FAILURE);                          exit(EXIT_FAILURE);
                 }                  }
                 req->p[req->psz++] = dp;                  req->p[req->psz++] = dp;
                   dp = NULL;
                   dpsz = 0;
         }          }
           free(dp);
   
         if ( req->p == NULL ) {          if ( req->p == NULL ) {
                 fprintf(stderr, "%s/manpath.conf is empty\n", MAN_DIR);                  fprintf(stderr, "%s/manpath.conf is empty\n", MAN_DIR);

Legend:
Removed from v.1.112  
changed lines
  Added in v.1.115

CVSweb