/*
 * Project: MoleCuilder
 * Description: creates and alters molecular systems
 * Copyright (C)  2010-2012 University of Bonn. All rights reserved.
 * Copyright (C)  2013 Frederik Heber. All rights reserved.
 * 
 *
 *   This file is part of MoleCuilder.
 *
 *    MoleCuilder 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.
 *
 *    MoleCuilder 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 MoleCuilder.  If not, see .
 */
/*
 * Registry.cpp
 *
 *  Created on: Jan 7, 2010
 *      Author: crueger
 */
// include config.h
#ifdef HAVE_CONFIG_H
#include 
#endif
#include "CodePatterns/MemDebug.hpp"
#include "CodePatterns/Assert.hpp"
#include "Actions/ActionRegistry.hpp"
#include "CodePatterns/Registry_impl.hpp"
#include "GlobalListOfActions.hpp"
#include "AllActionHeaders.hpp"
#include 
#include 
#include 
using namespace MoleCuilder;
// static entities
bool ActionRegistry::completely_instatiated = false;
/** Constructor for class ActionRegistry.
 */
ActionRegistry::ActionRegistry()
{
  //std::cout << "ActionRegistry::ActionRegistry() called, instance is " << this << "." << std::endl;
  fillRegistry();
  completely_instatiated = true;
}
/** Destructor for class ActionRegistry.
 */
ActionRegistry::~ActionRegistry()
{
  // first clear each macro action that require presence of all primitive ones
  {
    MakroAction * presentAction =
        dynamic_cast(getActionByName("subgraph-dissection"));
    ASSERT( presentAction != NULL,
        "ActionRegistry::fillRegistry() - makro action has not been registered.");
    presentAction->unprepare(*this);
  }
#ifdef HAVE_JOBMARKET
  {
    MakroAction * presentAction =
        dynamic_cast(getActionByName("molecular-dynamics"));
    ASSERT( presentAction != NULL,
        "ActionRegistry::fillRegistry() - makro action has not been registered.");
    presentAction->unprepare(*this);
  }
#endif
  //std::cout << "ActionRegistry::~ActionRegistry() called, instance is " << this << "." << std::endl;
  cleanup();
}
/** Instantiates each existing Action.
 *
 */
void ActionRegistry::fillRegistry()
{
#define instance_print(z,n,list) \
	{ \
	Action * presentAction = new \
	BOOST_PP_CAT(BOOST_PP_SEQ_ELEM(n, list), Action) \
	(); \
	registerInstance(presentAction); \
	}
#define BOOST_PP_LOCAL_MACRO(n) instance_print(~, n, GLOBALLISTOFACTIONS)
#define BOOST_PP_LOCAL_LIMITS  (0, BOOST_PP_DEC(BOOST_PP_SEQ_SIZE(GLOBALLISTOFACTIONS)))
#include BOOST_PP_LOCAL_ITERATE()
#undef instance_print  
  // now prepare each macro action that require presence of all primitive ones
  {
    MakroAction * presentAction =
        dynamic_cast(getActionByName("subgraph-dissection"));
    ASSERT( presentAction != NULL,
        "ActionRegistry::fillRegistry() - makro action has not been registered.");
    presentAction->prepare(*this);
  }
#ifdef HAVE_JOBMARKET
  {
    MakroAction * presentAction =
        dynamic_cast(getActionByName("molecular-dynamics"));
    ASSERT( presentAction != NULL,
        "ActionRegistry::fillRegistry() - makro action has not been registered.");
    presentAction->prepare(*this);
  }
#endif
}
/** Just passes on call to Registry::getByName().
 * \param name name of Action
 * \return pointer to Action
 */
Action* ActionRegistry::getActionByName(const std::string &name)
{
  return getByName(name);
}
/** Just passes on call to Registry::isPresentByName().
 * \param name name of Action
 * \return true - Action instance present, false - not
 */
bool ActionRegistry::isActionPresentByName(const std::string &name) const
{
  return isPresentByName(name);
}
CONSTRUCT_REGISTRY(Action)