X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fstartup.h;h=19cb1b609d4693d4bac6ca7ad526c3744f714299;hb=d7deaa21bb78222e25b820c9583942a47dbc8fac;hp=ae4b17b1632d5acf876b6229369d9144b120cbfb;hpb=7689d72875e77e15c87f6c49e8a509cd37925435;p=ardour.git diff --git a/gtk2_ardour/startup.h b/gtk2_ardour/startup.h index ae4b17b163..19cb1b609d 100644 --- a/gtk2_ardour/startup.h +++ b/gtk2_ardour/startup.h @@ -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__ @@ -20,6 +39,8 @@ #include #include +#include "pbd/filesystem.h" + #include "ardour/utils.h" class EngineControl; @@ -30,12 +51,13 @@ class ArdourStartup : public Gtk::Assistant { ~ArdourStartup (); void set_new_only (bool); + void set_load_template( std::string load_template ); - Glib::ustring session_name (bool& should_be_new); - Glib::ustring session_folder (); + std::string session_name (bool& should_be_new); + std::string session_folder (); bool use_session_template(); - Glib::ustring session_template_name(); + std::string session_template_name(); EngineControl* engine_control() { return engine_dialog; } @@ -55,7 +77,7 @@ class ArdourStartup : public Gtk::Assistant { bool connect_outs_to_master() const; bool connect_outs_to_physical() const; - gint response () const { + gint response () const { return _response; } @@ -65,6 +87,8 @@ class ArdourStartup : public Gtk::Assistant { bool new_user; bool new_only; + PBD::sys::path been_here_before_path () const; + void on_apply (); void on_cancel (); bool on_delete_event (GdkEventAny*); @@ -80,6 +104,7 @@ 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; @@ -90,9 +115,9 @@ class ArdourStartup : public Gtk::Assistant { void setup_initial_choice_page (); Gtk::VBox ic_vbox; - Gtk::RadioButton ic_new_session_button; - Gtk::RadioButton ic_existing_session_button; + Gtk::CheckButton ic_new_session_button; bool initial_button_press(GdkEventButton *); + void initial_button_clicked (); void initial_button_activated(); /* monitoring choices */ @@ -111,15 +136,11 @@ class ArdourStartup : public Gtk::Assistant { 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 */ + /* new session page */ - void setup_existing_session_page (); + void setup_new_session_page (); + Gtk::VBox new_session_vbox; + Gtk::HBox new_session_hbox; struct RecentSessionsSorter { bool operator() (std::pair a, std::pair b) const { @@ -132,18 +153,21 @@ class ArdourStartup : public Gtk::Assistant { add (visible_name); add (fullpath); } - Gtk::TreeModelColumn visible_name; - Gtk::TreeModelColumn fullpath; + Gtk::TreeModelColumn visible_name; + Gtk::TreeModelColumn fullpath; }; RecentSessionModelColumns recent_session_columns; Gtk::TreeView recent_session_display; Glib::RefPtr recent_session_model; Gtk::ScrolledWindow recent_scroller; + 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 (); + /* audio setup page */ void setup_audio_page (); @@ -151,10 +175,10 @@ class ArdourStartup : public Gtk::Assistant { /* new sessions */ - void setup_new_session_page (); Gtk::Entry new_name_entry; Gtk::FileChooserButton new_folder_chooser; Gtk::FileChooserButton session_template_chooser; + void new_name_mapped (); struct SessionTemplateColumns : public Gtk::TreeModel::ColumnRecord { SessionTemplateColumns () { @@ -171,10 +195,12 @@ class ArdourStartup : public Gtk::Assistant { 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 (); @@ -253,13 +279,15 @@ class ArdourStartup : public Gtk::Assistant { gint default_folder_page_index; gint monitoring_page_index; gint monitor_section_page_index; - gint session_page_index; + gint new_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 (); }; #endif /* __gtk2_ardour_startup_h__ */