fix #1637 (needs merging to 2.0.1 branch); remove debug printf
[ardour.git] / gtk2_ardour / visual_time_axis.cc
index 285f72c8a52d1c8ed28f9baa39e5f0bde8cce3b3..b68597114488e8e95a2992d22476b0f15186e1a6 100644 (file)
@@ -15,7 +15,6 @@
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-    $Id$
 */
 
 #include <cstdlib>
@@ -26,6 +25,7 @@
 
 #include <pbd/error.h>
 #include <pbd/stl_delete.h>
+#include <pbd/whitespace.h>
 
 #include <gtkmm2ext/utils.h>
 #include <gtkmm2ext/selector.h>
 #include "i18n.h"
 
 using namespace ARDOUR;
+using namespace PBD;
 using namespace sigc;
 using namespace Gtk;
-
-//XXX should really have a common home...
-static const gchar* small_x_xpm[] = {
-       "11 11 2 1",
-       "       c None",
-       ".      c #000000",
-       "           ",
-       "           ",
-       "  .     .  ",
-       "   .   .   ",
-       "    . .    ",
-       "     .     ",
-       "    . .    ",
-       "   .   .   ",
-       "  .     .  ",
-       "           ",
-       "           "};
-
        
 /**
  * Abstract Constructor for base visual time axis classes
@@ -90,7 +73,6 @@ VisualTimeAxis::VisualTimeAxis(const string & name, PublicEditor& ed, ARDOUR::Se
          size_button (_("h"))
 {
        time_axis_name = name ;
-       name_prompter = 0 ;
        _color = unique_random_color() ;
        _marked_for_display = true;
        
@@ -102,8 +84,7 @@ VisualTimeAxis::VisualTimeAxis(const string & name, PublicEditor& ed, ARDOUR::Se
        size_button.set_name("TrackSizeButton") ;
        visual_button.set_name("TrackVisualButton") ;
        hide_button.set_name("TrackRemoveButton") ;
-       Glib::RefPtr<Gdk::Pixbuf> small_x_pixbuf = Gdk::Pixbuf::create_from_xpm_data(small_x_xpm);
-       hide_button.add(*(Gtk::manage(new Gtk::Image(small_x_pixbuf)))) ;
+       hide_button.add(*(Gtk::manage(new Gtk::Image(get_xpm("small_x.xpm")))));
        size_button.signal_button_release_event().connect (mem_fun (*this, &VisualTimeAxis::size_click)) ;
        visual_button.signal_clicked().connect (mem_fun (*this, &VisualTimeAxis::visual_click)) ;
        hide_button.signal_clicked().connect (mem_fun (*this, &VisualTimeAxis::hide_click)) ;
@@ -129,11 +110,6 @@ VisualTimeAxis::VisualTimeAxis(const string & name, PublicEditor& ed, ARDOUR::Se
  */
 VisualTimeAxis::~VisualTimeAxis()
 {
-       if(name_prompter)
-       {
-               delete name_prompter ;
-               name_prompter = 0 ;
-       }
 }
 
 
@@ -182,22 +158,22 @@ VisualTimeAxis::set_height(TrackHeight h)
                case Larger:
                case Normal:
                {
-                       name_label.hide() ;
-                       name_entry.show() ;
+                       hide_name_label ();
+                       show_name_entry ();
                        other_button_hbox.show_all() ;
                        break;
                }
                case Smaller:
                {
-                       name_label.hide() ;
-                       name_entry.show() ;
+                       hide_name_label ();
+                       show_name_entry ();
                        other_button_hbox.hide_all() ;
                        break;
                }
                case Small:
                {
-                       name_label.show() ;
-                       name_entry.hide() ;
+                       hide_name_entry ();
+                       show_name_label ();
                        other_button_hbox.hide_all() ;
                }
                break;
@@ -222,7 +198,12 @@ VisualTimeAxis::visual_click()
 void
 VisualTimeAxis::hide_click()
 {
-       editor.unselect_strip_in_display (*this);
+       // LAME fix for hide_button display refresh
+       hide_button.set_sensitive(false);
+       
+       editor.hide_track_in_display (*this);
+       
+       hide_button.set_sensitive(true);
 }
 
 
@@ -278,7 +259,7 @@ VisualTimeAxis::set_time_axis_color(Gdk::Color c)
 }
 
 void
-VisualTimeAxis::set_selected_regionviews (AudioRegionSelection& regions)
+VisualTimeAxis::set_selected_regionviews (RegionSelection& regions)
 {
        // Not handled by purely visual TimeAxis
 }
@@ -298,23 +279,17 @@ VisualTimeAxis::remove_this_time_axis(void* src)
 
        std::string prompt  = string_compose (_("Do you really want to remove track \"%1\" ?\n(cannot be undone)"), time_axis_name);
 
-       choices.push_back (_("Yes, remove it."));
        choices.push_back (_("No, do nothing."));
+       choices.push_back (_("Yes, remove it."));
 
        Gtkmm2ext::Choice prompter (prompt, choices);
 
-       prompter.chosen.connect(sigc::ptr_fun(Gtk::Main::quit));
-       prompter.show_all ();
-
-       Gtk::Main::run ();
-
-       if (prompter.get_choice() == 0)
-       {
+       if (prompter.run () == 1) {
                /*
-                  defer to idle loop, otherwise we'll delete this object
-                  while we're still inside this function ...
+                 defer to idle loop, otherwise we'll delete this object
+                 while we're still inside this function ...
                */
-         Glib::signal_idle().connect(bind(sigc::ptr_fun(&VisualTimeAxis::idle_remove_this_time_axis), this, src));
+               Glib::signal_idle().connect(bind(sigc::ptr_fun(&VisualTimeAxis::idle_remove_this_time_axis), this, src));
        }
 }
 
@@ -349,33 +324,27 @@ VisualTimeAxis::idle_remove_this_time_axis(VisualTimeAxis* ta, void* src)
 void
 VisualTimeAxis::start_time_axis_rename()
 {
-       if(name_prompter)
-       {
-               delete name_prompter ;
-               name_prompter = 0 ;
-       }
-
-       name_prompter = new ArdourPrompter() ;
+       ArdourPrompter name_prompter;
 
-       name_prompter->set_prompt (_("new name: ")) ;
-       name_prompter->show_all() ;
+       name_prompter.set_prompt (_("new name: ")) ;
+       name_prompter.add_button (_("Rename"), Gtk::RESPONSE_ACCEPT);
+       name_prompter.set_response_sensitive (Gtk::RESPONSE_ACCEPT, false);
+       name_prompter.show_all() ;
 
-       switch (name_prompter->run ()) {
-       case GTK_RESPONSE_ACCEPT:
+       switch (name_prompter.run ()) {
+       case Gtk::RESPONSE_ACCEPT:
          string result;
-         name_prompter->get_result (result);
-         if (editor.get_named_time_axis(result) != 0) {
-           ARDOUR_UI::instance()->popup_error (_("A track already exists with that name"));
-           return ;
-         }
+         name_prompter.get_result (result);
+         if (result.length()) {
+                 if (editor.get_named_time_axis(result) != 0) {
+                   ARDOUR_UI::instance()->popup_error (_("A track already exists with that name"));
+                   return ;
+                 }
          
-         set_time_axis_name(result, this) ;
+                 set_time_axis_name(result, this) ;
+         }
        }
-       delete name_prompter ;
-       name_prompter = 0 ;
        label_view() ;
-
-
 }
 
 /**
@@ -405,17 +374,17 @@ VisualTimeAxis::name_entry_changed()
                return;
        }
 
+       strip_whitespace_edges(x);
+
        if (x.length() == 0) {
                name_entry.set_text (time_axis_name);
                return;
        }
 
-       strip_whitespace_edges(x);
-
        if (!editor.get_named_time_axis(x)) {
                set_time_axis_name(x, this);
        } else {
-               ARDOUR_UI::instance()->popup_error (_("a track already exists with that name"));
+               ARDOUR_UI::instance()->popup_error (_("A track already exists with that name"));
                name_entry.set_text(time_axis_name);
        }
 }
@@ -455,7 +424,7 @@ VisualTimeAxis::name_entry_key_release_handler(GdkEventKey* ev)
 // Super class methods not handled by VisualTimeAxis
                
 void
-VisualTimeAxis::show_timestretch (jack_nframes_t start, jack_nframes_t end)
+VisualTimeAxis::show_timestretch (nframes_t start, nframes_t end)
 {
   // Not handled by purely visual TimeAxis
 }