/* Copyright (C) 2000 Paul Davis 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., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef __ardour_route_group_h__ #define __ardour_route_group_h__ #include #include #include #include #include "pbd/signals.h" #include "pbd/stateful.h" #include "pbd/signals.h" #include "ardour/types.h" #include "ardour/session_object.h" namespace ARDOUR { namespace Properties { extern PBD::PropertyDescriptor relative; extern PBD::PropertyDescriptor active; extern PBD::PropertyDescriptor gain; extern PBD::PropertyDescriptor mute; extern PBD::PropertyDescriptor solo; extern PBD::PropertyDescriptor recenable; extern PBD::PropertyDescriptor select; extern PBD::PropertyDescriptor edit; /* we use this, but its declared in region.cc */ extern PBD::PropertyDescriptor hidden; }; class Route; class Track; class AudioTrack; class Session; class RouteGroup : public SessionObject { public: static void make_property_quarks(); RouteGroup (Session& s, const std::string &n); ~RouteGroup (); bool is_active () const { return _active.val(); } bool is_relative () const { return _relative.val(); } bool is_hidden () const { return _hidden.val(); } bool is_gain () const { return _gain.val(); } bool is_mute () const { return _mute.val(); } bool is_solo () const { return _solo.val(); } bool is_recenable () const { return _recenable.val(); } bool is_select () const { return _select.val(); } bool is_edit () const { return _edit.val(); } bool empty() const {return routes->empty();} size_t size() const { return routes->size();} gain_t get_max_factor(gain_t factor); gain_t get_min_factor(gain_t factor); void set_active (bool yn, void *src); void set_relative (bool yn, void *src); void set_hidden (bool yn, void *src); void set_gain (bool yn); void set_mute (bool yn); void set_solo (bool yn); void set_recenable (bool yn); void set_select (bool yn); void set_edit (bool yn); bool enabled_property (PBD::PropertyID); int add (boost::shared_ptr); int remove (boost::shared_ptr); void apply (void (Route::*func)(void *), void *src) { for (RouteList::iterator i = routes->begin(); i != routes->end(); ++i) { ((*i).get()->*func)(src); } } template void apply (void (Route::*func)(T, void *), T val, void *src) { for (RouteList::iterator i = routes->begin(); i != routes->end(); ++i) { ((*i).get()->*func)(val, src); } } template void foreach_route (T *obj, void (T::*func)(Route&)) { for (RouteList::iterator i = routes->begin(); i != routes->end(); ++i) { (obj->*func)(**i); } } /* to use these, #include "ardour/route_group_specialized.h" */ template void apply (void (Track::*func)(T, void *), T val, void *src); /* fills at_set with all members of the group that are AudioTracks */ void audio_track_group (std::set >& at_set); void clear () { routes->clear (); changed(); } void make_subgroup (); void destroy_subgroup (); boost::shared_ptr route_list() { return routes; } /** Emitted when a route has been added to or removed from this group */ PBD::Signal0 MembershipChanged; XMLNode& get_state (); int set_state (const XMLNode&, int version); private: boost::shared_ptr routes; boost::shared_ptr subgroup_bus; PBD::Property _relative; PBD::Property _active; PBD::Property _hidden; PBD::Property _gain; PBD::Property _mute; PBD::Property _solo; PBD::Property _recenable; PBD::Property _select; PBD::Property _edit; void remove_when_going_away (boost::weak_ptr); int set_state_2X (const XMLNode&, int); }; } /* namespace */ #endif /* __ardour_route_group_h__ */