]> git.saurik.com Git - wxWidgets.git/commitdiff
applied patch 90459
authorStefan Csomor <csomor@advancedconcepts.ch>
Thu, 15 Jul 2004 18:17:31 +0000 (18:17 +0000)
committerStefan Csomor <csomor@advancedconcepts.ch>
Thu, 15 Jul 2004 18:17:31 +0000 (18:17 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@28247 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

src/common/http.cpp

index d5fa45d6bd227f2d9baa2d9821d9b8dcdf3d4181..21381bd83a5dd7e05371269dd9c47e07aecc27a5 100644 (file)
@@ -218,6 +218,8 @@ bool wxHTTP::BuildRequest(const wxString& path, wxHTTP_Req req)
     break;
   case wxHTTP_POST:
     request = wxT("POST");
+    if ( GetHeader( wxT("Content-Length") ).IsNull() )
+      SetHeader( wxT("Content-Length"), wxString::Format( wxT("%ld"), m_post_buf.Len() ) );
     break;
   default:
     return FALSE;
@@ -230,7 +232,7 @@ bool wxHTTP::BuildRequest(const wxString& path, wxHTTP_Req req)
     SetHeader(wxT("User-Agent"), wxT("wxWidgets 2.x"));
 
   SaveState();
-  SetFlags(wxSOCKET_NONE);
+  SetFlags( wxThread::IsMain() ? wxSOCKET_NONE : wxSOCKET_BLOCK );
   Notify(FALSE);
 
   wxString buf;
@@ -241,7 +243,7 @@ bool wxHTTP::BuildRequest(const wxString& path, wxHTTP_Req req)
   Write("\r\n", 2);
 
   if ( req == wxHTTP_POST ) {
-    Write(m_post_buf, m_post_buf.Len());
+    Write(m_post_buf.mbc_str(), m_post_buf.Len());
     m_post_buf = wxEmptyString;
   }