#include "tparamcontainer.h"
//#include "tdoubleparam.h"
#include "tparamset.h"
#include "tparam.h"
void TParamVar::setParamObserver(TParamObserver *obs)
{
if (m_paramObserver == obs)
return;
TParam *param = getParam();
if (param) {
if (obs)
param->addObserver(obs);
if (m_paramObserver)
param->removeObserver(m_paramObserver);
}
m_paramObserver = obs;
}
class TParamContainer::Imp
{
public:
std::map<string, TParamVar *> m_nameTable;
std::vector<TParamVar *> m_vars;
TParamObserver *m_paramObserver;
Imp() : m_paramObserver(0) {}
~Imp() { clearPointerContainer(m_vars); }
};
TParamContainer::TParamContainer()
: m_imp(new Imp())
{
}
TParamContainer::~TParamContainer()
{
}
void TParamContainer::setParamObserver(TParamObserver *observer)
{
m_imp->m_paramObserver = observer;
}
TParamObserver *TParamContainer::getParamObserver() const
{
return m_imp->m_paramObserver;
}
void TParamContainer::add(TParamVar *var)
{
m_imp->m_vars.push_back(var);
m_imp->m_nameTable[var->getName()] = var;
var->setParamObserver(m_imp->m_paramObserver);
var->getParam()->setName(var->getName());
}
int TParamContainer::getParamCount() const
{
return m_imp->m_vars.size();
}
TParam *TParamContainer::getParam(int index) const
{
assert(0 <= index && index < getParamCount());
return m_imp->m_vars[index]->getParam();
}
bool TParamContainer::isParamHidden(int index) const
{
assert(0 <= index && index < getParamCount());
return m_imp->m_vars[index]->isHidden();
}
string TParamContainer::getParamName(int index) const
{
assert(0 <= index && index < getParamCount());
return m_imp->m_vars[index]->getName();
}
const TParamVar *TParamContainer::getParamVar(int index) const
{
assert(0 <= index && index < getParamCount());
return m_imp->m_vars[index];
}
TParam *TParamContainer::getParam(string name) const
{
std::map<string, TParamVar *>::const_iterator it;
it = m_imp->m_nameTable.find(name);
if (it == m_imp->m_nameTable.end())
return 0;
else
return it->second->getParam();
}
void TParamContainer::unlink()
{
for (int i = 0; i < getParamCount(); i++) {
//TRangeParam *p0;//,*p1;
TParamVar *var = m_imp->m_vars[i];
TParam *param = var->getParam();
//p0 = dynamic_cast<TRangeParam *>(param);
var->setParam(param->clone());
/*p1 = dynamic_cast<TRangeParam *>(var->getParam());
if(p0 && p1)
{
string name = p0->getName();
name = p1->getName();
}*/
}
}
void TParamContainer::link(const TParamContainer *src)
{
assert(getParamCount() == src->getParamCount());
for (int i = 0; i < getParamCount(); i++) {
assert(getParamName(i) == src->getParamName(i));
assert(m_imp->m_vars[i]->getName() == getParamName(i));
m_imp->m_vars[i]->setParam(src->getParam(i));
}
}
void TParamContainer::copy(const TParamContainer *src)
{
assert(getParamCount() == src->getParamCount());
for (int i = 0; i < getParamCount(); i++) {
assert(getParamName(i) == src->getParamName(i));
assert(m_imp->m_vars[i]->getName() == getParamName(i));
getParam(i)->copy(src->getParam(i));
}
}