summaryrefslogtreecommitdiff
path: root/scripts/template_band.lua
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/template_band.lua')
-rw-r--r--scripts/template_band.lua382
1 files changed, 382 insertions, 0 deletions
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