X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fbundle_manager.h;h=468346e54ca0529eba3e8b591411ea5cb78e02be;hb=d9dc2592d02924718d9f181dbbca423a5eac364f;hp=18b0b29e92ec601dadf0ca505eeffc102131d606;hpb=61db2175eb8b8fffd0c1796ace78ac33c9e1adf0;p=ardour.git diff --git a/gtk2_ardour/bundle_manager.h b/gtk2_ardour/bundle_manager.h index 18b0b29e92..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,36 +37,37 @@ namespace ARDOUR { class BundleEditorMatrix : public PortMatrix { public: - BundleEditorMatrix (ARDOUR::Session &, boost::shared_ptr); - - void set_state ( - boost::shared_ptr ab, - uint32_t ac, - boost::shared_ptr bb, - uint32_t bc, - bool s, - uint32_t k - ); - - bool get_state ( - boost::shared_ptr ab, - uint32_t ac, - boost::shared_ptr bb, - uint32_t bc - ) const; - - void add_channel (boost::shared_ptr); - void remove_channel (boost::shared_ptr, uint32_t); - bool can_rename_channels () const { - return true; - } - void rename_channel (boost::shared_ptr, uint32_t); + BundleEditorMatrix (Gtk::Window *, ARDOUR::Session *, boost::shared_ptr); + + void set_state (ARDOUR::BundleChannel c[2], bool s); + 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 (boost::shared_ptr) const; + void rename_channel (ARDOUR::BundleChannel); + 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; }; class BundleEditor : public ArdourDialog { public: - BundleEditor (ARDOUR::Session &, boost::shared_ptr, bool); + BundleEditor (ARDOUR::Session *, boost::shared_ptr); protected: void on_map (); @@ -71,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: @@ -91,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 { @@ -101,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 @@ -125,9 +129,8 @@ public: private: void setup (); - + boost::shared_ptr _bundle; - uint32_t _channel; Gtk::Entry _name; bool _adding; };