To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / vamp-hostsdk / PluginWrapper.h

History | View | Annotate | Download (5.41 KB)

1
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*-  vi:set ts=8 sts=4 sw=4: */
2

    
3
/*
4
    Vamp
5

6
    An API for audio analysis and feature extraction plugins.
7

8
    Centre for Digital Music, Queen Mary, University of London.
9
    Copyright 2006-2009 Chris Cannam and QMUL.
10
  
11
    Permission is hereby granted, free of charge, to any person
12
    obtaining a copy of this software and associated documentation
13
    files (the "Software"), to deal in the Software without
14
    restriction, including without limitation the rights to use, copy,
15
    modify, merge, publish, distribute, sublicense, and/or sell copies
16
    of the Software, and to permit persons to whom the Software is
17
    furnished to do so, subject to the following conditions:
18

19
    The above copyright notice and this permission notice shall be
20
    included in all copies or substantial portions of the Software.
21

22
    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
23
    EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24
    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
25
    NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
26
    ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
27
    CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28
    WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29

30
    Except as contained in this notice, the names of the Centre for
31
    Digital Music; Queen Mary, University of London; and Chris Cannam
32
    shall not be used in advertising or otherwise to promote the sale,
33
    use or other dealings in this Software without prior written
34
    authorization.
35
*/
36

    
37
#ifndef _VAMP_PLUGIN_WRAPPER_H_
38
#define _VAMP_PLUGIN_WRAPPER_H_
39

    
40
#include "hostguard.h"
41
#include <vamp-hostsdk/Plugin.h>
42

    
43
_VAMP_SDK_HOSTSPACE_BEGIN(PluginWrapper.h)
44

    
45
namespace Vamp {
46

    
47
namespace HostExt {
48

    
49
/**
50
 * \class PluginWrapper PluginWrapper.h <vamp-hostsdk/PluginWrapper.h>
51
 * 
52
 * PluginWrapper is a simple base class for adapter plugins.  It takes
53
 * a pointer to a "to be wrapped" Vamp plugin on construction, and
54
 * provides implementations of all the Vamp plugin methods that simply
55
 * delegate through to the wrapped plugin.  A subclass can therefore
56
 * override only the methods that are meaningful for the particular
57
 * adapter.
58
 *
59
 * A PluginWrapper takes ownership of the plugin it wraps, and deletes
60
 * it when it is itself deleted. To prevent this, call disownPlugin().
61
 *
62
 * \note This class was introduced in version 1.1 of the Vamp plugin SDK.
63
 */
64

    
65
class PluginWrapper : public Plugin
66
{
67
public:
68
    virtual ~PluginWrapper();
69
    
70
    bool initialise(size_t channels, size_t stepSize, size_t blockSize);
71
    void reset();
72

    
73
    InputDomain getInputDomain() const;
74

    
75
    unsigned int getVampApiVersion() const;
76
    std::string getIdentifier() const;
77
    std::string getName() const;
78
    std::string getDescription() const;
79
    std::string getMaker() const;
80
    int getPluginVersion() const;
81
    std::string getCopyright() const;
82

    
83
    ParameterList getParameterDescriptors() const;
84
    float getParameter(std::string) const;
85
    void setParameter(std::string, float);
86

    
87
    ProgramList getPrograms() const;
88
    std::string getCurrentProgram() const;
89
    void selectProgram(std::string);
90

    
91
    size_t getPreferredStepSize() const;
92
    size_t getPreferredBlockSize() const;
93

    
94
    size_t getMinChannelCount() const;
95
    size_t getMaxChannelCount() const;
96

    
97
    OutputList getOutputDescriptors() const;
98

    
99
    FeatureSet process(const float *const *inputBuffers, RealTime timestamp);
100

    
101
    FeatureSet getRemainingFeatures();
102

    
103
    /**
104
     * Return a pointer to the plugin wrapper of type WrapperType
105
     * surrounding this wrapper's plugin, if present.
106
     *
107
     * This is useful in situations where a plugin is wrapped by
108
     * multiple different wrappers (one inside another) and the host
109
     * wants to call some wrapper-specific function on one of the
110
     * layers without having to care about the order in which they are
111
     * wrapped.  For example, the plugin returned by
112
     * PluginLoader::loadPlugin may have more than one wrapper; if the
113
     * host wanted to query or fine-tune some property of one of them,
114
     * it would be hard to do so without knowing the order of the
115
     * wrappers.  This function therefore gives direct access to the
116
     * wrapper of a particular type.
117
     */
118
    template <typename WrapperType>
119
    WrapperType *getWrapper() {
120
        WrapperType *w = dynamic_cast<WrapperType *>(this);
121
        if (w) return w;
122
        PluginWrapper *pw = dynamic_cast<PluginWrapper *>(m_plugin);
123
        if (pw) return pw->getWrapper<WrapperType>();
124
        return 0;
125
    }
126

    
127
    /**
128
     * Disown the wrapped plugin, so that we no longer delete it on
129
     * our own destruction. The identity of the wrapped plugin is
130
     * unchanged, but this switches the expectation about ownership so
131
     * that the caller is expected to handle the lifecycle of the
132
     * wrapped plugin and to ensure that it outlasts this wrapper.
133
     *
134
     * This is not the normal model, but could be useful in situations
135
     * where a plugin is already managed using a smart pointer model
136
     * before being adapted into this wrapper. Note that this can't be
137
     * reversed - if you call this, you must subsequently take charge
138
     * of the wrapped plugin yourself.
139
     */
140
    void disownPlugin();
141
    
142
protected:
143
    PluginWrapper(Plugin *plugin); // I take ownership of plugin
144
    Plugin *m_plugin;
145
    bool m_pluginIsOwned;
146
};
147

    
148
}
149

    
150
}
151

    
152
_VAMP_SDK_HOSTSPACE_END(PluginWrapper.h)
153

    
154
#endif