Chris@423
|
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
|
Chris@423
|
2
|
Chris@423
|
3 /*
|
Chris@423
|
4 Vamp
|
Chris@423
|
5
|
Chris@423
|
6 An API for audio analysis and feature extraction plugins.
|
Chris@423
|
7
|
Chris@423
|
8 Centre for Digital Music, Queen Mary, University of London.
|
Chris@423
|
9 Copyright 2006-2016 Chris Cannam and QMUL.
|
Chris@423
|
10
|
Chris@423
|
11 Permission is hereby granted, free of charge, to any person
|
Chris@423
|
12 obtaining a copy of this software and associated documentation
|
Chris@423
|
13 files (the "Software"), to deal in the Software without
|
Chris@423
|
14 restriction, including without limitation the rights to use, copy,
|
Chris@423
|
15 modify, merge, publish, distribute, sublicense, and/or sell copies
|
Chris@423
|
16 of the Software, and to permit persons to whom the Software is
|
Chris@423
|
17 furnished to do so, subject to the following conditions:
|
Chris@423
|
18
|
Chris@423
|
19 The above copyright notice and this permission notice shall be
|
Chris@423
|
20 included in all copies or substantial portions of the Software.
|
Chris@423
|
21
|
Chris@423
|
22 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
Chris@423
|
23 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
Chris@423
|
24 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
Chris@423
|
25 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
|
Chris@423
|
26 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
Chris@423
|
27 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
Chris@423
|
28 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
Chris@423
|
29
|
Chris@423
|
30 Except as contained in this notice, the names of the Centre for
|
Chris@423
|
31 Digital Music; Queen Mary, University of London; and Chris Cannam
|
Chris@423
|
32 shall not be used in advertising or otherwise to promote the sale,
|
Chris@423
|
33 use or other dealings in this Software without prior written
|
Chris@423
|
34 authorization.
|
Chris@423
|
35 */
|
Chris@423
|
36
|
Chris@423
|
37 #ifndef VAMP_LOAD_REQUEST_H
|
Chris@423
|
38 #define VAMP_LOAD_REQUEST_H
|
Chris@423
|
39
|
Chris@423
|
40 #include "PluginStaticData.h"
|
Chris@423
|
41 #include "PluginConfiguration.h"
|
Chris@423
|
42
|
Chris@423
|
43 #include "hostguard.h"
|
Chris@423
|
44
|
Chris@423
|
45 #include <map>
|
Chris@423
|
46 #include <string>
|
Chris@423
|
47
|
Chris@423
|
48 _VAMP_SDK_HOSTSPACE_BEGIN(LoadRequest.h)
|
Chris@423
|
49
|
Chris@423
|
50 namespace Vamp {
|
Chris@423
|
51
|
Chris@423
|
52 class Plugin;
|
Chris@423
|
53
|
Chris@423
|
54 namespace HostExt {
|
Chris@423
|
55
|
Chris@423
|
56 /**
|
Chris@423
|
57 * \class LoadRequest LoadRequest.h <vamp-hostsdk/LoadRequest.h>
|
Chris@423
|
58 *
|
Chris@423
|
59 * Vamp::HostExt::LoadRequest is a structure containing the
|
Chris@423
|
60 * information necessary to load a plugin. When a request is made to
|
Chris@423
|
61 * load a plugin using a LoadRequest, the response is typically
|
Chris@423
|
62 * returned in a LoadResponse structure.
|
Chris@423
|
63 *
|
Chris@423
|
64 * \see LoadResponse
|
Chris@423
|
65 *
|
Chris@423
|
66 * \note This class was introduced in version 2.7 of the Vamp plugin
|
Chris@423
|
67 * SDK, along with the PluginLoader method that accepts this structure
|
Chris@423
|
68 * rather than accepting its elements individually.
|
Chris@423
|
69 */
|
Chris@423
|
70 struct LoadRequest
|
Chris@423
|
71 {
|
Chris@423
|
72 LoadRequest() : // invalid request by default
|
Chris@423
|
73 inputSampleRate(0.f),
|
Chris@423
|
74 adapterFlags(0) { }
|
Chris@423
|
75
|
Chris@423
|
76 std::string pluginKey; //!!! separate out key from PluginLoader??
|
Chris@423
|
77 float inputSampleRate;
|
Chris@423
|
78 int adapterFlags; //!!! from PluginLoader::AdapterFlags, but how best to handle?
|
Chris@423
|
79 };
|
Chris@423
|
80
|
Chris@423
|
81 /**
|
Chris@423
|
82 * \class LoadResponse LoadResponse.h <vamp-hostsdk/LoadResponse.h>
|
Chris@423
|
83 *
|
Chris@423
|
84 * Vamp::HostExt::LoadResponse is a structure containing the
|
Chris@423
|
85 * information returned by PluginLoader when asked to load a plugin
|
Chris@423
|
86 * using a LoadRequest.
|
Chris@423
|
87 *
|
Chris@423
|
88 * If the plugin could not be loaded, the plugin field will be 0.
|
Chris@423
|
89 *
|
Chris@423
|
90 * The caller takes ownership of the plugin contained here, which
|
Chris@423
|
91 * should be deleted (using the standard C++ delete keyword) after
|
Chris@423
|
92 * use.
|
Chris@423
|
93 *
|
Chris@423
|
94 * \see LoadRequest
|
Chris@423
|
95 *
|
Chris@423
|
96 * \note This class was introduced in version 2.7 of the Vamp plugin
|
Chris@423
|
97 * SDK, along with the PluginLoader method that returns this structure.
|
Chris@423
|
98 */
|
Chris@423
|
99 struct LoadResponse
|
Chris@423
|
100 {
|
Chris@423
|
101 LoadResponse() : // invalid (failed) response by default
|
Chris@423
|
102 plugin(0) { }
|
Chris@423
|
103
|
Chris@423
|
104 Plugin *plugin;
|
Chris@423
|
105 PluginStaticData staticData;
|
Chris@423
|
106 PluginConfiguration defaultConfiguration;
|
Chris@423
|
107 };
|
Chris@423
|
108
|
Chris@423
|
109 }
|
Chris@423
|
110
|
Chris@423
|
111 }
|
Chris@423
|
112
|
Chris@423
|
113 _VAMP_SDK_HOSTSPACE_END(LoadRequest.h)
|
Chris@423
|
114
|
Chris@423
|
115 #endif
|