annotate vamp-sdk/PluginHostAdapter.h @ 61:97c5ac99d725 host-factory-stuff

* install hostext headers to vamp-sdk/hostext/ rather than vamp-sdk/ * adjust timestamps in input-domain adapter so as to centre them on block as required by Plugin documentation * better handling for frequency-domain plugins that want non-power-of-two blocksizes (can't handle them, but at least try offering them a power-of-two alternative) * couple of Plugin doc additions * make PluginLoader capable of returning ready-wrapped plugins
author cannam
date Fri, 01 Jun 2007 13:53:42 +0000
parents 0284955e31e5
children
rev   line source
cannam@1 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
cannam@1 2
cannam@1 3 /*
cannam@1 4 Vamp
cannam@1 5
cannam@1 6 An API for audio analysis and feature extraction plugins.
cannam@1 7
cannam@1 8 Centre for Digital Music, Queen Mary, University of London.
cannam@1 9 Copyright 2006 Chris Cannam.
cannam@1 10
cannam@1 11 Permission is hereby granted, free of charge, to any person
cannam@1 12 obtaining a copy of this software and associated documentation
cannam@1 13 files (the "Software"), to deal in the Software without
cannam@1 14 restriction, including without limitation the rights to use, copy,
cannam@1 15 modify, merge, publish, distribute, sublicense, and/or sell copies
cannam@1 16 of the Software, and to permit persons to whom the Software is
cannam@1 17 furnished to do so, subject to the following conditions:
cannam@1 18
cannam@1 19 The above copyright notice and this permission notice shall be
cannam@1 20 included in all copies or substantial portions of the Software.
cannam@1 21
cannam@1 22 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
cannam@1 23 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
cannam@1 24 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
cannam@6 25 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
cannam@1 26 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
cannam@1 27 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
cannam@1 28 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
cannam@1 29
cannam@1 30 Except as contained in this notice, the names of the Centre for
cannam@1 31 Digital Music; Queen Mary, University of London; and Chris Cannam
cannam@1 32 shall not be used in advertising or otherwise to promote the sale,
cannam@1 33 use or other dealings in this Software without prior written
cannam@1 34 authorization.
cannam@1 35 */
cannam@1 36
cannam@5 37 #ifndef _VAMP_PLUGIN_HOST_ADAPTER_H_
cannam@5 38 #define _VAMP_PLUGIN_HOST_ADAPTER_H_
cannam@1 39
cannam@10 40 #include <vamp/vamp.h>
cannam@56 41 #include <vamp-sdk/Plugin.h>
cannam@1 42
cannam@32 43 #include <vector>
cannam@32 44
cannam@1 45 namespace Vamp {
cannam@1 46
cannam@53 47 /**
cannam@53 48 * PluginHostAdapter is a wrapper class that a Vamp host can use to
cannam@53 49 * make the C-language VampPluginDescriptor object appear as a C++
cannam@53 50 * Vamp::Plugin object.
cannam@53 51 *
cannam@53 52 * The Vamp API is defined in vamp/vamp.h as a C API. The C++ objects
cannam@53 53 * used for convenience by plugins and hosts actually communicate
cannam@53 54 * using the C low-level API, but the details of this communication
cannam@53 55 * are handled seamlessly by the Vamp SDK implementation provided the
cannam@53 56 * plugin and host use the proper C++ wrapper objects.
cannam@53 57 *
cannam@53 58 * See also PluginAdapter, the plugin-side wrapper that makes a C++
cannam@53 59 * plugin object available using the C query API.
cannam@53 60 */
cannam@53 61
cannam@1 62 class PluginHostAdapter : public Plugin
cannam@1 63 {
cannam@1 64 public:
cannam@1 65 PluginHostAdapter(const VampPluginDescriptor *descriptor,
cannam@1 66 float inputSampleRate);
cannam@1 67 virtual ~PluginHostAdapter();
cannam@32 68
cannam@32 69 static std::vector<std::string> getPluginPath();
cannam@1 70
cannam@1 71 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
cannam@1 72 void reset();
cannam@1 73
cannam@1 74 InputDomain getInputDomain() const;
cannam@1 75
cannam@50 76 unsigned int getVampApiVersion() const;
cannam@49 77 std::string getIdentifier() const;
cannam@1 78 std::string getName() const;
cannam@1 79 std::string getDescription() const;
cannam@1 80 std::string getMaker() const;
cannam@1 81 int getPluginVersion() const;
cannam@1 82 std::string getCopyright() const;
cannam@1 83
cannam@1 84 ParameterList getParameterDescriptors() const;
cannam@1 85 float getParameter(std::string) const;
cannam@1 86 void setParameter(std::string, float);
cannam@1 87
cannam@1 88 ProgramList getPrograms() const;
cannam@1 89 std::string getCurrentProgram() const;
cannam@1 90 void selectProgram(std::string);
cannam@1 91
cannam@1 92 size_t getPreferredStepSize() const;
cannam@1 93 size_t getPreferredBlockSize() const;
cannam@1 94
cannam@26 95 size_t getMinChannelCount() const;
cannam@26 96 size_t getMaxChannelCount() const;
cannam@26 97
cannam@1 98 OutputList getOutputDescriptors() const;
cannam@1 99
cannam@47 100 FeatureSet process(const float *const *inputBuffers, RealTime timestamp);
cannam@1 101
cannam@1 102 FeatureSet getRemainingFeatures();
cannam@1 103
cannam@1 104 protected:
cannam@12 105 void convertFeatures(VampFeatureList *, FeatureSet &);
cannam@1 106
cannam@1 107 const VampPluginDescriptor *m_descriptor;
cannam@1 108 VampPluginHandle m_handle;
cannam@1 109 };
cannam@1 110
cannam@1 111 }
cannam@1 112
cannam@1 113 #endif
cannam@1 114
cannam@1 115