diff options
author | David Robillard <d@drobilla.net> | 2014-12-01 14:28:03 -0500 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2014-12-01 23:35:24 -0500 |
commit | 767c0238a34ef4acc4d345e88cd5ddb0c8a8e421 (patch) | |
tree | fed11fb6f4e4e08a7c35eb45f53aea70dc66e4f8 /libs/ardour/plugin_insert.cc | |
parent | cb8abbe8d2f0e4dfe52bd35613ebba7689628eca (diff) |
Replace half-baked param metadata with descriptor.
Among other things, this means that automation controls/lists have the actual
min/max/normal/toggled of parameters, and not those inferred from the Parameter
ID, which is not correct for things like plugin parameters.
Pushing things down to the Evoral::ParmeterDescriptor may be useful in the
future to have lists do smarter things based on parameter range, but currently
I have just pushed down the above-mentioned currently used attributes.
Diffstat (limited to 'libs/ardour/plugin_insert.cc')
-rw-r--r-- | libs/ardour/plugin_insert.cc | 9 |
1 files changed, 2 insertions, 7 deletions
diff --git a/libs/ardour/plugin_insert.cc b/libs/ardour/plugin_insert.cc index 5dd35c881c..156f7b02a0 100644 --- a/libs/ardour/plugin_insert.cc +++ b/libs/ardour/plugin_insert.cc @@ -248,13 +248,8 @@ PluginInsert::create_automatable_parameters () ParameterDescriptor desc; _plugins.front()->get_parameter_descriptor(i->id(), desc); - /* the Parameter belonging to the actual plugin doesn't have its range set - but we want the Controllable related to this Parameter to have those limits. - */ - - param.set_range (desc.lower, desc.upper, _plugins.front()->default_value(i->id()), desc.toggled); can_automate (param); - boost::shared_ptr<AutomationList> list(new AutomationList(param)); + boost::shared_ptr<AutomationList> list(new AutomationList(param, desc)); add_control (boost::shared_ptr<AutomationControl> (new PluginControl(this, param, desc, list))); } else if (i->type() == PluginPropertyAutomation) { Evoral::Parameter param(*i); @@ -262,7 +257,7 @@ PluginInsert::create_automatable_parameters () if (desc.datatype != Variant::NOTHING) { boost::shared_ptr<AutomationList> list; if (Variant::type_is_numeric(desc.datatype)) { - list = boost::shared_ptr<AutomationList>(new AutomationList(param)); + list = boost::shared_ptr<AutomationList>(new AutomationList(param, desc)); } add_control (boost::shared_ptr<AutomationControl> (new PluginPropertyControl(this, param, desc, list))); } |