--- gvpe/src/sockinfo.h 2003/04/02 03:25:17 1.2 +++ gvpe/src/sockinfo.h 2003/04/07 01:12:56 1.6 @@ -35,35 +35,36 @@ u8 prot; u8 pad1; - void set (const sockaddr_in *sa, u8 prot_ = PROT_UDPv4); - void set (const conf_node *conf); + 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; const sockaddr *sav4 () const; const socklen_t salenv4 () const - { - return sizeof (sockaddr_in); - } + { return sizeof (sockaddr_in); } const char *ntoa () const; - sockinfo() - { - prot = 0; - } - - sockinfo(const sockaddr_in &sa, u8 prot_ = PROT_UDPv4) - { - set (&sa, prot_); - } + bool valid () const + { return prot != 0 && host != 0; } + + sockinfo() { prot = 0; } + + sockinfo(const sockaddr_in &sa, u8 prot) + { set (&sa, 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