// Created: 26/04/97
// RCS-ID: $Id$
// Copyright: (c) 1997, 1998 Guilhem Lavaux
-// Licence: wxWindows license
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
-#pragma implementation "sckaddr.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
-#pragma hdrstop
+ #pragma hdrstop
#endif
-#ifndef WX_PRECOMP
-#endif
+#if wxUSE_SOCKETS
-#include <stdio.h>
-#include <stdlib.h>
-#include <ctype.h>
+#ifndef WX_PRECOMP
+ #include "wx/defs.h"
+ #include "wx/object.h"
+ #include "wx/log.h"
+ #include "wx/intl.h"
+
+ #include <stdio.h>
+ #include <stdlib.h>
+ #include <ctype.h>
+
+ #if !defined(__MWERKS__) && !defined(__SALFORDC__)
+ #include <memory.h>
+ #endif
+#endif // !WX_PRECOMP
+
+#include "wx/gsocket.h"
+#include "wx/socket.h"
+#include "wx/sckaddr.h"
-#if !defined(__MWERKS__) && !defined(__SALFORDC__)
-#include <memory.h>
+IMPLEMENT_ABSTRACT_CLASS(wxSockAddress, wxObject)
+IMPLEMENT_ABSTRACT_CLASS(wxIPaddress, wxSockAddress)
+IMPLEMENT_DYNAMIC_CLASS(wxIPV4address, wxIPaddress)
+#if wxUSE_IPV6
+IMPLEMENT_DYNAMIC_CLASS(wxIPV6address, wxIPaddress)
+#endif
+#if defined(__UNIX__) && !defined(__WINDOWS__) && !defined(__WINE__) && (!defined(__WXMAC__) || defined(__DARWIN__))
+IMPLEMENT_DYNAMIC_CLASS(wxUNIXaddress, wxSockAddress)
#endif
-#include "wx/defs.h"
-#include "wx/object.h"
+// ---------------------------------------------------------------------------
+// wxSockAddress
+// ---------------------------------------------------------------------------
-#if defined(__WXMAC__)
-#include "/wx/mac/macsock.h"
-#endif
+void wxSockAddress::Init()
+{
+ if ( !wxSocketBase::IsInitialized() )
+ {
+ // we must do it before using GAddress_XXX functions
+ (void)wxSocketBase::Initialize();
+ }
+}
-#if defined(__WINDOWS__)
-#include <winsock.h>
-#endif // __WINDOWS__
+wxSockAddress::wxSockAddress()
+{
+ Init();
-#if defined(__UNIX__)
+ m_address = GAddress_new();
+}
-#ifdef VMS
-#include <socket.h>
-#include <in.h>
-#else
-#if defined(__FreeBSD__) || defined (__NetBSD__)
-#include <sys/types.h>
-#endif
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <arpa/inet.h>
-#endif
-#include <unistd.h>
-#include <netdb.h>
+wxSockAddress::wxSockAddress(const wxSockAddress& other)
+ : wxObject()
+{
+ Init();
-#ifdef __SUN__
-extern "C" {
- int gethostname(char *name, int namelen);
-};
-#endif
+ m_address = GAddress_copy(other.m_address);
+}
-#endif // __UNIX__
+wxSockAddress::~wxSockAddress()
+{
+ GAddress_destroy(m_address);
+}
-#include "wx/sckaddr.h"
+void wxSockAddress::SetAddress(GAddress *address)
+{
+ if ( address != m_address )
+ {
+ GAddress_destroy(m_address);
+ m_address = GAddress_copy(address);
+ }
+}
-#define CHECK_ADDRTYPE(var, type)
+wxSockAddress& wxSockAddress::operator=(const wxSockAddress& addr)
+{
+ SetAddress(addr.GetAddress());
+ return *this;
+}
-#if !USE_SHARED_LIBRARY
-IMPLEMENT_ABSTRACT_CLASS(wxSockAddress, wxObject)
-IMPLEMENT_DYNAMIC_CLASS(wxIPV4address, wxSockAddress)
-#ifdef ENABLE_IPV6
-IMPLEMENT_DYNAMIC_CLASS(wxIPV6address, wxSockAddress)
-#endif
-#ifdef __UNIX__
-IMPLEMENT_DYNAMIC_CLASS(wxUNIXaddress, wxSockAddress)
-#endif
-#endif
+void wxSockAddress::Clear()
+{
+ GAddress_destroy(m_address);
+ m_address = GAddress_new();
+}
-wxIPV4address::wxIPV4address()
- m_addr = new sockaddr_in;
+// ---------------------------------------------------------------------------
+// wxIPaddress
+// ---------------------------------------------------------------------------
+
+wxIPaddress::wxIPaddress()
+ : wxSockAddress()
{
- Clear();
}
-wxIPV4address::~wxIPV4address()
+wxIPaddress::wxIPaddress(const wxIPaddress& other)
+ : wxSockAddress(other)
{
}
-int wxIPV4address::SockAddrLen()
+wxIPaddress::~wxIPaddress()
{
- return sizeof(*m_addr);
}
-int wxIPV4address::GetFamily()
+// ---------------------------------------------------------------------------
+// wxIPV4address
+// ---------------------------------------------------------------------------
+
+wxIPV4address::wxIPV4address()
+ : wxIPaddress()
{
- return AF_INET;
}
-void wxIPV4address::Clear()
+wxIPV4address::wxIPV4address(const wxIPV4address& other)
+ : wxIPaddress(other)
{
- memset(m_addr, 0, sizeof(*m_addr));
- m_addr->sin_family = AF_INET;
- m_addr->sin_addr.s_addr = INADDR_ANY;
}
-/*
-const wxSockAddress& wxIPV4address::operator =(const wxSockAddress& addr)
+wxIPV4address::~wxIPV4address()
{
- wxIPV4address *ip_addr = (wxIPV4address *)&addr;
- CHECK_ADDRTYPE(addr, wxIPV4address);
- m_addr = ip_addr->m_addr;
- return *this;
}
-*/
bool wxIPV4address::Hostname(const wxString& name)
{
- struct hostent *theHostent;
- struct in_addr *addr;
-
- if (name.IsNull())
- return FALSE;
-
- if (!name.IsNumber()) {
- if ((theHostent = gethostbyname(name.GetData())) == 0) {
- return FALSE;
- }
- } else {
-#ifdef __WXMAC__
- long len_addr = inet_addr(name.GetData()).s_addr ;
-#else
- long len_addr = inet_addr(name.GetData());
-#endif
- if (len_addr == -1)
- return FALSE;
- m_addr->sin_addr.s_addr = len_addr;
- return TRUE;
+ // Some people are sometimes fool.
+ if (name.empty())
+ {
+ wxLogWarning( _("Trying to solve a NULL hostname: giving up") );
+ return false;
}
-
- addr = (struct in_addr *) *(theHostent->h_addr_list);
-
- m_addr->sin_addr.s_addr = addr[0].s_addr;
- return TRUE;
+ m_origHostname = name;
+ return (GAddress_INET_SetHostName(m_address, name.mb_str()) == GSOCK_NOERROR);
}
bool wxIPV4address::Hostname(unsigned long addr)
{
- m_addr->sin_addr.s_addr = htonl(addr);
- return TRUE;
+ bool rv = (GAddress_INET_SetHostAddress(m_address, addr) == GSOCK_NOERROR);
+ if (rv)
+ m_origHostname = Hostname();
+ else
+ m_origHostname = wxEmptyString;
+ return rv;
}
bool wxIPV4address::Service(const wxString& name)
{
- struct servent *theServent;
-
- if (name.IsNull())
- return FALSE;
-
- if (!name.IsNumber()) {
- if ((theServent = getservbyname(name, "tcp")) == 0)
- return FALSE;
- } else {
- if ((theServent = getservbyport(atoi(name), "tcp")) == 0) {
- m_addr->sin_port = htons(atoi(name));
- return TRUE;
- }
- }
-
- m_addr->sin_port = theServent->s_port;
- return TRUE;
+ return (GAddress_INET_SetPortName(m_address, name.mb_str(), "tcp") == GSOCK_NOERROR);
}
bool wxIPV4address::Service(unsigned short port)
{
- m_addr->sin_port = htons(port);
- return TRUE;
+ return (GAddress_INET_SetPort(m_address, port) == GSOCK_NOERROR);
}
bool wxIPV4address::LocalHost()
{
- static char buf[256];
-
- if (gethostname(buf, sizeof(buf)) < 0)
- return Hostname("localhost");
- else
- return Hostname(buf);
+ return (GAddress_INET_SetHostName(m_address, "localhost") == GSOCK_NOERROR);
}
-wxString wxIPV4address::Hostname()
+bool wxIPV4address::IsLocalHost() const
{
- struct hostent *h_ent;
-
- h_ent = gethostbyaddr((char *)&(m_addr->sin_addr), sizeof(m_addr->sin_addr),
- GetFamily());
- return wxString(h_ent->h_name);
+ return (Hostname() == wxT("localhost") || IPAddress() == wxT("127.0.0.1"));
}
-unsigned short wxIPV4address::Service()
+bool wxIPV4address::AnyAddress()
{
- return ntohs(m_addr->sin_port);
+ return (GAddress_INET_SetAnyAddress(m_address) == GSOCK_NOERROR);
}
-void wxIPV4address::Build(struct sockaddr *&addr, size_t& len)
+wxString wxIPV4address::Hostname() const
{
- addr = (struct sockaddr *)m_addr;
- len = sizeof(*m_addr);
+ char hostname[1024];
+
+ hostname[0] = 0;
+ GAddress_INET_GetHostName(m_address, hostname, 1024);
+ return wxString::FromAscii(hostname);
}
-void wxIPV4address::Disassemble(struct sockaddr *addr, size_t len)
+unsigned short wxIPV4address::Service() const
{
- if (len != sizeof(*m_addr))
- return;
- *m_addr = *(struct sockaddr_in *)addr;
+ return GAddress_INET_GetPort(m_address);
}
-#ifdef IPV6_ENABLE
-
-wxIPV6address::wxIPV6address()
+wxSockAddress *wxIPV4address::Clone() const
{
- m_addr = new sockaddr_in6;
- Clear();
+ wxIPV4address *addr = new wxIPV4address(*this);
+ addr->m_origHostname = m_origHostname;
+ return addr;
}
-wxIPV6address::~wxIPV6address()
+wxString wxIPV4address::IPAddress() const
{
+ 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
+ );
}
-int wxIPV6address::SockAddrLen()
+bool wxIPV4address::operator==(const wxIPV4address& addr) const
{
- return sizeof(*m_addr);
+ return Hostname().Cmp(addr.Hostname().c_str()) == 0 &&
+ Service() == addr.Service();
}
-int wxIPV6address::GetFamily()
+#if wxUSE_IPV6
+// ---------------------------------------------------------------------------
+// wxIPV6address
+// ---------------------------------------------------------------------------
+
+wxIPV6address::wxIPV6address()
+ : wxIPaddress()
{
- return AF_INET6;
}
-void wxIPV6address::Clear()
-{
- memset(m_addr, 0, sizeof(*m_addr));
- m_addr->sin6_family = AF_INET6;
- m_addr->sin6_addr.s_addr = INADDR_ANY;
+wxIPV6address::wxIPV6address(const wxIPV6address& other)
+ : wxIPaddress(other)
+{
}
-/*
-const wxSockAddress& wxIPV6address::operator =(const wxSockAddress& addr)
+wxIPV6address::~wxIPV6address()
{
- wxIPV6address *ip_addr = (wxIPV6address *)&addr;
-
- CHECK_ADDRTYPE(addr, wxIPV6address);
- m_addr = ip_addr->m_addr;
- return *this;
}
-*/
bool wxIPV6address::Hostname(const wxString& name)
{
- struct hostent *theHostent;
- struct in_addr *addr;
-
- if (name.IsNull())
- return FALSE;
-
- if (!name.IsNumber()) {
- hostent = gethostbyname2((char*) name, AF_INET6);
- if (!theHostent)
- return FALSE;
- } else {
- // Don't how to do
- return FALSE;
+ if (name.empty())
+ {
+ wxLogWarning( _("Trying to solve a NULL hostname: giving up") );
+ return false;
}
-
- addr = (struct in6_addr *) *(theHostent->h_addr_list);
-
- m_addr->sin6_addr.s6_addr = addr[0].s6_addr;
- return TRUE;
+ return (GAddress_INET_SetHostName(m_address, name.mb_str()) == GSOCK_NOERROR);
}
-bool wxIPV6address::Hostname(unsigned char addr[16])
+bool wxIPV6address::Hostname(unsigned char[16] WXUNUSED(addr))
{
- m_addr->sin6_addr.s6_addr = addr;
- return TRUE;
+ return true;
}
-bool wxIPV6address::Service(const char *name)
+bool wxIPV6address::Service(const wxString& name)
{
- struct servent *theServent;
-
- if (!name || !strlen(name))
- return FALSE;
-
- if (!isdigit(*name)) {
- if ((theServent = getservbyname((char*) name, "tcp")) == 0)
- return FALSE;
- } else {
- if ((theServent = getservbyport(atoi(name), "tcp")) == 0) {
- m_addr->sin_port = htons(atoi(name));
- return TRUE;
- }
- }
-
- m_addr->sin_port = theServent->s_port;
- return TRUE;
+ return (GAddress_INET_SetPortName(m_address, name.mb_str(), "tcp") == GSOCK_NOERROR);
}
bool wxIPV6address::Service(unsigned short port)
{
- m_addr->sin_port = htons(port);
- return TRUE;
+ return (GAddress_INET_SetPort(m_address, port) == GSOCK_NOERROR);
}
bool wxIPV6address::LocalHost()
{
- static char buf[256];
-
- if (gethostname(buf, sizeof(buf)) < 0)
- return Hostname("localhost");
- else
- return Hostname(buf);
+ return (GAddress_INET_SetHostName(m_address, "localhost") == GSOCK_NOERROR);
}
-const wxString& wxIPV6address::Hostname()
+bool wxIPV6address::IsLocalHost() const
{
- struct hostent *h_ent;
-
- h_ent = gethostbyaddr((char *)&(m_addr->sin_addr), sizeof(m_addr->sin_addr),
- GetFamily());
- return wxString(h_ent->h_name);
+ return (Hostname() == wxT("localhost") || IPAddress() == wxT("127.0.0.1"));
}
-unsigned short wxIPV6address::Service()
+bool wxIPV6address::AnyAddress()
{
- return ntohs(m_addr->sin_port);
+ return (GAddress_INET_SetAnyAddress(m_address) == GSOCK_NOERROR);
}
-void wxIPV6address::Build(struct sockaddr& *addr, size_t& len)
+wxString wxIPV6address::IPAddress() const
{
- len = sizeof(*m_addr);
- addr = m_addr;
+ 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)
+ );
}
-void wxIPV6address::Disassemble(struct sockaddr& *addr, size_t len)
+wxString wxIPV6address::Hostname() const
{
- if (len != sizeof(*m_addr))
- return;
- *m_addr = *(struct sockaddr_in6 *)addr;
-}
-
-#endif
-
-#ifdef __UNIX__
-#include <sys/un.h>
+ char hostname[1024];
-wxUNIXaddress::wxUNIXaddress()
-{
- m_addr = new sockaddr_un;
- Clear();
+ hostname[0] = 0;
+ GAddress_INET_GetHostName(m_address, hostname, 1024);
+ return wxString::FromAscii(hostname);
}
-wxUNIXaddress::~wxUNIXaddress()
+unsigned short wxIPV6address::Service() const
{
+ return GAddress_INET_GetPort(m_address);
}
-int wxUNIXaddress::SockAddrLen()
-{
- return sizeof(*m_addr);
-}
+#endif // wxUSE_IPV6
+
+#if defined(__UNIX__) && !defined(__WINDOWS__) && !defined(__WINE__) && (!defined(__WXMAC__) || defined(__DARWIN__))
-int wxUNIXaddress::GetFamily()
+// ---------------------------------------------------------------------------
+// wxUNIXaddress
+// ---------------------------------------------------------------------------
+
+wxUNIXaddress::wxUNIXaddress()
+ : wxSockAddress()
{
- return AF_UNIX;
}
-void wxUNIXaddress::Clear()
+wxUNIXaddress::wxUNIXaddress(const wxUNIXaddress& other)
+ : wxSockAddress(other)
{
- memset(m_addr, 0, sizeof(m_addr));
- m_addr->sun_family = AF_UNIX;
}
-/*
-const wxSockAddress& wxUNIXaddress::operator =(const wxSockAddress& addr)
+wxUNIXaddress::~wxUNIXaddress()
{
- wxUNIXaddress *unx_addr = (wxUNIXaddress *)&addr;
- CHECK_ADDRTYPE(addr, wxUNIXaddress);
- m_addr = unx_addr->m_addr;
- return *this;
}
-*/
void wxUNIXaddress::Filename(const wxString& fname)
{
- sprintf(m_addr->sun_path, "%s", WXSTRINGCAST fname);
+ GAddress_UNIX_SetPath(m_address, fname.fn_str());
}
wxString wxUNIXaddress::Filename()
{
- return wxString(m_addr->sun_path);
-}
+ char path[1024];
-void wxUNIXaddress::Build(struct sockaddr*& addr, size_t& len)
-{
- addr = (struct sockaddr *)m_addr;
- len = sizeof(*m_addr);
-}
+ path[0] = 0;
+ GAddress_UNIX_GetPath(m_address, path, 1024);
-void wxUNIXaddress::Disassemble(struct sockaddr *addr, size_t len)
-{
- if (len != sizeof(*m_addr))
- return;
- *m_addr = *(struct sockaddr_un *)addr;
+ return wxString::FromAscii(path);
}
+
+#endif // __UNIX__
+
#endif
+ // wxUSE_SOCKETS