commit 0cec4cbb396dedb52e543743058fb8b68b0aaafb
parent ab4fa1fdbc51ec4d952b097f076ca0fdfcb10934
Author: Andrey Uzunov <andrey.uzunov@gmail.com>
Date: Thu, 10 Oct 2013 00:34:52 +0000
spdy2http: handle servers which dont use CR
Diffstat:
1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/src/spdy2http/proxy.c b/src/spdy2http/proxy.c
@@ -452,6 +452,7 @@ response_callback (void *cls,
if(!proxy->http_body_size)//nothing to write now
{
+ PRINT_VERBOSE2("nothing to write now? %i", proxy->done);
if(proxy->done) *more = false;
return 0;
}
@@ -503,7 +504,6 @@ response_done_callback(void *cls,
if(SPDY_RESPONSE_RESULT_SUCCESS != status)
{
- PRINT_VERBOSE2("answer was NOT sent, %i\n",status);
free(proxy->http_body);
proxy->http_body = NULL;
}
@@ -540,7 +540,7 @@ curl_header_cb(void *ptr, size_t size, size_t nmemb, void *userp)
//trailer
if(NULL != proxy->response) return 0;
- if('\r' == line[0])
+ if('\r' == line[0] || '\n' == line[0])
{
//all headers were already handled; prepare spdy frames
if(NULL == (proxy->response = SPDY_build_response_with_callback(proxy->status,
@@ -589,16 +589,16 @@ curl_header_cb(void *ptr, size_t size, size_t nmemb, void *userp)
pos = i+1;
//status (number)
- for(i=pos; i<realsize && ' '!=line[i] && '\r'!=line[i]; ++i);
+ for(i=pos; i<realsize && ' '!=line[i] && '\r'!=line[i] && '\n'!=line[i]; ++i);
if(NULL == (status = strndup(&(line[pos]), i - pos)))
DIE("No memory");
proxy->status = atoi(status);
free(status);
- if(i<realsize && '\r'!=line[i])
+ if(i<realsize && '\r'!=line[i] && '\n'!=line[i])
{
//status (message)
pos = i+1;
- for(i=pos; i<realsize && '\r'!=line[i]; ++i);
+ for(i=pos; i<realsize && '\r'!=line[i] && '\n'!=line[i]; ++i);
if(NULL == (proxy->status_msg = strndup(&(line[pos]), i - pos)))
DIE("No memory");
}
@@ -608,7 +608,7 @@ curl_header_cb(void *ptr, size_t size, size_t nmemb, void *userp)
//other lines
//header name
- for(i=pos; i<realsize && ':'!=line[i] && '\r'!=line[i]; ++i)
+ for(i=pos; i<realsize && ':'!=line[i] && '\r'!=line[i] && '\n'!=line[i]; ++i)
line[i] = tolower(line[i]); //spdy requires lower case
if(NULL == (name = strndup(line, i - pos)))
DIE("No memory");
@@ -621,7 +621,7 @@ curl_header_cb(void *ptr, size_t size, size_t nmemb, void *userp)
free(name);
return realsize;
}
- if(i == realsize || '\r'==line[i])
+ if(i == realsize || '\r'==line[i] || '\n'==line[i])
{
//no value. is it possible?
if(SPDY_YES != SPDY_name_value_add(proxy->headers, name, ""))
@@ -632,7 +632,7 @@ curl_header_cb(void *ptr, size_t size, size_t nmemb, void *userp)
//header value
pos = i+1;
while(pos<realsize && isspace(line[pos])) ++pos; //remove leading space
- for(i=pos; i<realsize && '\r'!=line[i]; ++i);
+ for(i=pos; i<realsize && '\r'!=line[i] && '\n'!=line[i]; ++i);
if(NULL == (value = strndup(&(line[pos]), i - pos)))
DIE("No memory");
PRINT_VERBOSE2("Adding header: '%s': '%s'", name, value);