X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fadd_route_dialog.h;h=e5622db3bae2b9f712f638d336c2176db5eaf6d3;hb=7d8b93add17620135eadee5029325a3d22512b12;hp=691a1c549d6f32025325562cdc1f06bf1bb461a5;hpb=c83e48e07a0b4790512c6251d8ad8f941c881021;p=ardour.git diff --git a/gtk2_ardour/add_route_dialog.h b/gtk2_ardour/add_route_dialog.h index 691a1c549d..e5622db3ba 100644 --- a/gtk2_ardour/add_route_dialog.h +++ b/gtk2_ardour/add_route_dialog.h @@ -29,69 +29,141 @@ #include #include #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 (); - bool track (); - int channels (); + enum ResponseId { + Add, + AddAndClose, + }; + + enum TypeWanted { + AudioTrack, + MidiTrack, + MixedTrack, + AudioBus, + MidiBus, + VCAMaster, + }; + 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::DataType type(); ARDOUR::TrackMode mode(); ARDOUR::RouteGroup* route_group (); - private: - ARDOUR::Session& _session; + 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 track_mode_label; - Gtk::ComboBoxText track_mode_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; - - 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 (); void refill_route_groups (); + void refill_track_modes (); void add_route_group (ARDOUR::RouteGroup *); void group_changed (); + void channel_combo_changed (); bool channel_separator (const Glib::RefPtr &m, const Gtk::TreeModel::iterator &i); bool route_separator (const Glib::RefPtr &m, const Gtk::TreeModel::iterator &i); + void maybe_update_name_template_entry (); + + 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; + }; - void reset_template_option_visibility (); + 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; - std::vector channel_combo_strings; - std::vector track_mode_strings; + static std::vector > builtin_types; + static std::vector channel_combo_strings; + static std::vector bus_mode_strings; + + 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__ */