Use general VisibilityGroup class to manage visibility
[ardour.git] / gtk2_ardour / ardour_ui_ed.cc
index 81cf8091e2763a13a2bf6e279e7890c0d1c97687..8ab5a9aa50fdea1d90f11db14589949556c61104 100644 (file)
@@ -98,7 +98,7 @@ ARDOUR_UI::install_actions ()
        /* menus + submenus that need action items */
 
        ActionManager::register_action (main_actions, X_("Session"), _("Session"));
-       act = ActionManager::register_action (main_actions, X_("Cleanup"), _("Cleanup"));
+       act = ActionManager::register_action (main_actions, X_("Cleanup"), _("Clean-up"));
        ActionManager::write_sensitive_actions.push_back (act);
        ActionManager::register_action (main_actions, X_("Sync"), _("Sync"));
        ActionManager::register_action (main_actions, X_("TransportOptions"), _("Options"));
@@ -147,6 +147,10 @@ ARDOUR_UI::install_actions ()
        ActionManager::session_sensitive_actions.push_back (act);
        ActionManager::write_sensitive_actions.push_back (act);
 
+       act = ActionManager::register_action (main_actions, X_("Rename"), _("Rename..."), sigc::mem_fun(*this, &ARDOUR_UI::rename_session));
+       ActionManager::session_sensitive_actions.push_back (act);
+       ActionManager::write_sensitive_actions.push_back (act);
+
        act = ActionManager::register_action (main_actions, X_("SaveTemplate"), _("Save Template..."),  sigc::mem_fun(*this, &ARDOUR_UI::save_template));
        ActionManager::session_sensitive_actions.push_back (act);
 
@@ -161,14 +165,14 @@ ARDOUR_UI::install_actions ()
 
        act = ActionManager::register_action (main_actions, X_("ExportAudio"), _("Export To Audio File(s)..."),  sigc::mem_fun (*editor, &PublicEditor::export_audio));
        ActionManager::session_sensitive_actions.push_back (act);
-       
+
        act = ActionManager::register_action (main_actions, X_("StemExport"), _("Stem export..."),  sigc::mem_fun (*editor, &PublicEditor::stem_export));
        ActionManager::session_sensitive_actions.push_back (act);
 
        act = ActionManager::register_action (main_actions, X_("Export"), _("Export"));
        ActionManager::session_sensitive_actions.push_back (act);
 
-       act = ActionManager::register_action (main_actions, X_("CleanupUnused"), _("Cleanup Unused Sources..."),  sigc::mem_fun (*(ARDOUR_UI::instance()), &ARDOUR_UI::cleanup));
+       act = ActionManager::register_action (main_actions, X_("CleanupUnused"), _("Clean-up Unused Sources..."),  sigc::mem_fun (*(ARDOUR_UI::instance()), &ARDOUR_UI::cleanup));
        ActionManager::session_sensitive_actions.push_back (act);
        ActionManager::write_sensitive_actions.push_back (act);
 
@@ -354,31 +358,34 @@ ARDOUR_UI::install_actions ()
        ActionManager::session_sensitive_actions.push_back (act);
        ActionManager::transport_sensitive_actions.push_back (act);
 
+       act = ActionManager::register_action (transport_actions, X_("primary-clock-timecode"), _("Timecode"), sigc::bind (sigc::mem_fun(primary_clock, &AudioClock::set_mode), AudioClock::Timecode));
+       ActionManager::session_sensitive_actions.push_back (act);
        act = ActionManager::register_action (transport_actions, X_("primary-clock-bbt"), _("Bars & Beats"), sigc::bind (sigc::mem_fun(primary_clock, &AudioClock::set_mode), AudioClock::BBT));
        ActionManager::session_sensitive_actions.push_back (act);
        act = ActionManager::register_action (transport_actions, X_("primary-clock-minsec"), _("Minutes & Seconds"), sigc::bind (sigc::mem_fun(primary_clock, &AudioClock::set_mode), AudioClock::MinSec));
        ActionManager::session_sensitive_actions.push_back (act);
        act = ActionManager::register_action (transport_actions, X_("primary-clock-samples"), _("Samples"), sigc::bind (sigc::mem_fun(primary_clock, &AudioClock::set_mode), AudioClock::Frames));
        ActionManager::session_sensitive_actions.push_back (act);
-       act = ActionManager::register_action (transport_actions, X_("primary-clock-off"), _("Off"), sigc::bind (sigc::mem_fun(primary_clock, &AudioClock::set_mode), AudioClock::Off));
-       ActionManager::session_sensitive_actions.push_back (act);
 
+       act = ActionManager::register_action (transport_actions, X_("secondary-clock-timecode"), _("Timecode"), sigc::bind (sigc::mem_fun(secondary_clock, &AudioClock::set_mode), AudioClock::Timecode));
+       ActionManager::session_sensitive_actions.push_back (act);
        act = ActionManager::register_action (transport_actions, X_("secondary-clock-bbt"), _("Bars & Beats"), sigc::bind (sigc::mem_fun(secondary_clock, &AudioClock::set_mode), AudioClock::BBT));
        ActionManager::session_sensitive_actions.push_back (act);
        act = ActionManager::register_action (transport_actions, X_("secondary-clock-minsec"), _("Minutes & Seconds"), sigc::bind (sigc::mem_fun(secondary_clock, &AudioClock::set_mode), AudioClock::MinSec));
        ActionManager::session_sensitive_actions.push_back (act);
        act = ActionManager::register_action (transport_actions, X_("secondary-clock-samples"), _("Samples"), sigc::bind (sigc::mem_fun(secondary_clock, &AudioClock::set_mode), AudioClock::Frames));
        ActionManager::session_sensitive_actions.push_back (act);
-       act = ActionManager::register_action (transport_actions, X_("secondary-clock-off"), _("Off"), sigc::bind (sigc::mem_fun(secondary_clock, &AudioClock::set_mode), AudioClock::Off));
-       ActionManager::session_sensitive_actions.push_back (act);
 
        act = ActionManager::register_toggle_action (transport_actions, X_("TogglePunchIn"), _("Punch In"), sigc::mem_fun(*this, &ARDOUR_UI::toggle_punch_in));
+       act->set_short_label (_("In"));
        ActionManager::session_sensitive_actions.push_back (act);
        ActionManager::transport_sensitive_actions.push_back (act);
        act = ActionManager::register_toggle_action (transport_actions, X_("TogglePunchOut"), _("Punch Out"), sigc::mem_fun(*this, &ARDOUR_UI::toggle_punch_out));
+       act->set_short_label (_("Out"));
        ActionManager::session_sensitive_actions.push_back (act);
        ActionManager::transport_sensitive_actions.push_back (act);
        act = ActionManager::register_toggle_action (transport_actions, X_("TogglePunch"), _("Punch In/Out"), sigc::mem_fun(*this, &ARDOUR_UI::toggle_punch));
+       act->set_short_label (_("In/Out"));
        ActionManager::session_sensitive_actions.push_back (act);
        ActionManager::transport_sensitive_actions.push_back (act);
        act = ActionManager::register_toggle_action (transport_actions, X_("ToggleClick"), _("Click"), sigc::mem_fun(*this, &ARDOUR_UI::toggle_click));
@@ -515,6 +522,13 @@ ARDOUR_UI::build_menu_bar ()
        // so use this instead ...
        gtk_settings_set_long_property (gtk_settings_get_default(), "gtk-can-change-accels", 1, "Ardour:designers");
 
+       EventBox* ev = manage (new EventBox);
+       ev->show ();
+       HBox* hbox = manage (new HBox);
+       hbox->show ();
+       
+       ev->add (*hbox);
+
        wall_clock_box.add (wall_clock_label);
        wall_clock_box.set_name ("WallClock");
        wall_clock_label.set_name ("WallClock");
@@ -522,18 +536,29 @@ ARDOUR_UI::build_menu_bar ()
        disk_space_box.add (disk_space_label);
        disk_space_box.set_name ("WallClock");
        disk_space_label.set_name ("WallClock");
+       disk_space_label.set_use_markup ();
 
        cpu_load_box.add (cpu_load_label);
        cpu_load_box.set_name ("CPULoad");
        cpu_load_label.set_name ("CPULoad");
+       cpu_load_label.set_use_markup ();
+       set_size_request_to_display_given_text (cpu_load_label, "DSP: 100.0%", 2, 2);
 
        buffer_load_box.add (buffer_load_label);
        buffer_load_box.set_name ("BufferLoad");
        buffer_load_label.set_name ("BufferLoad");
+       buffer_load_label.set_use_markup ();
+       set_size_request_to_display_given_text (buffer_load_label, "Buffers: p:100% c:100%", 2, 2);
 
        sample_rate_box.add (sample_rate_label);
        sample_rate_box.set_name ("SampleRate");
        sample_rate_label.set_name ("SampleRate");
+       sample_rate_label.set_use_markup ();
+
+       format_box.add (format_label);
+       format_box.set_name ("Format");
+       format_label.set_name ("Format");
+       format_label.set_use_markup ();
 
 #ifndef TOP_MENUBAR
        menu_hbox.pack_start (*menu_bar, false, false);
@@ -541,20 +566,37 @@ ARDOUR_UI::build_menu_bar ()
        use_menubar_as_top_menubar ();
 #endif
 
+       bool wall_clock = false;
+       bool disk_space = false;
+
        if (!Profile->get_small_screen()) {
 #ifndef GTKOSX
                // OSX provides its own wallclock, thank you very much
-               menu_hbox.pack_end (wall_clock_box, false, false, 2);
+               wall_clock = true;
 #endif
-               menu_hbox.pack_end (disk_space_box, false, false, 4);
+               disk_space = true;
        }
+       
+       hbox->pack_end (wall_clock_box, false, false, 2);
+       hbox->pack_end (disk_space_box, false, false, 4);
+       hbox->pack_end (cpu_load_box, false, false, 4);
+       hbox->pack_end (buffer_load_box, false, false, 4);
+       hbox->pack_end (sample_rate_box, false, false, 4);
+       hbox->pack_end (format_box, false, false, 4);
 
-       menu_hbox.pack_end (cpu_load_box, false, false, 4);
-       menu_hbox.pack_end (buffer_load_box, false, false, 4);
-       menu_hbox.pack_end (sample_rate_box, false, false, 4);
+       menu_hbox.pack_end (*ev, false, false);
 
        menu_bar_base.set_name ("MainMenuBar");
        menu_bar_base.add (menu_hbox);
+
+       _status_bar_visibility.add (&wall_clock_box,  X_("WallClock"), _("Wall Clock"), wall_clock);
+       _status_bar_visibility.add (&disk_space_box,  X_("Disk"),      _("Disk Space"), disk_space);
+       _status_bar_visibility.add (&cpu_load_box,    X_("DSP"),       _("DSP"));
+       _status_bar_visibility.add (&buffer_load_box, X_("Buffers"),   _("Buffers"));
+       _status_bar_visibility.add (&sample_rate_box, X_("JACK"),      _("JACK Sampling Rate and Latency"));
+       _status_bar_visibility.add (&format_box,      X_("Format"),    _("File Format"));
+
+       ev->signal_button_press_event().connect (sigc::mem_fun (_status_bar_visibility, &VisibilityGroup::button_press_event));
 }
 
 void
@@ -591,10 +633,9 @@ ARDOUR_UI::setup_clock ()
 
        big_clock_window->get()->set_keep_above (true);
        big_clock_window->get()->set_border_width (0);
-       big_clock_window->get()->add (big_clock);
+       big_clock_window->get()->add (*big_clock);
 
        big_clock_window->get()->set_title (_("Big Clock"));
-       big_clock_window->get()->set_type_hint (Gdk::WINDOW_TYPE_HINT_UTILITY);
        big_clock_window->get()->signal_realize().connect (sigc::mem_fun (*this, &ARDOUR_UI::big_clock_realized));
        big_clock_window->get()->signal_unmap().connect (sigc::bind (sigc::ptr_fun(&ActionManager::uncheck_toggleaction), X_("<Actions>/Common/ToggleBigClock")));
        big_clock_window->get()->signal_key_press_event().connect (sigc::bind (sigc::ptr_fun (relay_key_press), big_clock_window->get()), false);
@@ -614,9 +655,9 @@ ARDOUR_UI::big_clock_realized ()
        original_big_clock_height = big_clock_height;
        original_big_clock_width = w;
 
-       Pango::FontDescription fd (big_clock.get_style()->get_font());
+       Pango::FontDescription fd (big_clock->get_style()->get_font());
        original_big_clock_font_size = fd.get_size ();
-        
+
        if (!fd.get_size_is_absolute ()) {
                original_big_clock_font_size /= PANGO_SCALE;
        }
@@ -651,7 +692,7 @@ ARDOUR_UI::idle_big_clock_text_resizer (int, int)
        big_clock_resize_in_progress = false;
 
        Glib::RefPtr<Gdk::Window> win = big_clock_window->get()->get_window();
-       Pango::FontDescription fd (big_clock.get_style()->get_font());
+       Pango::FontDescription fd (big_clock->get_style()->get_font());
        int current_size = fd.get_size ();
        int x, y, w, h, d;
 
@@ -661,7 +702,7 @@ ARDOUR_UI::idle_big_clock_text_resizer (int, int)
 
        win->get_geometry (x, y, w, h, d);
 
-       double scale  = min (((double) w / (double) original_big_clock_width), 
+       double scale  = min (((double) w / (double) original_big_clock_width),
                             ((double) h / (double) original_big_clock_height));
 
        int size = (int) lrintf (original_big_clock_font_size * scale);
@@ -671,14 +712,14 @@ ARDOUR_UI::idle_big_clock_text_resizer (int, int)
                string family = fd.get_family();
                char buf[family.length()+16];
                snprintf (buf, family.length()+16, "%s %d", family.c_str(), size);
-                
-               try { 
+
+               try {
                        Pango::FontDescription fd (buf);
-                       Glib::RefPtr<Gtk::RcStyle> rcstyle = big_clock.get_modifier_style ();
+                       Glib::RefPtr<Gtk::RcStyle> rcstyle = big_clock->get_modifier_style ();
                        rcstyle->set_font (fd);
-                       big_clock.modify_style (rcstyle);
-               } 
-                
+                       big_clock->modify_style (rcstyle);
+               }
+
                catch (...) {
                        /* oh well, do nothing */
                }
@@ -703,13 +744,14 @@ ARDOUR_UI::save_ardour_state ()
        Config->add_extra_xml (get_transport_controllable_state());
 
        XMLNode* window_node = new XMLNode (X_("UI"));
+       window_node->add_property (_status_bar_visibility.get_state_name().c_str(), _status_bar_visibility.get_state_value ());
 
        for (list<WindowProxyBase*>::iterator i = _window_proxies.begin(); i != _window_proxies.end(); ++i) {
                if ((*i)->rc_configured()) {
                        window_node->add_child_nocopy (*((*i)->get_state ()));
                }
        }
-        
+
        /* tearoffs */
 
        XMLNode* tearoff_node = new XMLNode (X_("Tearoffs"));
@@ -718,20 +760,20 @@ ARDOUR_UI::save_ardour_state ()
                XMLNode* t = new XMLNode (X_("transport"));
                transport_tearoff->add_state (*t);
                tearoff_node->add_child_nocopy (*t);
-       } 
+       }
 
        if (mixer && mixer->monitor_section()) {
                XMLNode* t = new XMLNode (X_("monitor-section"));
                mixer->monitor_section()->tearoff().add_state (*t);
                tearoff_node->add_child_nocopy (*t);
-       } 
+       }
 
        if (editor && editor->mouse_mode_tearoff()) {
                XMLNode* t = new XMLNode (X_("mouse-mode"));
                editor->mouse_mode_tearoff ()->add_state (*t);
                tearoff_node->add_child_nocopy (*t);
-       } 
-        
+       }
+
        window_node->add_child_nocopy (*tearoff_node);
 
        Config->add_extra_xml (*window_node);
@@ -740,10 +782,12 @@ ARDOUR_UI::save_ardour_state ()
                Config->add_extra_xml (_startup->engine_control()->get_state());
        }
        Config->save_state();
-       ui_config->save_state ();
+       if (ui_config->dirty()) {
+               ui_config->save_state ();
+       }
 
-       XMLNode enode(static_cast<Stateful*>(editor)->get_state());
-       XMLNode mnode(mixer->get_state());
+       XMLNode& enode (static_cast<Stateful*>(editor)->get_state());
+       XMLNode& mnode (mixer->get_state());
 
        if (_session) {
                _session->add_instant_xml (enode);
@@ -760,7 +804,7 @@ void
 ARDOUR_UI::toggle_global_port_matrix (ARDOUR::DataType t)
 {
        std::string const action = string_compose ("toggle-%1-connection-manager", t.to_string ());
-       
+
        if (_global_port_matrix[t]->get() == 0) {
                _global_port_matrix[t]->set (new GlobalPortMatrixWindow (_session, t));
                _global_port_matrix[t]->get()->signal_unmap().connect(sigc::bind (sigc::ptr_fun (&ActionManager::uncheck_toggleaction), string_compose (X_("<Actions>/Common/%1"), action)));