--- gvpe/src/sockinfo.h 2003/04/02 05:15:00 1.3 +++ gvpe/src/sockinfo.h 2003/10/16 02:41:21 1.8 @@ -1,6 +1,5 @@ /* sockinfo.h -- socket address management - Copyright (C) 2003 Marc Lehmann This program is free software; you can redistribute it and/or modify @@ -21,8 +20,7 @@ #ifndef VPE_SOCKINFO_H__ #define VPE_SOCKINFO_H__ -#include -#include +#include "netcompat.h" #include "conf.h" @@ -35,8 +33,13 @@ u8 prot; u8 pad1; - void set (const sockaddr_in *sa, u8 prot_ = PROT_UDPv4); - void set (const conf_node *conf, u8 prot_ = PROT_UDPv4); + void set (const sockaddr_in *sa, u8 prot_); + void set (const conf_node *conf, u8 prot_); + void set (const char *hostname, u16 port_, u8 prot_); + + // return the supported protocols + u8 supported_protocols (conf_node *conf = 0); + bool upgrade_protocol (u8 prot_, conf_node *conf = 0); operator const char *() const; @@ -46,20 +49,20 @@ const char *ntoa () const; + bool valid () const + { return prot != 0 && host != 0; } + sockinfo() { prot = 0; } - sockinfo(const sockaddr_in &sa, u8 prot_ = PROT_UDPv4) - { set (&sa, prot_); } + sockinfo(const sockaddr_in &sa, u8 prot) + { set (&sa, prot); } - sockinfo(const conf_node *conf, u8 prot_ = PROT_UDPv4) - { set (conf, prot_); } + sockinfo(const conf_node *conf, u8 prot) + { set (conf, prot); } }; -inline bool -operator == (const sockinfo &a, const sockinfo &b) -{ - return a.host == b.host && a.port == b.port && a.prot == b.prot; -} +bool operator == (const sockinfo &a, const sockinfo &b); +bool operator < (const sockinfo &a, const sockinfo &b); #endif