X-Git-Url: http://sru.miketaylor.org.uk/?a=blobdiff_plain;f=src%2Fsession.hpp;h=420f2fc046ddd73dc29c9fc44211ea54d6b0b7a1;hb=f82b19f2b93707657fee804bd1242f2548d51ada;hp=d3574636cb819fdd3810db68219f5867c2d568c5;hpb=85016b609dc5cabc1ba230d39acf143f3519c103;p=metaproxy-moved-to-github.git diff --git a/src/session.hpp b/src/session.hpp index d357463..420f2fc 100644 --- a/src/session.hpp +++ b/src/session.hpp @@ -1,3 +1,8 @@ +/* $Id: session.hpp,v 1.7 2005-10-15 14:09:09 adam Exp $ + Copyright (c) 2005, Index Data. + +%LICENSE% + */ #ifndef SESSION_HPP #define SESSION_HPP @@ -7,45 +12,66 @@ #include namespace yp2 { - - class Session + + class Session { + //typedef unsigned long type; public: - //Session() {}; - - /// 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; - }; + + /// 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; + }; + 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; + }; - + } -// defining and 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 */