X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsockaddr.h;h=ff2f88a9b7be650064d4528f18ba3ff88ddd510e;hb=f9cc7ff2e1e5af865220e9fbe16673619ecb78bd;hp=745e6d45afc59adda0889843a257da05dbf16b24;hpb=a81c41acd873cda7f40bca634782230d9e57dc4f;p=libs%2Fnet.git diff --git a/source/sockaddr.h b/source/sockaddr.h index 745e6d4..ff2f88a 100644 --- a/source/sockaddr.h +++ b/source/sockaddr.h @@ -12,26 +12,23 @@ namespace Net { class SockAddr { +protected: + SockAddr() { } public: + virtual ~SockAddr() { } + + static SockAddr *create(const sockaddr &sa) { return create(reinterpret_cast(sa)); } + static SockAddr *create(const sockaddr_storage &); + + virtual SockAddr *copy() const = 0; + virtual Family get_family() const = 0; virtual std::string str() const = 0; - /** - Fills the given struct sockaddr with information from this SockAddr. - - @return Number of bytes used - */ + /** Fills a struct sockaddr with information from this SockAddr. Returns + the number of bytes used. */ virtual unsigned fill_sockaddr(sockaddr &) const = 0; virtual unsigned fill_sockaddr(sockaddr_storage &) const; - - virtual SockAddr *copy() const =0; - - virtual ~SockAddr() { } - - static SockAddr *create(const sockaddr &sa) { return create(reinterpret_cast(sa)); } - static SockAddr *create(const sockaddr_storage &); -protected: - SockAddr() { } }; } // namespace Net