correct check for presence of / or \ in a session name
[ardour.git] / gtk2_ardour / option_editor.h
index 81372f577549fa696ad481439696ee1c3dfda197..ed6d752e6e6bfe1e082950159dadaeaedbdb9e3e 100644 (file)
@@ -1,3 +1,6 @@
+#ifndef __gtk_ardour_option_editor_h__
+#define __gtk_ardour_option_editor_h__
+
 /*
     Copyright (C) 2001 Paul Davis 
 
@@ -17,8 +20,7 @@
 
 */
 
-#ifndef __gtk_ardour_option_editor_h__
-#define __gtk_ardour_option_editor_h__
+#include <vector>
 
 #include <gtkmm/notebook.h>
 #include <gtkmm/checkbutton.h>
@@ -45,7 +47,7 @@ class IOSelector;
 class GainMeter;
 class PannerUI;
 
-class OptionEditor : public Gtk::Dialog
+class OptionEditor : public ArdourDialog
 {
   public:
        OptionEditor (ARDOUR_UI&, PublicEditor&, Mixer_UI&);
@@ -66,6 +68,7 @@ class OptionEditor : public Gtk::Dialog
 
        gint wm_close (GdkEventAny *);
        bool focus_out_event_handler (GdkEventFocus*, void (OptionEditor::*pmf)());
+       void parameter_changed (const char* name);
 
        /* paths */
 
@@ -77,18 +80,32 @@ class OptionEditor : public Gtk::Dialog
        void remove_session_paths ();
        void raid_path_changed ();
 
-       /* fades */
+       /* misc */
+
+       Gtk::VBox        misc_packer;
 
-       Gtk::VBox        fade_packer;
        Gtk::Adjustment  short_xfade_adjustment;
        Gtk::HScale      short_xfade_slider;
        Gtk::Adjustment  destructo_xfade_adjustment;
        Gtk::HScale      destructo_xfade_slider;
 
-       void setup_fade_options();
+       void setup_misc_options();
+
        void short_xfade_adjustment_changed ();
        void destructo_xfade_adjustment_changed ();
 
+       Gtk::Adjustment history_depth;
+       Gtk::Adjustment saved_history_depth;
+       Gtk::SpinButton     history_depth_spinner;
+       Gtk::SpinButton     saved_history_depth_spinner;
+       Gtk::CheckButton    limit_history_button;
+       Gtk::CheckButton    save_history_button;
+
+       void history_depth_changed();
+       void saved_history_depth_changed();
+       void save_history_toggled ();
+       void limit_history_toggled ();
+
        /* Sync */
 
        Gtk::VBox sync_packer;
@@ -96,11 +113,13 @@ class OptionEditor : public Gtk::Dialog
        Gtk::ComboBoxText slave_type_combo;
        AudioClock smpte_offset_clock;
        Gtk::CheckButton smpte_offset_negative_button;
+       Gtk::CheckButton synced_timecode_button;
 
        void setup_sync_options ();
 
        void smpte_offset_chosen ();
        void smpte_offset_negative_clicked ();
+       void synced_timecode_toggled ();
 
        /* MIDI */
 
@@ -112,9 +131,13 @@ class OptionEditor : public Gtk::Dialog
 
        Gtk::Table      midi_port_table;
        std::vector<Gtk::Widget*> midi_port_table_widgets;
-       Gtk::Adjustment mmc_device_id_adjustment;
-       Gtk::SpinButton mmc_device_id_spinner;
+       Gtk::Adjustment mmc_receive_device_id_adjustment;
+       Gtk::SpinButton mmc_receive_device_id_spinner;
+       Gtk::Adjustment mmc_send_device_id_adjustment;
+       Gtk::SpinButton mmc_send_device_id_spinner;
        Gtk::Button     add_midi_port_button;
+       Gtk::Adjustment initial_program_change_adjustment;
+       Gtk::SpinButton initial_program_change_spinner;
 
        void add_midi_port ();
        void remove_midi_port (MIDI::Port*);
@@ -129,7 +152,10 @@ class OptionEditor : public Gtk::Dialog
        void midi_port_chosen (MIDI::Port*,Gtk::RadioButton*, Gtk::Button*);
        bool port_removable (MIDI::Port*);
 
-       void mmc_device_id_adjusted ();
+       void mmc_receive_device_id_adjusted ();
+       void mmc_send_device_id_adjusted ();
+
+       void initial_program_change_adjusted ();
 
        void map_port_online (MIDI::Port*, Gtk::ToggleButton*);
 
@@ -148,6 +174,8 @@ class OptionEditor : public Gtk::Dialog
        IOSelector*   click_io_selector;
        GainMeter* click_gpm;
        PannerUI*     click_panner;
+       bool          first_click_setup;
+       Gtk::HBox     click_hpacker;
        Gtk::VBox     click_packer;
        Gtk::Table    click_table;
        Gtk::Entry    click_path_entry;
@@ -183,6 +211,7 @@ class OptionEditor : public Gtk::Dialog
        /* keyboard/mouse */
 
        Gtk::Table keyboard_mouse_table;
+       Gtk::ComboBoxText keyboard_layout_selector;
        Gtk::ComboBoxText edit_modifier_combo;
        Gtk::ComboBoxText delete_modifier_combo;
        Gtk::ComboBoxText snap_modifier_combo;
@@ -191,14 +220,15 @@ class OptionEditor : public Gtk::Dialog
        Gtk::Adjustment edit_button_adjustment;
        Gtk::SpinButton edit_button_spin;
 
+       std::map<std::string,std::string> bindings_files;
+
        void setup_keyboard_options ();
        void delete_modifier_chosen ();
        void edit_modifier_chosen ();
        void snap_modifier_chosen ();
        void edit_button_changed ();
        void delete_button_changed ();
-
-       void fixup_combo_size (Gtk::ComboBoxText&, std::vector<std::string>& strings);
+       void bindings_changed ();
 };
 
 #endif /* __gtk_ardour_option_editor_h__ */