mirror of
https://github.com/Ardour/ardour.git
synced 2026-01-30 08:53:08 +01:00
Allow to query Windows VST user-preset-names
This commit is contained in:
parent
1973e6ec93
commit
087610dc56
2 changed files with 36 additions and 0 deletions
|
|
@ -47,6 +47,7 @@ public:
|
|||
~WindowsVSTPluginInfo () {}
|
||||
|
||||
PluginPtr load (Session& session);
|
||||
virtual std::vector<Plugin::PresetRecord> get_presets(Session&);
|
||||
};
|
||||
|
||||
} // namespace ARDOUR
|
||||
|
|
|
|||
|
|
@ -19,6 +19,10 @@
|
|||
|
||||
#include "fst.h"
|
||||
|
||||
#include <glibmm/fileutils.h>
|
||||
#include <glibmm/miscutils.h>
|
||||
|
||||
#include "ardour/filesystem_paths.h"
|
||||
#include "ardour/windows_vst_plugin.h"
|
||||
#include "ardour/session.h"
|
||||
|
||||
|
|
@ -90,6 +94,37 @@ WindowsVSTPluginInfo::load (Session& session)
|
|||
}
|
||||
}
|
||||
|
||||
std::vector<Plugin::PresetRecord>
|
||||
WindowsVSTPluginInfo::get_presets(Session&)
|
||||
{
|
||||
std::vector<Plugin::PresetRecord> p;
|
||||
#ifndef NO_PLUGIN_STATE
|
||||
if (!Config->get_use_lxvst()) {
|
||||
return p;
|
||||
}
|
||||
|
||||
// TODO cache and load factory-preset names
|
||||
|
||||
/* user presets */
|
||||
XMLTree* t = new XMLTree;
|
||||
std::string pf = Glib::build_filename (ARDOUR::user_config_directory (), "presets", string_compose ("vst-%1", unique_id));
|
||||
if (Glib::file_test (pf, Glib::FILE_TEST_EXISTS)) {
|
||||
t->set_filename (pf);
|
||||
if (t->read ()) {
|
||||
XMLNode* root = t->root ();
|
||||
for (XMLNodeList::const_iterator i = root->children().begin(); i != root->children().end(); ++i) {
|
||||
XMLProperty* uri = (*i)->property (X_("uri"));
|
||||
XMLProperty* label = (*i)->property (X_("label"));
|
||||
p.push_back (Plugin::PresetRecord (uri->value(), label->value(), true));
|
||||
}
|
||||
}
|
||||
}
|
||||
delete t;
|
||||
#endif
|
||||
|
||||
return p;
|
||||
}
|
||||
|
||||
WindowsVSTPluginInfo::WindowsVSTPluginInfo()
|
||||
{
|
||||
type = ARDOUR::Windows_VST;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue