Add missing files.
[ardour.git] / gtk2_ardour / ardour_ui.h
index 283bcbe915353ecaaf47d6e8eee012ba8acf0ff9..025039156e5677ab484ecba67462ffe90452e59e 100644 (file)
 #include "ardour/utils.h"
 #include "ardour/session_handle.h"
 
-#include "audio_clock.h"
 #include "ardour_dialog.h"
 #include "editing.h"
 #include "ui_config.h"
 #include "window_proxy.h"
+#include "enums.h"
+#include "visibility_group.h"
 
 class About;
 class AddRouteDialog;
@@ -87,9 +88,11 @@ class ShuttleControl;
 class Splash;
 class SpeakerDialog;
 class ThemeManager;
+class TimeInfoBox;
 class MidiTracer;
 class WindowProxyBase;
 class GlobalPortMatrixWindow;
+class GUIObjectState;
 
 namespace Gtkmm2ext {
        class TearOff;
@@ -193,10 +196,14 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
        void xrun_handler (framepos_t);
        void create_xrun_marker (framepos_t);
 
-       AudioClock primary_clock;
-       AudioClock secondary_clock;
-       AudioClock preroll_clock;
-       AudioClock postroll_clock;
+       GUIObjectState* gui_object_state;
+
+       AudioClock* primary_clock;
+       AudioClock* secondary_clock;
+       AudioClock* preroll_clock;
+       AudioClock* postroll_clock;
+
+       TimeInfoBox* time_info_box;
 
        void store_clock_modes ();
        void restore_clock_modes ();
@@ -214,7 +221,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
                uint32_t how_many,
                std::string const & name_template
                ) {
-               
+
                session_add_audio_route (true, input_channels, output_channels, mode, route_group, how_many, name_template);
        }
 
@@ -225,7 +232,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
                uint32_t how_many,
                std::string const & name_template
                ) {
-               
+
                session_add_audio_route (false, input_channels, output_channels, ARDOUR::Normal, route_group, how_many, name_template);
        }
 
@@ -234,7 +241,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
                uint32_t how_many,
                std::string const & name_template
                ) {
-               
+
                session_add_midi_route (true, route_group, how_many, name_template);
        }
 
@@ -337,7 +344,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
 
        void manage_window (Gtk::Window&);
 
-       AudioClock   big_clock;
+       AudioClock*   big_clock;
        ActionWindowProxy<Gtk::Window>* big_clock_window;
        int original_big_clock_width;
        int original_big_clock_height;
@@ -396,8 +403,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
            void set_value (double);
            double get_value (void) const;
 
-           void set_id (const std::string&);
-
            ARDOUR_UI& ui;
            ToggleType type;
        };
@@ -430,8 +435,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
 
        ShuttleControl* shuttle_box;
 
-       Gtkmm2ext::StatefulToggleButton punch_in_button;
-       Gtkmm2ext::StatefulToggleButton punch_out_button;
        Gtkmm2ext::StatefulToggleButton auto_return_button;
        Gtkmm2ext::StatefulToggleButton auto_play_button;
        Gtkmm2ext::StatefulToggleButton auto_input_button;
@@ -520,6 +523,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
        Gtk::EventBox sample_rate_box;
        void update_sample_rate (ARDOUR::framecnt_t);
 
+       Gtk::Label    format_label;
+       Gtk::EventBox format_box;
+       void update_format ();
+       
        gint every_second ();
        gint every_point_one_seconds ();
        gint every_point_zero_one_seconds ();
@@ -571,6 +578,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
        guint32  last_key_press_time;
 
        void snapshot_session (bool switch_to_it);
+       void rename_session ();
 
        Mixer_UI   *mixer;
        int         create_mixer ();
@@ -611,7 +619,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
        /* Keyboard Handling */
 
        ArdourKeyboard* keyboard;
-       
+
        /* Keymap handling */
 
        void install_actions ();
@@ -673,6 +681,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
        void toggle_use_osc ();
 
        void parameter_changed (std::string);
+       void session_parameter_changed (std::string);
 
        bool first_idle ();
 
@@ -698,10 +707,14 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
 
         void step_edit_status_change (bool);
 
+       void platform_specific ();
+       void platform_setup ();
+
        /* these are used only in response to a platform-specific "ShouldQuit" signal
         */
        bool idle_finish ();
        void queue_finish ();
+       void fontconfig_dialog ();
 
        std::list<WindowProxyBase*> _window_proxies;
 
@@ -709,6 +722,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
         int ambiguous_file (std::string file, std::string path, std::vector<std::string> hits);
 
        bool click_button_clicked (GdkEventButton *);
+
+       VisibilityGroup _status_bar_visibility;
 };
 
 #endif /* __ardour_gui_h__ */