missing initialization
[ardour.git] / gtk2_ardour / startup.h
index 96adf954ba3c450ff0e9569fc6b5112f0ea0c4fb..4dcc3a9fb217beac9c4dcd3c5cfc0aff749c59f9 100644 (file)
@@ -1,3 +1,22 @@
+/*
+    Copyright (C) 2010 Paul Davis
+
+    This program is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
+
+    This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with this program; if not, write to the Free Software
+    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
 #ifndef __gtk2_ardour_startup_h__
 #define __gtk2_ardour_startup_h__
 
 #include <gtkmm/treeview.h>
 #include <gtkmm/treestore.h>
 #include <gtkmm/checkbutton.h>
+#include <gtkmm/table.h>
+#include <gtkmm/frame.h>
+#include <gtkmm/spinbutton.h>
+#include <gtkmm/liststore.h>
+#include <gtkmm/combobox.h>
+
+#include "ardour/utils.h"
+
+class EngineControl;
 
 class ArdourStartup : public Gtk::Assistant {
   public:
-       ArdourStartup ();
+        ArdourStartup (bool require_new, const std::string& session_name, const std::string& session_path, const std::string& template_name);
        ~ArdourStartup ();
 
+        bool ready_without_display () const;
+
+       std::string session_name (bool& should_be_new);
+       std::string session_folder ();
+
+       bool use_session_template();
+       std::string session_template_name();
+
+       // advanced session options
+
+       bool create_master_bus() const;
+       int master_channel_count() const;
+
+       bool connect_inputs() const;
+       bool limit_inputs_used_for_connection() const;
+       int input_limit_count() const;
+
+       bool connect_outputs() const;
+       bool limit_outputs_used_for_connection() const;
+       int output_limit_count() const;
+
+       bool connect_outs_to_master() const;
+       bool connect_outs_to_physical() const;
+
+       gint response () const {
+               return  _response;
+       }
+
   private:
-       bool applying;
+       gint _response;
+       bool config_modified;
+       bool new_user;
+        bool need_session_info;
+       bool new_only;
+        std::string _provided_session_name;
+        std::string _provided_session_path;
+
+       std::string been_here_before_path () const;
 
        void on_apply ();
        void on_cancel ();
-       void on_close ();
+       bool on_delete_event (GdkEventAny*);
        void on_prepare (Gtk::Widget*);
 
        static ArdourStartup *the_startup;
@@ -38,8 +102,11 @@ class ArdourStartup : public Gtk::Assistant {
        bool splash_expose (GdkEventExpose* ev);
 
        void setup_first_time_config_page ();
+        void config_changed ();
 
        /* first page */
+       Gtk::FileChooserButton* default_dir_chooser;
+       void default_dir_changed();
        void setup_first_page ();
 
        /* initial choice page */
@@ -48,6 +115,8 @@ class ArdourStartup : public Gtk::Assistant {
        Gtk::VBox ic_vbox;
        Gtk::RadioButton ic_new_session_button;
        Gtk::RadioButton ic_existing_session_button;
+        bool initial_button_clicked(GdkEventButton*);
+       void initial_button_activated();
 
        /* monitoring choices */
 
@@ -57,16 +126,24 @@ class ArdourStartup : public Gtk::Assistant {
        Gtk::RadioButton monitor_via_ardour_button;
        void setup_monitoring_choice_page ();
 
+       /* monitor section choices */
+
+       Gtk::VBox mon_sec_vbox;
+       Gtk::Label monitor_section_label;
+       Gtk::RadioButton use_monitor_section_button;
+       Gtk::RadioButton no_monitor_section_button;
+       void setup_monitor_section_choice_page ();
+
        /* session page (could be new or existing) */
 
        void setup_session_page ();
        Gtk::VBox session_vbox;
        Gtk::HBox session_hbox;
-       
+
        /* 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 cmp_nocase(a.first, b.first) == -1;
@@ -76,18 +153,24 @@ class ArdourStartup : public Gtk::Assistant {
        struct RecentSessionModelColumns : public Gtk::TreeModel::ColumnRecord {
            RecentSessionModelColumns() {
                    add (visible_name);
+                   add (tip);
                    add (fullpath);
            }
-           Gtk::TreeModelColumn<Glib::ustring> visible_name;
-           Gtk::TreeModelColumn<Glib::ustring> fullpath;
+           Gtk::TreeModelColumn<std::string> visible_name;
+           Gtk::TreeModelColumn<std::string> tip;
+           Gtk::TreeModelColumn<std::string> fullpath;
        };
 
        RecentSessionModelColumns    recent_session_columns;
        Gtk::TreeView                recent_session_display;
        Glib::RefPtr<Gtk::TreeStore> recent_session_model;
        Gtk::ScrolledWindow          recent_scroller;
-       void redisplay_recent_sessions ();
+       Gtk::FileChooserButton       existing_session_chooser;
+       int redisplay_recent_sessions ();
        void recent_session_row_selected ();
+       void recent_row_activated (const Gtk::TreePath& path, Gtk::TreeViewColumn* col);
+
+       void existing_session_selected ();
 
        /* new sessions */
 
@@ -95,16 +178,88 @@ class ArdourStartup : public Gtk::Assistant {
        Gtk::Entry new_name_entry;
        Gtk::FileChooserButton new_folder_chooser;
        Gtk::FileChooserButton session_template_chooser;
+
+       struct SessionTemplateColumns : public Gtk::TreeModel::ColumnRecord {
+               SessionTemplateColumns () {
+                       add (name);
+                       add (path);
+               }
+
+               Gtk::TreeModelColumn<std::string> name;
+               Gtk::TreeModelColumn<std::string> path;
+       };
+
+       SessionTemplateColumns session_template_columns;
+       Glib::RefPtr<Gtk::ListStore>  template_model;
+       Gtk::ComboBox template_chooser;
+
        Gtk::VBox session_new_vbox;
+       Gtk::VBox session_existing_vbox;
        Gtk::CheckButton more_new_session_options_button;
+       Gtk::RadioButtonGroup session_template_group;
+       Gtk::RadioButton use_session_as_template_button;
+       Gtk::RadioButton use_template_button;
+        std::string load_template_override;
 
        void more_new_session_options_button_clicked();
        void new_name_changed ();
+       void populate_session_templates ();
 
        /* more options for new sessions */
 
        Gtk::VBox more_options_vbox;
-       Gtk::HBox more_options_hbox;
+
+       Gtk::Label chan_count_label_1;
+       Gtk::Label chan_count_label_3;
+       Gtk::Label chan_count_label_4;
+       Gtk::Table advanced_table;
+       Gtk::HBox input_port_limit_hbox;
+       Gtk::VBox input_port_vbox;
+       Gtk::Table input_table;
+       Gtk::HBox input_hbox;
+
+       Gtk::Label bus_label;
+       Gtk::Frame bus_frame;
+       Gtk::Table bus_table;
+       Gtk::HBox bus_hbox;
+
+       Gtk::Label input_label;
+       Gtk::Frame input_frame;
+       Gtk::HBox output_port_limit_hbox;
+       Gtk::VBox output_port_vbox;
+       Gtk::VBox output_conn_vbox;
+       Gtk::VBox output_vbox;
+       Gtk::HBox output_hbox;
+
+       Gtk::Label output_label;
+       Gtk::Frame output_frame;
+       Gtk::VBox advanced_vbox;
+       Gtk::Label advanced_label;
+
+       Gtk::CheckButton _create_master_bus;
+       Gtk::SpinButton _master_bus_channel_count;
+
+       Gtk::CheckButton _connect_inputs;
+       Gtk::CheckButton _limit_input_ports;
+       Gtk::SpinButton _input_limit_count;
+
+       Gtk::CheckButton _connect_outputs;
+       Gtk::CheckButton _limit_output_ports;
+       Gtk::SpinButton _output_limit_count;
+
+       Gtk::RadioButtonGroup connect_outputs_group;
+       Gtk::RadioButton _connect_outputs_to_master;
+       Gtk::RadioButton _connect_outputs_to_physical;
+
+       Gtk::Adjustment _output_limit_count_adj;
+       Gtk::Adjustment _input_limit_count_adj;
+       Gtk::Adjustment _master_bus_channel_count_adj;
+
+       void connect_inputs_clicked ();
+       void connect_outputs_clicked ();
+       void limit_inputs_clicked ();
+       void limit_outputs_clicked ();
+       void master_bus_button_clicked ();
        void setup_more_options_page ();
 
        /* final page */
@@ -116,8 +271,28 @@ class ArdourStartup : public Gtk::Assistant {
 
        Glib::RefPtr<Pango::Layout> layout;
 
+       /* page indices */
+
+       gint audio_page_index;
+       gint new_user_page_index;
+       gint default_folder_page_index;
+       gint monitoring_page_index;
+       gint monitor_section_page_index;
+       gint session_page_index;
+       gint initial_choice_index;
+       gint final_page_index;
+       gint session_options_page_index;
+
+       void move_along_now ();
 
+       bool _existing_session_chooser_used; ///< set to true when the existing session chooser has been used
+        void setup_prerelease_page ();
 
+       Gtk::Label info_scroller_label;
+        std::string::size_type info_scroller_count;
+        bool info_scroller_update();
+       sigc::connection info_scroller_connection;
+        void updates_button_clicked ();
 };
 
 #endif /* __gtk2_ardour_startup_h__ */