X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fsession.hpp;h=148749dd578d3d81d75eb79dabfda74d243c48ad;hb=bcc3baa237f591a4769f290a2d4e2690f57a971b;hp=08301a7358b9e945eee3c2d4ac4ca56bc81e32e0;hpb=073a9efb12b18f9bbd2bceaf778eb66124a0db65;p=metaproxy-moved-to-github.git diff --git a/src/session.hpp b/src/session.hpp index 08301a7..148749d 100644 --- a/src/session.hpp +++ b/src/session.hpp @@ -1,3 +1,8 @@ +/* $Id: session.hpp,v 1.9 2005-10-25 11:48:30 adam Exp $ + Copyright (c) 2005, Index Data. + +%LICENSE% + */ #ifndef SESSION_HPP #define SESSION_HPP @@ -7,24 +12,35 @@ #include namespace yp2 { - + class Session { //typedef unsigned long type; public: - - /// create new session with new unique id - Session() { + + /// create new session with new unique id + Session() { boost::mutex::scoped_lock scoped_lock(m_mutex); ++m_global_id; m_id = m_global_id; m_close = false; }; + + /// copy session including old id + Session(const Session &s) : m_id(s.m_id), m_close(s.m_close) {}; + + Session& operator=(const Session &s) { + if (this != &s) + { + m_id = s.m_id; + m_close = s.m_close; + } + return *this; + } - /// copy session including old id - Session(const Session &s) : m_id(s.m_id), m_close(s.m_close) {}; - - //Session& operator=(const Session &); + bool operator<(const Session &s) const { + return m_id < s.m_id ? true : false; + } unsigned long id() const { return m_id; @@ -33,17 +49,20 @@ namespace yp2 { bool is_closed() const { return m_close; }; - + /// mark session closed, can not be unset void close() { m_close = true; }; - private: - + bool operator == (Session &ses) const { + return ses.m_id == m_id; + } + private: + unsigned long int m_id; bool m_close; - + /// static mutex to lock static m_id static boost::mutex m_mutex; @@ -54,16 +73,12 @@ namespace yp2 { } -// defining and initializing static members -boost::mutex yp2::Session::m_mutex; -unsigned long int yp2::Session::m_global_id = 0; - - #endif /* * Local variables: * c-basic-offset: 4 * indent-tabs-mode: nil + * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */