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();
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);
- }
- 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;
+ 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 */
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;
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 ();
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;
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__ */