X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/999836aacade840a5d9a0cbb5fad7b1d4de62c93..02a525b385836d41f63e3bbebec869c7b8249026:/src/common/url.cpp?ds=sidebyside diff --git a/src/common/url.cpp b/src/common/url.cpp index e265e0c5f3..9e02d03dca 100644 --- a/src/common/url.cpp +++ b/src/common/url.cpp @@ -45,7 +45,7 @@ USE_PROTOCOL(wxHTTP) USE_PROTOCOL(wxFTP) wxHTTP *wxURL::ms_proxyDefault = NULL; - bool wxURL::ms_useDefaultProxy = FALSE; + bool wxURL::ms_useDefaultProxy = false; #endif // -------------------------------------------------------------- @@ -61,6 +61,9 @@ wxURL::wxURL(const wxString& url) m_protocol = NULL; m_error = wxURL_NOERR; m_url = url; +#if wxUSE_URL_NATIVE + m_nativeImp = CreateNativeImpObject(); +#endif #if wxUSE_SOCKETS if ( ms_useDefaultProxy && !ms_proxyDefault ) @@ -70,7 +73,7 @@ wxURL::wxURL(const wxString& url) if ( !ms_proxyDefault ) { // don't try again - ms_useDefaultProxy = FALSE; + ms_useDefaultProxy = false; } } @@ -95,14 +98,14 @@ bool wxURL::ParseURL() if (!PrepProto(last_url)) { m_error = wxURL_SNTXERR; - return FALSE; + return false; } // Find and create the protocol object if (!FetchProtocol()) { m_error = wxURL_NOPROTO; - return FALSE; + return false; } // Do we need a host name ? @@ -112,7 +115,7 @@ bool wxURL::ParseURL() if (!PrepHost(last_url)) { m_error = wxURL_SNTXERR; - return FALSE; + return false; } } @@ -120,7 +123,7 @@ bool wxURL::ParseURL() if (!PrepPath(last_url)) { m_error = wxURL_NOPATH; - return FALSE; + return false; } } // URL parse finished. @@ -128,8 +131,8 @@ bool wxURL::ParseURL() #if wxUSE_SOCKETS if (m_useProxy) { - // We destroy the newly created protocol. - CleanData(); + // destroy the previously created protocol as we'll be using m_proxy + delete m_protocol; // Third, we rebuild the URL. m_url = m_protoname + wxT(":"); @@ -144,7 +147,7 @@ bool wxURL::ParseURL() #endif m_error = wxURL_NOERR; - return TRUE; + return true; } void wxURL::CleanData() @@ -157,10 +160,13 @@ void wxURL::CleanData() wxURL::~wxURL() { - CleanData(); + CleanData(); #if wxUSE_SOCKETS - if (m_proxy && m_proxy != ms_proxyDefault) - delete m_proxy; + if (m_proxy && m_proxy != ms_proxyDefault) + delete m_proxy; +#endif +#if wxUSE_URL_NATIVE + delete m_nativeImp; #endif } @@ -174,14 +180,14 @@ bool wxURL::PrepProto(wxString& url) // Find end pos = url.Find(wxT(':')); - if (pos == -1) - return FALSE; + if (pos == wxNOT_FOUND) + return false; m_protoname = url(0, pos); url = url(pos+1, url.Length()); - return TRUE; + return true; } bool wxURL::PrepHost(wxString& url) @@ -190,51 +196,51 @@ bool wxURL::PrepHost(wxString& url) int pos, pos2; if ((url.GetChar(0) != wxT('/')) || (url.GetChar(1) != wxT('/'))) - return FALSE; + return false; url = url(2, url.Length()); pos = url.Find(wxT('/')); - if (pos == -1) + if (pos == wxNOT_FOUND) pos = url.Length(); if (pos == 0) - return FALSE; + return false; temp_url = url(0, pos); url = url(url.Find(wxT('/')), url.Length()); // Retrieve service number - pos2 = temp_url.Find(wxT(':'), TRUE); - if (pos2 != -1 && pos2 < pos) + pos2 = temp_url.Find(wxT(':'), true); + if (pos2 != wxNOT_FOUND && pos2 < pos) { m_servname = temp_url(pos2+1, pos); if (!m_servname.IsNumber()) - return FALSE; + return false; temp_url = temp_url(0, pos2); } // Retrieve user and password. pos2 = temp_url.Find(wxT('@')); - // Even if pos2 equals -1, this code is right. + // Even if pos2 equals wxNOT_FOUND, this code is right. m_hostname = temp_url(pos2+1, temp_url.Length()); m_user = wxT(""); m_password = wxT(""); - if (pos2 == -1) - return TRUE; + if (pos2 == wxNOT_FOUND) + return true; temp_url = temp_url(0, pos2); pos2 = temp_url.Find(wxT(':')); - if (pos2 == -1) - return FALSE; + if (pos2 == wxNOT_FOUND) + return false; m_user = temp_url(0, pos2); m_password = temp_url(pos2+1, url.Length()); - return TRUE; + return true; } bool wxURL::PrepPath(wxString& url) @@ -243,7 +249,7 @@ bool wxURL::PrepPath(wxString& url) m_path = ConvertToValidURI(url); else m_path = wxT("/"); - return TRUE; + return true; } bool wxURL::FetchProtocol() @@ -259,11 +265,11 @@ bool wxURL::FetchProtocol() m_protoinfo = info; m_protocol = (wxProtocol *)m_protoinfo->m_cinfo->CreateObject(); - return TRUE; + return true; } info = info->next; } - return FALSE; + return false; } // -------------------------------------------------------------- @@ -285,6 +291,19 @@ wxInputStream *wxURL::GetInputStream() m_protocol->SetPassword(m_password); } +#if wxUSE_URL_NATIVE + // give the native implementation to return a better stream + // such as the native WinINet functionality under MS-Windows + if (m_nativeImp) + { + wxInputStream *rc; + rc = m_nativeImp->GetInputStream(this); + if (rc != 0) + return rc; + } + // else use the standard behaviour +#endif // wxUSE_URL_NATIVE + #if wxUSE_SOCKETS wxIPV4address addr; @@ -299,7 +318,7 @@ wxInputStream *wxURL::GetInputStream() addr.Service(m_servname); - if (!m_protocol->Connect(addr, TRUE)) // Watcom needs the 2nd arg for some reason + if (!m_protocol->Connect(addr, true)) // Watcom needs the 2nd arg for some reason { m_error = wxURL_CONNERR; return NULL; @@ -308,7 +327,7 @@ wxInputStream *wxURL::GetInputStream() #endif // When we use a proxy, we have to pass the whole URL to it. - wxInputStream *the_i_stream = + wxInputStream *the_i_stream = (m_useProxy) ? m_protocol->GetInputStream(m_url) : m_protocol->GetInputStream(m_path); @@ -337,7 +356,7 @@ void wxURL::SetDefaultProxy(const wxString& url_proxy) { wxString tmp_str = url_proxy; int pos = tmp_str.Find(wxT(':')); - if (pos == -1) + if (pos == wxNOT_FOUND) return; wxString hostname = tmp_str(0, pos), @@ -354,7 +373,7 @@ void wxURL::SetDefaultProxy(const wxString& url_proxy) ms_proxyDefault->Close(); else ms_proxyDefault = new wxHTTP(); - ms_proxyDefault->Connect(addr, TRUE); // Watcom needs the 2nd arg for some reason + ms_proxyDefault->Connect(addr, true); // Watcom needs the 2nd arg for some reason } } @@ -368,7 +387,7 @@ void wxURL::SetProxy(const wxString& url_proxy) delete m_proxy; } - m_useProxy = FALSE; + m_useProxy = false; } else { @@ -380,7 +399,7 @@ void wxURL::SetProxy(const wxString& url_proxy) tmp_str = url_proxy; pos = tmp_str.Find(wxT(':')); // This is an invalid proxy name. - if (pos == -1) + if (pos == wxNOT_FOUND) return; hostname = tmp_str(0, pos); @@ -393,11 +412,11 @@ void wxURL::SetProxy(const wxString& url_proxy) if (m_proxy && m_proxy != ms_proxyDefault) delete m_proxy; m_proxy = new wxHTTP(); - m_proxy->Connect(addr, TRUE); // Watcom needs the 2nd arg for some reason + m_proxy->Connect(addr, true); // Watcom needs the 2nd arg for some reason CleanData(); // Reparse url. - m_useProxy = TRUE; + m_useProxy = true; ParseURL(); } } @@ -422,7 +441,7 @@ wxString wxURL::ConvertToValidURI(const wxString& uri, const wxChar* delims) else { // GRG, Apr/2000: modified according to the URI definition (RFC 2396) - // + // // - Alphanumeric characters are never escaped // - Unreserved marks are never escaped // - Delimiters must be escaped if they appear within a component @@ -511,10 +530,10 @@ bool wxURLModule::OnInit() if ( getenv("HTTP_PROXY") ) { - wxURL::ms_useDefaultProxy = TRUE; + wxURL::ms_useDefaultProxy = true; } - return TRUE; + return true; } void wxURLModule::OnExit()