From 820983f40c909f901674c2705c6226afb78d595b Mon Sep 17 00:00:00 2001 From: Carsten Sandtner Date: Thu, 23 May 2013 14:37:32 +0200 Subject: [PATCH] Fixed setHeader while Android had problems with stringstreams. --- .../javascript/bindings/XMLHTTPRequest.cpp | 21 ++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/scripting/javascript/bindings/XMLHTTPRequest.cpp b/scripting/javascript/bindings/XMLHTTPRequest.cpp index e0fc7a25b8..e40ed78299 100644 --- a/scripting/javascript/bindings/XMLHTTPRequest.cpp +++ b/scripting/javascript/bindings/XMLHTTPRequest.cpp @@ -139,15 +139,21 @@ void MinXmlHttpRequest::_setHttpRequestHeader() { std::vector header; for (std::map::iterator it = request_header.begin(); it != request_header.end(); ++it) { + + const char* first = it->first.c_str(); + const char* second = it->second.c_str(); + size_t len = sizeof(char) * (strlen(first) + 3 + strlen(second)); + char* test = (char*) malloc(len); + memset(test, 0,len); - stringstream value_s; - const char* value; + strcpy(test, first); + strcpy(test + strlen(first) , ": "); + strcpy(test + strlen(first) + 2, second); + + header.push_back(test); - value_s << it->first << ": " << it->second; - value = value_s.str().c_str(); - header.push_back(value); + free(test); - } if (!header.empty()) { @@ -252,6 +258,7 @@ MinXmlHttpRequest::MinXmlHttpRequest() : onreadystateCallback(NULL), isNetwork(t http_header.clear(); request_header.clear(); + withCredentialsValue = true; cx = ScriptingCore::getInstance()->getGlobalContext(); cc_request = new cocos2d::extension::CCHttpRequest(); } @@ -736,7 +743,7 @@ JS_BINDED_FUNC_IMPL(MinXmlHttpRequest, setRequestHeader) JSStringWrapper w2(jsValue); field = w1; value = w2; - + // Populate the request_header map. _setRequestHeader(field, value);