browsercore/core/singleton.h
author hgs
Fri, 15 Oct 2010 17:30:59 -0400
changeset 16 3c88a81ff781
parent 3 0954f5dd2cd0
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
*
hgs
parents:
diff changeset
     5
* This program is free software: you can redistribute it and/or modify
hgs
parents:
diff changeset
     6
* it under the terms of the GNU Lesser General Public License as published by
hgs
parents:
diff changeset
     7
* the Free Software Foundation, version 2.1 of the License.
hgs
parents:
diff changeset
     8
* 
hgs
parents:
diff changeset
     9
* This program is distributed in the hope that it will be useful,
hgs
parents:
diff changeset
    10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
hgs
parents:
diff changeset
    11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
hgs
parents:
diff changeset
    12
* GNU Lesser General Public License for more details.
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* You should have received a copy of the GNU Lesser General Public License
hgs
parents:
diff changeset
    15
* along with this program.  If not, 
hgs
parents:
diff changeset
    16
* see "http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html/".
hgs
parents:
diff changeset
    17
*
hgs
parents:
diff changeset
    18
* Description:
hgs
parents:
diff changeset
    19
*  This defines both Meyers Singleton and Gamma Singleton template.
hgs
parents:
diff changeset
    20
*/
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#ifndef __SINGLETON_H
hgs
parents:
diff changeset
    24
#define __SINGLETON_H
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
/* 
hgs
parents:
diff changeset
    27
 * This is how a Gamma Singleton would instantiate its object.
hgs
parents:
diff changeset
    28
 */
hgs
parents:
diff changeset
    29
template <class T> struct CreateGamma {
hgs
parents:
diff changeset
    30
    static T* Create() { return new T; }
hgs
parents:
diff changeset
    31
};
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
/* 
hgs
parents:
diff changeset
    34
 * This is how a Meyers Singleton would instantiate its object.
hgs
parents:
diff changeset
    35
 */
hgs
parents:
diff changeset
    36
template <class T> struct CreateMeyers {
hgs
parents:
diff changeset
    37
    static T* Create() {
hgs
parents:
diff changeset
    38
        static T _instance;
hgs
parents:
diff changeset
    39
        return &_instance;
hgs
parents:
diff changeset
    40
    }
hgs
parents:
diff changeset
    41
};
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
/*
hgs
parents:
diff changeset
    44
 * This Singleton class accepts different creation policies.
hgs
parents:
diff changeset
    45
 */
hgs
parents:
diff changeset
    46
template <class T, template<class> class CreationPolicy=CreateMeyers>
hgs
parents:
diff changeset
    47
class Singleton {
hgs
parents:
diff changeset
    48
public:
hgs
parents:
diff changeset
    49
    static T& Instance() {
hgs
parents:
diff changeset
    50
        if (!m_pInstance)
hgs
parents:
diff changeset
    51
            m_pInstance=CreationPolicy<T>::Create();
hgs
parents:
diff changeset
    52
        return *m_pInstance;
hgs
parents:
diff changeset
    53
}
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
private:
hgs
parents:
diff changeset
    56
    Singleton();           // hide constrcutor
hgs
parents:
diff changeset
    57
    ~Singleton();          // hide desctructor
hgs
parents:
diff changeset
    58
    Singleton(Singleton const&);    // hide copy constructor
hgs
parents:
diff changeset
    59
    Singleton& operator=(Singleton const&);  // hide assignment operator
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
    static T* m_pInstance;
hgs
parents:
diff changeset
    62
};
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
template <class T, template<class> class C>
hgs
parents:
diff changeset
    65
T* Singleton<T,C>::m_pInstance=0;
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
#endif // __SINGLETON_H