X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fsession.hpp;h=2ca4931881b7bf141f01f4ab8a4d8248569c08b2;hb=ec40d94aeb48a31ebe0ac8c9b9457f28a2d54fcc;hp=08301a7358b9e945eee3c2d4ac4ca56bc81e32e0;hpb=073a9efb12b18f9bbd2bceaf778eb66124a0db65;p=metaproxy-moved-to-github.git diff --git a/src/session.hpp b/src/session.hpp index 08301a7..2ca4931 100644 --- a/src/session.hpp +++ b/src/session.hpp @@ -1,3 +1,8 @@ +/* $Id: session.hpp,v 1.8 2005-10-16 16:05:18 adam Exp $ + Copyright (c) 2005, Index Data. + +%LICENSE% + */ #ifndef SESSION_HPP #define SESSION_HPP @@ -7,24 +12,31 @@ #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 &); + + /// 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; + } unsigned long id() const { return m_id; @@ -33,17 +45,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) { + 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 +69,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 */