From 92f480adab917e7f7ecca5657c4c728af70af69b Mon Sep 17 00:00:00 2001 From: Nikolaus Gullotta Date: Fri, 13 Jul 2018 19:05:09 -0500 Subject: Fix silly typo in script script name --- scripts/sotre_recall_mixer.lua | 381 ----------------------------------------- scripts/store_recall_mixer.lua | 381 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 381 insertions(+), 381 deletions(-) delete mode 100644 scripts/sotre_recall_mixer.lua create mode 100644 scripts/store_recall_mixer.lua diff --git a/scripts/sotre_recall_mixer.lua b/scripts/sotre_recall_mixer.lua deleted file mode 100644 index 85e6acbeae..0000000000 --- a/scripts/sotre_recall_mixer.lua +++ /dev/null @@ -1,381 +0,0 @@ -ardour { - ["type"] = "EditorAction", - name = "Mixer Store", - author = "Ardour Lua Taskforce", - description = [[Stores the current Mixer state as a file that can be read and recalled arbitrarily. - Supports: processor settings, grouping, mute, solo, gain, trim, pan and processor ordering, plus re-adding certain deleted plugins.]] -} - -function factory() return function() - - local invalidate = {} - local path = ARDOUR.LuaAPI.build_filename(Session:path(), "export", "params.lua") - - function new_plugin(name) - for x = 0, 6 do - plugin = ARDOUR.LuaAPI.new_plugin(Session, name, x, "") - if not(plugin:isnil()) then return plugin end - end - end - - function group_by_id(id) - local id = tonumber(id) - for g in Session:route_groups():iter() do - local group_id = tonumber(g:to_stateful():id():to_s()) - if group_id == id then return g end - end - end - - function route_groupid_interrogate(t) - local group = false - for g in Session:route_groups():iter() do - for r in g:route_list():iter() do - if r:name() == t:name() then group = g:to_stateful():id():to_s() end - end - end return group - end - - function route_group_interrogate(t) - for g in Session:route_groups():iter() do - for r in g:route_list():iter() do - if r:name() == t:name() then return g end - end - end - end - - function empty_last_store() --empty current file from last run - local file = io.open(path, "w") - file:write("") - file:close() - end - - function mark_selected_tracks() - empty_last_store() - - local sel = Editor:get_selection () - local groups_to_write = {} - local i = 0 - - for r in sel.tracks:routelist():iter() do - local group = route_group_interrogate(r) - if group then groups_to_write[#groups_to_write + 1] = group end - end - - for k, g in pairs(groups_to_write) do - local g_route_str, group_str = "", "" - group_str = "instance = {group_id = " .. g:to_stateful():id():to_s() .. ", name = " .. "\"" .. g:name() .. "\"" .. ", routes = {" - for t in g:route_list():iter() do - g_route_str = g_route_str .."[".. i .."] = " .. t:to_stateful():id():to_s() .. "," - i = i + 1 - end - group_str = group_str .. g_route_str .. "}}" - if not(group_str == "") then --sometimes there are no groups in the session - file = io.open(path, "a") - file:write(group_str, "\r\n") - file:close() - end - end - - for r in sel.tracks:routelist():iter() do - if r:is_monitor () or r:is_auditioner () then goto nextroute end -- skip special routes - - local order = ARDOUR.ProcessorList() - local x = 0 - repeat - local proc = r:nth_processor(x) - if not proc:isnil() then - order:push_back(proc) - end - x = x + 1 - until proc:isnil() - - local route_str, proc_order_str, cache_str = "", "", "" - local rid = r:to_stateful():id():to_s() - local pan = r:pan_azimuth_control() - if pan:isnil() then pan = false else pan = pan:get_value() end --sometimes a route doesn't have pan, like the master. - - local on = 0 - for p in order:iter() do - local pid = p:to_stateful():id():to_s() - if not(string.find(p:display_name(), "latcomp")) then - proc_order_str = proc_order_str .. "[" .. on .. "] = " .. pid .."," - cache_str = cache_str .. "[" .. pid .. "] = " .. "\"" .. p:display_name() .. "\"" .."," - end - on = on + 1 - end - - route_str = "instance = {route_id = " .. rid .. ", gain_control = " .. r:gain_control():get_value() .. ", trim_control = " .. r:trim_control():get_value() .. ", pan_control = " .. tostring(pan) .. ", muted = " .. tostring(r:muted()) .. ", soloed = " .. tostring(r:soloed()) .. ", order = {" .. proc_order_str .."}, cache = {" .. cache_str .. "}, group = " .. tostring(route_groupid_interrogate(r)) .. "}" - file = io.open(path, "a") - file:write(route_str, "\r\n") - file:close() - - local i = 0 - while true do - local params = {} - local proc_str, params_str = "", "" - local proc = r:nth_plugin (i) - if proc:isnil () then break end - local active = proc:active() - local id = proc:to_stateful():id():to_s() - local plug = proc:to_insert ():plugin (0) - local n = 0 -- count control-ports - for j = 0, plug:parameter_count () - 1 do -- iterate over all plugin parameters - if plug:parameter_is_control (j) then - local label = plug:parameter_label (j) - if plug:parameter_is_input (j) and label ~= "hidden" and label:sub (1,1) ~= "#" then - local _, _, pd = ARDOUR.LuaAPI.plugin_automation(proc, n) - local val = ARDOUR.LuaAPI.get_processor_param(proc, j, true) - --print(r:name(), "->", proc:display_name(), label, val) - params[n] = val - end - n = n + 1 - end - end - i = i + 1 - for k, v in pairs(params) do - params_str = params_str .. "[".. k .."] = " .. v .. "," - end - proc_str = "instance = {plugin_id = " .. id .. ", parameters = {" .. params_str .. "}, active = " .. tostring(active) .. "}" - file = io.open(path, "a") - file:write(proc_str, "\r\n") - file:close() - end - ::nextroute:: - end - end - - function mark_all_tracks() - empty_last_store() - - local i = 0 - for g in Session:route_groups():iter() do --@ToDo: Color, and other bools - local g_route_str, group_str = "", "" - group_str = "instance = {group_id = " .. g:to_stateful():id():to_s() .. ", name = " .. "\"" .. g:name() .. "\"" .. ", routes = {" - for t in g:route_list():iter() do - g_route_str = g_route_str .."[".. i .."] = " .. t:to_stateful():id():to_s() .. "," - i = i + 1 - end - group_str = group_str .. g_route_str .. "}}" - if not(group_str == "") then --sometimes there are no groups in the session - file = io.open(path, "a") - file:write(group_str, "\r\n") - file:close() - end - end - - for r in Session:get_routes():iter() do - if r:is_monitor () or r:is_auditioner () then goto nextroute end -- skip special routes - - local order = ARDOUR.ProcessorList() - local x = 0 - repeat - local proc = r:nth_processor(x) - if not proc:isnil() then - order:push_back(proc) - end - x = x + 1 - until proc:isnil() - - local route_str, proc_order_str, cache_str = "", "", "" - local rid = r:to_stateful():id():to_s() - local pan = r:pan_azimuth_control() - if pan:isnil() then pan = false else pan = pan:get_value() end --sometimes a route doesn't have pan, like the master. - - local on = 0 - for p in order:iter() do - local pid = p:to_stateful():id():to_s() - if not(string.find(p:display_name(), "latcomp")) then - proc_order_str = proc_order_str .. "[" .. on .. "] = " .. pid .."," - cache_str = cache_str .. "[" .. pid .. "] = " .. "\"" .. p:display_name() .. "\"" .."," - end - on = on + 1 - end - - route_str = "instance = {route_id = " .. rid .. ", gain_control = " .. r:gain_control():get_value() .. ", trim_control = " .. r:trim_control():get_value() .. ", pan_control = " .. tostring(pan) .. ", muted = " .. tostring(r:muted()) .. ", soloed = " .. tostring(r:soloed()) .. ", order = {" .. proc_order_str .."}, cache = {" .. cache_str .. "}, group = " .. tostring(route_groupid_interrogate(r)) .. "}" - file = io.open(path, "a") - file:write(route_str, "\r\n") - file:close() - - local i = 0 - while true do - local params = {} - local proc_str, params_str = "", "" - local proc = r:nth_plugin (i) - if proc:isnil () then break end - local active = proc:active() - local id = proc:to_stateful():id():to_s() - local plug = proc:to_insert ():plugin (0) - local n = 0 -- count control-ports - for j = 0, plug:parameter_count () - 1 do -- iterate over all plugin parameters - if plug:parameter_is_control (j) then - local label = plug:parameter_label (j) - if plug:parameter_is_input (j) and label ~= "hidden" and label:sub (1,1) ~= "#" then - local _, _, pd = ARDOUR.LuaAPI.plugin_automation(proc, n) - local val = ARDOUR.LuaAPI.get_processor_param(proc, j, true) - --print(r:name(), "->", proc:display_name(), label, val) - params[n] = val - end - n = n + 1 - end - end - i = i + 1 - for k, v in pairs(params) do - params_str = params_str .. "[".. k .."] = " .. v .. "," - end - proc_str = "instance = {plugin_id = " .. id .. ", parameters = {" .. params_str .. "}, active = " .. tostring(active) .. "}" - file = io.open(path, "a") - file:write(proc_str, "\r\n") - file:close() - end - ::nextroute:: - end - end - - function recall() - local file = io.open(path, "r") - assert(file, "File not found!") - for l in file:lines() do - --print(l) - - local plugin, route, group = false, false, false - local f = load(l) - f () - - if instance["route_id"] then route = true end - if instance["plugin_id"] then plugin = true end - if instance["group_id"] then group = true end - - if group then - local g_id = instance["group_id"] - local routes = instance["routes"] - local name = instance["name"] - local group = group_by_id(g_id) - if not(group) then group = Session:new_route_group(name) end - for k, v in pairs(routes) do - local rt = Session:route_by_id(PBD.ID(v)) - if not(rt:isnil()) then group:add(rt) end - end - end - - if route then - - local old_order = ARDOUR.ProcessorList() - local r_id = PBD.ID(instance["route_id"]) - local muted, soloed = instance["muted"], instance["soloed"] - local order = instance["order"] - local cache = instance["cache"] - local group = instance["group"] - local gc, tc, pc = instance["gain_control"], instance["trim_control"], instance["pan_control"] - - local rt = Session:route_by_id(r_id) - if rt:isnil() then goto nextline end - - local cur_group_id = route_groupid_interrogate(rt) - if not(group) and (cur_group_id) then - local g = group_by_id(cur_group_id) - if g then g:remove(rt) end - end - - for k, v in pairs(order) do - local proc = Session:processor_by_id(PBD.ID(v)) - if proc:isnil() then - for id, name in pairs(cache) do - if v == id then - proc = new_plugin(name) - if not(proc:isnil()) then - rt:add_processor_by_index(proc, 0, nil, true) - invalidate[v] = proc:to_stateful():id():to_s() - end - end - end - end - if not(proc:isnil()) then old_order:push_back(proc) end - end - - if muted then rt:mute_control():set_value(1, 1) else rt:mute_control():set_value(0, 1) end - if soloed then rt:solo_control():set_value(1, 1) else rt:solo_control():set_value(0, 1) end - rt:gain_control():set_value(gc, 1) - rt:trim_control():set_value(tc, 1) - if pc ~= false then rt:pan_azimuth_control():set_value(pc, 1) end - rt:reorder_processors(old_order, nil) - end - - if plugin then - local enable = {} - local params = instance["parameters"] - local p_id = instance["plugin_id"] - local act = instance["active"] - - for k, v in pairs(invalidate) do --invalidate any deleted plugin's id - if p_id == k then - p_id = v - end - end - - local proc = Session:processor_by_id(PBD.ID(p_id)) - if proc:isnil() then goto nextline end - local plug = proc:to_insert():plugin(0) - - for k, v in pairs(params) do - local label = plug:parameter_label(k) - if string.find(label, "Assign") or string.find(label, "Enable") then --@ToDo: Check Plugin type == LADSPA or VST? - enable[k] = v --queue any assignments/enables for after the initial parameter recalling to duck the 'in-on-change' feature - end - ARDOUR.LuaAPI.set_processor_param(proc, k, v) - end - - for k, v in pairs(enable) do - ARDOUR.LuaAPI.set_processor_param(proc, k, v) - end - if act then proc:activate() else proc:deactivate() end - end - ::nextline:: - end - end - - local dialog_options = { - { type = "label", colspan = 5, title = "" }, - { type = "radio", col = 1, colspan = 7, key = "select", title = "", values ={ ["Store"] = "store", ["Recall"] = "recall" }, default = "Store"}, - { type = "label", colspan = 5, title = "" }, - } - - local store_options = { - { type = "label", colspan = 5, title = "" }, - { type = "checkbox", col=1, colspan = 1, key = "selected", default = false, title = "Selected tracks only"}, - { type = "entry", col=2, colspan = 10, key = "filename", default = "params", title = "Store name" }, - { type = "label", colspan = 5, title = "" }, - } - - local recall_options = { - { type = "label", colspan = 5, title = "" }, - { type = "file", col =1, colspan = 10, key = "file", title = "Select a File", path = ARDOUR.LuaAPI.build_filename(Session:path(), "export", "params.lua") }, - { type = "label", colspan = 5, title = "" }, - } - - local rv = LuaDialog.Dialog("Mixer Store:", dialog_options):run() - - if rv then - local choice = rv["select"] - if choice == "store" then - local srv = LuaDialog.Dialog("Mixer Store:", store_options):run() - if srv then - empty_last_store() --ensures that params.lua will exist for the recall dialog - path = ARDOUR.LuaAPI.build_filename(Session:path(), "export", srv["filename"] .. ".lua") - if srv['selected'] then - mark_selected_tracks() - else - mark_all_tracks() - end - end - end - - if choice == "recall" then - local rrv = LuaDialog.Dialog("Mixer Store:", recall_options):run() - if rrv then - if rrv['file'] ~= path then path = rrv['file'] end - recall() - end - end - end - -end end diff --git a/scripts/store_recall_mixer.lua b/scripts/store_recall_mixer.lua new file mode 100644 index 0000000000..85e6acbeae --- /dev/null +++ b/scripts/store_recall_mixer.lua @@ -0,0 +1,381 @@ +ardour { + ["type"] = "EditorAction", + name = "Mixer Store", + author = "Ardour Lua Taskforce", + description = [[Stores the current Mixer state as a file that can be read and recalled arbitrarily. + Supports: processor settings, grouping, mute, solo, gain, trim, pan and processor ordering, plus re-adding certain deleted plugins.]] +} + +function factory() return function() + + local invalidate = {} + local path = ARDOUR.LuaAPI.build_filename(Session:path(), "export", "params.lua") + + function new_plugin(name) + for x = 0, 6 do + plugin = ARDOUR.LuaAPI.new_plugin(Session, name, x, "") + if not(plugin:isnil()) then return plugin end + end + end + + function group_by_id(id) + local id = tonumber(id) + for g in Session:route_groups():iter() do + local group_id = tonumber(g:to_stateful():id():to_s()) + if group_id == id then return g end + end + end + + function route_groupid_interrogate(t) + local group = false + for g in Session:route_groups():iter() do + for r in g:route_list():iter() do + if r:name() == t:name() then group = g:to_stateful():id():to_s() end + end + end return group + end + + function route_group_interrogate(t) + for g in Session:route_groups():iter() do + for r in g:route_list():iter() do + if r:name() == t:name() then return g end + end + end + end + + function empty_last_store() --empty current file from last run + local file = io.open(path, "w") + file:write("") + file:close() + end + + function mark_selected_tracks() + empty_last_store() + + local sel = Editor:get_selection () + local groups_to_write = {} + local i = 0 + + for r in sel.tracks:routelist():iter() do + local group = route_group_interrogate(r) + if group then groups_to_write[#groups_to_write + 1] = group end + end + + for k, g in pairs(groups_to_write) do + local g_route_str, group_str = "", "" + group_str = "instance = {group_id = " .. g:to_stateful():id():to_s() .. ", name = " .. "\"" .. g:name() .. "\"" .. ", routes = {" + for t in g:route_list():iter() do + g_route_str = g_route_str .."[".. i .."] = " .. t:to_stateful():id():to_s() .. "," + i = i + 1 + end + group_str = group_str .. g_route_str .. "}}" + if not(group_str == "") then --sometimes there are no groups in the session + file = io.open(path, "a") + file:write(group_str, "\r\n") + file:close() + end + end + + for r in sel.tracks:routelist():iter() do + if r:is_monitor () or r:is_auditioner () then goto nextroute end -- skip special routes + + local order = ARDOUR.ProcessorList() + local x = 0 + repeat + local proc = r:nth_processor(x) + if not proc:isnil() then + order:push_back(proc) + end + x = x + 1 + until proc:isnil() + + local route_str, proc_order_str, cache_str = "", "", "" + local rid = r:to_stateful():id():to_s() + local pan = r:pan_azimuth_control() + if pan:isnil() then pan = false else pan = pan:get_value() end --sometimes a route doesn't have pan, like the master. + + local on = 0 + for p in order:iter() do + local pid = p:to_stateful():id():to_s() + if not(string.find(p:display_name(), "latcomp")) then + proc_order_str = proc_order_str .. "[" .. on .. "] = " .. pid .."," + cache_str = cache_str .. "[" .. pid .. "] = " .. "\"" .. p:display_name() .. "\"" .."," + end + on = on + 1 + end + + route_str = "instance = {route_id = " .. rid .. ", gain_control = " .. r:gain_control():get_value() .. ", trim_control = " .. r:trim_control():get_value() .. ", pan_control = " .. tostring(pan) .. ", muted = " .. tostring(r:muted()) .. ", soloed = " .. tostring(r:soloed()) .. ", order = {" .. proc_order_str .."}, cache = {" .. cache_str .. "}, group = " .. tostring(route_groupid_interrogate(r)) .. "}" + file = io.open(path, "a") + file:write(route_str, "\r\n") + file:close() + + local i = 0 + while true do + local params = {} + local proc_str, params_str = "", "" + local proc = r:nth_plugin (i) + if proc:isnil () then break end + local active = proc:active() + local id = proc:to_stateful():id():to_s() + local plug = proc:to_insert ():plugin (0) + local n = 0 -- count control-ports + for j = 0, plug:parameter_count () - 1 do -- iterate over all plugin parameters + if plug:parameter_is_control (j) then + local label = plug:parameter_label (j) + if plug:parameter_is_input (j) and label ~= "hidden" and label:sub (1,1) ~= "#" then + local _, _, pd = ARDOUR.LuaAPI.plugin_automation(proc, n) + local val = ARDOUR.LuaAPI.get_processor_param(proc, j, true) + --print(r:name(), "->", proc:display_name(), label, val) + params[n] = val + end + n = n + 1 + end + end + i = i + 1 + for k, v in pairs(params) do + params_str = params_str .. "[".. k .."] = " .. v .. "," + end + proc_str = "instance = {plugin_id = " .. id .. ", parameters = {" .. params_str .. "}, active = " .. tostring(active) .. "}" + file = io.open(path, "a") + file:write(proc_str, "\r\n") + file:close() + end + ::nextroute:: + end + end + + function mark_all_tracks() + empty_last_store() + + local i = 0 + for g in Session:route_groups():iter() do --@ToDo: Color, and other bools + local g_route_str, group_str = "", "" + group_str = "instance = {group_id = " .. g:to_stateful():id():to_s() .. ", name = " .. "\"" .. g:name() .. "\"" .. ", routes = {" + for t in g:route_list():iter() do + g_route_str = g_route_str .."[".. i .."] = " .. t:to_stateful():id():to_s() .. "," + i = i + 1 + end + group_str = group_str .. g_route_str .. "}}" + if not(group_str == "") then --sometimes there are no groups in the session + file = io.open(path, "a") + file:write(group_str, "\r\n") + file:close() + end + end + + for r in Session:get_routes():iter() do + if r:is_monitor () or r:is_auditioner () then goto nextroute end -- skip special routes + + local order = ARDOUR.ProcessorList() + local x = 0 + repeat + local proc = r:nth_processor(x) + if not proc:isnil() then + order:push_back(proc) + end + x = x + 1 + until proc:isnil() + + local route_str, proc_order_str, cache_str = "", "", "" + local rid = r:to_stateful():id():to_s() + local pan = r:pan_azimuth_control() + if pan:isnil() then pan = false else pan = pan:get_value() end --sometimes a route doesn't have pan, like the master. + + local on = 0 + for p in order:iter() do + local pid = p:to_stateful():id():to_s() + if not(string.find(p:display_name(), "latcomp")) then + proc_order_str = proc_order_str .. "[" .. on .. "] = " .. pid .."," + cache_str = cache_str .. "[" .. pid .. "] = " .. "\"" .. p:display_name() .. "\"" .."," + end + on = on + 1 + end + + route_str = "instance = {route_id = " .. rid .. ", gain_control = " .. r:gain_control():get_value() .. ", trim_control = " .. r:trim_control():get_value() .. ", pan_control = " .. tostring(pan) .. ", muted = " .. tostring(r:muted()) .. ", soloed = " .. tostring(r:soloed()) .. ", order = {" .. proc_order_str .."}, cache = {" .. cache_str .. "}, group = " .. tostring(route_groupid_interrogate(r)) .. "}" + file = io.open(path, "a") + file:write(route_str, "\r\n") + file:close() + + local i = 0 + while true do + local params = {} + local proc_str, params_str = "", "" + local proc = r:nth_plugin (i) + if proc:isnil () then break end + local active = proc:active() + local id = proc:to_stateful():id():to_s() + local plug = proc:to_insert ():plugin (0) + local n = 0 -- count control-ports + for j = 0, plug:parameter_count () - 1 do -- iterate over all plugin parameters + if plug:parameter_is_control (j) then + local label = plug:parameter_label (j) + if plug:parameter_is_input (j) and label ~= "hidden" and label:sub (1,1) ~= "#" then + local _, _, pd = ARDOUR.LuaAPI.plugin_automation(proc, n) + local val = ARDOUR.LuaAPI.get_processor_param(proc, j, true) + --print(r:name(), "->", proc:display_name(), label, val) + params[n] = val + end + n = n + 1 + end + end + i = i + 1 + for k, v in pairs(params) do + params_str = params_str .. "[".. k .."] = " .. v .. "," + end + proc_str = "instance = {plugin_id = " .. id .. ", parameters = {" .. params_str .. "}, active = " .. tostring(active) .. "}" + file = io.open(path, "a") + file:write(proc_str, "\r\n") + file:close() + end + ::nextroute:: + end + end + + function recall() + local file = io.open(path, "r") + assert(file, "File not found!") + for l in file:lines() do + --print(l) + + local plugin, route, group = false, false, false + local f = load(l) + f () + + if instance["route_id"] then route = true end + if instance["plugin_id"] then plugin = true end + if instance["group_id"] then group = true end + + if group then + local g_id = instance["group_id"] + local routes = instance["routes"] + local name = instance["name"] + local group = group_by_id(g_id) + if not(group) then group = Session:new_route_group(name) end + for k, v in pairs(routes) do + local rt = Session:route_by_id(PBD.ID(v)) + if not(rt:isnil()) then group:add(rt) end + end + end + + if route then + + local old_order = ARDOUR.ProcessorList() + local r_id = PBD.ID(instance["route_id"]) + local muted, soloed = instance["muted"], instance["soloed"] + local order = instance["order"] + local cache = instance["cache"] + local group = instance["group"] + local gc, tc, pc = instance["gain_control"], instance["trim_control"], instance["pan_control"] + + local rt = Session:route_by_id(r_id) + if rt:isnil() then goto nextline end + + local cur_group_id = route_groupid_interrogate(rt) + if not(group) and (cur_group_id) then + local g = group_by_id(cur_group_id) + if g then g:remove(rt) end + end + + for k, v in pairs(order) do + local proc = Session:processor_by_id(PBD.ID(v)) + if proc:isnil() then + for id, name in pairs(cache) do + if v == id then + proc = new_plugin(name) + if not(proc:isnil()) then + rt:add_processor_by_index(proc, 0, nil, true) + invalidate[v] = proc:to_stateful():id():to_s() + end + end + end + end + if not(proc:isnil()) then old_order:push_back(proc) end + end + + if muted then rt:mute_control():set_value(1, 1) else rt:mute_control():set_value(0, 1) end + if soloed then rt:solo_control():set_value(1, 1) else rt:solo_control():set_value(0, 1) end + rt:gain_control():set_value(gc, 1) + rt:trim_control():set_value(tc, 1) + if pc ~= false then rt:pan_azimuth_control():set_value(pc, 1) end + rt:reorder_processors(old_order, nil) + end + + if plugin then + local enable = {} + local params = instance["parameters"] + local p_id = instance["plugin_id"] + local act = instance["active"] + + for k, v in pairs(invalidate) do --invalidate any deleted plugin's id + if p_id == k then + p_id = v + end + end + + local proc = Session:processor_by_id(PBD.ID(p_id)) + if proc:isnil() then goto nextline end + local plug = proc:to_insert():plugin(0) + + for k, v in pairs(params) do + local label = plug:parameter_label(k) + if string.find(label, "Assign") or string.find(label, "Enable") then --@ToDo: Check Plugin type == LADSPA or VST? + enable[k] = v --queue any assignments/enables for after the initial parameter recalling to duck the 'in-on-change' feature + end + ARDOUR.LuaAPI.set_processor_param(proc, k, v) + end + + for k, v in pairs(enable) do + ARDOUR.LuaAPI.set_processor_param(proc, k, v) + end + if act then proc:activate() else proc:deactivate() end + end + ::nextline:: + end + end + + local dialog_options = { + { type = "label", colspan = 5, title = "" }, + { type = "radio", col = 1, colspan = 7, key = "select", title = "", values ={ ["Store"] = "store", ["Recall"] = "recall" }, default = "Store"}, + { type = "label", colspan = 5, title = "" }, + } + + local store_options = { + { type = "label", colspan = 5, title = "" }, + { type = "checkbox", col=1, colspan = 1, key = "selected", default = false, title = "Selected tracks only"}, + { type = "entry", col=2, colspan = 10, key = "filename", default = "params", title = "Store name" }, + { type = "label", colspan = 5, title = "" }, + } + + local recall_options = { + { type = "label", colspan = 5, title = "" }, + { type = "file", col =1, colspan = 10, key = "file", title = "Select a File", path = ARDOUR.LuaAPI.build_filename(Session:path(), "export", "params.lua") }, + { type = "label", colspan = 5, title = "" }, + } + + local rv = LuaDialog.Dialog("Mixer Store:", dialog_options):run() + + if rv then + local choice = rv["select"] + if choice == "store" then + local srv = LuaDialog.Dialog("Mixer Store:", store_options):run() + if srv then + empty_last_store() --ensures that params.lua will exist for the recall dialog + path = ARDOUR.LuaAPI.build_filename(Session:path(), "export", srv["filename"] .. ".lua") + if srv['selected'] then + mark_selected_tracks() + else + mark_all_tracks() + end + end + end + + if choice == "recall" then + local rrv = LuaDialog.Dialog("Mixer Store:", recall_options):run() + if rrv then + if rrv['file'] ~= path then path = rrv['file'] end + recall() + end + end + end + +end end -- cgit v1.2.3