X-Git-Url: http://www.privoxy.org/gitweb/?a=blobdiff_plain;ds=inline;f=urlmatch.c;h=86d211be5081b55068717f99cd3afcdb255bf4de;hb=d08efb68329798242aa848d30b50fc58254b1aaf;hp=4ba17cf10cbd72c8b737d6a8dfa2b11ae7cb6ea5;hpb=8fe6bb275095d03b4dc1c68edf2dd72babf56428;p=privoxy.git diff --git a/urlmatch.c b/urlmatch.c index 4ba17cf1..86d211be 100644 --- a/urlmatch.c +++ b/urlmatch.c @@ -1,4 +1,4 @@ -const char urlmatch_rcs[] = "$Id: urlmatch.c,v 1.42 2008/05/04 13:24:16 fabiankeil Exp $"; +const char urlmatch_rcs[] = "$Id: urlmatch.c,v 1.44 2008/05/04 16:18:32 fabiankeil Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/urlmatch.c,v $ @@ -33,6 +33,13 @@ const char urlmatch_rcs[] = "$Id: urlmatch.c,v 1.42 2008/05/04 13:24:16 fabianke * * Revisions : * $Log: urlmatch.c,v $ + * Revision 1.44 2008/05/04 16:18:32 fabiankeil + * Provide parse_http_url() with a third parameter to specify + * whether or not URLs without protocol are acceptable. + * + * Revision 1.43 2008/05/04 13:30:55 fabiankeil + * Streamline parse_http_url()'s prototype. + * * Revision 1.42 2008/05/04 13:24:16 fabiankeil * If the method isn't CONNECT, reject URLs without protocol. * @@ -371,6 +378,8 @@ jb_err init_domain_components(struct http_request *http) * 1 : url = URL (or is it URI?) to break down * 2 : http = pointer to the http structure to hold elements. * Must be initialized with valid values (like NULLs). + * 3 : require_protocol = Whether or not URLs without + * protocol are acceptable. * * Returns : JB_ERR_OK on success * JB_ERR_MEMORY on out of memory @@ -378,7 +387,7 @@ jb_err init_domain_components(struct http_request *http) * or >100 domains deep. * *********************************************************************/ -jb_err parse_http_url(const char * url, struct http_request *http) +jb_err parse_http_url(const char *url, struct http_request *http, int require_protocol) { int host_available = 1; /* A proxy can dream. */ @@ -448,7 +457,7 @@ jb_err parse_http_url(const char * url, struct http_request *http) http->host = NULL; host_available = 0; } - else if (!http->ssl) + else if (require_protocol) { freez(buf); return JB_ERR_PARSE; @@ -668,7 +677,7 @@ jb_err parse_http_request(const char *req, http->ssl = !strcmpic(v[0], "CONNECT"); - err = parse_http_url(v[1], http); + err = parse_http_url(v[1], http, !http->ssl); if (err) { freez(buf); @@ -721,7 +730,7 @@ static jb_err compile_pattern(const char *pattern, enum regex_anchoring anchorin { int errcode; char rebuf[BUFFER_SIZE]; - const char *fmt; + const char *fmt = NULL; assert(pattern); assert(strlen(pattern) < sizeof(rebuf) - 2);