restore ConvertToValidURI to prev. version for bw compat. Note changes
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@30187 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
e4e3bbb447
commit
997ba01b28
@ -106,11 +106,11 @@ INCOMPATIBLE CHANGES SINCE 2.4.x
|
|||||||
! wxURL has undergone some radical changes.
|
! wxURL has undergone some radical changes.
|
||||||
|
|
||||||
* Many accessors of wxURL - GetHostName, GetProtocolName, and GetPath,
|
* Many accessors of wxURL - GetHostName, GetProtocolName, and GetPath,
|
||||||
have been replaced by its parent's (wxURI) counterparts.
|
have been replaced by its parent's (wxURI) counterparts - GetServer,
|
||||||
|
GetScheme, and GetPath, respectively.
|
||||||
|
|
||||||
* ConvertToValidURI has been replaced by wxURI, and even applications
|
* ConvertToValidURI has been replaced by wxURI. Do not use
|
||||||
with 2.4 compatability enabled will have the second parameter, delims,
|
ConvertToValidURI for future applications.
|
||||||
completely ignored.
|
|
||||||
|
|
||||||
* ConvertFromURI has been replaced by wxURI::Unescape.
|
* ConvertFromURI has been replaced by wxURI::Unescape.
|
||||||
|
|
||||||
@ -220,7 +220,8 @@ All:
|
|||||||
- added wxTextInputStream::operator>>(wchar_t) for compilers which support this
|
- added wxTextInputStream::operator>>(wchar_t) for compilers which support this
|
||||||
- added wxURI, a class for dealing with Uniform Resource Identifiers
|
- added wxURI, a class for dealing with Uniform Resource Identifiers
|
||||||
- changed wxURL to inherit from wxURI and provide assignment and comparison
|
- changed wxURL to inherit from wxURI and provide assignment and comparison
|
||||||
- Added UTF7 character conversion for platforms that don't support it
|
- implemented wxConvUTF7 (modified patch from Fredrik Roubert)
|
||||||
|
- added versions of MB2WC and WC2MB for wxMBConv that for embedded null chars
|
||||||
|
|
||||||
All (GUI):
|
All (GUI):
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ public:
|
|||||||
wxString GetHostName() const { return m_server; }
|
wxString GetHostName() const { return m_server; }
|
||||||
wxString GetPath() const { return m_path; }
|
wxString GetPath() const { return m_path; }
|
||||||
|
|
||||||
//Use wxURI instead - delims is ignored
|
//Use wxURI instead - this does not work that well
|
||||||
static wxString ConvertToValidURI(
|
static wxString ConvertToValidURI(
|
||||||
const wxString& uri,
|
const wxString& uri,
|
||||||
const wxChar* delims = wxT(";/?:@&=+$,")
|
const wxChar* delims = wxT(";/?:@&=+$,")
|
||||||
|
@ -1226,9 +1226,52 @@ bool wxURI::IsDigit(const wxChar& c)
|
|||||||
|
|
||||||
#include "wx/url.h"
|
#include "wx/url.h"
|
||||||
|
|
||||||
wxString wxURL::ConvertToValidURI(const wxString& uri, const wxChar* WXUNUSED(delims))
|
//Note that this old code really doesn't convert to a URI that well and looks
|
||||||
|
//more like a dirty hack than anything else...
|
||||||
|
|
||||||
|
wxString wxURL::ConvertToValidURI(const wxString& uri, const wxChar* delims)
|
||||||
{
|
{
|
||||||
return wxURI(uri).BuildURI();
|
wxString out_str;
|
||||||
|
wxString hexa_code;
|
||||||
|
size_t i;
|
||||||
|
|
||||||
|
for (i = 0; i < uri.Len(); i++)
|
||||||
|
{
|
||||||
|
wxChar c = uri.GetChar(i);
|
||||||
|
|
||||||
|
if (c == wxT(' '))
|
||||||
|
{
|
||||||
|
// GRG, Apr/2000: changed to "%20" instead of '+'
|
||||||
|
|
||||||
|
out_str += wxT("%20");
|
||||||
|
}
|
||||||
|
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
|
||||||
|
// but not if they are used to separate components. Here we have
|
||||||
|
// no clear way to distinguish between these two cases, so they
|
||||||
|
// are escaped unless they are passed in the 'delims' parameter
|
||||||
|
// (allowed delimiters).
|
||||||
|
|
||||||
|
static const wxChar marks[] = wxT("-_.!~*()'");
|
||||||
|
|
||||||
|
if ( !wxIsalnum(c) && !wxStrchr(marks, c) && !wxStrchr(delims, c) )
|
||||||
|
{
|
||||||
|
hexa_code.Printf(wxT("%%%02X"), c);
|
||||||
|
out_str += hexa_code;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
out_str += c;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return out_str;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxURL::ConvertFromURI(const wxString& uri)
|
wxString wxURL::ConvertFromURI(const wxString& uri)
|
||||||
|
Loading…
Reference in New Issue
Block a user