Blob Blame Raw


#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<std::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();
}

std::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(std::string name) const {
  std::map<std::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));
  }
}