annotate vamp-sdk/PluginHostAdapter.h @ 53:74822738965b

* Some doc updates
author cannam
date Wed, 21 Mar 2007 14:15:25 +0000
parents b907557b2fb9
children 9d3272c7db60
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@1 41
cannam@1 42 #include "Plugin.h"
cannam@1 43
cannam@32 44 #include <vector>
cannam@32 45
cannam@1 46 namespace Vamp {
cannam@1 47
cannam@53 48 /**
cannam@53 49 * PluginHostAdapter is a wrapper class that a Vamp host can use to
cannam@53 50 * make the C-language VampPluginDescriptor object appear as a C++
cannam@53 51 * Vamp::Plugin object.
cannam@53 52 *
cannam@53 53 * The Vamp API is defined in vamp/vamp.h as a C API. The C++ objects
cannam@53 54 * used for convenience by plugins and hosts actually communicate
cannam@53 55 * using the C low-level API, but the details of this communication
cannam@53 56 * are handled seamlessly by the Vamp SDK implementation provided the
cannam@53 57 * plugin and host use the proper C++ wrapper objects.
cannam@53 58 *
cannam@53 59 * See also PluginAdapter, the plugin-side wrapper that makes a C++
cannam@53 60 * plugin object available using the C query API.
cannam@53 61 */
cannam@53 62
cannam@1 63 class PluginHostAdapter : public Plugin
cannam@1 64 {
cannam@1 65 public:
cannam@1 66 PluginHostAdapter(const VampPluginDescriptor *descriptor,
cannam@1 67 float inputSampleRate);
cannam@1 68 virtual ~PluginHostAdapter();
cannam@32 69
cannam@32 70 static std::vector<std::string> getPluginPath();
cannam@1 71
cannam@1 72 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
cannam@1 73 void reset();
cannam@1 74
cannam@1 75 InputDomain getInputDomain() const;
cannam@1 76
cannam@50 77 unsigned int getVampApiVersion() const;
cannam@49 78 std::string getIdentifier() const;
cannam@1 79 std::string getName() const;
cannam@1 80 std::string getDescription() const;
cannam@1 81 std::string getMaker() const;
cannam@1 82 int getPluginVersion() const;
cannam@1 83 std::string getCopyright() const;
cannam@1 84
cannam@1 85 ParameterList getParameterDescriptors() const;
cannam@1 86 float getParameter(std::string) const;
cannam@1 87 void setParameter(std::string, float);
cannam@1 88
cannam@1 89 ProgramList getPrograms() const;
cannam@1 90 std::string getCurrentProgram() const;
cannam@1 91 void selectProgram(std::string);
cannam@1 92
cannam@1 93 size_t getPreferredStepSize() const;
cannam@1 94 size_t getPreferredBlockSize() const;
cannam@1 95
cannam@26 96 size_t getMinChannelCount() const;
cannam@26 97 size_t getMaxChannelCount() const;
cannam@26 98
cannam@1 99 OutputList getOutputDescriptors() const;
cannam@1 100
cannam@47 101 FeatureSet process(const float *const *inputBuffers, RealTime timestamp);
cannam@1 102
cannam@1 103 FeatureSet getRemainingFeatures();
cannam@1 104
cannam@1 105 protected:
cannam@12 106 void convertFeatures(VampFeatureList *, FeatureSet &);
cannam@1 107
cannam@1 108 const VampPluginDescriptor *m_descriptor;
cannam@1 109 VampPluginHandle m_handle;
cannam@1 110 };
cannam@1 111
cannam@1 112 }
cannam@1 113
cannam@1 114 #endif
cannam@1 115
cannam@1 116