1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

proxy.c: make get_line_end return a bool.

Now the integer output value is never negative (because the condition
that used to be signalled by setting it to -1 is now signalled by
returning false from the actual function), which frees me to make it
an unsigned type in an upcoming change.
This commit is contained in:
Simon Tatham 2019-02-06 20:11:11 +00:00
parent 0f405ae8a3
commit eb16dee2a4

28
proxy.c
View File

@ -545,7 +545,7 @@ Socket *new_listener(const char *srcaddr, int port, Plug *plug,
* HTTP CONNECT proxy type. * HTTP CONNECT proxy type.
*/ */
static int get_line_end (char * data, int len) static bool get_line_end(char *data, int len, int *out)
{ {
int off = 0; int off = 0;
@ -556,16 +556,20 @@ static int get_line_end (char * data, int len)
off++; off++;
/* is that the only thing on this line? */ /* is that the only thing on this line? */
if (off <= 2) return off; if (off <= 2) {
*out = off;
return true;
}
/* if not, then there is the possibility that this header /* if not, then there is the possibility that this header
* continues onto the next line, if it starts with a space * continues onto the next line, if it starts with a space
* or a tab. * or a tab.
*/ */
if (off + 1 < len && if (off + 1 < len && data[off+1] != ' ' && data[off+1] != '\t') {
data[off+1] != ' ' && *out = off;
data[off+1] != '\t') return off; return true;
}
/* the line does continue, so we have to keep going /* the line does continue, so we have to keep going
* until we see an the header's "real" end of line. * until we see an the header's "real" end of line.
@ -576,7 +580,7 @@ static int get_line_end (char * data, int len)
off++; off++;
} }
return -1; return false;
} }
int proxy_http_negotiate (ProxySocket *p, int change) int proxy_http_negotiate (ProxySocket *p, int change)
@ -677,8 +681,7 @@ int proxy_http_negotiate (ProxySocket *p, int change)
*/ */
data[len] = '\0'; data[len] = '\0';
eol = get_line_end(data, len); if (!get_line_end(data, len, &eol)) {
if (eol < 0) {
sfree(data); sfree(data);
return 1; return 1;
} }
@ -726,17 +729,16 @@ int proxy_http_negotiate (ProxySocket *p, int change)
datap = data; datap = data;
bufchain_fetch(&p->pending_input_data, data, len); bufchain_fetch(&p->pending_input_data, data, len);
eol = get_line_end(datap, len); if (!get_line_end(datap, len, &eol)) {
if (eol < 0) {
sfree(data); sfree(data);
return 1; return 1;
} }
while (eol > 2) while (eol > 2) {
{
bufchain_consume(&p->pending_input_data, eol); bufchain_consume(&p->pending_input_data, eol);
datap += eol; datap += eol;
len -= eol; len -= eol;
eol = get_line_end(datap, len); if (!get_line_end(datap, len, &eol))
eol = 0; /* terminate the loop */
} }
if (eol == 2) { if (eol == 2) {