annotate capnproto/VampnProto.h @ 28:b5005ebc5116

Be sure not to get any unnecessary lookups -- I think this is probably redundant but at least it's explicit
author Chris Cannam <c.cannam@qmul.ac.uk>
date Tue, 24 May 2016 14:09:54 +0100
parents cc85c2851605
children f3f7561233d6
rev   line source
c@5 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
c@5 2
c@18 3 /*
c@18 4 VamPipe
c@18 5
c@18 6 Centre for Digital Music, Queen Mary, University of London.
c@18 7 Copyright 2015-2016 QMUL.
c@18 8
c@18 9 Permission is hereby granted, free of charge, to any person
c@18 10 obtaining a copy of this software and associated documentation
c@18 11 files (the "Software"), to deal in the Software without
c@18 12 restriction, including without limitation the rights to use, copy,
c@18 13 modify, merge, publish, distribute, sublicense, and/or sell copies
c@18 14 of the Software, and to permit persons to whom the Software is
c@18 15 furnished to do so, subject to the following conditions:
c@18 16
c@18 17 The above copyright notice and this permission notice shall be
c@18 18 included in all copies or substantial portions of the Software.
c@18 19
c@18 20 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
c@18 21 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
c@18 22 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
c@18 23 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
c@18 24 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
c@18 25 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
c@18 26 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
c@18 27
c@18 28 Except as contained in this notice, the names of the Centre for
c@18 29 Digital Music; Queen Mary, University of London; and Chris Cannam
c@18 30 shall not be used in advertising or otherwise to promote the sale,
c@18 31 use or other dealings in this Software without prior written
c@18 32 authorization.
c@18 33 */
c@18 34
c@5 35 #include "vamp.capnp.h"
c@5 36
c@5 37 #include <capnp/message.h>
c@5 38 #include <capnp/serialize-packed.h>
c@5 39
c@5 40 #include <vamp-hostsdk/Plugin.h>
c@5 41 #include <vamp-hostsdk/PluginLoader.h>
c@5 42 #include <vamp-hostsdk/PluginStaticData.h>
c@5 43
c@10 44 #include "bits/PluginHandleMapper.h"
c@26 45 #include "bits/RequestResponseType.h"
c@10 46
c@5 47 namespace vampipe
c@5 48 {
c@5 49
c@5 50 /**
c@5 51 * Convert the structures laid out in the Vamp SDK classes into Cap'n
c@6 52 * Proto structures (and back again).
c@5 53 *
c@6 54 * At least some of this will be necessary for any implementation
c@6 55 * using Cap'n Proto that uses the C++ Vamp SDK to provide its
c@6 56 * reference structures. An implementation could alternatively use the
c@6 57 * Cap'n Proto structures directly, and interact with Vamp plugins
c@6 58 * using the Vamp C API, without using the C++ Vamp SDK classes at
c@18 59 * all. That would avoid a lot of copying (in Cap'n Proto style).
c@5 60 */
c@6 61 class VampnProto
c@5 62 {
c@5 63 public:
c@5 64 typedef ::capnp::MallocMessageBuilder MsgBuilder;
c@5 65
c@5 66 template <typename T, typename B>
c@5 67 static void buildBasicDescriptor(B &basic, const T &t) {
c@5 68 basic.setIdentifier(t.identifier);
c@5 69 basic.setName(t.name);
c@5 70 basic.setDescription(t.description);
c@5 71 }
c@5 72
c@5 73 template <typename T, typename B>
c@5 74 static void readBasicDescriptor(T &t, const B &basic) {
c@5 75 t.identifier = basic.getIdentifier();
c@5 76 t.name = basic.getName();
c@5 77 t.description = basic.getDescription();
c@5 78 }
c@5 79
c@5 80 template <typename T, typename M>
c@5 81 static void buildValueExtents(M &m, const T &t) {
c@5 82 m.setMinValue(t.minValue);
c@5 83 m.setMaxValue(t.maxValue);
c@5 84 }
c@5 85
c@5 86 template <typename T, typename M>
c@5 87 static void readValueExtents(T &t, const M &m) {
c@5 88 t.minValue = m.getMinValue();
c@5 89 t.maxValue = m.getMaxValue();
c@5 90 }
c@5 91
c@5 92 static void buildRealTime(RealTime::Builder &b, const Vamp::RealTime &t) {
c@5 93 b.setSec(t.sec);
c@5 94 b.setNsec(t.nsec);
c@5 95 }
c@5 96
c@5 97 static void readRealTime(Vamp::RealTime &t, const RealTime::Reader &r) {
c@5 98 t.sec = r.getSec();
c@5 99 t.nsec = r.getNsec();
c@5 100 }
c@5 101
c@5 102 static SampleType
c@5 103 fromSampleType(Vamp::Plugin::OutputDescriptor::SampleType t) {
c@5 104 switch (t) {
c@5 105 case Vamp::Plugin::OutputDescriptor::OneSamplePerStep:
c@5 106 return SampleType::ONE_SAMPLE_PER_STEP;
c@5 107 case Vamp::Plugin::OutputDescriptor::FixedSampleRate:
c@5 108 return SampleType::FIXED_SAMPLE_RATE;
c@5 109 case Vamp::Plugin::OutputDescriptor::VariableSampleRate:
c@5 110 return SampleType::VARIABLE_SAMPLE_RATE;
c@5 111 }
c@5 112 throw std::logic_error("unexpected Vamp SampleType enum value");
c@5 113 }
c@5 114
c@5 115 static Vamp::Plugin::OutputDescriptor::SampleType
c@5 116 toSampleType(SampleType t) {
c@5 117 switch (t) {
c@5 118 case SampleType::ONE_SAMPLE_PER_STEP:
c@5 119 return Vamp::Plugin::OutputDescriptor::OneSamplePerStep;
c@5 120 case SampleType::FIXED_SAMPLE_RATE:
c@5 121 return Vamp::Plugin::OutputDescriptor::FixedSampleRate;
c@5 122 case SampleType::VARIABLE_SAMPLE_RATE:
c@5 123 return Vamp::Plugin::OutputDescriptor::VariableSampleRate;
c@5 124 }
c@5 125 throw std::logic_error("unexpected Capnp SampleType enum value");
c@5 126 }
c@5 127
c@5 128 static void
c@5 129 buildOutputDescriptor(OutputDescriptor::Builder &b,
c@5 130 const Vamp::Plugin::OutputDescriptor &od) {
c@5 131
c@5 132 auto basic = b.initBasic();
c@5 133 buildBasicDescriptor(basic, od);
c@5 134
c@5 135 b.setUnit(od.unit);
c@5 136
c@5 137 b.setSampleType(fromSampleType(od.sampleType));
c@5 138 b.setSampleRate(od.sampleRate);
c@5 139 b.setHasDuration(od.hasDuration);
c@5 140
c@5 141 b.setHasFixedBinCount(od.hasFixedBinCount);
c@5 142 if (od.hasFixedBinCount) {
c@5 143 b.setBinCount(od.binCount);
c@5 144 if (od.binNames.size() > 0) {
c@5 145 auto binNames = b.initBinNames(od.binNames.size());
c@5 146 for (size_t i = 0; i < od.binNames.size(); ++i) {
c@5 147 binNames.set(i, od.binNames[i]);
c@5 148 }
c@5 149 }
c@5 150 }
c@5 151
c@5 152 b.setHasKnownExtents(od.hasKnownExtents);
c@5 153 if (od.hasKnownExtents) {
c@5 154 buildValueExtents(b, od);
c@5 155 }
c@5 156
c@5 157 b.setIsQuantized(od.isQuantized);
c@5 158 if (od.isQuantized) {
c@5 159 b.setQuantizeStep(od.quantizeStep);
c@5 160 }
c@5 161 }
c@5 162
c@5 163 static void
c@5 164 readOutputDescriptor(Vamp::Plugin::OutputDescriptor &od,
c@5 165 const OutputDescriptor::Reader &r) {
c@5 166
c@5 167 readBasicDescriptor(od, r.getBasic());
c@5 168
c@5 169 od.unit = r.getUnit();
c@5 170
c@5 171 od.sampleType = toSampleType(r.getSampleType());
c@5 172 od.sampleRate = r.getSampleRate();
c@5 173 od.hasDuration = r.getHasDuration();
c@5 174
c@5 175 od.hasFixedBinCount = r.getHasFixedBinCount();
c@5 176 if (od.hasFixedBinCount) {
c@5 177 od.binCount = r.getBinCount();
c@13 178 od.binNames.clear();
c@28 179 auto nn = r.getBinNames();
c@28 180 for (const auto &n: nn) {
c@5 181 od.binNames.push_back(n);
c@5 182 }
c@5 183 }
c@5 184
c@5 185 od.hasKnownExtents = r.getHasKnownExtents();
c@5 186 if (od.hasKnownExtents) {
c@5 187 readValueExtents(od, r);
c@5 188 }
c@5 189
c@5 190 od.isQuantized = r.getIsQuantized();
c@5 191 if (od.isQuantized) {
c@5 192 od.quantizeStep = r.getQuantizeStep();
c@5 193 }
c@5 194 }
c@5 195
c@5 196 static void
c@5 197 buildParameterDescriptor(ParameterDescriptor::Builder &b,
c@5 198 const Vamp::Plugin::ParameterDescriptor &pd) {
c@5 199
c@5 200 auto basic = b.initBasic();
c@5 201 buildBasicDescriptor(basic, pd);
c@5 202
c@5 203 b.setUnit(pd.unit);
c@5 204
c@5 205 buildValueExtents(b, pd);
c@5 206
c@5 207 b.setDefaultValue(pd.defaultValue);
c@5 208
c@5 209 b.setIsQuantized(pd.isQuantized);
c@5 210 if (pd.isQuantized) {
c@5 211 b.setQuantizeStep(pd.quantizeStep);
c@5 212 }
c@5 213
c@5 214 if (pd.valueNames.size() > 0) {
c@5 215 auto valueNames = b.initValueNames(pd.valueNames.size());
c@5 216 for (size_t i = 0; i < pd.valueNames.size(); ++i) {
c@5 217 valueNames.set(i, pd.valueNames[i]);
c@5 218 }
c@5 219 }
c@5 220 }
c@5 221
c@5 222 static void
c@5 223 readParameterDescriptor(Vamp::Plugin::ParameterDescriptor &pd,
c@5 224 const ParameterDescriptor::Reader &r) {
c@5 225
c@5 226 readBasicDescriptor(pd, r.getBasic());
c@5 227
c@5 228 pd.unit = r.getUnit();
c@5 229
c@5 230 readValueExtents(pd, r);
c@5 231
c@5 232 pd.defaultValue = r.getDefaultValue();
c@5 233
c@5 234 pd.isQuantized = r.getIsQuantized();
c@5 235 if (pd.isQuantized) {
c@5 236 pd.quantizeStep = r.getQuantizeStep();
c@5 237 }
c@5 238
c@13 239 pd.valueNames.clear();
c@28 240 auto nn = r.getValueNames();
c@28 241 for (const auto &n: nn) {
c@5 242 pd.valueNames.push_back(n);
c@5 243 }
c@5 244 }
c@5 245
c@5 246 static void
c@5 247 buildFeature(Feature::Builder &b,
c@5 248 const Vamp::Plugin::Feature &f) {
c@5 249
c@5 250 b.setHasTimestamp(f.hasTimestamp);
c@5 251 if (f.hasTimestamp) {
c@5 252 auto timestamp = b.initTimestamp();
c@5 253 buildRealTime(timestamp, f.timestamp);
c@5 254 }
c@5 255
c@5 256 b.setHasDuration(f.hasDuration);
c@5 257 if (f.hasDuration) {
c@5 258 auto duration = b.initDuration();
c@5 259 buildRealTime(duration, f.duration);
c@5 260 }
c@5 261
c@5 262 b.setLabel(f.label);
c@5 263
c@5 264 if (f.values.size() > 0) {
c@5 265 auto values = b.initValues(f.values.size());
c@5 266 for (size_t i = 0; i < f.values.size(); ++i) {
c@5 267 values.set(i, f.values[i]);
c@5 268 }
c@5 269 }
c@5 270 }
c@5 271
c@5 272 static void
c@5 273 readFeature(Vamp::Plugin::Feature &f,
c@5 274 const Feature::Reader &r) {
c@5 275
c@5 276 f.hasTimestamp = r.getHasTimestamp();
c@5 277 if (f.hasTimestamp) {
c@5 278 readRealTime(f.timestamp, r.getTimestamp());
c@5 279 }
c@5 280
c@5 281 f.hasDuration = r.getHasDuration();
c@5 282 if (f.hasDuration) {
c@5 283 readRealTime(f.duration, r.getDuration());
c@5 284 }
c@5 285
c@5 286 f.label = r.getLabel();
c@5 287
c@13 288 f.values.clear();
c@28 289 auto vv = r.getValues();
c@28 290 for (auto v: vv) {
c@5 291 f.values.push_back(v);
c@5 292 }
c@5 293 }
c@5 294
c@5 295 static void
c@5 296 buildFeatureSet(FeatureSet::Builder &b,
c@5 297 const Vamp::Plugin::FeatureSet &fs) {
c@5 298
c@5 299 auto featureset = b.initFeaturePairs(fs.size());
c@5 300 int ix = 0;
c@5 301 for (const auto &fsi : fs) {
c@5 302 auto fspair = featureset[ix];
c@5 303 fspair.setOutput(fsi.first);
c@5 304 auto featurelist = fspair.initFeatures(fsi.second.size());
c@5 305 for (size_t j = 0; j < fsi.second.size(); ++j) {
c@5 306 auto feature = featurelist[j];
c@5 307 buildFeature(feature, fsi.second[j]);
c@5 308 }
c@5 309 ++ix;
c@5 310 }
c@5 311 }
c@5 312
c@5 313 static void
c@5 314 readFeatureSet(Vamp::Plugin::FeatureSet &fs,
c@5 315 const FeatureSet::Reader &r) {
c@5 316
c@13 317 fs.clear();
c@28 318 auto pp = r.getFeaturePairs();
c@28 319 for (const auto &p: pp) {
c@5 320 Vamp::Plugin::FeatureList vfl;
c@28 321 auto ff = p.getFeatures();
c@28 322 for (const auto &f: ff) {
c@5 323 Vamp::Plugin::Feature vf;
c@5 324 readFeature(vf, f);
c@5 325 vfl.push_back(vf);
c@5 326 }
c@5 327 fs[p.getOutput()] = vfl;
c@5 328 }
c@5 329 }
c@5 330
c@5 331 static InputDomain
c@5 332 fromInputDomain(Vamp::Plugin::InputDomain d) {
c@5 333 switch(d) {
c@5 334 case Vamp::Plugin::TimeDomain:
c@5 335 return InputDomain::TIME_DOMAIN;
c@5 336 case Vamp::Plugin::FrequencyDomain:
c@5 337 return InputDomain::FREQUENCY_DOMAIN;
c@5 338 default:
c@5 339 throw std::logic_error("unexpected Vamp InputDomain enum value");
c@5 340 }
c@5 341 }
c@5 342
c@5 343 static Vamp::Plugin::InputDomain
c@5 344 toInputDomain(InputDomain d) {
c@5 345 switch(d) {
c@5 346 case InputDomain::TIME_DOMAIN:
c@5 347 return Vamp::Plugin::TimeDomain;
c@5 348 case InputDomain::FREQUENCY_DOMAIN:
c@5 349 return Vamp::Plugin::FrequencyDomain;
c@5 350 default:
c@5 351 throw std::logic_error("unexpected Capnp InputDomain enum value");
c@5 352 }
c@5 353 }
c@5 354
c@5 355 static void
c@5 356 buildPluginStaticData(PluginStaticData::Builder &b,
c@5 357 const Vamp::HostExt::PluginStaticData &d) {
c@5 358
c@5 359 b.setPluginKey(d.pluginKey);
c@5 360
c@5 361 auto basic = b.initBasic();
c@5 362 buildBasicDescriptor(basic, d.basic);
c@5 363
c@5 364 b.setMaker(d.maker);
c@5 365 b.setCopyright(d.copyright);
c@5 366 b.setPluginVersion(d.pluginVersion);
c@5 367
c@5 368 auto clist = b.initCategory(d.category.size());
c@5 369 for (size_t i = 0; i < d.category.size(); ++i) {
c@5 370 clist.set(i, d.category[i]);
c@5 371 }
c@5 372
c@5 373 b.setMinChannelCount(d.minChannelCount);
c@5 374 b.setMaxChannelCount(d.maxChannelCount);
c@5 375
c@5 376 const auto &vparams = d.parameters;
c@5 377 auto plist = b.initParameters(vparams.size());
c@5 378 for (size_t i = 0; i < vparams.size(); ++i) {
c@5 379 auto pd = plist[i];
c@5 380 buildParameterDescriptor(pd, vparams[i]);
c@5 381 }
c@5 382
c@5 383 const auto &vprogs = d.programs;
c@5 384 auto pglist = b.initPrograms(vprogs.size());
c@5 385 for (size_t i = 0; i < vprogs.size(); ++i) {
c@5 386 pglist.set(i, vprogs[i]);
c@5 387 }
c@5 388
c@5 389 b.setInputDomain(fromInputDomain(d.inputDomain));
c@5 390
c@5 391 const auto &vouts = d.basicOutputInfo;
c@5 392 auto olist = b.initBasicOutputInfo(vouts.size());
c@5 393 for (size_t i = 0; i < vouts.size(); ++i) {
c@5 394 auto od = olist[i];
c@5 395 buildBasicDescriptor(od, vouts[i]);
c@5 396 }
c@5 397 }
c@5 398
c@5 399 static void
c@5 400 readPluginStaticData(Vamp::HostExt::PluginStaticData &d,
c@5 401 const PluginStaticData::Reader &r) {
c@5 402
c@5 403 d.pluginKey = r.getPluginKey();
c@5 404
c@5 405 readBasicDescriptor(d.basic, r.getBasic());
c@5 406
c@5 407 d.maker = r.getMaker();
c@5 408 d.copyright = r.getCopyright();
c@5 409 d.pluginVersion = r.getPluginVersion();
c@5 410
c@13 411 d.category.clear();
c@28 412 auto cc = r.getCategory();
c@28 413 for (auto c: cc) {
c@5 414 d.category.push_back(c);
c@5 415 }
c@5 416
c@5 417 d.minChannelCount = r.getMinChannelCount();
c@5 418 d.maxChannelCount = r.getMaxChannelCount();
c@5 419
c@13 420 d.parameters.clear();
c@28 421 auto pp = r.getParameters();
c@28 422 for (auto p: pp) {
c@5 423 Vamp::Plugin::ParameterDescriptor pd;
c@5 424 readParameterDescriptor(pd, p);
c@5 425 d.parameters.push_back(pd);
c@5 426 }
c@5 427
c@13 428 d.programs.clear();
c@28 429 auto prp = r.getPrograms();
c@28 430 for (auto p: prp) {
c@5 431 d.programs.push_back(p);
c@5 432 }
c@5 433
c@5 434 d.inputDomain = toInputDomain(r.getInputDomain());
c@5 435
c@13 436 d.basicOutputInfo.clear();
c@28 437 auto oo = r.getBasicOutputInfo();
c@28 438 for (auto o: oo) {
c@5 439 Vamp::HostExt::PluginStaticData::Basic b;
c@5 440 readBasicDescriptor(b, o);
c@5 441 d.basicOutputInfo.push_back(b);
c@5 442 }
c@5 443 }
c@5 444
c@5 445 static void
c@5 446 buildPluginConfiguration(PluginConfiguration::Builder &b,
c@5 447 const Vamp::HostExt::PluginConfiguration &c) {
c@5 448
c@5 449 const auto &vparams = c.parameterValues;
c@5 450 auto params = b.initParameterValues(vparams.size());
c@5 451 int i = 0;
c@5 452 for (const auto &pp : vparams) {
c@5 453 auto param = params[i++];
c@5 454 param.setParameter(pp.first);
c@5 455 param.setValue(pp.second);
c@5 456 }
c@5 457
c@5 458 b.setCurrentProgram(c.currentProgram);
c@5 459 b.setChannelCount(c.channelCount);
c@5 460 b.setStepSize(c.stepSize);
c@5 461 b.setBlockSize(c.blockSize);
c@5 462 }
c@5 463
c@5 464 static void
c@5 465 readPluginConfiguration(Vamp::HostExt::PluginConfiguration &c,
c@5 466 const PluginConfiguration::Reader &r) {
c@5 467
c@28 468 auto pp = r.getParameterValues();
c@28 469 for (const auto &p: pp) {
c@28 470 c.parameterValues[p.getParameter()] = p.getValue();
c@5 471 }
c@5 472
c@5 473 c.currentProgram = r.getCurrentProgram();
c@5 474 c.channelCount = r.getChannelCount();
c@5 475 c.stepSize = r.getStepSize();
c@5 476 c.blockSize = r.getBlockSize();
c@5 477 }
c@5 478
c@5 479 static void
c@5 480 buildLoadRequest(LoadRequest::Builder &r,
c@5 481 const Vamp::HostExt::LoadRequest &req) {
c@5 482
c@5 483 r.setPluginKey(req.pluginKey);
c@5 484 r.setInputSampleRate(req.inputSampleRate);
c@5 485
c@5 486 std::vector<AdapterFlag> flags;
c@5 487 if (req.adapterFlags & Vamp::HostExt::PluginLoader::ADAPT_INPUT_DOMAIN) {
c@5 488 flags.push_back(AdapterFlag::ADAPT_INPUT_DOMAIN);
c@5 489 }
c@5 490 if (req.adapterFlags & Vamp::HostExt::PluginLoader::ADAPT_CHANNEL_COUNT) {
c@5 491 flags.push_back(AdapterFlag::ADAPT_CHANNEL_COUNT);
c@5 492 }
c@5 493 if (req.adapterFlags & Vamp::HostExt::PluginLoader::ADAPT_BUFFER_SIZE) {
c@5 494 flags.push_back(AdapterFlag::ADAPT_BUFFER_SIZE);
c@5 495 }
c@5 496
c@5 497 auto f = r.initAdapterFlags(flags.size());
c@5 498 for (size_t i = 0; i < flags.size(); ++i) {
c@5 499 f.set(i, flags[i]);
c@5 500 }
c@5 501 }
c@5 502
c@5 503 static void
c@5 504 readLoadRequest(Vamp::HostExt::LoadRequest &req,
c@5 505 const LoadRequest::Reader &r) {
c@5 506
c@5 507 req.pluginKey = r.getPluginKey();
c@5 508 req.inputSampleRate = r.getInputSampleRate();
c@5 509
c@5 510 int flags = 0;
c@28 511 auto aa = r.getAdapterFlags();
c@28 512 for (auto a: aa) {
c@5 513 if (a == AdapterFlag::ADAPT_INPUT_DOMAIN) {
c@5 514 flags |= Vamp::HostExt::PluginLoader::ADAPT_INPUT_DOMAIN;
c@5 515 }
c@5 516 if (a == AdapterFlag::ADAPT_CHANNEL_COUNT) {
c@5 517 flags |= Vamp::HostExt::PluginLoader::ADAPT_CHANNEL_COUNT;
c@5 518 }
c@5 519 if (a == AdapterFlag::ADAPT_BUFFER_SIZE) {
c@5 520 flags |= Vamp::HostExt::PluginLoader::ADAPT_BUFFER_SIZE;
c@5 521 }
c@5 522 }
c@5 523 req.adapterFlags = flags;
c@5 524 }
c@10 525
c@10 526 static void
c@10 527 buildLoadResponse(LoadResponse::Builder &b,
c@10 528 const Vamp::HostExt::LoadResponse &resp,
c@10 529 PluginHandleMapper &mapper) {
c@10 530
c@10 531 b.setPluginHandle(mapper.pluginToHandle(resp.plugin));
c@10 532 auto sd = b.initStaticData();
c@10 533 buildPluginStaticData(sd, resp.staticData);
c@10 534 auto conf = b.initDefaultConfiguration();
c@10 535 buildPluginConfiguration(conf, resp.defaultConfiguration);
c@10 536 }
c@10 537
c@10 538 static void
c@10 539 readLoadResponse(Vamp::HostExt::LoadResponse &resp,
c@10 540 const LoadResponse::Reader &r,
c@10 541 PluginHandleMapper &mapper) {
c@10 542
c@10 543 resp.plugin = mapper.handleToPlugin(r.getPluginHandle());
c@10 544 readPluginStaticData(resp.staticData, r.getStaticData());
c@10 545 readPluginConfiguration(resp.defaultConfiguration,
c@10 546 r.getDefaultConfiguration());
c@10 547 }
c@13 548
c@13 549 static void
c@13 550 buildConfigurationRequest(ConfigurationRequest::Builder &b,
c@13 551 const Vamp::HostExt::ConfigurationRequest &cr,
c@13 552 PluginHandleMapper &mapper) {
c@13 553
c@13 554 b.setPluginHandle(mapper.pluginToHandle(cr.plugin));
c@13 555 auto c = b.initConfiguration();
c@13 556 buildPluginConfiguration(c, cr.configuration);
c@13 557 }
c@13 558
c@13 559 static void
c@13 560 readConfigurationRequest(Vamp::HostExt::ConfigurationRequest &cr,
c@13 561 const ConfigurationRequest::Reader &r,
c@13 562 PluginHandleMapper &mapper) {
c@13 563
c@13 564 auto h = r.getPluginHandle();
c@13 565 cr.plugin = mapper.handleToPlugin(h);
c@13 566 auto c = r.getConfiguration();
c@13 567 readPluginConfiguration(cr.configuration, c);
c@13 568 }
c@13 569
c@13 570 static void
c@13 571 buildConfigurationResponse(ConfigurationResponse::Builder &b,
c@13 572 const Vamp::HostExt::ConfigurationResponse &cr) {
c@13 573
c@13 574 auto olist = b.initOutputs(cr.outputs.size());
c@13 575 for (size_t i = 0; i < cr.outputs.size(); ++i) {
c@13 576 auto od = olist[i];
c@13 577 buildOutputDescriptor(od, cr.outputs[i]);
c@13 578 }
c@13 579 }
c@13 580
c@13 581 static void
c@13 582 readConfigurationResponse(Vamp::HostExt::ConfigurationResponse &cr,
c@13 583 const ConfigurationResponse::Reader &r) {
c@13 584
c@13 585 cr.outputs.clear();
c@28 586 auto oo = r.getOutputs();
c@28 587 for (const auto &o: oo) {
c@13 588 Vamp::Plugin::OutputDescriptor desc;
c@13 589 readOutputDescriptor(desc, o);
c@13 590 cr.outputs.push_back(desc);
c@13 591 }
c@13 592 }
c@14 593
c@14 594 static void
c@14 595 buildProcessInput(ProcessInput::Builder &b,
c@14 596 Vamp::RealTime timestamp,
c@14 597 const std::vector<std::vector<float> > &buffers) {
c@14 598
c@14 599 auto t = b.initTimestamp();
c@14 600 buildRealTime(t, timestamp);
c@14 601 auto vv = b.initInputBuffers(buffers.size());
c@14 602 for (size_t ch = 0; ch < buffers.size(); ++ch) {
c@14 603 const int n = int(buffers[ch].size());
c@14 604 vv.init(ch, n);
c@14 605 auto v = vv[ch];
c@14 606 for (int i = 0; i < n; ++i) {
c@14 607 v.set(i, buffers[ch][i]);
c@14 608 }
c@14 609 }
c@14 610 }
c@14 611
c@14 612 static void
c@14 613 readProcessInput(Vamp::RealTime &timestamp,
c@14 614 std::vector<std::vector<float> > &buffers,
c@14 615 const ProcessInput::Reader &b) {
c@14 616
c@14 617 readRealTime(timestamp, b.getTimestamp());
c@14 618 buffers.clear();
c@28 619 auto vv = b.getInputBuffers();
c@28 620 for (const auto &v: vv) {
c@14 621 std::vector<float> buf;
c@14 622 for (auto x: v) {
c@14 623 buf.push_back(x);
c@14 624 }
c@14 625 buffers.push_back(buf);
c@14 626 }
c@14 627 }
c@14 628
c@14 629 static void
c@14 630 buildProcessRequest(ProcessRequest::Builder &b,
c@14 631 const Vamp::HostExt::ProcessRequest &pr,
c@14 632 PluginHandleMapper &mapper) {
c@14 633
c@14 634 b.setPluginHandle(mapper.pluginToHandle(pr.plugin));
c@14 635 auto input = b.initInput();
c@14 636 buildProcessInput(input, pr.timestamp, pr.inputBuffers);
c@14 637 }
c@14 638
c@14 639 static void
c@14 640 readProcessRequest(Vamp::HostExt::ProcessRequest &pr,
c@14 641 const ProcessRequest::Reader &r,
c@14 642 PluginHandleMapper &mapper) {
c@14 643
c@14 644 auto h = r.getPluginHandle();
c@14 645 pr.plugin = mapper.handleToPlugin(h);
c@14 646 readProcessInput(pr.timestamp, pr.inputBuffers, r.getInput());
c@14 647 }
c@14 648
c@14 649 static void
c@15 650 buildProcessResponse(ProcessResponse::Builder &b,
c@15 651 const Vamp::HostExt::ProcessResponse &pr) {
c@15 652
c@15 653 auto f = b.initFeatures();
c@15 654 buildFeatureSet(f, pr.features);
c@15 655 }
c@15 656
c@15 657 static void
c@15 658 readProcessResponse(Vamp::HostExt::ProcessResponse &pr,
c@15 659 const ProcessResponse::Reader &r) {
c@15 660
c@15 661 readFeatureSet(pr.features, r.getFeatures());
c@15 662 }
c@15 663
c@15 664 static void
c@15 665 buildVampRequest_List(VampRequest::Builder &b) {
c@14 666 b.getRequest().setList();
c@14 667 }
c@14 668
c@14 669 static void
c@15 670 buildVampResponse_List(VampResponse::Builder &b,
c@17 671 std::string errorText,
c@17 672 const std::vector<Vamp::HostExt::PluginStaticData> &d) {
c@15 673 b.setSuccess(errorText == "");
c@15 674 b.setErrorText(errorText);
c@24 675 auto r = b.getResponse().initList();
c@24 676 auto p = r.initPlugins(d.size());
c@15 677 for (size_t i = 0; i < d.size(); ++i) {
c@24 678 auto pd = p[i];
c@24 679 buildPluginStaticData(pd, d[i]);
c@15 680 }
c@15 681 }
c@15 682
c@15 683 static void
c@15 684 buildVampRequest_Load(VampRequest::Builder &b,
c@15 685 const Vamp::HostExt::LoadRequest &req) {
c@14 686 auto u = b.getRequest().initLoad();
c@14 687 buildLoadRequest(u, req);
c@14 688 }
c@14 689
c@14 690 static void
c@15 691 buildVampResponse_Load(VampResponse::Builder &b,
c@15 692 const Vamp::HostExt::LoadResponse &resp,
c@15 693 PluginHandleMapper &mapper) {
c@17 694 b.setSuccess(resp.plugin != 0);
c@17 695 b.setErrorText("");
c@15 696 auto u = b.getResponse().initLoad();
c@15 697 buildLoadResponse(u, resp, mapper);
c@15 698 }
c@15 699
c@15 700 static void
c@15 701 buildVampRequest_Configure(VampRequest::Builder &b,
c@15 702 const Vamp::HostExt::ConfigurationRequest &cr,
c@15 703 PluginHandleMapper &mapper) {
c@14 704 auto u = b.getRequest().initConfigure();
c@14 705 buildConfigurationRequest(u, cr, mapper);
c@14 706 }
c@14 707
c@14 708 static void
c@15 709 buildVampResponse_Configure(VampResponse::Builder &b,
c@15 710 const Vamp::HostExt::ConfigurationResponse &cr) {
c@17 711 b.setSuccess(!cr.outputs.empty());
c@17 712 b.setErrorText("");
c@15 713 auto u = b.getResponse().initConfigure();
c@15 714 buildConfigurationResponse(u, cr);
c@15 715 }
c@15 716
c@15 717 static void
c@15 718 buildVampRequest_Process(VampRequest::Builder &b,
c@15 719 const Vamp::HostExt::ProcessRequest &pr,
c@15 720 PluginHandleMapper &mapper) {
c@14 721 auto u = b.getRequest().initProcess();
c@14 722 buildProcessRequest(u, pr, mapper);
c@14 723 }
c@15 724
c@15 725 static void
c@15 726 buildVampResponse_Process(VampResponse::Builder &b,
c@23 727 const Vamp::HostExt::ProcessResponse &pr) {
c@17 728 b.setSuccess(true);
c@17 729 b.setErrorText("");
c@15 730 auto u = b.getResponse().initProcess();
c@15 731 buildProcessResponse(u, pr);
c@15 732 }
c@17 733
c@17 734 static void
c@23 735 buildVampRequest_Finish(VampRequest::Builder &b,
c@23 736 Vamp::Plugin *p,
c@23 737 PluginHandleMapper &mapper) {
c@17 738
c@23 739 auto u = b.getRequest().initFinish();
c@23 740 u.setPluginHandle(mapper.pluginToHandle(p));
c@17 741 }
c@17 742
c@17 743 static void
c@17 744 buildVampResponse_Finish(VampResponse::Builder &b,
c@17 745 const Vamp::HostExt::ProcessResponse &pr) {
c@17 746
c@17 747 buildVampResponse_Process(b, pr);
c@17 748 }
c@26 749
c@26 750 static RRType
c@26 751 getRequestResponseType(const VampRequest::Reader &r) {
c@26 752 switch (r.getRequest().which()) {
c@26 753 case VampRequest::Request::Which::LIST:
c@26 754 return RRType::List;
c@26 755 case VampRequest::Request::Which::LOAD:
c@26 756 return RRType::Load;
c@26 757 case VampRequest::Request::Which::CONFIGURE:
c@26 758 return RRType::Configure;
c@26 759 case VampRequest::Request::Which::PROCESS:
c@26 760 return RRType::Process;
c@26 761 case VampRequest::Request::Which::FINISH:
c@26 762 return RRType::Finish;
c@26 763 }
c@27 764 return RRType::NotValid;
c@26 765 }
c@26 766
c@26 767 static RRType
c@26 768 getRequestResponseType(const VampResponse::Reader &r) {
c@26 769 switch (r.getResponse().which()) {
c@26 770 case VampResponse::Response::Which::LIST:
c@26 771 return RRType::List;
c@26 772 case VampResponse::Response::Which::LOAD:
c@26 773 return RRType::Load;
c@26 774 case VampResponse::Response::Which::CONFIGURE:
c@26 775 return RRType::Configure;
c@26 776 case VampResponse::Response::Which::PROCESS:
c@26 777 return RRType::Process;
c@26 778 case VampResponse::Response::Which::FINISH:
c@26 779 return RRType::Finish;
c@26 780 }
c@27 781 return RRType::NotValid;
c@26 782 }
c@26 783
c@26 784 static void
c@26 785 readVampRequest_List(const VampRequest::Reader &r) {
c@26 786 if (getRequestResponseType(r) != RRType::List) {
c@27 787 throw std::logic_error("not a list request");
c@26 788 }
c@26 789 }
c@26 790
c@26 791 static void
c@26 792 readVampResponse_List(std::vector<Vamp::HostExt::PluginStaticData> &v,
c@26 793 const VampResponse::Reader &r) {
c@26 794 if (getRequestResponseType(r) != RRType::List) {
c@27 795 throw std::logic_error("not a list response");
c@26 796 }
c@26 797 v.clear();
c@26 798 if (r.getSuccess()) {
c@28 799 auto pp = r.getResponse().getList().getPlugins();
c@28 800 for (const auto &p: pp) {
c@26 801 Vamp::HostExt::PluginStaticData psd;
c@26 802 readPluginStaticData(psd, p);
c@26 803 v.push_back(psd);
c@26 804 }
c@26 805 }
c@26 806 }
c@26 807
c@27 808 static void
c@27 809 readVampRequest_Load(Vamp::HostExt::LoadRequest &req,
c@27 810 const VampRequest::Reader &r) {
c@27 811 if (getRequestResponseType(r) != RRType::Load) {
c@27 812 throw std::logic_error("not a load request");
c@27 813 }
c@27 814 readLoadRequest(req, r.getRequest().getLoad());
c@27 815 }
c@27 816
c@27 817 static void
c@27 818 readVampResponse_Load(Vamp::HostExt::LoadResponse &resp,
c@27 819 const VampResponse::Reader &r,
c@27 820 PluginHandleMapper &mapper) {
c@27 821 if (getRequestResponseType(r) != RRType::Load) {
c@27 822 throw std::logic_error("not a load response");
c@27 823 }
c@27 824 resp = {};
c@27 825 if (r.getSuccess()) {
c@27 826 readLoadResponse(resp, r.getResponse().getLoad(), mapper);
c@27 827 }
c@27 828 }
c@27 829
c@27 830 static void
c@27 831 readVampRequest_Configure(Vamp::HostExt::ConfigurationRequest &req,
c@27 832 const VampRequest::Reader &r,
c@27 833 PluginHandleMapper &mapper) {
c@27 834 if (getRequestResponseType(r) != RRType::Configure) {
c@27 835 throw std::logic_error("not a configuration request");
c@27 836 }
c@27 837 readConfigurationRequest(req, r.getRequest().getConfigure(), mapper);
c@27 838 }
c@27 839
c@27 840 static void
c@27 841 readVampResponse_Configure(Vamp::HostExt::ConfigurationResponse &resp,
c@27 842 const VampResponse::Reader &r) {
c@27 843 if (getRequestResponseType(r) != RRType::Configure) {
c@27 844 throw std::logic_error("not a configuration response");
c@27 845 }
c@27 846 resp = {};
c@27 847 if (r.getSuccess()) {
c@27 848 readConfigurationResponse(resp, r.getResponse().getConfigure());
c@27 849 }
c@27 850 }
c@27 851
c@27 852 static void
c@27 853 readVampRequest_Process(Vamp::HostExt::ProcessRequest &req,
c@27 854 const VampRequest::Reader &r,
c@27 855 PluginHandleMapper &mapper) {
c@27 856 if (getRequestResponseType(r) != RRType::Process) {
c@27 857 throw std::logic_error("not a process request");
c@27 858 }
c@27 859 readProcessRequest(req, r.getRequest().getProcess(), mapper);
c@27 860 }
c@27 861
c@27 862 static void
c@27 863 readVampResponse_Process(Vamp::HostExt::ProcessResponse &resp,
c@27 864 const VampResponse::Reader &r) {
c@27 865 if (getRequestResponseType(r) != RRType::Process) {
c@27 866 throw std::logic_error("not a process response");
c@27 867 }
c@27 868 resp = {};
c@27 869 if (r.getSuccess()) {
c@27 870 readProcessResponse(resp, r.getResponse().getProcess());
c@27 871 }
c@27 872 }
c@27 873
c@27 874 static void
c@27 875 readVampRequest_Finish(Vamp::Plugin *&finishPlugin,
c@27 876 const VampRequest::Reader &r,
c@27 877 PluginHandleMapper &mapper) {
c@27 878 if (getRequestResponseType(r) != RRType::Finish) {
c@27 879 throw std::logic_error("not a finish request");
c@27 880 }
c@27 881 finishPlugin = mapper.handleToPlugin
c@27 882 (r.getRequest().getFinish().getPluginHandle());
c@27 883 }
c@27 884
c@27 885 static void
c@27 886 readVampResponse_Finish(Vamp::HostExt::ProcessResponse &resp,
c@27 887 const VampResponse::Reader &r) {
c@27 888 if (getRequestResponseType(r) != RRType::Finish) {
c@27 889 throw std::logic_error("not a finish response");
c@27 890 }
c@27 891 resp = {};
c@27 892 if (r.getSuccess()) {
c@27 893 readProcessResponse(resp, r.getResponse().getFinish());
c@27 894 }
c@27 895 }
c@5 896 };
c@5 897
c@5 898 }
c@5 899
c@5 900