Add support for scripted meta-templates.
[ardour.git] / gtk2_ardour / session_dialog.h
index 1a5d1a8386457dbad39bb7beb16659cf34fc199c..5f4062fc1bdd3a5badd783ec6e7472b761e8371f 100644 (file)
 
 class EngineControl;
 
-class SessionDialog : public ArdourDialog {
-  public:
-        SessionDialog (bool require_new, const std::string& session_name, const std::string& session_path, 
-                      const std::string& template_name, bool cancel_not_quit);
+class SessionDialog : public ArdourDialog
+{
+public:
+       SessionDialog (bool require_new, const std::string& session_name, const std::string& session_path,
+                      const std::string& template_name, bool cancel_not_quit);
+       SessionDialog ();
        ~SessionDialog ();
 
-        void clear_given ();
+       void clear_given ();
 
        std::string session_name (bool& should_be_new);
        std::string session_folder ();
-    
+
        bool use_session_template();
        std::string session_template_name();
 
@@ -75,71 +77,83 @@ class SessionDialog : public ArdourDialog {
        bool connect_outs_to_master() const;
        bool connect_outs_to_physical() const;
 
-  private:
+       void set_provided_session(const std::string& session_name, const std::string& session_path) {
+               _provided_session_name = session_name;
+               _provided_session_path = session_path;
+       }
+
+private:
        bool new_only;
-        std::string _provided_session_name;
-        std::string _provided_session_path;
+       std::string _provided_session_name;
+       std::string _provided_session_path;
 
        bool on_delete_event (GdkEventAny*);
 
-        Gtk::Button* cancel_button;
-        Gtk::Button* open_button;
-        Gtk::Button* back_button;
-        Gtk::Button* quit_button;
+       Gtk::Button* cancel_button;
+       Gtk::Button* open_button;
+       Gtk::Button* back_button;
+       Gtk::Button* quit_button;
 
-        bool back_button_pressed (GdkEventButton*);
+       bool back_button_pressed (GdkEventButton*);
+       bool open_button_pressed (GdkEventButton*);
 
-        Gtk::Frame info_frame;
+       Gtk::Frame info_frame;
 
        /* initial choice page */
 
        void setup_initial_choice_box ();
+       void setup_recent_sessions ();
        Gtk::VBox ic_vbox;
        Gtk::Button ic_new_session_button;
-        void new_session_button_clicked ();
+       void new_session_button_clicked ();
 
        /* recent sessions */
 
        void setup_existing_session_page ();
 
-       struct RecentSessionsSorter {
-           bool operator() (std::pair<std::string,std::string> a, std::pair<std::string,std::string> b) const {
-                   return ARDOUR::cmp_nocase(a.first, b.first) == -1;
-           }
+       struct RecentSessionsSorter
+       {
+               bool operator() (std::pair<std::string,std::string> a, std::pair<std::string,std::string> b) const {
+                       return ARDOUR::cmp_nocase(a.first, b.first) == -1;
+               }
        };
 
        struct RecentSessionModelColumns : public Gtk::TreeModel::ColumnRecord {
-           RecentSessionModelColumns() {
-                   add (visible_name);
-                   add (tip);
-                   add (fullpath);
-                   add (sample_rate);
-                   add (disk_format);
-                   add (time_modified);
-                   add (time_formatted);
-           }
-           Gtk::TreeModelColumn<std::string> visible_name;
-           Gtk::TreeModelColumn<std::string> tip;
-           Gtk::TreeModelColumn<std::string> fullpath;
-           Gtk::TreeModelColumn<std::string> sample_rate;
-           Gtk::TreeModelColumn<std::string> disk_format;
-           Gtk::TreeModelColumn<int64_t>     time_modified;
-           Gtk::TreeModelColumn<std::string> time_formatted;
+               RecentSessionModelColumns()
+               {
+                       add (visible_name);
+                       add (tip);
+                       add (fullpath);
+                       add (sample_rate);
+                       add (disk_format);
+                       add (time_modified);
+                       add (time_formatted);
+               }
+               Gtk::TreeModelColumn<std::string> visible_name;
+               Gtk::TreeModelColumn<std::string> tip;
+               Gtk::TreeModelColumn<std::string> fullpath;
+               Gtk::TreeModelColumn<std::string> sample_rate;
+               Gtk::TreeModelColumn<std::string> disk_format;
+               Gtk::TreeModelColumn<int64_t>     time_modified;
+               Gtk::TreeModelColumn<std::string> time_formatted;
        };
 
        RecentSessionModelColumns    recent_session_columns;
        Gtk::TreeView                recent_session_display;
        Glib::RefPtr<Gtk::TreeStore> recent_session_model;
        Gtk::ScrolledWindow          recent_scroller;
-        Gtk::Label                   recent_label;
+       Gtk::Label                   recent_label;
        Gtk::FileChooserButton       existing_session_chooser;
        int redisplay_recent_sessions ();
        void recent_session_row_selected ();
        void recent_session_sort_changed ();
        void recent_row_activated (const Gtk::TreePath& path, Gtk::TreeViewColumn* col);
+       bool recent_button_press (GdkEventButton*);
+       void recent_context_mennu (GdkEventButton*);
+       void recent_remove_selected ();
 
        void existing_session_selected ();
-        void session_selected ();
+       void session_selected ();
 
        /* new sessions */
 
@@ -151,10 +165,12 @@ class SessionDialog : public ArdourDialog {
                SessionTemplateColumns () {
                        add (name);
                        add (path);
+                       add (desc);
                }
 
                Gtk::TreeModelColumn<std::string> name;
                Gtk::TreeModelColumn<std::string> path;
+               Gtk::TreeModelColumn<std::string> desc;
        };
 
        SessionTemplateColumns session_template_columns;
@@ -165,7 +181,9 @@ class SessionDialog : public ArdourDialog {
        Gtk::VBox session_existing_vbox;
        Gtk::Expander more_new_session_options_button;
        Gtk::CheckButton use_template_button;
-        std::string load_template_override;
+       std::string load_template_override;
+
+       void template_checkbox_toggled ();
 
        void more_new_session_options_button_clicked();
        void new_name_changed ();
@@ -229,6 +247,10 @@ class SessionDialog : public ArdourDialog {
        void master_bus_button_clicked ();
        void setup_more_options_box ();
 
+       /* --disable plugins UI */
+       Gtk::CheckButton _disable_plugins;
+       void disable_plugins_clicked ();
+
        /* always there */
 
        Glib::RefPtr<Pango::Layout> layout;
@@ -236,10 +258,10 @@ class SessionDialog : public ArdourDialog {
        bool _existing_session_chooser_used; ///< set to true when the existing session chooser has been used
 
        Gtk::Label info_scroller_label;
-        std::string::size_type info_scroller_count;
-        bool info_scroller_update();
+       std::string::size_type info_scroller_count;
+       bool info_scroller_update();
        sigc::connection info_scroller_connection;
-        void updates_button_clicked ();
+       void updates_button_clicked ();
 };
 
 #endif /* __gtk2_ardour_session_dialog_h__ */