Committing modified version of jwiesemann's patch (see #11223):

Fix wxURL copy ctor and assignment: the default ones provided by the compiler are wrong because wxURL uses pointers internally. 
Also add a test for copy & assignment in URLTestCase.

Closes #11223

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@63806 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Francesco Montorsi
2010-03-30 21:38:31 +00:00
parent 38442edb48
commit 00e075e551
3 changed files with 97 additions and 14 deletions

View File

@@ -48,11 +48,13 @@ class WXDLLIMPEXP_NET wxURL : public wxURI
{ {
public: public:
wxURL(const wxString& sUrl = wxEmptyString); wxURL(const wxString& sUrl = wxEmptyString);
wxURL(const wxURI& url); wxURL(const wxURI& uri);
wxURL(const wxURL& url);
virtual ~wxURL(); virtual ~wxURL();
wxURL& operator = (const wxString& url); wxURL& operator = (const wxString& url);
wxURL& operator = (const wxURI& url); wxURL& operator = (const wxURI& uri);
wxURL& operator = (const wxURL& url);
wxProtocol& GetProtocol() { return *m_protocol; } wxProtocol& GetProtocol() { return *m_protocol; }
wxURLError GetError() const { return m_error; } wxURLError GetError() const { return m_error; }
@@ -99,6 +101,7 @@ protected:
void Init(const wxString&); void Init(const wxString&);
bool ParseURL(); bool ParseURL();
void CleanData(); void CleanData();
void Free();
bool FetchProtocol(); bool FetchProtocol();
friend class wxProtoInfo; friend class wxProtoInfo;

View File

@@ -65,9 +65,15 @@ wxURL::wxURL(const wxString& url) : wxURI(url)
ParseURL(); ParseURL();
} }
wxURL::wxURL(const wxURI& url) : wxURI(url) wxURL::wxURL(const wxURI& uri) : wxURI(uri)
{ {
Init(url.BuildURI()); Init(uri.BuildURI());
ParseURL();
}
wxURL::wxURL(const wxURL& url) : wxURI(url)
{
Init(url.GetURL());
ParseURL(); ParseURL();
} }
@@ -102,18 +108,39 @@ void wxURL::Init(const wxString& url)
// Assignment // Assignment
// -------------------------------------------------------------- // --------------------------------------------------------------
wxURL& wxURL::operator = (const wxURI& url)
{
wxURI::operator = (url);
Init(url.BuildURI());
ParseURL();
return *this;
}
wxURL& wxURL::operator = (const wxString& url) wxURL& wxURL::operator = (const wxString& url)
{ {
wxURI::operator = (url); wxURI::operator = (url);
Free();
Init(url); Init(url);
ParseURL(); ParseURL();
return *this;
}
wxURL& wxURL::operator = (const wxURI& uri)
{
if (&uri != this)
{
wxURI::operator = (uri);
Free();
Init(uri.BuildURI());
ParseURL();
}
return *this;
}
wxURL& wxURL::operator = (const wxURL& url)
{
if (&url != this)
{
wxURI::operator = (url);
Free();
Init(url.GetURL());
ParseURL();
}
return *this; return *this;
} }
@@ -195,7 +222,7 @@ void wxURL::CleanData()
} }
} }
wxURL::~wxURL() void wxURL::Free()
{ {
CleanData(); CleanData();
#if wxUSE_PROTOCOL_HTTP #if wxUSE_PROTOCOL_HTTP
@@ -207,6 +234,11 @@ wxURL::~wxURL()
#endif #endif
} }
wxURL::~wxURL()
{
Free();
}
// -------------------------------------------------------------- // --------------------------------------------------------------
// FetchProtocol // FetchProtocol
// -------------------------------------------------------------- // --------------------------------------------------------------

View File

@@ -37,9 +37,11 @@ public:
private: private:
CPPUNIT_TEST_SUITE( URLTestCase ); CPPUNIT_TEST_SUITE( URLTestCase );
CPPUNIT_TEST( GetInputStream ); CPPUNIT_TEST( GetInputStream );
CPPUNIT_TEST( CopyAndAssignment );
CPPUNIT_TEST_SUITE_END(); CPPUNIT_TEST_SUITE_END();
void GetInputStream(); void GetInputStream();
void CopyAndAssignment();
DECLARE_NO_COPY_CLASS(URLTestCase) DECLARE_NO_COPY_CLASS(URLTestCase)
}; };
@@ -80,5 +82,51 @@ void URLTestCase::GetInputStream()
// wx logo image currently is 13219 bytes // wx logo image currently is 13219 bytes
CPPUNIT_ASSERT(ostream.GetSize() == 13219); CPPUNIT_ASSERT(ostream.GetSize() == 13219);
// we have to delete the object created by GetInputStream()
delete in_stream;
} }
void URLTestCase::CopyAndAssignment()
{
wxURL url1("http://www.example.org/");
wxURL url2;
wxURI *puri = &url2; // downcast
{ // Copy constructor
wxURL url3(url1);
CPPUNIT_ASSERT(url1 == url3);
}
{ // Constructor for string
wxURL url3(url1.GetURL());
CPPUNIT_ASSERT(url1 == url3);
}
{ // 'Copy' constructor for uri
wxURL url3(*puri);
CPPUNIT_ASSERT(url2 == url3);
}
// assignment for uri
*puri = url1;
CPPUNIT_ASSERT(url1 == url2);
// assignment to self through base pointer
*puri = url2;
// Assignment of string
url1 = wxS("http://www.example2.org/index.html");
*puri = wxS("http://www.example2.org/index.html");
CPPUNIT_ASSERT(url1 == url2);
// Assignment
url1 = wxS("");
url2 = url1;
CPPUNIT_ASSERT(url1 == url2);
// assignment to self
url2 = url2;
// check for destructor (with base pointer!)
puri = new wxURL();
delete puri;
}