annotate src/vamp-plugin-sdk-2.5/vamp-sdk/plugguard.h @ 83:ae30d91d2ffe

Replace these with versions built using an older toolset (so as to avoid ABI compatibilities when linking on Ubuntu 14.04 for packaging purposes)
author Chris Cannam
date Fri, 07 Feb 2020 11:51:13 +0000
parents 619f715526df
children
rev   line source
Chris@23 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@23 2
Chris@23 3 /*
Chris@23 4 Vamp
Chris@23 5
Chris@23 6 An API for audio analysis and feature extraction plugins.
Chris@23 7
Chris@23 8 Centre for Digital Music, Queen Mary, University of London.
Chris@23 9 Copyright 2006 Chris Cannam.
Chris@23 10
Chris@23 11 Permission is hereby granted, free of charge, to any person
Chris@23 12 obtaining a copy of this software and associated documentation
Chris@23 13 files (the "Software"), to deal in the Software without
Chris@23 14 restriction, including without limitation the rights to use, copy,
Chris@23 15 modify, merge, publish, distribute, sublicense, and/or sell copies
Chris@23 16 of the Software, and to permit persons to whom the Software is
Chris@23 17 furnished to do so, subject to the following conditions:
Chris@23 18
Chris@23 19 The above copyright notice and this permission notice shall be
Chris@23 20 included in all copies or substantial portions of the Software.
Chris@23 21
Chris@23 22 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
Chris@23 23 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
Chris@23 24 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
Chris@23 25 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
Chris@23 26 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
Chris@23 27 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
Chris@23 28 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Chris@23 29
Chris@23 30 Except as contained in this notice, the names of the Centre for
Chris@23 31 Digital Music; Queen Mary, University of London; and Chris Cannam
Chris@23 32 shall not be used in advertising or otherwise to promote the sale,
Chris@23 33 use or other dealings in this Software without prior written
Chris@23 34 authorization.
Chris@23 35 */
Chris@23 36
Chris@23 37 #ifndef _VAMP_SDK_PLUGGUARD_H_
Chris@23 38 #define _VAMP_SDK_PLUGGUARD_H_
Chris@23 39
Chris@23 40 /**
Chris@23 41 * Normal usage should be:
Chris@23 42 *
Chris@23 43 * - Plugins include vamp-sdk/Plugin.h or vamp-sdk/PluginBase.h.
Chris@23 44 * These files include this header, which specifies an appropriate
Chris@23 45 * namespace for the plugin classes to avoid any risk of conflict
Chris@23 46 * with non-plugin class implementations in the host on load.
Chris@23 47 *
Chris@23 48 * - Hosts include vamp-hostsdk/Plugin.h, vamp-hostsdk/PluginBase.h,
Chris@23 49 * vamp-hostsdk/PluginHostAdapter, vamp-hostsdk/PluginLoader.h etc.
Chris@23 50 * These files include vamp-hostsdk/hostguard.h, which makes a note
Chris@23 51 * that we are in a host. A file such as vamp-hostsdk/Plugin.h
Chris@23 52 * then simply includes vamp-sdk/Plugin.h, and this guard header
Chris@23 53 * takes notice of the fact that it has been included from a host
Chris@23 54 * and leaves the plugin namespace unset.
Chris@23 55 *
Chris@23 56 * Problems will occur when a host includes files directly from the
Chris@23 57 * vamp-sdk directory. There are two reasons this might happen:
Chris@23 58 * mistake, perhaps owing to ignorance of the fact that this isn't
Chris@23 59 * allowed (particularly since it was the normal mechanism in v1 of
Chris@23 60 * the SDK); and a wish to incorporate plugin code directly into the
Chris@23 61 * host rather than having to load it.
Chris@23 62 *
Chris@23 63 * What if the host does include a vamp-sdk header by mistake? We can
Chris@23 64 * catch it if it's included before something from vamp-hostsdk. If
Chris@23 65 * it's included after something from vamp-hostsdk, it will work OK
Chris@23 66 * anyway. The remaining problem case is where nothing from
Chris@23 67 * vamp-hostsdk is included in the same file. We can't catch that.
Chris@23 68 */
Chris@23 69
Chris@23 70 #ifndef _VAMP_IN_HOSTSDK
Chris@23 71
Chris@23 72 #define _VAMP_IN_PLUGINSDK 1
Chris@23 73
Chris@23 74 #define VAMP_SDK_VERSION "2.5"
Chris@23 75 #define VAMP_SDK_MAJOR_VERSION 2
Chris@23 76 #define VAMP_SDK_MINOR_VERSION 5
Chris@23 77
Chris@23 78 #ifdef _VAMP_NO_PLUGIN_NAMESPACE
Chris@23 79 #define _VAMP_SDK_PLUGSPACE_BEGIN(h)
Chris@23 80 #define _VAMP_SDK_PLUGSPACE_END(h)
Chris@23 81 #else
Chris@23 82 #ifdef _VAMP_PLUGIN_IN_HOST_NAMESPACE
Chris@23 83 #define _VAMP_SDK_PLUGSPACE_BEGIN(h) \
Chris@23 84 namespace _VampHost {
Chris@23 85
Chris@23 86 #define _VAMP_SDK_PLUGSPACE_END(h) \
Chris@23 87 } \
Chris@23 88 using namespace _VampHost;
Chris@23 89 #else
Chris@23 90 #define _VAMP_SDK_PLUGSPACE_BEGIN(h) \
Chris@23 91 namespace _VampPlugin {
Chris@23 92
Chris@23 93 #define _VAMP_SDK_PLUGSPACE_END(h) \
Chris@23 94 } \
Chris@23 95 using namespace _VampPlugin;
Chris@23 96 #endif
Chris@23 97 #endif
Chris@23 98
Chris@23 99 #endif
Chris@23 100
Chris@23 101 #endif
Chris@23 102