171 lines
5.8 KiB
Plaintext
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
|