annotate vamp-hostsdk/LoadRequest.h @ 423:8c45dee08a95 vampipe

Add PluginConfiguration, PluginStaticData, and LoadRequest structures, and use them in PluginLoader
author Chris Cannam
date Thu, 12 May 2016 12:22:02 +0100
parents
children 6b2567f365b0
rev   line source
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