Remove unused variable and the accessor methods for it from ARDOUR_UI
[ardour.git] / gtk2_ardour / new_session_dialog.h
index 79e7000ee73b81d53c09e2cbbcf79ce8b56cc4f4..2a2081e56a5d58cd21257b593561932906d48f39 100644 (file)
@@ -15,7 +15,6 @@
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-    $Id$
 */
 
 // -*- c++ -*-
 #define NEW_SESSION_DIALOG_H
 
 #include <string>
-#include <gtkmm.h>
-
-#include "glade_factory.h"
-
-struct NewSessionDialogFactory : public GladeFactory
-{
-       static GladeRef create();
-
-       static const char* top_level_widget_name();
-
-private:
-
-       static const char* s_m_top_level_widget_name;
-       
-};
-
-class NewSessionDialog : public Gtk::Dialog
+#include <gtkmm/treeview.h>
+#include <gtkmm/treestore.h>
+#include <gtkmm/treepath.h>
+#include <gtkmm/scrolledwindow.h>
+#include <gtkmm/notebook.h>
+#include <gtkmm/table.h>
+#include <gtkmm/alignment.h>
+#include <gtkmm/frame.h>
+#include <gtkmm/expander.h>
+
+#include <ardour/utils.h>
+
+#include <glibmm/refptr.h>
+
+#include "ardour_dialog.h"
+
+namespace Gtk {
+       class Entry;
+       class FileChooserButton;
+       class SpinButton;
+       class CheckButton;
+       class RadioButton;
+       class TreeView;
+       class Notebook;
+}
+
+class NewSessionDialog : public ArdourDialog
 {
 public:
                
-       NewSessionDialog(BaseObjectType* cobject,
-                        const Glib::RefPtr<Gnome::Glade::Xml>& xml);
+       NewSessionDialog();
 
        void set_session_name(const Glib::ustring& name);
 
@@ -57,10 +65,10 @@ public:
 
        // advanced.
 
-       bool create_master_track() const;
-               int master_channel_count() const;
+       bool create_master_bus() const;
+       int master_channel_count() const;
 
-       bool create_control_track() const;
+       bool create_control_bus() const;
        int control_channel_count() const;
 
        bool connect_inputs() const;
@@ -74,25 +82,67 @@ public:
        bool connect_outs_to_master() const;
        bool connect_outs_to_physical() const ;
 
-protected:
-
-       void reset_name();
-       void reset_template();
+       bool on_new_session_page () const;
        
+       void set_current_page (int);
+       void reset_recent();
+
        // reset everything to default values.
        void reset();
 
-       // references to widgets we care about.
+protected:
 
+       void reset_name();
+       void reset_template();
+
+       Gtk::Label * session_name_label;
+       Gtk::Label * session_location_label;
+       Gtk::Label * session_template_label;
+       Gtk::Label * chan_count_label_1;
+       Gtk::Label * chan_count_label_2;
+       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::Expander * advanced_expander;
+       Gtk::Table * new_session_table;
+       Gtk::HBox * open_session_hbox;
+       Gtk::ScrolledWindow * recent_scrolledwindow;
+
+       Gtk::Label * recent_sesion_label;
+       Gtk::Frame * recent_frame;
+       Gtk::VBox * open_session_vbox;
        Gtk::Entry*  m_name;
        Gtk::FileChooserButton* m_folder;
        Gtk::FileChooserButton* m_template;
-       
-       Gtk::CheckButton* m_create_master_track;
-       Gtk::SpinButton* m_master_track_channel_count;
+       Gtk::Label * open_session_file_label;
+
+       Gtk::CheckButton* m_create_master_bus;
+       Gtk::SpinButton* m_master_bus_channel_count;
                
-       Gtk::CheckButton* m_create_control_track;
-       Gtk::SpinButton* m_control_track_channel_count;
+       Gtk::CheckButton* m_create_control_bus;
+       Gtk::SpinButton* m_control_bus_channel_count;
 
        Gtk::CheckButton* m_connect_inputs;
        Gtk::CheckButton* m_limit_input_ports;
@@ -104,7 +154,46 @@ protected:
 
        Gtk::RadioButton* m_connect_outputs_to_master;
        Gtk::RadioButton* m_connect_outputs_to_physical;
-       
+       Gtk::Button* m_okbutton;
+
+       Gtk::FileChooserButton* m_open_filechooser;
+       Gtk::TreeView* m_treeview;
+       Gtk::Notebook* m_notebook;
+
+ private:
+       struct RecentSessionModelColumns : public Gtk::TreeModel::ColumnRecord {
+           RecentSessionModelColumns() { 
+                   add (visible_name);
+                   add (fullpath);
+           }
+         Gtk::TreeModelColumn<std::string> visible_name;
+         Gtk::TreeModelColumn<std::string> fullpath;
+       };
+
+       RecentSessionModelColumns    recent_columns;
+       Glib::RefPtr<Gtk::TreeStore> recent_model;
+
+       void recent_session_selection_changed ();
+       void nsd_redisplay_recent_sessions();
+       void nsd_recent_session_row_activated (const Gtk::TreePath& path, Gtk::TreeViewColumn* col);
+       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;
+           }
+       };
+       void on_new_session_name_entry_changed();
+       void notebook_page_changed (GtkNotebookPage*, uint);
+       void treeview_selection_changed ();
+       void file_chosen ();
+       void template_chosen ();
+       void recent_row_activated (const Gtk::TreePath&, Gtk::TreeViewColumn*);
+       void connect_inputs_clicked ();
+       void connect_outputs_clicked ();
+       void limit_inputs_clicked ();
+       void limit_outputs_clicked ();
+       void master_bus_button_clicked ();
+       void monitor_bus_button_clicked ();
+
 };
 
 #endif // NEW_SESSION_DIALOG_H