📄 ip_address_getaddr.h
字号:
/* $Id: ip_address_getaddr.h,v 1.7 2003/07/20 22:34:40 grumbel Exp $
**
** ClanLib Game SDK
** Copyright (C) 2003 The ClanLib Team
** For a total list of contributers see the file CREDITS.
**
** This library is free software; you can redistribute it and/or
** modify it under the terms of the GNU Lesser General Public
** License as published by the Free Software Foundation; either
** version 2.1 of the License, or (at your option) any later version.
**
** This library is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
** Lesser General Public License for more details.
**
** You should have received a copy of the GNU Lesser General Public
** License along with this library; if not, write to the Free Software
** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
**
*/
#ifndef ip_address_getaddr_header
#define ip_address_getaddr_header
#include "ip_address_generic.h"
#ifndef WIN32
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <netdb.h>
#else
#define _inline inline
#include <ws2tcpip.h>
#include <tpipv6.h>
#include <windows.h>
#endif
//: Socket name; container class for an IP address and port.
class CL_IPAddress_GetAddr : public CL_IPAddress_Generic
{
//! Construction:
public:
//: Constructs an IP address using INADDR_ANY and port 0.
CL_IPAddress_GetAddr();
//: Constructs an IP address using INADDR_ANY and the specified port.
CL_IPAddress_GetAddr(const std::string &port);
//: Constructs an IP address using the passed address.
// CL_IPAddress(const std::string &hostname);
//: Construct an IP address using the hostname and the port.
CL_IPAddress_GetAddr(const std::string &hostname, const std::string &port);
//: Copy constructor.
CL_IPAddress_GetAddr(const CL_IPAddress ©);
//! Attributes:
public:
//: Returns the internal addrinfo struct
void get_addrinfo(int type, sockaddr &addr, int &len, int domain) const;
//: Returns the IP address in network byte order.
std::string get_address() const;
//: Returns the IP port in host byte order.
std::string get_port() const;
//: Returns true if objects are the same.
bool operator == (const CL_IPAddress &other_instance) const;
//: Returns true if the other address is less.
//- <p>This is used for sorting
//- purposes (eg. if you use a std::map<CL_IPAddress, CL_Socket>), and sorts
//- the address based on lowest IP number address.</p>
bool operator < (const CL_IPAddress &other_instance) const;
//: Returns true if the other address is greater.
//- <p>This is used for sorting
//- purposes (eg. if you use a std::map<CL_IPAddress, CL_Socket>), and sorts
//- the address based on lowest IP number address.</p>
bool operator > (const CL_IPAddress &other_instance) const;
//! Operations:
public:
//: Set the IP address using a hostname.
//param hostname: Can be an IPv4 dotted-quad, hostname or a valid IPv6 address.
// The port number cannot be passed here.
// Port number is reassigned to default(any port)
//: Sets both the address and the port.
void set_address(const std::string &hostname, const std::string &port);
//: Set the IP port.
void set_port(const std::string &new_port);
//: Do a DNS lookup on the IP address.
std::string dns_lookup() const;
//: Check to see if the address has an IPv4 mapping
//: is_ipv4() and is_ipv6() are not mutally exclusive
//: An address can have both IPv4 and IPv6 mappings
bool is_ipv4() const;
//: Check to see if the address has an IPv6 mapping
//: is_ipv4() and is_ipv6() are not mutally exclusive
//: An address can have both IPv4 and IPv6 mappings
bool is_ipv6() const;
private:
addrinfo hints;
addrinfo *info;
//: Will merge two addrinfo lists into one.
void merge_lists(addrinfo *first, addrinfo *second);
};
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -