X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Utils%2Fsingleton.cti;h=79dd1f761068001344dad80eec9cfe942f72f815;hb=412024ed31a4ab4eaea7a4165a434f8efebee325;hp=b99e39d44f3a73c76463e1a448f542a0d3d775e3;hpb=88fb64d9945353340238d1b8c5b7a1038ad7a775;p=senf.git diff --git a/Utils/singleton.cti b/Utils/singleton.cti index b99e39d..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,17 +31,40 @@ ///////////////////////////////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_; - creator_.nop(); // Force instantiation of force_creation + // Force instantiation of force_creation (at static object creation time) + creator_.nop(); return instance_; } template +prefix_ bool senf::singleton::alive() +{ + return alive_; +} + +template prefix_ senf::singleton::force_creation::force_creation() { - senf::singleton::instance(); // Force execution of instance() thereby creating instance + // Force execution of instance() thereby creating instance + senf::singleton::instance(); } template @@ -52,7 +75,7 @@ prefix_ void senf::singleton::force_creation::nop() } template -typename senf::singleton::force_creation senf::singleton::create_; +typename senf::singleton::force_creation senf::singleton::creator_; ///////////////////////////////cti.e/////////////////////////////////////// #undef prefix_