openbsd-ports/www/junkbuster/patches/patch-loaders_c
2010-05-24 22:17:03 +00:00

171 lines
5.8 KiB
Plaintext

$OpenBSD: patch-loaders_c,v 1.3 2010/05/24 22:17:03 espie Exp $
--- loaders.c.orig Sat Oct 31 04:58:47 1998
+++ loaders.c Sat May 22 16:47:47 2010
@@ -8,7 +8,7 @@ char *loaders_rcs = "$Id: loaders.c,v 1.24 1998/10/22
#include <stdlib.h>
#include <sys/types.h>
#include <string.h>
-#include <malloc.h>
+/* #include <malloc.h> We dont need this */
#include <errno.h>
#include <sys/stat.h>
#include <ctype.h>
@@ -213,7 +213,7 @@ load_blockfile(struct client_state *csp)
p = url_encode(html_code_map, blockfile);
- sprintf(buf, "<h2>The file `%s' contains the following patterns</h2>\n", p);
+ snprintf(buf, sizeof(buf), "<h2>The file `%s' contains the following patterns</h2>\n", p);
freez(p);
fs->proxy_args = strsav(fs->proxy_args, buf);
@@ -291,7 +291,7 @@ load_blockfile(struct client_state *csp)
int errcode;
char rebuf[BUFSIZ];
- sprintf(rebuf, "^(%s)", b->url->path);
+ snprintf(rebuf, sizeof(rebuf), "^(%s)", b->url->path);
errcode = regcomp(b->url->preg, rebuf,
(REG_EXTENDED|REG_NOSUB|REG_ICASE));
@@ -399,7 +399,7 @@ load_cookiefile(struct client_state *csp)
p = url_encode(html_code_map, cookiefile);
- sprintf(buf, "<h2>The file `%s' contains the following patterns</h2>\n", p);
+ snprintf(buf, sizeof(buf), "<h2>The file `%s' contains the following patterns</h2>\n", p);
freez(p);
@@ -500,7 +500,7 @@ load_cookiefile(struct client_state *csp)
int errcode;
char rebuf[BUFSIZ];
- sprintf(rebuf, "^(%s)", b->url->path);
+ snprintf(rebuf, sizeof(rebuf), "^(%s)", b->url->path);
errcode = regcomp(b->url->preg, rebuf,
(REG_EXTENDED|REG_NOSUB|REG_ICASE));
@@ -609,7 +609,7 @@ load_trustfile(struct client_state *csp)
p = url_encode(html_code_map, trustfile);
- sprintf(buf, "<h2>The file `%s' contains the following patterns</h2>\n", p);
+ snprintf(buf, sizeof(buf), "<h2>The file `%s' contains the following patterns</h2>\n", p);
freez(p);
@@ -696,7 +696,7 @@ load_trustfile(struct client_state *csp)
int errcode;
char rebuf[BUFSIZ];
- sprintf(rebuf, "^(%s)", b->url->path);
+ snprintf(rebuf, sizeof(rebuf), "^(%s)", b->url->path);
errcode = regcomp(b->url->preg, rebuf,
(REG_EXTENDED|REG_NOSUB|REG_ICASE));
@@ -816,7 +816,7 @@ load_forwardfile(struct client_state *csp)
p = url_encode(html_code_map, forwardfile);
- sprintf(buf, "<h2>The file `%s' contains the following patterns</h2>\n", p);
+ snprintf(buf, sizeof(buf), "<h2>The file `%s' contains the following patterns</h2>\n", p);
freez(p);
@@ -855,7 +855,7 @@ load_forwardfile(struct client_state *csp)
continue;
}
- strcpy(buf, vec[0]);
+ strlcpy(buf, vec[0], sizeof(buf));
reject = 1;
@@ -906,7 +906,7 @@ load_forwardfile(struct client_state *csp)
int errcode;
char rebuf[BUFSIZ];
- sprintf(rebuf, "^(%s)", b->url->path);
+ snprintf(rebuf, sizeof(rebuf), "^(%s)", b->url->path);
errcode = regcomp(b->url->preg, rebuf,
(REG_EXTENDED|REG_NOSUB|REG_ICASE));
@@ -1059,7 +1059,7 @@ strsav(char *old, char *text_to_append)
}
}
- strcpy(p + old_len, text_to_append);
+ strlcpy(p + old_len, text_to_append, new_len-old_len);
return(p);
}
@@ -1083,26 +1083,28 @@ savearg(char *c, char *o)
if(c && *c) {
if((c = url_encode(html_code_map, c))) {
- sprintf(buf, "<a " OPT "%s\">%s</a> ", c, c);
+ snprintf(buf, sizeof(buf), "<a " OPT "%s\">%s</a> ", c, c);
}
freez(c);
}
if(o && *o) {
if((o = url_encode(html_code_map, o))) {
if(strncmpic(o, "http://", 7) == 0) {
- strcat(buf, "<a href=\"");
- strcat(buf, o);
- strcat(buf, "\">");
- strcat(buf, o);
- strcat(buf, "</a>");
+ int l = strlen(buf);
+
+ l += strlcat(buf, "<a href=\"", sizeof(buf)-l);
+ l += strlcat(buf, o, sizeof(buf)-l);
+ l += strlcat(buf, "\">", sizeof(buf)-l);
+ l += strlcat(buf, o, sizeof(buf)-l);
+ l += strlcat(buf, "</a>", sizeof(buf)-l);
} else {
- strcat(buf, o);
+ strlcat(buf, o, sizeof(buf)-strlen(buf));
}
}
freez(o);
}
- strcat(buf, "<br>\n");
+ strlcat(buf, "<br>\n", sizeof(buf)-strlen(buf));
proxy_args->invocation = strsav(proxy_args->invocation, buf);
}
@@ -1164,18 +1166,18 @@ end_proxy_args()
b = strsav(b, "<h2>Source versions:</h2>\n");
b = strsav(b, "<pre>");
- sprintf(buf, "%s\n", jcc_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", parsers_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", filters_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", loaders_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", conn_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", bind_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", encode_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", socks4_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", ssplit_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", acl_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", gnu_regex_rcs ); b = strsav(b, buf);
- sprintf(buf, "%s\n", win32_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", jcc_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", parsers_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", filters_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", loaders_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", conn_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", bind_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", encode_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", socks4_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", ssplit_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", acl_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", gnu_regex_rcs ); b = strsav(b, buf);
+ snprintf(buf, sizeof(buf), "%s\n", win32_rcs ); b = strsav(b, buf);
b = strsav(b, "</pre>");
#ifdef REGEX