GetClbInfoProcess.cc 2.54 KB
/*
 * GetClbInfoProcess.cc
 *
 *  Created on: Dec 12, 2012
 *      Author: f.casimir
 */
#include <stdlib.h>
#include <string>

#include "AMDA_exception.hh"
#include "DicError.hh"

#include "Operation.hh"
#include "ParameterManager.hh"
#include "GetClbInfoProcess.hh"
#include "GetClbInfoCreator.hh"
#include "ParameterCreatorFromExpression.hh"

using namespace std;
using namespace boost;
using namespace log4cxx;

namespace AMDA {
namespace GetClbInfo {

  GetClbInfoProcess::GetClbInfoProcess(Parameter &parameter)
  : SingleParamProcess_CRTP(parameter) {
  }

  GetClbInfoProcess::GetClbInfoProcess(const GetClbInfoProcess& pProcess, Parameter &parameter)
    : SingleParamProcess_CRTP(pProcess,parameter) {
  }

  GetClbInfoProcess::~GetClbInfoProcess() {
  }

TimeStamp GetClbInfoProcess::init() {
	TimeStamp timeStamp = _parameterInput->init( this, _timeIntervalList);
	Parameter::InfoList lInfoList = _parameterInput->getInfoList();
	_parameter.getInfoList().insert(lInfoList.begin(), lInfoList.end());
	_paramInput = _parameterInput->getParamData(this).get();

	//GET Sampling
	if (_attributList.size() == 0) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_PROCESS_ERR) << AMDA::ex_msg(std::string("GetClbInfoProcess::init required at least one attribute'")));
	}

	GetClbInfoCreator lGetClbInfoCreator(*this,*_paramInput);
	_operation = lGetClbInfoCreator.getOperation();
	dynamic_cast<Base::GetClbInfo*>(_operation)->init(*_parameterInput,_attributList);
	_paramData = ParamDataSPtr(_operation->getParamOutput());
	_paramData->setMinSampling(_paramInput->getMinSampling());
                    AMDA::Parameters::SemiVariableTable semiVariableTableElements;
                    int i = 0;
                    unsigned int nbHeader = 0;
                    for (auto info : lInfoList){
                               semiVariableTableElements.tabValues[i] = *info.second; 
                               if (nbHeader < (*info.second).size()) 
                                        nbHeader = (*info.second).size();  
                               i++;
                    }
                    for (unsigned int i = 0 ; i < nbHeader; i++)
                        semiVariableTableElements.tabHeader.push_back("Energy[" + std::to_string(i)+"]"); 
                    this->setSemiVariableTable(semiVariableTableElements);
                    if (!semiVariableTableElements.tabValues.empty())
                           _parameterInput->setIsTableIndexParam(true);
           
	return timeStamp;
         }


} /* namespace GetClbInfo */
} /* namespace AMDA */