Files
ardour/libs/ardour/ardour/plugin_manager.h
Ben Loftis afedd214a7 Method to generate an initial tag file:
rm config/plugin_tags
touch config/init_plugin_tags
2018-02-21 18:05:33 -06:00

224 lines
6.6 KiB
C++

/*
Copyright (C) 2000-2007 Paul Davis
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#ifndef __ardour_plugin_manager_h__
#define __ardour_plugin_manager_h__
#ifdef WAF_BUILD
#include "libardour-config.h"
#endif
#include <list>
#include <map>
#include <string>
#include <set>
#include <boost/utility.hpp>
#include "ardour/libardour_visibility.h"
#include "ardour/types.h"
#include "ardour/plugin.h"
namespace ARDOUR {
class Plugin;
class LIBARDOUR_API PluginManager : public boost::noncopyable {
public:
static PluginManager& instance();
static std::string scanner_bin_path;
~PluginManager ();
const ARDOUR::PluginInfoList& windows_vst_plugin_info ();
const ARDOUR::PluginInfoList& lxvst_plugin_info ();
const ARDOUR::PluginInfoList& mac_vst_plugin_info ();
const ARDOUR::PluginInfoList& ladspa_plugin_info ();
const ARDOUR::PluginInfoList& lv2_plugin_info ();
const ARDOUR::PluginInfoList& au_plugin_info ();
const ARDOUR::PluginInfoList& lua_plugin_info ();
void refresh (bool cache_only = false);
void cancel_plugin_scan();
void cancel_plugin_timeout();
void clear_vst_cache ();
void clear_vst_blacklist ();
void clear_au_cache ();
void clear_au_blacklist ();
const std::string get_default_windows_vst_path() const { return windows_vst_path; }
const std::string get_default_lxvst_path() const { return lxvst_path; }
/* always return LXVST for any VST subtype */
static PluginType to_generic_vst (PluginType);
bool cancelled () { return _cancel_scan; }
bool no_timeout () { return _cancel_timeout; }
enum PluginStatusType {
Normal = 0,
Favorite,
Hidden
};
std::string user_plugin_metadata_dir () const;
void load_statuses ();
void save_statuses ();
void set_status (ARDOUR::PluginType type, std::string unique_id, PluginStatusType status);
PluginStatusType get_status (const PluginInfoPtr&) const;
void load_tags ();
void save_tags ();
void set_tags (std::string name, ARDOUR::PluginType type, std::string unique_id, std::string tags, bool factory, bool force = false);
void reset_tags (PluginInfoPtr const&);
std::string get_tags_as_string (PluginInfoPtr const&) const;
std::vector<std::string> get_tags (PluginInfoPtr const&) const;
enum TagFilter {
All,
OnlyFavorites,
NoHidden
};
std::vector<std::string> get_all_tags (enum TagFilter) const;
/** plugins were added to or removed from one of the PluginInfoLists, OR the user has made changes to the status/tags */
PBD::Signal0<void> PluginListChanged;
/** A single plugin's Hidden/Favorite status changed */
PBD::Signal3<void, ARDOUR::PluginType, std::string, PluginStatusType> PluginStatusChanged; //PluginType t, string id, string tag
/** A single plugin's Tags status changed */
PBD::Signal3<void, ARDOUR::PluginType, std::string, std::string> PluginTagChanged; //PluginType t, string id, string tag
private:
struct PluginTag {
std::string name;
ARDOUR::PluginType type;
std::string unique_id;
std::string tags;
bool user_set;
PluginTag (std::string n, ARDOUR::PluginType t, std::string id, std::string s, bool user_set)
: name (n), type (t), unique_id (id), tags (s), user_set (user_set) {}
bool operator== (PluginTag const& other) const {
return other.type == type && other.unique_id == unique_id;
}
bool operator< (PluginTag const& other) const {
if (other.type < type) {
return true;
} else if (other.type == type && other.unique_id < unique_id) {
return true;
}
return false;
}
};
typedef std::set<PluginTag> PluginTagList;
PluginTagList ptags;
std::string sanitize_tag (const std::string) const;
struct PluginStatus {
ARDOUR::PluginType type;
std::string unique_id;
PluginStatusType status;
PluginStatus (ARDOUR::PluginType t, std::string id, PluginStatusType s = Normal)
: type (t), unique_id (id), status (s) {}
bool operator==(const PluginStatus& other) const {
return other.type == type && other.unique_id == unique_id;
}
bool operator<(const PluginStatus& other) const {
if (other.type < type) {
return true;
} else if (other.type == type && other.unique_id < unique_id) {
return true;
}
return false;
}
};
typedef std::set<PluginStatus> PluginStatusList;
PluginStatusList statuses;
ARDOUR::PluginInfoList _empty_plugin_info;
ARDOUR::PluginInfoList* _windows_vst_plugin_info;
ARDOUR::PluginInfoList* _lxvst_plugin_info;
ARDOUR::PluginInfoList* _mac_vst_plugin_info;
ARDOUR::PluginInfoList* _ladspa_plugin_info;
ARDOUR::PluginInfoList* _lv2_plugin_info;
ARDOUR::PluginInfoList* _au_plugin_info;
ARDOUR::PluginInfoList* _lua_plugin_info;
std::map<uint32_t, std::string> rdf_type;
std::string windows_vst_path;
std::string lxvst_path;
bool _cancel_scan;
bool _cancel_timeout;
void ladspa_refresh ();
void lua_refresh ();
void lua_refresh_cb ();
void windows_vst_refresh (bool cache_only = false);
void mac_vst_refresh (bool cache_only = false);
void lxvst_refresh (bool cache_only = false);
void add_lrdf_data (const std::string &path);
void add_ladspa_presets ();
void add_windows_vst_presets ();
void add_mac_vst_presets ();
void add_lxvst_presets ();
void add_presets (std::string domain);
void au_refresh (bool cache_only = false);
void lv2_refresh ();
int windows_vst_discover_from_path (std::string path, bool cache_only = false);
int windows_vst_discover (std::string path, bool cache_only = false);
int mac_vst_discover_from_path (std::string path, bool cache_only = false);
int mac_vst_discover (std::string path, bool cache_only = false);
int lxvst_discover_from_path (std::string path, bool cache_only = false);
int lxvst_discover (std::string path, bool cache_only = false);
int ladspa_discover (std::string path);
std::string get_ladspa_category (uint32_t id);
std::vector<uint32_t> ladspa_plugin_whitelist;
PBD::ScopedConnection lua_refresh_connection;
Glib::Threads::Mutex _lock;
static PluginManager* _instance; // singleton
PluginManager ();
};
} /* namespace ARDOUR */
#endif /* __ardour_plugin_manager_h__ */