ardour/gtk2_ardour/stripable_treemodel.cc
Robin Gareus 4050ca5633
Update GPL boilerplate and (C)
Copyright-holder and year information is extracted from git log.

git history begins in 2005. So (C) from 1998..2005 is lost. Also some
(C) assignment of commits where the committer didn't use --author.
2019-08-03 15:53:15 +02:00

267 lines
5.7 KiB
C++

/*
* Copyright (C) 2017 Paul Davis <paul@linuxaudiosystems.com>
* Copyright (C) 2017 Robin Gareus <robin@gareus.org>
*
* 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 2 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, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include <iostream>
#include "ardour/session.h"
#include "ardour/types.h"
#include "axis_provider.h"
#include "stripable_treemodel.h"
using namespace ARDOUR;
StripableTreeModel::Glue::Glue (boost::shared_ptr<Stripable> s)
: stripable (s)
{
}
StripableTreeModel::StripableTreeModel (AxisViewProvider& avp)
: Glib::ObjectBase( typeid(StripableTreeModel) ) //register a custom GType.
, Glib::Object() //The custom GType is actually registered here.
, axis_view_provider (avp)
{
n_columns = columns.size();
}
void
StripableTreeModel::set_session (Session& s)
{
_session = &s;
}
StripableTreeModel::~StripableTreeModel()
{
}
Glib::RefPtr<StripableTreeModel>
StripableTreeModel::create (AxisViewProvider& avp)
{
return Glib::RefPtr<StripableTreeModel> (new StripableTreeModel (avp));
}
Gtk::TreeModelFlags
StripableTreeModel::get_flags_vfunc() const
{
return Gtk::TREE_MODEL_LIST_ONLY;
}
int
StripableTreeModel::get_n_columns_vfunc() const
{
return n_columns;
}
GType
StripableTreeModel::get_column_type_vfunc (int index) const
{
if (index <= n_columns) {
return columns.types()[index];
}
return 0;
}
void
StripableTreeModel::get_value_vfunc (const TreeModel::iterator& iter, int column, Glib::ValueBase& value) const
{
if (!_session) {
return;
}
if (column > n_columns) {
return;
}
const Glue* glue = (const Glue*)iter.gobj()->user_data;
boost::shared_ptr<Stripable> iter_stripable = glue->stripable.lock();
if (!iter_stripable) {
return;
}
switch (column) {
case 0:
return text_value (iter_stripable, value);
}
}
void
StripableTreeModel::text_value (boost::shared_ptr<Stripable> stripable, Glib::ValueBase& value) const
{
StringColumn::ValueType val;
val.set (stripable->name());
value = val;
}
bool
StripableTreeModel::iter_next_vfunc (const iterator& iter, iterator& iter_next) const
{
if (!_session) {
return false;
}
const Glue* glue = (const Glue*)iter.gobj()->user_data;
boost::shared_ptr<Stripable> iter_stripable = glue->stripable.lock();
if (!iter_stripable) {
return false;
}
//initialize the next iterator:
iter_next = iterator();
StripableList sl;
_session->get_stripables (sl);
if (sl.empty()) {
return false;
}
sl.sort (Stripable::Sorter());
for (StripableList::const_iterator s = sl.begin(); s != sl.end(); ++s) {
if (*s == iter_stripable) {
++s;
if (s != sl.end()) {
Glue* new_glue = new Glue (iter_stripable);
iter_next.gobj()->user_data = (void*)new_glue;
remember_glue_item (new_glue);
return true; //success
}
break;
}
}
return false; //There is no next row.
}
bool
StripableTreeModel::iter_children_vfunc(const iterator& parent, iterator& iter) const
{
return false;
}
bool
StripableTreeModel::iter_has_child_vfunc(const iterator& iter) const
{
return false;
}
int
StripableTreeModel::iter_n_children_vfunc(const iterator& iter) const
{
return 0;
}
int
StripableTreeModel::iter_n_root_children_vfunc() const
{
if (_session) {
StripableList sl;
_session->get_stripables (sl);
return sl.size();
}
return 0;
}
bool
StripableTreeModel::iter_nth_child_vfunc(const iterator& parent, int /* n */, iterator& iter) const
{
iter = iterator(); //Set is as invalid, as the TreeModel documentation says that it should be.
return false; //There are no children.
}
bool
StripableTreeModel::iter_nth_root_child_vfunc(int n, iterator& iter) const
{
iter = iterator(); //clear the input parameter.
if (!_session) {
return false;
}
StripableList sl;
_session->get_stripables (sl);
if (sl.empty()) {
return false;
}
sl.sort (Stripable::Sorter());
StripableList::const_iterator s;
for (s = sl.begin(); s != sl.end() && n > 0; ++s, --n);
if (s != sl.end()) {
Glue* new_glue = new Glue (*s);
iter.gobj()->user_data = new_glue;
remember_glue_item (new_glue);
return true;
}
return false; //There are no children.
}
bool
StripableTreeModel::iter_parent_vfunc(const iterator& child, iterator& iter) const
{
iter = iterator(); //Set is as invalid, as the TreeModel documentation says that it should be.
return false; //There are no children, so no parents.
}
Gtk::TreeModel::Path
StripableTreeModel::get_path_vfunc(const iterator& /* iter */) const
{
//TODO:
return Path();
}
bool
StripableTreeModel::get_iter_vfunc (const Path& path, iterator& iter) const
{
unsigned sz = path.size();
if (!sz || sz > 1) {
/* path must refer to something, but not children since we
don't do children.
*/
iter = iterator(); //Set is as invalid, as the TreeModel documentation says that it should be.
return false;
}
return iter_nth_root_child_vfunc (path[0], iter);
}
bool
StripableTreeModel::iter_is_valid(const iterator& iter) const
{
const Glue* glue = (const Glue*)iter.gobj()->user_data;
if (!glue->stripable.lock()) {
return false;
}
return Gtk::TreeModel::iter_is_valid(iter);
}
void
StripableTreeModel::remember_glue_item (Glue* item) const
{
glue_list.insert (item);
}