X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fadd_route_dialog.h;h=381bebee4457bdfb7fd6967ae12cef4a8a3a9d1b;hb=a58f7caca133af3ce68f9a1e6aa9c50f61a1bc28;hp=f2e2168f14ef2e72fc7fa08bbc1d883b5004fd0d;hpb=d70429a066dfd33cca0b6f64be7014649a9910ca;p=ardour.git diff --git a/gtk2_ardour/add_route_dialog.h b/gtk2_ardour/add_route_dialog.h index f2e2168f14..381bebee44 100644 --- a/gtk2_ardour/add_route_dialog.h +++ b/gtk2_ardour/add_route_dialog.h @@ -31,55 +31,83 @@ #include #include #include +#include #include +#include +#include #include +#include #include "ardour/plugin.h" #include "ardour/types.h" #include "ardour/template_utils.h" #include "ardour_dialog.h" +#include "instrument_selector.h" +#include "route_dialogs.h" class Editor; +class RouteGroupDialog; class AddRouteDialog : public ArdourDialog { - public: - AddRouteDialog (ARDOUR::Session*); +public: + AddRouteDialog (); ~AddRouteDialog (); - enum TypeWanted { + enum ResponseId { + Add, + AddAndClose, + }; + + enum TypeWanted { AudioTrack, MidiTrack, MixedTrack, - AudioBus + AudioBus, + MidiBus, + VCAMaster, + ListenBus, }; - TypeWanted type_wanted() const; - - ARDOUR::ChanCount channels (); + TypeWanted type_wanted(); + + ARDOUR::ChanCount channels (); + uint32_t channel_count (); int count (); - std::string name_template (); - std::string track_template (); + std::string name_template () const; + bool name_template_is_default () const; ARDOUR::PluginInfoPtr requested_instrument (); - + ARDOUR::TrackMode mode(); ARDOUR::RouteGroup* route_group (); - private: + RouteDialogs::InsertAt insert_at(); + bool use_strict_io(); + + std::string get_template_path(); + + void reset_name_edited () { name_edited_by_user = false; } + +private: Gtk::Entry name_template_entry; - Gtk::ComboBoxText track_bus_combo; Gtk::Adjustment routes_adjustment; Gtk::SpinButton routes_spinner; Gtk::ComboBoxText channel_combo; Gtk::Label configuration_label; + Gtk::Label manual_label; + Gtk::Label add_label; + Gtk::Label name_label; + Gtk::Label group_label; + Gtk::Label insert_label; + Gtk::Label strict_io_label; Gtk::Label mode_label; Gtk::Label instrument_label; Gtk::ComboBoxText mode_combo; Gtk::ComboBoxText route_group_combo; - Gtk::ComboBox instrument_combo; - - std::vector route_templates; + InstrumentSelector instrument_combo; + Gtk::ComboBoxText insert_at_combo; + Gtk::ComboBoxText strict_io_combo; void track_type_chosen (); void refill_channel_setups (); @@ -92,35 +120,51 @@ class AddRouteDialog : public ArdourDialog bool route_separator (const Glib::RefPtr &m, const Gtk::TreeModel::iterator &i); void maybe_update_name_template_entry (); - void reset_template_option_visibility (); + struct TrackTemplateColumns : public Gtk::TreeModel::ColumnRecord { + TrackTemplateColumns () { + add (name); + add (path); + add (description); + add (modified_with); + } + Gtk::TreeModelColumn name; + Gtk::TreeModelColumn path; + Gtk::TreeModelColumn description; + Gtk::TreeModelColumn modified_with; + }; + + TrackTemplateColumns track_template_columns; + + Glib::RefPtr trk_template_model; + Gtk::TreeView trk_template_chooser; + + void trk_template_row_selected (); + + Gtk::TextView trk_template_desc; + Gtk::Frame trk_template_outer_frame; + Gtk::Frame trk_template_desc_frame; + + void reset_template_option_visibility (); + void new_group_dialog_finished (int, RouteGroupDialog*); void on_show (); + void on_response (int); struct ChannelSetup { - std::string name; - std::string template_path; - uint32_t channels; + std::string name; + uint32_t channels; }; typedef std::vector ChannelSetups; ChannelSetups channel_setups; + static std::vector > builtin_types; static std::vector channel_combo_strings; static std::vector bus_mode_strings; - struct InstrumentListColumns : public Gtk::TreeModel::ColumnRecord { - InstrumentListColumns () { - add (name); - add (info_ptr); - } - Gtk::TreeModelColumn name; - Gtk::TreeModelColumn info_ptr; - }; - - Glib::RefPtr instrument_list; - InstrumentListColumns instrument_list_columns; - - void build_instrument_list (); + bool name_edited_by_user; + void name_template_entry_insertion (Glib::ustring const &,int*); + void name_template_entry_deletion (int, int); }; #endif /* __gtk_ardour_add_route_dialog_h__ */