/* * Copyright (C) 2000-2013 Paul Davis * Copyright (C) 2005-2006 Taybin Rutkin * Copyright (C) 2008-2011 David Robillard * Copyright (C) 2009-2011 Carl Hetherington * Copyright (C) 2014-2019 Robin Gareus * Copyright (C) 2018 Ben Loftis * * 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., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #ifndef __ardour_plugin_manager_h__ #define __ardour_plugin_manager_h__ #ifdef WAF_BUILD #include "libardour-config.h" #endif #include #include #include #include #include #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, Concealed }; 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 (); bool load_plugin_order_file (XMLNode &n) const; //returns TRUE if the passed-in node has valid info void save_plugin_order_file (XMLNode &elem) const; enum TagType { FromPlug, //tag info is being set from plugin metadata FromFactoryFile, // ... from the factory metadata file FromUserFile, // ... from the user's config data FromGui // ... from the UI, in realtime: will emit a signal so ui can show "sanitized" string as it is generated }; void set_tags (ARDOUR::PluginType type, std::string unique_id, std::string tags, std::string name, TagType tagtype); void reset_tags (PluginInfoPtr const&); std::string get_tags_as_string (PluginInfoPtr const&) const; std::vector get_tags (PluginInfoPtr const&) const; enum TagFilter { All, OnlyFavorites, NoHidden }; std::vector get_all_tags (enum TagFilter) const; /** plugins were added to or removed from one of the PluginInfoLists */ PBD::Signal0 PluginListChanged; /** A single plugin's Hidden/Favorite status changed */ PBD::Signal3 PluginStatusChanged; //PluginType t, string id, string tag /** A single plugin's Tags status changed */ PBD::Signal3 PluginTagChanged; //PluginType t, string id, string tag private: struct PluginTag { ARDOUR::PluginType type; std::string unique_id; std::string tags; std::string name; TagType tagtype; PluginTag (ARDOUR::PluginType t, std::string id, std::string tag, std::string n, TagType tt) : type (t), unique_id (id), tags (tag), name(n), tagtype (tt) {} 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 PluginTagList; PluginTagList ptags; PluginTagList ftags; /* factory-file defaults */ 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 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 rdf_type; std::string windows_vst_path; std::string lxvst_path; bool _cancel_scan; bool _cancel_timeout; void detect_name_ambiguities (ARDOUR::PluginInfoList*); void detect_type_ambiguities (ARDOUR::PluginInfoList&); 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 ladspa_plugin_whitelist; PBD::ScopedConnection lua_refresh_connection; Glib::Threads::Mutex _lock; static PluginManager* _instance; // singleton PluginManager (); }; } /* namespace ARDOUR */ #endif /* __ardour_plugin_manager_h__ */