/* * Copyright 2008-2009 Ben Boeckel * * 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 3 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, see . */ // Header include #include "GroupObjectModel.h" using namespace Sigmod; using namespace Sigmodr::Tree; GroupObjectModel::GroupObjectModel(BaseModel* parent, Object* object) : BaseObjectModel(parent, object), Grouping() { } GroupObjectModel::~GroupObjectModel() { } QVariant GroupObjectModel::data(int role) const { return BaseObjectModel::data(role); } int GroupObjectModel::rowCount() const { return m_objects.size(); } BaseModel* GroupObjectModel::childItem(const int row) { if (row < m_objects.size()) return m_objects[row]; return NULL; } void GroupObjectModel::addChild(BaseModel* model) { connect(model, SIGNAL(rowChanged(int)), this, SLOT(childRowChanged(int))); connect(model, SIGNAL(rowsChanged(QList)), this, SLOT(childRowsChanged(QList))); m_objects.append(model); emit(rowChanged(m_objects.size() - 1)); } int GroupObjectModel::findChild(BaseModel* model) const { return find(model); }