X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Utils%2Fsingleton.cti;h=79dd1f761068001344dad80eec9cfe942f72f815;hb=5443435c4c2b6e4386c5334b5b8358273f2bae93;hp=51a8c8919b7e0a21271e5a5abc5c7cb502e69179;hpb=e8b91aa6a817af6d9a3714e7b66be6c0d6b0a4e5;p=senf.git diff --git a/Utils/singleton.cti b/Utils/singleton.cti index 51a8c89..79dd1f7 100644 --- a/Utils/singleton.cti +++ b/Utils/singleton.cti @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// Copyright (C) 2007 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify @@ -31,15 +31,36 @@ ///////////////////////////////cti.p/////////////////////////////////////// template +prefix_ senf::singleton::singleton() +{ + alive_ = true; +} + +template +prefix_ senf::singleton::~singleton() +{ + alive_ = false; +} + +template +bool senf::singleton::alive_ (false); + +template prefix_ Self & senf::singleton::instance() { static Self instance_; // Force instantiation of force_creation (at static object creation time) - creator_.nop(); + creator_.nop(); return instance_; } template +prefix_ bool senf::singleton::alive() +{ + return alive_; +} + +template prefix_ senf::singleton::force_creation::force_creation() { // Force execution of instance() thereby creating instance