2005-02-27 05:50:54 +00:00
|
|
|
//This file is part of Photon (http://photon.sourceforge.net)
|
|
|
|
//Copyright (C) 2004-2005 James Turk
|
|
|
|
//
|
|
|
|
// Author:
|
|
|
|
// James Turk (jpt2433@rit.edu)
|
|
|
|
//
|
|
|
|
// Version:
|
2005-03-15 18:51:00 +00:00
|
|
|
// $Id: Singleton.hpp,v 1.7 2005/03/15 18:51:00 cozman Exp $
|
2005-02-27 05:50:54 +00:00
|
|
|
|
|
|
|
#ifndef PHOTON_UTIL_SINGLETON_HPP
|
|
|
|
#define PHOTON_UTIL_SINGLETON_HPP
|
|
|
|
|
|
|
|
#include <boost/utility.hpp>
|
|
|
|
|
2005-03-03 09:25:19 +00:00
|
|
|
#include "exceptions.hpp"
|
|
|
|
|
2005-02-27 05:50:54 +00:00
|
|
|
namespace photon
|
|
|
|
{
|
|
|
|
namespace util
|
|
|
|
{
|
|
|
|
|
2005-03-01 07:51:23 +00:00
|
|
|
// Class: Singleton
|
|
|
|
// Template class for singleton pattern. Is non-copyable to enforce
|
|
|
|
// correct behavior.
|
|
|
|
//
|
|
|
|
// Defining a Singleton:
|
|
|
|
// (code)
|
|
|
|
// YourClass : public Singleton<Class>
|
2005-03-15 18:51:00 +00:00
|
|
|
// {
|
|
|
|
// // class definition
|
2005-03-01 07:51:23 +00:00
|
|
|
// };
|
|
|
|
// (end)
|
|
|
|
//
|
|
|
|
// Using The Singleton:
|
|
|
|
// (code)
|
2005-03-15 18:51:00 +00:00
|
|
|
// new YourClass;
|
2005-03-01 07:51:23 +00:00
|
|
|
// YourClass& yc(YourClass::getInstance());
|
|
|
|
//
|
|
|
|
// // use yc
|
|
|
|
//
|
2005-03-15 18:51:00 +00:00
|
|
|
// YourClass::destroy();
|
2005-03-01 07:51:23 +00:00
|
|
|
// (end)
|
2005-02-27 05:50:54 +00:00
|
|
|
template<class T>
|
|
|
|
class Singleton : public boost::noncopyable
|
|
|
|
{
|
|
|
|
public:
|
2005-03-01 07:51:23 +00:00
|
|
|
// Function: initialize
|
2005-03-04 13:06:49 +00:00
|
|
|
// Initialize the instance of the singleton, can be done explicitly if
|
|
|
|
// order of construction matters. Will be done on first call to
|
|
|
|
// getInstance otherwise.
|
2005-02-27 07:43:37 +00:00
|
|
|
static void initialize();
|
2005-02-27 05:50:54 +00:00
|
|
|
|
2005-03-01 07:51:23 +00:00
|
|
|
// Function: destroy
|
|
|
|
// Destroy the instance of the singleton, can be done explicitly if order
|
|
|
|
// of destruction matters. Will be done automatically if not done.
|
2005-02-27 07:43:37 +00:00
|
|
|
static void destroy();
|
2005-02-27 05:50:54 +00:00
|
|
|
|
2005-03-01 07:51:23 +00:00
|
|
|
// Function: getInstance
|
|
|
|
// Get a reference to the instance of the derived class.
|
2005-02-27 07:43:37 +00:00
|
|
|
static T& getInstance();
|
2005-02-27 05:50:54 +00:00
|
|
|
|
2005-03-01 07:51:23 +00:00
|
|
|
protected:
|
2005-03-15 18:51:00 +00:00
|
|
|
Singleton();
|
|
|
|
virtual ~Singleton(); // allow inheritance
|
2005-02-27 05:50:54 +00:00
|
|
|
|
|
|
|
private:
|
2005-03-15 18:51:00 +00:00
|
|
|
static T* instance_;
|
2005-02-27 05:50:54 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// template implementation
|
|
|
|
|
|
|
|
template<class T>
|
2005-03-15 18:51:00 +00:00
|
|
|
Singleton<T>::Singleton()
|
2005-02-27 05:50:54 +00:00
|
|
|
{
|
2005-03-15 18:51:00 +00:00
|
|
|
if(instance_ != 0)
|
2005-03-03 09:25:19 +00:00
|
|
|
{
|
|
|
|
throw PreconditionException("Attempt to double-initialize singleton.");
|
|
|
|
}
|
2005-02-27 07:43:37 +00:00
|
|
|
|
2005-03-15 18:51:00 +00:00
|
|
|
instance_ = static_cast<T*>(this); // cast self to type of T*
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
Singleton<T>::~Singleton()
|
|
|
|
{
|
2005-02-27 05:50:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template<class T>
|
2005-02-27 07:43:37 +00:00
|
|
|
void Singleton<T>::destroy()
|
2005-02-27 05:50:54 +00:00
|
|
|
{
|
2005-03-15 18:51:00 +00:00
|
|
|
if(instance_ == 0)
|
2005-03-03 09:25:19 +00:00
|
|
|
{
|
|
|
|
throw PreconditionException("Attempt to destroy null singleton.");
|
|
|
|
}
|
2005-02-27 07:43:37 +00:00
|
|
|
|
2005-03-15 18:51:00 +00:00
|
|
|
if(instance_)
|
|
|
|
{
|
|
|
|
delete instance_;
|
|
|
|
instance_ = 0;
|
|
|
|
}
|
2005-02-27 05:50:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template<class T>
|
2005-02-27 07:43:37 +00:00
|
|
|
T& Singleton<T>::getInstance()
|
2005-02-27 05:50:54 +00:00
|
|
|
{
|
2005-03-15 18:51:00 +00:00
|
|
|
if(instance_ == 0)
|
2005-03-03 09:25:19 +00:00
|
|
|
{
|
2005-03-15 18:51:00 +00:00
|
|
|
throw PreconditionException("Attempt to access null singleton.");
|
2005-03-03 09:25:19 +00:00
|
|
|
}
|
2005-02-27 07:43:37 +00:00
|
|
|
|
2005-03-15 18:51:00 +00:00
|
|
|
return *instance_; //return dereferenced instance
|
2005-02-27 05:50:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template<class T>
|
2005-03-15 18:51:00 +00:00
|
|
|
T* Singleton<T>::instance_(0);
|
2005-02-27 05:50:54 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif //PHOTON_UTIL_SINGLETON_HPP
|