first compiling, mostly working version of group controls changes
[ardour.git] / gtk2_ardour / export_channel_selector.cc
index 20155471af11c5d87edab625d15c65066a238045..c868d698532843dcfe37a8b23b60291fe458a126 100644 (file)
@@ -40,6 +40,12 @@ using namespace Glib;
 using namespace ARDOUR;
 using namespace PBD;
 
+struct EditorOrderRouteSorter {
+    bool operator() (boost::shared_ptr<Route> a, boost::shared_ptr<Route> b) {
+           return a->order_key () < b->order_key ();
+    }
+};
+
 PortExportChannelSelector::PortExportChannelSelector (ARDOUR::Session * session, ProfileManagerPtr manager) :
   ExportChannelSelector (session, manager),
   channels_label (_("Channels:"), Gtk::ALIGN_LEFT),
@@ -115,6 +121,8 @@ PortExportChannelSelector::fill_route_list ()
                channel_view.add_route (master);
        }
 
+       routes.sort (EditorOrderRouteSorter ());
+
        for (RouteList::iterator it = routes.begin(); it != routes.end(); ++it) {
                if ((*it)->is_master () || (*it)->is_monitor ()) {
                        continue;
@@ -154,7 +162,7 @@ PortExportChannelSelector::RouteCols::Channel &
 PortExportChannelSelector::RouteCols::get_channel (uint32_t channel)
 {
        if (channel > n_channels) {
-               std::cout << "Invalid channel cout for get_channel!" << std::endl;
+               std::cout << "Invalid channel count for get_channel!" << std::endl;
        }
 
        std::list<Channel>::iterator it = channels.begin();
@@ -179,16 +187,21 @@ PortExportChannelSelector::ChannelTreeView::ChannelTreeView (uint32_t max_channe
 
        /* Add column with toggle and text */
 
-       append_column_editable (_("Bus or Track"), route_cols.selected);
+       append_column_editable (_("Export"), route_cols.selected);
 
        Gtk::CellRendererText* text_renderer = Gtk::manage (new Gtk::CellRendererText);
        text_renderer->property_editable() = false;
+       text_renderer->set_alignment (0.0, 0.5);
 
-       Gtk::TreeView::Column* column = get_column (0);
+       Gtk::TreeView::Column* column = Gtk::manage (new Gtk::TreeView::Column);
+       column->set_title (_("Bus or Track"));
        column->pack_start (*text_renderer);
+       column->set_expand (true);
        column->add_attribute (text_renderer->property_text(), route_cols.name);
+       append_column  (*column);
 
        Gtk::CellRendererToggle *toggle = dynamic_cast<Gtk::CellRendererToggle *>(get_column_cell_renderer (0));
+       toggle->set_alignment (0.0, 0.5);
        toggle->signal_toggled().connect (sigc::mem_fun (*this, &PortExportChannelSelector::ChannelTreeView::update_toggle_selection));
 
        static_columns = get_columns().size();
@@ -315,6 +328,7 @@ PortExportChannelSelector::ChannelTreeView::set_channel_count (uint32_t channels
 
                Gtk::CellRendererCombo* combo_renderer = Gtk::manage (new Gtk::CellRendererCombo);
                combo_renderer->property_text_column() = 2;
+               combo_renderer->property_has_entry() = false;
                column->pack_start (*combo_renderer);
 
                append_column (*column);
@@ -533,14 +547,18 @@ RegionExportChannelSelector::handle_selection ()
 
 TrackExportChannelSelector::TrackExportChannelSelector (ARDOUR::Session * session, ProfileManagerPtr manager)
   : ExportChannelSelector(session, manager)
-  , region_contents_button(source_group, _("Export region contents"))
-  , track_output_button(source_group, _("Export track output"))
+  , track_output_button(_("Apply track/bus processing"))
+  , select_tracks_button (_("Select all tracks"))
+  , select_busses_button (_("Select all busses"))
+  , select_none_button (_("Deselect all"))
 {
        pack_start(main_layout);
 
        // Options
-       options_box.pack_start(region_contents_button);
        options_box.pack_start(track_output_button);
+       options_box.pack_start (select_tracks_button);
+       options_box.pack_start (select_busses_button);
+       options_box.pack_start (select_none_button);
        main_layout.pack_start(options_box, false, false);
 
        // Track scroller
@@ -551,20 +569,33 @@ TrackExportChannelSelector::TrackExportChannelSelector (ARDOUR::Session * sessio
 
        // Track list
        track_list = Gtk::ListStore::create (track_cols);
+       track_list->set_sort_column (track_cols.order_key, Gtk::SORT_ASCENDING);
        track_view.set_model (track_list);
        track_view.set_headers_visible (true);
 
-       track_view.append_column_editable (_("Track"), track_cols.selected);
+       track_view.append_column_editable (_("Export"), track_cols.selected);
        Gtk::CellRendererToggle *toggle = dynamic_cast<Gtk::CellRendererToggle *>(track_view.get_column_cell_renderer (0));
+       toggle->set_alignment (0.0, 0.5);
+
        toggle->signal_toggled().connect (sigc::hide (sigc::mem_fun (*this, &TrackExportChannelSelector::update_config)));
 
        Gtk::CellRendererText* text_renderer = Gtk::manage (new Gtk::CellRendererText);
        text_renderer->property_editable() = false;
+       text_renderer->set_alignment (0.0, 0.5);
 
-       Gtk::TreeView::Column* column = track_view.get_column (0);
-       column->pack_start (*text_renderer);
+       Gtk::TreeView::Column* column = Gtk::manage (new Gtk::TreeView::Column);
+       column->set_title (_("Track name"));
+
+       track_view.append_column  (*column);
+       column->pack_start (*text_renderer, false);
        column->add_attribute (text_renderer->property_text(), track_cols.label);
 
+       select_tracks_button.signal_clicked().connect (sigc::mem_fun (*this, &TrackExportChannelSelector::select_tracks));
+       select_busses_button.signal_clicked().connect (sigc::mem_fun (*this, &TrackExportChannelSelector::select_busses));
+       select_none_button.signal_clicked().connect (sigc::mem_fun (*this, &TrackExportChannelSelector::select_none));
+
+       track_output_button.signal_clicked().connect (sigc::mem_fun (*this, &TrackExportChannelSelector::track_outputs_selected));
+
        fill_list();
 
        show_all_children ();
@@ -577,6 +608,50 @@ TrackExportChannelSelector::sync_with_manager ()
        update_config();
 }
 
+void
+TrackExportChannelSelector::select_tracks ()
+{
+       for (Gtk::ListStore::Children::iterator it = track_list->children().begin(); it != track_list->children().end(); ++it) {
+               Gtk::TreeModel::Row row = *it;
+               boost::shared_ptr<Route> route = row[track_cols.route];
+               if (boost::dynamic_pointer_cast<Track> (route)) {
+                       // it's a track
+                       row[track_cols.selected] = true;
+               }
+       }
+       update_config();
+}
+
+void
+TrackExportChannelSelector::select_busses ()
+{
+       for (Gtk::ListStore::Children::iterator it = track_list->children().begin(); it != track_list->children().end(); ++it) {
+               Gtk::TreeModel::Row row = *it;
+               boost::shared_ptr<Route> route = row[track_cols.route];
+               if (!boost::dynamic_pointer_cast<Track> (route)) {
+                       // it's not a track, must be a bus
+                       row[track_cols.selected] = true;
+               }
+       }
+       update_config();
+}
+
+void
+TrackExportChannelSelector::select_none ()
+{
+       for (Gtk::ListStore::Children::iterator it = track_list->children().begin(); it != track_list->children().end(); ++it) {
+               Gtk::TreeModel::Row row = *it;
+               row[track_cols.selected] = false;
+       }
+       update_config();
+}
+
+void
+TrackExportChannelSelector::track_outputs_selected ()
+{
+       update_config();
+}
+
 void
 TrackExportChannelSelector::fill_list()
 {
@@ -589,12 +664,21 @@ TrackExportChannelSelector::fill_list()
                        if ((*it)->is_master () || (*it)->is_monitor ()) {
                                continue;
                        }
+                       if (!(*it)->active ()) {
+                               // don't include inactive busses
+                               continue;
+                       }
+
                        // not monitor or master bus
                        add_track (*it);
                }
        }
        for (RouteList::iterator it = routes.begin(); it != routes.end(); ++it) {
                if (boost::dynamic_pointer_cast<AudioTrack>(*it)) {
+                       if (!(*it)->active ()) {
+                               // don't include inactive tracks
+                               continue;
+                       }
                        add_track (*it);
                }
        }
@@ -606,9 +690,10 @@ TrackExportChannelSelector::add_track (boost::shared_ptr<Route> route)
        Gtk::TreeModel::iterator iter = track_list->append();
        Gtk::TreeModel::Row row = *iter;
 
-       row[track_cols.selected] = true;
+       row[track_cols.selected] = false;
        row[track_cols.label] = route->name();
        row[track_cols.route] = route;
+       row[track_cols.order_key] = route->order_key();
 }
 
 void
@@ -645,6 +730,7 @@ TrackExportChannelSelector::update_config()
                }
 
                state->config->set_name (route->name());
+
        }
 
        CriticalSelectionChanged ();