X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fbundle_manager.h;h=468346e54ca0529eba3e8b591411ea5cb78e02be;hb=3d26a29e8a2ed1286091fda2dd480bf5bbebe365;hp=aa13967bff86ecf5270186b243c07f0ba81d311e;hpb=a384dab13095f3d909e52eff9e6170ae55416601;p=ardour.git diff --git a/gtk2_ardour/bundle_manager.h b/gtk2_ardour/bundle_manager.h index aa13967bff..468346e54c 100644 --- a/gtk2_ardour/bundle_manager.h +++ b/gtk2_ardour/bundle_manager.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2007 Paul Davis + Copyright (C) 2007 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 @@ -20,9 +20,12 @@ #ifndef __ardour_ui_bundle_manager_h__ #define __ardour_ui_bundle_manager_h__ -#include -#include #include +#include +#include + +#include "ardour/user_bundle.h" + #include "ardour_dialog.h" #include "port_matrix.h" @@ -34,27 +37,29 @@ namespace ARDOUR { class BundleEditorMatrix : public PortMatrix { public: - BundleEditorMatrix (ARDOUR::Session &, boost::shared_ptr); + BundleEditorMatrix (Gtk::Window *, ARDOUR::Session *, boost::shared_ptr); void set_state (ARDOUR::BundleChannel c[2], bool s); - State get_state (ARDOUR::BundleChannel c[2]) const; - void add_channel (boost::shared_ptr); - bool can_remove_channels (int d) const { - return d == OURS; - } + PortMatrixNode::State get_state (ARDOUR::BundleChannel c[2]) const; + + bool can_add_channels (boost::shared_ptr) const; + + void add_channel (boost::shared_ptr, ARDOUR::DataType); + bool can_remove_channels (boost::shared_ptr) const; void remove_channel (ARDOUR::BundleChannel); - bool can_rename_channels (int d) const { - return d == OURS; - } + bool can_rename_channels (boost::shared_ptr) const; void rename_channel (ARDOUR::BundleChannel); - void setup (); + void setup_ports (int); + bool list_is_global (int) const; + + std::string disassociation_verb () const; private: enum { OTHER = 0, OURS = 1 }; - + boost::shared_ptr _port_group; boost::shared_ptr _bundle; }; @@ -62,7 +67,7 @@ class BundleEditorMatrix : public PortMatrix class BundleEditor : public ArdourDialog { public: - BundleEditor (ARDOUR::Session &, boost::shared_ptr, bool); + BundleEditor (ARDOUR::Session *, boost::shared_ptr); protected: void on_map (); @@ -70,19 +75,18 @@ class BundleEditor : public ArdourDialog private: void name_changed (); void input_or_output_changed (); - void type_changed (); - + void on_show (); + BundleEditorMatrix _matrix; boost::shared_ptr _bundle; Gtk::Entry _name; Gtk::ComboBoxText _input_or_output; - Gtk::ComboBoxText _type; }; class BundleManager : public ArdourDialog { public: - BundleManager (ARDOUR::Session &); + BundleManager (ARDOUR::Session *); private: @@ -90,8 +94,9 @@ class BundleManager : public ArdourDialog void edit_clicked (); void delete_clicked (); void add_bundle (boost::shared_ptr); - void bundle_name_changed (boost::shared_ptr); + void bundle_changed (ARDOUR::Bundle::Change, boost::shared_ptr); void set_button_sensitivity (); + void row_activated (Gtk::TreeModel::Path const & p, Gtk::TreeViewColumn* c); class ModelColumns : public Gtk::TreeModelColumnRecord { @@ -100,17 +105,17 @@ class BundleManager : public ArdourDialog add (name); add (bundle); } - - Gtk::TreeModelColumn name; + + Gtk::TreeModelColumn name; Gtk::TreeModelColumn > bundle; }; - + Gtk::TreeView _tree_view; Glib::RefPtr _list_model; ModelColumns _list_model_columns; - ARDOUR::Session& _session; Gtk::Button edit_button; Gtk::Button delete_button; + PBD::ScopedConnectionList bundle_connections; }; class NameChannelDialog : public ArdourDialog @@ -124,9 +129,8 @@ public: private: void setup (); - + boost::shared_ptr _bundle; - uint32_t _channel; Gtk::Entry _name; bool _adding; };