annotate bits/CountingPluginHandleMapper.h @ 42:91f5c92d3bf7

Some JSON fixes and a quick test program
author Chris Cannam <c.cannam@qmul.ac.uk>
date Tue, 23 Aug 2016 12:04:49 +0100
parents 55d69b26d4db
children f4244a2d55ac
rev   line source
c@40 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
c@40 2
c@40 3 /*
c@40 4 Vampipe
c@40 5
c@40 6 Centre for Digital Music, Queen Mary, University of London.
c@40 7 Copyright 2006-2016 Chris Cannam and QMUL.
c@40 8
c@40 9 Permission is hereby granted, free of charge, to any person
c@40 10 obtaining a copy of this software and associated documentation
c@40 11 files (the "Software"), to deal in the Software without
c@40 12 restriction, including without limitation the rights to use, copy,
c@40 13 modify, merge, publish, distribute, sublicense, and/or sell copies
c@40 14 of the Software, and to permit persons to whom the Software is
c@40 15 furnished to do so, subject to the following conditions:
c@40 16
c@40 17 The above copyright notice and this permission notice shall be
c@40 18 included in all copies or substantial portions of the Software.
c@40 19
c@40 20 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
c@40 21 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
c@40 22 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
c@40 23 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
c@40 24 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
c@40 25 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
c@40 26 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
c@40 27
c@40 28 Except as contained in this notice, the names of the Centre for
c@40 29 Digital Music; Queen Mary, University of London; and Chris Cannam
c@40 30 shall not be used in advertising or otherwise to promote the sale,
c@40 31 use or other dealings in this Software without prior written
c@40 32 authorization.
c@40 33 */
c@40 34
c@40 35 #ifndef VAMPIPE_COUNTING_PLUGIN_HANDLE_MAPPER_H
c@40 36 #define VAMPIPE_COUNTING_PLUGIN_HANDLE_MAPPER_H
c@40 37
c@40 38 #include "PluginHandleMapper.h"
c@40 39
c@40 40 #include <set>
c@40 41 #include <map>
c@40 42
c@40 43 namespace vampipe {
c@40 44
c@40 45 //!!! NB not thread-safe at present, should it be?
c@40 46 class CountingPluginHandleMapper : public PluginHandleMapper
c@40 47 {
c@40 48 public:
c@40 49 CountingPluginHandleMapper() : m_nextHandle(1) { }
c@40 50
c@40 51 void addPlugin(Vamp::Plugin *p) {
c@40 52 if (m_rplugins.find(p) == m_rplugins.end()) {
c@40 53 int32_t h = m_nextHandle++;
c@40 54 m_plugins[h] = p;
c@40 55 m_rplugins[p] = h;
c@40 56 }
c@40 57 }
c@40 58
c@40 59 void removePlugin(int32_t h) {
c@40 60 if (m_plugins.find(h) == m_plugins.end()) {
c@40 61 throw NotFound();
c@40 62 }
c@40 63 Vamp::Plugin *p = m_plugins[h];
c@40 64 m_plugins.erase(h);
c@40 65 if (isConfigured(h)) {
c@40 66 m_configuredPlugins.erase(h);
c@40 67 m_channelCounts.erase(h);
c@40 68 }
c@40 69 m_rplugins.erase(p);
c@40 70 }
c@40 71
c@40 72 int32_t pluginToHandle(Vamp::Plugin *p) const {
c@40 73 if (m_rplugins.find(p) == m_rplugins.end()) {
c@40 74 throw NotFound();
c@40 75 }
c@40 76 return m_rplugins.at(p);
c@40 77 }
c@40 78
c@40 79 Vamp::Plugin *handleToPlugin(int32_t h) const {
c@40 80 if (m_plugins.find(h) == m_plugins.end()) {
c@40 81 throw NotFound();
c@40 82 }
c@40 83 return m_plugins.at(h);
c@40 84 }
c@40 85
c@40 86 bool isConfigured(int32_t h) const {
c@40 87 return m_configuredPlugins.find(h) != m_configuredPlugins.end();
c@40 88 }
c@40 89
c@40 90 void markConfigured(int32_t h, int channelCount, int blockSize) {
c@40 91 m_configuredPlugins.insert(h);
c@40 92 m_channelCounts[h] = channelCount;
c@40 93 m_blockSizes[h] = blockSize;
c@40 94 }
c@40 95
c@40 96 int getChannelCount(int32_t h) const {
c@40 97 if (m_channelCounts.find(h) == m_channelCounts.end()) {
c@40 98 throw NotFound();
c@40 99 }
c@40 100 return m_channelCounts.at(h);
c@40 101 }
c@40 102
c@40 103 int getBlockSize(int32_t h) const {
c@40 104 if (m_blockSizes.find(h) == m_blockSizes.end()) {
c@40 105 throw NotFound();
c@40 106 }
c@40 107 return m_blockSizes.at(h);
c@40 108 }
c@40 109
c@40 110 private:
c@40 111 int32_t m_nextHandle; // NB plugin handle type must fit in JSON number
c@40 112 std::map<uint32_t, Vamp::Plugin *> m_plugins;
c@40 113 std::map<Vamp::Plugin *, uint32_t> m_rplugins;
c@40 114 std::set<uint32_t> m_configuredPlugins;
c@40 115 std::map<uint32_t, int> m_channelCounts;
c@40 116 std::map<uint32_t, int> m_blockSizes;
c@40 117 };
c@40 118
c@40 119 }
c@40 120
c@40 121 #endif