annotate plugin/FeatureExtractionPluginFactory.h @ 1178:bf05d9259dbc pluginscan

First cut running (but not yet using output of, or recovering from errors in) the plugin checker at startup
author Chris Cannam
date Thu, 14 Apr 2016 12:12:04 +0100
parents afed8be79032
children 6b1af0f05f06
rev   line source
Chris@49 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@0 2
Chris@0 3 /*
Chris@52 4 Sonic Visualiser
Chris@52 5 An audio file viewer and annotation editor.
Chris@52 6 Centre for Digital Music, Queen Mary, University of London.
Chris@52 7 This file copyright 2006 Chris Cannam.
Chris@0 8
Chris@52 9 This program is free software; you can redistribute it and/or
Chris@52 10 modify it under the terms of the GNU General Public License as
Chris@52 11 published by the Free Software Foundation; either version 2 of the
Chris@52 12 License, or (at your option) any later version. See the file
Chris@52 13 COPYING included with this distribution for more information.
Chris@0 14 */
Chris@0 15
Chris@0 16 #ifndef _FEATURE_EXTRACTION_PLUGIN_FACTORY_H_
Chris@0 17 #define _FEATURE_EXTRACTION_PLUGIN_FACTORY_H_
Chris@0 18
Chris@0 19 #include <QString>
Chris@0 20 #include <vector>
Chris@165 21 #include <map>
Chris@0 22
Chris@486 23 #include <vamp-hostsdk/Plugin.h>
Chris@0 24
Chris@686 25 #include "base/Debug.h"
Chris@1040 26 #include "base/BaseTypes.h"
Chris@686 27
Chris@0 28 class FeatureExtractionPluginFactory
Chris@0 29 {
Chris@0 30 public:
Chris@161 31 virtual ~FeatureExtractionPluginFactory() { }
Chris@161 32
Chris@0 33 static FeatureExtractionPluginFactory *instance(QString pluginType);
Chris@0 34 static FeatureExtractionPluginFactory *instanceFor(QString identifier);
Chris@0 35 static std::vector<QString> getAllPluginIdentifiers();
Chris@0 36
Chris@66 37 virtual std::vector<QString> getPluginPath();
Chris@66 38
Chris@66 39 virtual std::vector<QString> getPluginIdentifiers();
Chris@66 40
Chris@1149 41 /**
Chris@1149 42 * Return any error message arising from the initial plugin
Chris@1149 43 * scan. The return value will either be an empty string (nothing
Chris@1149 44 * to report) or an HTML string suitable for dropping into a
Chris@1149 45 * dialog and showing the user.
Chris@1149 46 */
Chris@1149 47 virtual QString getPluginPopulationWarning() { return m_pluginScanError; }
Chris@1149 48
Chris@66 49 virtual QString findPluginFile(QString soname, QString inDir = "");
Chris@0 50
Chris@0 51 // We don't set blockSize or channels on this -- they're
Chris@0 52 // negotiated and handled via initialize() on the plugin
Chris@66 53 virtual Vamp::Plugin *instantiatePlugin(QString identifier,
Chris@1040 54 sv_samplerate_t inputSampleRate);
Chris@0 55
Chris@165 56 /**
Chris@165 57 * Get category metadata about a plugin (without instantiating it).
Chris@165 58 */
Chris@165 59 virtual QString getPluginCategory(QString identifier);
Chris@165 60
Chris@0 61 protected:
Chris@117 62 std::vector<QString> m_pluginPath;
Chris@165 63 std::map<QString, QString> m_taxonomy;
Chris@165 64
Chris@298 65 friend class PluginDeletionNotifyAdapter;
Chris@298 66 void pluginDeleted(Vamp::Plugin *);
Chris@298 67 std::map<Vamp::Plugin *, void *> m_handleMap;
Chris@1148 68
Chris@1147 69 std::vector<QString> getPluginCandidateFiles();
Chris@1149 70 std::vector<QString> winnowPluginCandidates(std::vector<QString> candidates,
Chris@1149 71 QString &warningMessage);
Chris@1147 72
Chris@165 73 void generateTaxonomy();
Chris@1149 74
Chris@1149 75 QString m_pluginScanError;
Chris@0 76 };
Chris@0 77
Chris@0 78 #endif