X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fsession.hpp;h=2ca4931881b7bf141f01f4ab8a4d8248569c08b2;hb=c3805961da509f3e6dc69d5134bd6512be4a8be8;hp=504bb1477f08f308b5e6d12cbdaa2bd7ec45f2db;hpb=f05f2c3cb62b12590abf370d1681ed80fb1626d5;p=metaproxy-moved-to-github.git diff --git a/src/session.hpp b/src/session.hpp index 504bb14..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,45 +12,69 @@ #include namespace yp2 { - - class Session + + class Session { + //typedef unsigned long type; public: - //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; + } + + unsigned long id() const { + return m_id; + }; + + bool is_closed() const { + return m_close; + }; + + /// mark session closed, can not be unset + void close() { + m_close = true; + }; - /// returns next id, global state of id protected by boost::mutex - long unsigned int id() { - boost::mutex::scoped_lock scoped_lock(m_mutex); - ++m_id; - return m_id; - }; + bool operator == (Session &ses) { + return ses.m_id == m_id; + } private: - // disabled because class is singleton - // Session(const Session &); - - // disabled because class is singleton - // Session& operator=(const Session &); - - /// static mutex to lock static m_id - static boost::mutex m_mutex; - - /// static m_id to make sure that there is only one id counter - static unsigned long int m_id; - + + unsigned long int m_id; + bool m_close; + + /// static mutex to lock static m_id + static boost::mutex m_mutex; + + /// static m_id to make sure that there is only one id counter + static unsigned long int m_global_id; + }; - + } -// initializing static members -boost::mutex yp2::Session::m_mutex; -unsigned long int yp2::Session::m_id = 0; - - #endif /* * Local variables: * c-basic-offset: 4 * indent-tabs-mode: nil + * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */