From f62629f30f60797c94531b087531255ae114fe02 Mon Sep 17 00:00:00 2001 From: Robin Gareus Date: Sat, 19 Aug 2017 22:52:45 +0200 Subject: More template re-naming Unify "track-band" & "session-band" setup scripts --- scripts/template_band.lua | 382 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 382 insertions(+) create mode 100644 scripts/template_band.lua (limited to 'scripts/template_band.lua') diff --git a/scripts/template_band.lua b/scripts/template_band.lua new file mode 100644 index 0000000000..0ff65f1876 --- /dev/null +++ b/scripts/template_band.lua @@ -0,0 +1,382 @@ +ardour { + ["type"] = "EditorAction", + name = "Track Wizard", + description = [[ +This template helps create the tracks for a typical pop/rock band. + +You will be prompted to assemble your session from a list of track types. + +Each track will be pre-assigned with a color. + +Optionally, tracks may be assigned to sensible Groups ( vocals, guitars, drums ) + +Optionally, tracks may be assigned Gates and other plugins. + ]] +} + +function session_setup () + return true; +end + +function route_setup () + return + { + ['Insert_at'] = ARDOUR.PresentationInfo.max_order; + } +end + +function factory () return function () + + local p = params or route_setup () + local insert_at = p["insert_at"] or ARDOUR.PresentationInfo.max_order; + + --prompt the user for the tracks they'd like to instantiate + local dialog_options = { + { type = "heading", title = "Select the tracks you'd like\nto add to your session: ", col=0, align = "left", colspan = 1}, + { type = "heading", title = "Name", col=1, colspan = 1 }, + { type = "heading", title = "Stereo?", col=2, colspan = 1 }, + + { type = "checkbox", key = "check-ldvox", default = false, title = "Lead Vocal", col=0 }, + { type = "entry", key = "name-ldvox", default = "Lead Vocal", title = "", col=1 }, + { type = "checkbox", key = "stereo-ldvox", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-bass", default = false, title = "Bass", col=0 }, + { type = "entry", key = "name-bass", default = "Bass", title = "", col=1 }, + { type = "checkbox", key = "stereo-bass", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-piano", default = false, title = "Piano", col=0 }, + { type = "entry", key = "name-piano", default = "Piano", title = "", col=1 }, + { type = "checkbox", key = "stereo-piano", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-electric-piano", default = false, title = "Electric Piano", col=0 }, + { type = "entry", key = "name-electric-piano", default = "E Piano", title = "", col=1 }, + { type = "checkbox", key = "stereo-electric-piano", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-organ", default = false, title = "Organ", col=0 }, + { type = "entry", key = "name-organ", default = "Organ", title = "", col=1 }, + { type = "checkbox", key = "stereo-organ", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-electric-guitar", default = false, title = "Electric Guitar", col=0 }, + { type = "entry", key = "name-electric-guitar", default = "E Guitar", title = "", col=1 }, + { type = "checkbox", key = "stereo-electric-guitar", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-solo-guitar", default = false, title = "Lead Guitar", col=0 }, + { type = "entry", key = "name-solo-guitar", default = "Ld Gtr", title = "", col=1 }, + { type = "checkbox", key = "stereo-solo-guitar", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-accoustic-guitar", default = false, title = "Acoustic Guitar", col=0 }, + { type = "entry", key = "name-accoustic-guitar", default = "Ac Gtr", title = "", col=1 }, + { type = "checkbox", key = "stereo-accoustic-guitar", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-basic-kit", default = false, title = "Basic Drum Mics", col=0 }, + { type = "label", title = "(Kick + Snare)", col=1, colspan = 1, align = "left"}, +-- { type = "checkbox", key = "stereo-overhead-mono", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-full-kit", default = false, title = "Full Drum Mics", col=0 }, + { type = "label", title = "(Kick, Snare, HiHat, 3 Toms)", col=1, colspan = 1, align = "left"}, +-- { type = "checkbox", key = "stereo-overhead-mono", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-overkill-kit", default = false, title = "Overkill Drum Mics", col=0 }, + { type = "label", title = "(Kick (2x), Snare(2x), HiHat, 3 Toms)", col=1, colspan = 1, align = "left"}, +-- { type = "checkbox", key = "stereo-overhead-mono", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-overhead", default = false, title = "Drum Overheads", col=0 }, +-- { type = "entry", key = "name-ldvox", default = "Lead Vocal", title = "", col=1 }, + { type = "checkbox", key = "stereo-overhead", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-room", default = false, title = "Drum Room", col=0 }, +-- { type = "entry", key = "name-ldvox", default = "Lead Vocal", title = "", col=1 }, + { type = "checkbox", key = "stereo-room", default = false, title = "", col=2 }, + + { type = "checkbox", key = "check-bgvox", default = false, title = "Background Vocals (3x)", col=0 }, +-- { type = "entry", key = "name-ldvox", default = "Lead Vocal", title = "", col=1 }, + { type = "checkbox", key = "stereo-bgvox", default = false, title = "", col=2 }, + + { type = "hseparator", title="", col=0, colspan = 3}, + + { type = "checkbox", key = "group", default = false, title = "Group Track(s)?", col=0 }, + { type = "checkbox", key = "gates", default = false, title = "Add Gate(s)?", col=0 }, + { type = "checkbox", key = "char", default = false, title = "Add Character Plugin(s)?", col=0 }, + } + + local dlg = LuaDialog.Dialog ("Template Setup", dialog_options) + local rv = dlg:run() + if (not rv) then + return + end + + -- helper function to reference processors + function processor(t, s) --takes a track (t) and a string (s) as arguments + local i = 0 + local proc = t:nth_processor(i) + repeat + if ( proc:display_name() == s ) then + return proc + else + i = i + 1 + end + proc = t:nth_processor(i) + until proc:isnil() + end + + --INSTANTIATING MIDI TRACKS IS TOO DAMN HARD + function create_midi_track(name, chan_count) -- call this function with a name argument and output channel count + Session:new_midi_track(ARDOUR.ChanCount(ARDOUR.DataType ("midi"), 1), ARDOUR.ChanCount(ARDOUR.DataType ("audio"), chan_count), true, ARDOUR.PluginInfo(), nil, nil, 1, name, 1, ARDOUR.TrackMode.Normal) + return true + end + + if rv['group'] then + drum_group = Session:new_route_group("Drums") + drum_group:set_rgba(0x425CADff) + bass_group = Session:new_route_group("Bass") + bass_group:set_rgba(0x1AE54Eff) + guitar_group = Session:new_route_group("Guitars") + guitar_group:set_rgba(0xB475CBff) + key_group = Session:new_route_group("Keys") + key_group:set_rgba(0xDA8032ff) + vox_group = Session:new_route_group("Vox") + vox_group:set_rgba(0xC54249ff) + end + + local track_count = 0; + if rv['check-basic-kit'] then + local names = {"Kick", "Snare"} + for i = 1, #names do + local tl = Session:new_audio_track (1, 1, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + local gate = ARDOUR.LuaAPI.new_plugin(Session, "XT-EG Expander Gate (Mono)", ARDOUR.PluginType.LV2, "") + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then drum_group:add(track) end + if rv['gates'] then track:add_processor_by_index(eg, 0, nil, true) end + end + end + + track_count = track_count+2 + end + + if rv['check-full-kit'] then + local names = {"Kick", "Snare", "Hi-Hat", "Hi-tom", "Mid-tom", "Fl-tom"} + for i = 1, #names do + local tl = Session:new_audio_track (1, 1, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + local eg = ARDOUR.LuaAPI.new_plugin(Session, "XT-EG Expander Gate (Mono)", ARDOUR.PluginType.LV2, "") + local tg = ARDOUR.LuaAPI.new_plugin(Session, "XT-TG Tom Gate (Mono)", ARDOUR.PluginType.LV2, "") + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then drum_group:add(track) end + if rv['gates'] then + if string.find(track:name(), '-tom') then + track:add_processor_by_index(tg, 0, nil, true) + else + track:add_processor_by_index(eg, 0, nil, true) + end + end + end + end + + track_count = track_count+6 + end + + if rv['check-overkill-kit'] then + local names = {"Kick In", "Kick Out", "Snare Top", "Snare Btm", "Hi-Hat", "Hi-tom", "Mid-tom", "Fl-tom"} + for i = 1, #names do + local tl = Session:new_audio_track (1, 1, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + local eg = ARDOUR.LuaAPI.new_plugin(Session, "XT-EG Expander Gate (Mono)", ARDOUR.PluginType.LV2, "") + local tg = ARDOUR.LuaAPI.new_plugin(Session, "XT-TG Tom Gate (Mono)", ARDOUR.PluginType.LV2, "") + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then drum_group:add(track) end + if rv['gates'] then + if string.find(track:name(), '-tom') then + track:add_processor_by_index(tg, 0, nil, true) + else + track:add_processor_by_index(eg, 0, nil, true) + end + end + end + end + + track_count = track_count+8 + end + + if rv['check-overhead'] then + local names = { "OH" } + local ch = 1 + if rv["stereo-bass"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then drum_group:add(track) end + end + end + + track_count = track_count+ch + end + + + if rv['check-room'] then + local names = { "Drum Room" } + local ch = 1 + if rv["stereo-bass"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then drum_group:add(track) end + end + end + + track_count = track_count+ch + end + + if rv['check-bass'] then + local names = { rv["name-bass"] } + local ch = 1 + if rv["stereo-bass"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + local bc = ARDOUR.LuaAPI.new_plugin(Session, "XT-BC Bass Character (Mono)", ARDOUR.PluginType.LV2, "") + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then bass_group:add(track) end + if rv['char'] then track:add_processor_by_index(bc, 0, nil, true) end + end + end + + track_count = track_count+ch + end + + if rv['check-electric-guitar'] then + local names = { rv["name-electric-guitar"] } + local ch = 1 + if rv["stereo-electric-guitar"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then guitar_group:add(track) end + end + end + + track_count = track_count+ch + end + + if rv['check-solo-guitar'] then + local names = { rv["name-solo-guitar"] } + local ch = 1 + if rv["stereo-solo-guitar"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then guitar_group:add(track) end + end + end + + track_count = track_count+ch + end + + if rv['check-acoustic-guitar'] then + local names = { rv["name-acoustic-guitar"] } + local ch = 1 + if rv["stereo-acoustic-guitar"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then guitar_group:add(track) end + end + end + + track_count = track_count+ch + end + + if rv['check-piano'] then + local names = { rv["name-piano"] } + local ch = 1 + if rv["stereo-piano"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then key_group:add(track) end + end + end + + track_count = track_count+ch + end + + if rv['check-electric-piano'] then + local names = { rv["name-electric-piano"] } + local ch = 1 + if rv["stereo-electric-piano"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then key_group:add(track) end + end + end + + track_count = track_count+ch + end + + if rv['check-organ'] then + local names = { rv["name-organ"] } + local ch = 1 + if rv["stereo-organ"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then key_group:add(track) end + end + end + + track_count = track_count+ch + end + + if rv['check-ldvox'] then + local names = { rv["name-ldvox"] } + local ch = 1 + if rv["stereo-ldvox"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track ( ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + local vc = ARDOUR.LuaAPI.new_plugin(Session, "XT-VC Vocal Character (Mono)", ARDOUR.PluginType.LV2, "") + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then vox_group:add(track) end + if rv['char'] then track:add_processor_by_index(vc, 0, nil, true) end + end + end + + track_count = track_count+ch + end + + if rv['check-bgvox'] then + local names = { rv["name-bgvox"] } + local ch = 1 + if rv["stereo-bgvox"] then ch = 2 end --stereo + for i = 1, #names do + local tl = Session:new_audio_track (ch, ch, nil, 1, names[i], insert_at, ARDOUR.TrackMode.Normal) + for track in tl:iter() do + --track:rec_enable_control ():set_value (1, PBD.GroupControlDisposition.NoGroup) + if rv['group'] then vox_group:add(track) end + end + end + + track_count = track_count+ch + end + + --determine the number of tracks we can record + local e = Session:engine() + local _, t = e:get_backend_ports ("", ARDOUR.DataType("audio"), ARDOUR.PortFlags.IsOutput | ARDOUR.PortFlags.IsPhysical, C.StringVector()) -- from the engine's POV readable/capture ports are "outputs" + local num_inputs = t[4]:size(); -- table 't' holds argument references. t[4] is the C.StringVector (return value) + + --ToDo: if track_count > num_inputs, we should warn the user to check their routing. + + --fit all tracks on the screen + Editor:access_action("Editor","fit_all_tracks") + + Session:save_state(""); +end end -- cgit v1.2.3