/* APPCONFIG.hpp - for global initialization and configuration Copyright (C) CinelerraCV 2007, Christian Thaeter This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /** @file appconfig.hpp ** This header is special, as it causes global system initialisation ** to happen. On inclusion, it places static initialisation code, ** which on first run will create the Appconfig singleton instance. ** Additionally, the inclusion, configuration and initialisation ** of the NoBug library is handled here. Global definitions ** for NoBug are placed into the corresponding translation unit ** appconfig.cpp" ** ** @see nobugcfg.h */ #ifndef CINELERRA_APPCONFIG_H #define CINELERRA_APPCONFIG_H #include #include #include #include "nobugcfg.h" using std::string; using std::auto_ptr; namespace cinelerra { /** * Singleton to hold inevitable global flags and constants * and for performing early (static) global initialization tasks. */ class Appconfig { private: /** holds the single instance and triggers initialization */ static Appconfig* theApp_; /** perform initialization on first access. * A call is placed in static initialization code * included via cinelerra.h (see below), * thus it will happen rather early. */ Appconfig () ; public: static Appconfig& instance() { if (!theApp_) theApp_ = new Appconfig (); return *theApp_; } /** access the configuation value for a given key. * @return empty string for unknown keys, config value else * @todo do we need such a facility? */ static const string & get (const string& key) throw(); private: typedef std::map Configmap; typedef auto_ptr PConfig; /** @TODO the following is just placeholder code! * Appconfig could do such things if necessary. */ PConfig configParam_; }; namespace { /** "magic code" to cause early static initialization */ Appconfig& init (Appconfig::instance ()); } } // namespace cinelerra #endif