X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/be4bd4636d8e7e06ad5728ff1b398fbd0ab74d93..d39780517dc80c48d29b637f659e81ebd512d60d:/src/common/sckaddr.cpp diff --git a/src/common/sckaddr.cpp b/src/common/sckaddr.cpp index 3ac7e22d9f..8e79847d83 100644 --- a/src/common/sckaddr.cpp +++ b/src/common/sckaddr.cpp @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: sckaddr.cpp +// Name: src/common/sckaddr.cpp // Purpose: Network address manager // Author: Guilhem Lavaux // Modified by: @@ -9,21 +9,16 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) - #pragma implementation "sckaddr.h" -#endif - // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" #ifdef __BORLANDC__ - #pragma hdrstop + #pragma hdrstop #endif #if wxUSE_SOCKETS #ifndef WX_PRECOMP - #include "wx/defs.h" #include "wx/object.h" #include "wx/log.h" #include "wx/intl.h" @@ -47,7 +42,7 @@ IMPLEMENT_DYNAMIC_CLASS(wxIPV4address, wxIPaddress) #if wxUSE_IPV6 IMPLEMENT_DYNAMIC_CLASS(wxIPV6address, wxIPaddress) #endif -#if defined(__UNIX__) && !defined(__WINE__) && (!defined(__WXMAC__) || defined(__DARWIN__)) +#if defined(__UNIX__) && !defined(__WINDOWS__) && !defined(__WINE__) && (!defined(__WXMAC__) || defined(__DARWIN__)) IMPLEMENT_DYNAMIC_CLASS(wxUNIXaddress, wxSockAddress) #endif @@ -86,8 +81,11 @@ wxSockAddress::~wxSockAddress() void wxSockAddress::SetAddress(GAddress *address) { - GAddress_destroy(m_address); - m_address = GAddress_copy(address); + if ( address != m_address ) + { + GAddress_destroy(m_address); + m_address = GAddress_copy(address); + } } wxSockAddress& wxSockAddress::operator=(const wxSockAddress& addr) @@ -141,10 +139,10 @@ wxIPV4address::~wxIPV4address() bool wxIPV4address::Hostname(const wxString& name) { // Some people are sometimes fool. - if (name == wxT("")) + if (name.empty()) { wxLogWarning( _("Trying to solve a NULL hostname: giving up") ); - return FALSE; + return false; } m_origHostname = name; return (GAddress_INET_SetHostName(m_address, name.mb_str()) == GSOCK_NOERROR); @@ -180,6 +178,11 @@ bool wxIPV4address::IsLocalHost() const return (Hostname() == wxT("localhost") || IPAddress() == wxT("127.0.0.1")); } +bool wxIPV4address::BroadcastAddress() +{ + return (GAddress_INET_SetBroadcastAddress(m_address) == GSOCK_NOERROR); +} + bool wxIPV4address::AnyAddress() { return (GAddress_INET_SetAnyAddress(m_address) == GSOCK_NOERROR); @@ -207,21 +210,20 @@ wxSockAddress *wxIPV4address::Clone() const } wxString wxIPV4address::IPAddress() const -{ - unsigned long raw = GAddress_INET_GetHostAddress(m_address); - return wxString::Format( - _T("%u.%u.%u.%u"), - (unsigned char)(raw & 0xff), - (unsigned char)((raw>>8) & 0xff), - (unsigned char)((raw>>16) & 0xff), - (unsigned char)((raw>>24) & 0xff) - ); +{ + unsigned long raw = GAddress_INET_GetHostAddress(m_address); + return wxString::Format(_T("%lu.%lu.%lu.%lu"), + (raw>>24) & 0xff, + (raw>>16) & 0xff, + (raw>>8) & 0xff, + raw & 0xff + ); } -bool wxIPV4address::operator==(wxIPV4address& addr) +bool wxIPV4address::operator==(const wxIPV4address& addr) const { - if(Hostname().Cmp(addr.Hostname().c_str()) == 0 && Service() == addr.Service()) return true; - return false; + return Hostname().Cmp(addr.Hostname()) == 0 && + Service() == addr.Service(); } #if wxUSE_IPV6 @@ -245,17 +247,17 @@ wxIPV6address::~wxIPV6address() bool wxIPV6address::Hostname(const wxString& name) { - if (name == wxT("")) + if (name.empty()) { wxLogWarning( _("Trying to solve a NULL hostname: giving up") ); - return FALSE; + return false; } return (GAddress_INET_SetHostName(m_address, name.mb_str()) == GSOCK_NOERROR); } bool wxIPV6address::Hostname(unsigned char[16] WXUNUSED(addr)) { - return TRUE; + return true; } bool wxIPV6address::Service(const wxString& name) @@ -278,21 +280,26 @@ bool wxIPV6address::IsLocalHost() const return (Hostname() == wxT("localhost") || IPAddress() == wxT("127.0.0.1")); } +bool wxIPV6address::BroadcastAddress() +{ + return (GAddress_INET_SetBroadcastAddress(m_address) == GSOCK_NOERROR); +} + bool wxIPV6address::AnyAddress() { return (GAddress_INET_SetAnyAddress(m_address) == GSOCK_NOERROR); } wxString wxIPV6address::IPAddress() const -{ - unsigned long raw = GAddress_INET_GetHostAddress(m_address); - return wxString::Format( - _T("%u.%u.%u.%u"), - (unsigned char)(raw & 0xff), - (unsigned char)((raw>>8) & 0xff), - (unsigned char)((raw>>16) & 0xff), - (unsigned char)((raw>>24) & 0xff) - ); +{ + unsigned long raw = GAddress_INET_GetHostAddress(m_address); + return wxString::Format( + _T("%u.%u.%u.%u"), + (unsigned char)((raw>>24) & 0xff), + (unsigned char)((raw>>16) & 0xff), + (unsigned char)((raw>>8) & 0xff), + (unsigned char)(raw & 0xff) + ); } wxString wxIPV6address::Hostname() const @@ -311,7 +318,7 @@ unsigned short wxIPV6address::Service() const #endif // wxUSE_IPV6 -#if defined(__UNIX__) && !defined(__WINE__) && (!defined(__WXMAC__) || defined(__DARWIN__)) +#if defined(__UNIX__) && !defined(__WINDOWS__) && !defined(__WINE__) && (!defined(__WXMAC__) || defined(__DARWIN__)) // --------------------------------------------------------------------------- // wxUNIXaddress @@ -342,7 +349,7 @@ wxString wxUNIXaddress::Filename() path[0] = 0; GAddress_UNIX_GetPath(m_address, path, 1024); - + return wxString::FromAscii(path); }