X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fexport_filename_selector.h;h=a1a19b0bc7528b0609ec53c0dc695b212ef8d468;hb=05149f9bc54d0cfb8b162ba7cfac975b5eb79971;hp=a6c36da83d31b0750927ac3a97dafcdf39a7454b;hpb=bb9cc45cd22af67ac275a5e73accbe14fee664d8;p=ardour.git diff --git a/gtk2_ardour/export_filename_selector.h b/gtk2_ardour/export_filename_selector.h index a6c36da83d..a1a19b0bc7 100644 --- a/gtk2_ardour/export_filename_selector.h +++ b/gtk2_ardour/export_filename_selector.h @@ -25,13 +25,11 @@ #include "ardour/export_profile_manager.h" #include "ardour/export_filename.h" - -namespace ARDOUR { - class Session; -} +#include "ardour/session_handle.h" /// -class ExportFilenameSelector : public Gtk::VBox { +class ExportFilenameSelector : public Gtk::VBox, public ARDOUR::SessionHandlePtr +{ public: typedef boost::shared_ptr FilenamePtr; @@ -39,6 +37,8 @@ class ExportFilenameSelector : public Gtk::VBox { ~ExportFilenameSelector (); void set_state (ARDOUR::ExportProfileManager::FilenameStatePtr state_, ARDOUR::Session * session_); + void set_example_filename (std::string filename); + void require_timespan (bool); /* Compatibility with other elements */ @@ -50,17 +50,19 @@ class ExportFilenameSelector : public Gtk::VBox { void update_label (); void update_folder (); + void check_folder (); void change_date_format (); void change_time_format (); void change_session_selection (); + void change_timespan_selection (); void change_revision_selection (); void change_revision_value (); void open_browse_dialog (); + void open_folder (); - ARDOUR::Session * session; boost::shared_ptr filename; Glib::RefPtr label_sizegroup; @@ -72,7 +74,8 @@ class ExportFilenameSelector : public Gtk::VBox { Gtk::Label label_label; Gtk::Entry label_entry; - Gtk::CheckButton session_checkbox; + Gtk::ComboBoxText session_snap_name; + Gtk::CheckButton timespan_checkbox; Gtk::CheckButton revision_checkbox; Gtk::SpinButton revision_spinbutton; @@ -82,6 +85,8 @@ class ExportFilenameSelector : public Gtk::VBox { Gtk::Label path_label; Gtk::Entry path_entry; Gtk::Button browse_button; + Gtk::Button open_button; + Gtk::Label example_filename_label; /* Date combo */ @@ -91,7 +96,7 @@ class ExportFilenameSelector : public Gtk::VBox { { public: Gtk::TreeModelColumn format; - Gtk::TreeModelColumn label; + Gtk::TreeModelColumn label; DateFormatCols () { add(format); add(label); } }; @@ -107,7 +112,7 @@ class ExportFilenameSelector : public Gtk::VBox { { public: Gtk::TreeModelColumn format; - Gtk::TreeModelColumn label; + Gtk::TreeModelColumn label; TimeFormatCols () { add(format); add(label); } }; @@ -115,6 +120,9 @@ class ExportFilenameSelector : public Gtk::VBox { Glib::RefPtr time_format_list; Gtk::ComboBox time_format_combo; + /* timespan logic */ + void update_timespan_sensitivity (); + bool _require_timespan; }; #endif /* __export_filename_selector_h__ */