annotate PyPluginObject.cpp @ 37:fd249e29a721

Add remaining accessors to plugin; move outputs to getOutputs (distinguishing between static parameters and dynamic output descriptors... is this wise?)
author Chris Cannam
date Wed, 26 Nov 2014 14:20:54 +0000
parents 20a9fcbc2f5f
children 13dcfe8c7ed7
rev   line source
Chris@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@0 2
Chris@26 3 /*
Chris@26 4 VampyHost
Chris@26 5
Chris@26 6 Use Vamp audio analysis plugins in Python
Chris@26 7
Chris@26 8 Gyorgy Fazekas and Chris Cannam
Chris@26 9 Centre for Digital Music, Queen Mary, University of London
Chris@26 10 Copyright 2008-2014 Queen Mary, University of London
Chris@26 11
Chris@26 12 Permission is hereby granted, free of charge, to any person
Chris@26 13 obtaining a copy of this software and associated documentation
Chris@26 14 files (the "Software"), to deal in the Software without
Chris@26 15 restriction, including without limitation the rights to use, copy,
Chris@26 16 modify, merge, publish, distribute, sublicense, and/or sell copies
Chris@26 17 of the Software, and to permit persons to whom the Software is
Chris@26 18 furnished to do so, subject to the following conditions:
Chris@26 19
Chris@26 20 The above copyright notice and this permission notice shall be
Chris@26 21 included in all copies or substantial portions of the Software.
Chris@26 22
Chris@26 23 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
Chris@26 24 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
Chris@26 25 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
Chris@26 26 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
Chris@26 27 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
Chris@26 28 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
Chris@26 29 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Chris@26 30
Chris@26 31 Except as contained in this notice, the names of the Centre for
Chris@26 32 Digital Music; Queen Mary, University of London; and the authors
Chris@26 33 shall not be used in advertising or otherwise to promote the sale,
Chris@26 34 use or other dealings in this Software without prior written
Chris@26 35 authorization.
Chris@26 36 */
Chris@26 37
Chris@31 38 #include "PyPluginObject.h"
Chris@14 39
Chris@14 40 // define a unique API pointer
Chris@27 41 #define PY_ARRAY_UNIQUE_SYMBOL VAMPYHOST_ARRAY_API
Chris@14 42 #define NPY_NO_DEPRECATED_API NPY_1_7_API_VERSION
Chris@31 43 #define NO_IMPORT_ARRAY
Chris@14 44 #include "numpy/arrayobject.h"
Chris@14 45
Chris@33 46 #include "structmember.h"
Chris@33 47
Chris@29 48 #include "VectorConversion.h"
Chris@16 49 #include "PyRealTime.h"
Chris@0 50
Chris@0 51 #include <string>
Chris@31 52 #include <vector>
Chris@33 53 #include <cstddef>
Chris@0 54
Chris@0 55 using namespace std;
Chris@0 56 using namespace Vamp;
Chris@0 57
Chris@2 58 PyDoc_STRVAR(xx_foo_doc, "Some description"); //!!!
Chris@0 59
Chris@28 60 //!!! todo: conv errors
Chris@28 61
Chris@31 62 static
Chris@21 63 PyPluginObject *
Chris@21 64 getPluginObject(PyObject *pyPluginHandle)
Chris@21 65 {
Chris@21 66 PyPluginObject *pd = 0;
Chris@21 67 if (PyPlugin_Check(pyPluginHandle)) {
Chris@21 68 pd = (PyPluginObject *)pyPluginHandle;
Chris@16 69 }
Chris@16 70 if (!pd || !pd->plugin) {
Chris@16 71 PyErr_SetString(PyExc_AttributeError,
Chris@16 72 "Invalid or already deleted plugin handle.");
Chris@16 73 return 0;
Chris@0 74 } else {
Chris@16 75 return pd;
Chris@0 76 }
Chris@0 77 }
Chris@0 78
Chris@34 79 static
Chris@34 80 PyObject *
Chris@34 81 pystr(const string &s)
Chris@34 82 {
Chris@34 83 return PyString_FromString(s.c_str());
Chris@34 84 }
Chris@34 85
Chris@31 86 PyObject *
Chris@31 87 PyPluginObject_From_Plugin(Plugin *plugin)
Chris@0 88 {
Chris@31 89 PyPluginObject *pd =
Chris@31 90 (PyPluginObject *)PyType_GenericAlloc(&Plugin_Type, 0);
Chris@21 91 pd->plugin = plugin;
Chris@21 92 pd->isInitialised = false;
Chris@21 93 pd->channels = 0;
Chris@21 94 pd->blockSize = 0;
Chris@21 95 pd->stepSize = 0;
Chris@34 96
Chris@34 97 PyObject *infodict = PyDict_New();
Chris@34 98 PyDict_SetItemString
Chris@34 99 (infodict, "apiVersion", PyInt_FromLong(plugin->getVampApiVersion()));
Chris@34 100 PyDict_SetItemString
Chris@34 101 (infodict, "pluginVersion", PyInt_FromLong(plugin->getPluginVersion()));
Chris@34 102 PyDict_SetItemString
Chris@34 103 (infodict, "identifier", pystr(plugin->getIdentifier()));
Chris@34 104 PyDict_SetItemString
Chris@34 105 (infodict, "name", pystr(plugin->getName()));
Chris@34 106 PyDict_SetItemString
Chris@34 107 (infodict, "description", pystr(plugin->getDescription()));
Chris@34 108 PyDict_SetItemString
Chris@34 109 (infodict, "maker", pystr(plugin->getMaker()));
Chris@34 110 PyDict_SetItemString
Chris@34 111 (infodict, "copyright", pystr(plugin->getCopyright()));
Chris@34 112 pd->info = infodict;
Chris@34 113
Chris@34 114 pd->inputDomain = plugin->getInputDomain();
Chris@34 115
Chris@35 116 VectorConversion conv;
Chris@35 117
Chris@34 118 Plugin::ParameterList pl = plugin->getParameterDescriptors();
Chris@34 119 PyObject *params = PyList_New(pl.size());
Chris@34 120
Chris@34 121 for (int i = 0; i < (int)pl.size(); ++i) {
Chris@34 122 PyObject *paramdict = PyDict_New();
Chris@34 123 PyDict_SetItemString
Chris@34 124 (paramdict, "identifier", pystr(pl[i].identifier));
Chris@34 125 PyDict_SetItemString
Chris@34 126 (paramdict, "name", pystr(pl[i].name));
Chris@34 127 PyDict_SetItemString
Chris@34 128 (paramdict, "description", pystr(pl[i].description));
Chris@34 129 PyDict_SetItemString
Chris@34 130 (paramdict, "unit", pystr(pl[i].unit));
Chris@34 131 PyDict_SetItemString
Chris@34 132 (paramdict, "minValue", PyFloat_FromDouble(pl[i].minValue));
Chris@34 133 PyDict_SetItemString
Chris@34 134 (paramdict, "maxValue", PyFloat_FromDouble(pl[i].maxValue));
Chris@34 135 PyDict_SetItemString
Chris@34 136 (paramdict, "defaultValue", PyFloat_FromDouble(pl[i].defaultValue));
Chris@34 137 if (pl[i].isQuantized) {
Chris@34 138 PyDict_SetItemString
Chris@34 139 (paramdict, "isQuantized", Py_True);
Chris@34 140 PyDict_SetItemString
Chris@34 141 (paramdict, "quantizeStep", PyFloat_FromDouble(pl[i].quantizeStep));
Chris@34 142 if (!pl[i].valueNames.empty()) {
Chris@34 143 PyDict_SetItemString
Chris@34 144 (paramdict, "valueNames", conv.PyValue_From_StringVector(pl[i].valueNames));
Chris@34 145 }
Chris@34 146 } else {
Chris@34 147 PyDict_SetItemString
Chris@34 148 (paramdict, "isQuantized", Py_False);
Chris@34 149 }
Chris@34 150
Chris@34 151 PyList_SET_ITEM(params, i, paramdict);
Chris@34 152 }
Chris@34 153
Chris@34 154 pd->parameters = params;
Chris@37 155
Chris@37 156 return (PyObject *)pd;
Chris@37 157 }
Chris@35 158
Chris@37 159 static void
Chris@37 160 PyPluginObject_dealloc(PyPluginObject *self)
Chris@37 161 {
Chris@37 162 delete self->plugin;
Chris@37 163 PyObject_Del(self);
Chris@37 164 }
Chris@37 165
Chris@37 166 static PyObject *
Chris@37 167 getOutputs(PyObject *self, PyObject *args)
Chris@37 168 {
Chris@37 169 PyPluginObject *pd = getPluginObject(self);
Chris@37 170 if (!pd) return 0;
Chris@37 171
Chris@37 172 Plugin::OutputList ol = pd->plugin->getOutputDescriptors();
Chris@35 173 PyObject *outputs = PyList_New(ol.size());
Chris@35 174
Chris@35 175 for (int i = 0; i < (int)ol.size(); ++i) {
Chris@35 176 PyObject *outdict = PyDict_New();
Chris@35 177 PyDict_SetItemString
Chris@35 178 (outdict, "identifier", pystr(ol[i].identifier));
Chris@35 179 PyDict_SetItemString
Chris@35 180 (outdict, "name", pystr(ol[i].name));
Chris@35 181 PyDict_SetItemString
Chris@35 182 (outdict, "description", pystr(ol[i].description));
Chris@35 183 PyDict_SetItemString
Chris@35 184 (outdict, "binCount", PyInt_FromLong(ol[i].binCount));
Chris@35 185 if (ol[i].binCount > 0) {
Chris@35 186 if (ol[i].hasKnownExtents) {
Chris@35 187 PyDict_SetItemString
Chris@35 188 (outdict, "hasKnownExtents", Py_True);
Chris@35 189 PyDict_SetItemString
Chris@35 190 (outdict, "minValue", PyFloat_FromDouble(ol[i].minValue));
Chris@35 191 PyDict_SetItemString
Chris@35 192 (outdict, "maxValue", PyFloat_FromDouble(ol[i].maxValue));
Chris@35 193 } else {
Chris@35 194 PyDict_SetItemString
Chris@35 195 (outdict, "hasKnownExtents", Py_False);
Chris@35 196 }
Chris@35 197 if (ol[i].isQuantized) {
Chris@35 198 PyDict_SetItemString
Chris@35 199 (outdict, "isQuantized", Py_True);
Chris@35 200 PyDict_SetItemString
Chris@35 201 (outdict, "quantizeStep", PyFloat_FromDouble(ol[i].quantizeStep));
Chris@35 202 } else {
Chris@35 203 PyDict_SetItemString
Chris@35 204 (outdict, "isQuantized", Py_False);
Chris@35 205 }
Chris@35 206 }
Chris@35 207 PyDict_SetItemString
Chris@35 208 (outdict, "sampleType", PyInt_FromLong((int)ol[i].sampleType));
Chris@35 209 PyDict_SetItemString
Chris@35 210 (outdict, "sampleRate", PyFloat_FromDouble(ol[i].sampleRate));
Chris@35 211 PyDict_SetItemString
Chris@35 212 (outdict, "hasDuration", ol[i].hasDuration ? Py_True : Py_False);
Chris@35 213
Chris@35 214 PyList_SET_ITEM(outputs, i, outdict);
Chris@35 215 }
Chris@35 216
Chris@37 217 return outputs;
Chris@33 218 }
Chris@33 219
Chris@0 220 static PyObject *
Chris@0 221 vampyhost_initialise(PyObject *self, PyObject *args)
Chris@0 222 {
luis@7 223 size_t channels, blockSize, stepSize;
Chris@0 224
Chris@23 225 if (!PyArg_ParseTuple (args, "nnn",
luis@7 226 (size_t) &channels,
luis@7 227 (size_t) &stepSize,
Chris@23 228 (size_t) &blockSize)) {
Chris@0 229 PyErr_SetString(PyExc_TypeError,
Chris@23 230 "initialise() takes channel count, step size, and block size arguments");
Chris@16 231 return 0;
Chris@0 232 }
Chris@0 233
Chris@23 234 PyPluginObject *pd = getPluginObject(self);
Chris@16 235 if (!pd) return 0;
Chris@0 236
Chris@16 237 pd->channels = channels;
Chris@16 238 pd->stepSize = stepSize;
Chris@16 239 pd->blockSize = blockSize;
Chris@0 240
Chris@16 241 if (!pd->plugin->initialise(channels, stepSize, blockSize)) {
Chris@17 242 cerr << "Failed to initialise native plugin adapter with channels = " << channels << ", stepSize = " << stepSize << ", blockSize = " << blockSize << " and ADAPT_ALL_SAFE set" << endl;
Chris@0 243 PyErr_SetString(PyExc_TypeError,
Chris@17 244 "Plugin initialization failed");
Chris@16 245 return 0;
Chris@6 246 }
Chris@0 247
Chris@16 248 pd->isInitialised = true;
luis@7 249
Chris@0 250 return Py_True;
Chris@0 251 }
Chris@0 252
Chris@0 253 static PyObject *
Chris@23 254 vampyhost_reset(PyObject *self, PyObject *)
Chris@18 255 {
Chris@23 256 PyPluginObject *pd = getPluginObject(self);
Chris@18 257 if (!pd) return 0;
Chris@18 258
Chris@18 259 if (!pd->isInitialised) {
Chris@18 260 PyErr_SetString(PyExc_StandardError,
Chris@18 261 "Plugin has not been initialised");
Chris@18 262 return 0;
Chris@18 263 }
Chris@18 264
Chris@18 265 pd->plugin->reset();
Chris@18 266 return Py_True;
Chris@18 267 }
Chris@18 268
Chris@18 269 static PyObject *
Chris@20 270 vampyhost_getParameter(PyObject *self, PyObject *args)
Chris@20 271 {
Chris@20 272 PyObject *pyParam;
Chris@20 273
Chris@23 274 if (!PyArg_ParseTuple(args, "S", &pyParam)) {
Chris@20 275 PyErr_SetString(PyExc_TypeError,
Chris@23 276 "getParameter() takes parameter id (string) argument");
Chris@20 277 return 0; }
Chris@20 278
Chris@23 279 PyPluginObject *pd = getPluginObject(self);
Chris@20 280 if (!pd) return 0;
Chris@20 281
Chris@20 282 float value = pd->plugin->getParameter(PyString_AS_STRING(pyParam));
Chris@20 283 return PyFloat_FromDouble(double(value));
Chris@20 284 }
Chris@20 285
Chris@20 286 static PyObject *
Chris@20 287 vampyhost_setParameter(PyObject *self, PyObject *args)
Chris@20 288 {
Chris@20 289 PyObject *pyParam;
Chris@20 290 float value;
Chris@20 291
Chris@23 292 if (!PyArg_ParseTuple(args, "Sf", &pyParam, &value)) {
Chris@20 293 PyErr_SetString(PyExc_TypeError,
Chris@23 294 "setParameter() takes parameter id (string), and value (float) arguments");
Chris@20 295 return 0; }
Chris@20 296
Chris@23 297 PyPluginObject *pd = getPluginObject(self);
Chris@20 298 if (!pd) return 0;
Chris@20 299
Chris@20 300 pd->plugin->setParameter(PyString_AS_STRING(pyParam), value);
Chris@20 301 return Py_True;
Chris@20 302 }
Chris@20 303
Chris@35 304 static
Chris@35 305 PyObject *
Chris@35 306 convertFeatureSet(const Plugin::FeatureSet &fs)
Chris@35 307 {
Chris@35 308 VectorConversion conv;
Chris@35 309
Chris@35 310 PyObject *pyFs = PyDict_New();
Chris@35 311
Chris@35 312 for (Plugin::FeatureSet::const_iterator fsi = fs.begin();
Chris@35 313 fsi != fs.end(); ++fsi) {
Chris@35 314
Chris@35 315 int fno = fsi->first;
Chris@35 316 const Plugin::FeatureList &fl = fsi->second;
Chris@35 317
Chris@35 318 if (!fl.empty()) {
Chris@35 319
Chris@35 320 PyObject *pyFl = PyList_New(fl.size());
Chris@35 321
Chris@35 322 for (int fli = 0; fli < (int)fl.size(); ++fli) {
Chris@35 323
Chris@35 324 const Plugin::Feature &f = fl[fli];
Chris@35 325 PyObject *pyF = PyDict_New();
Chris@35 326
Chris@35 327 if (f.hasTimestamp) {
Chris@35 328 PyDict_SetItemString
Chris@35 329 (pyF, "timestamp", PyRealTime_FromRealTime(f.timestamp));
Chris@35 330 }
Chris@35 331 if (f.hasDuration) {
Chris@35 332 PyDict_SetItemString
Chris@35 333 (pyF, "duration", PyRealTime_FromRealTime(f.duration));
Chris@35 334 }
Chris@35 335
Chris@35 336 PyDict_SetItemString
Chris@35 337 (pyF, "label", pystr(f.label));
Chris@35 338
Chris@35 339 if (!f.values.empty()) {
Chris@35 340 PyDict_SetItemString
Chris@35 341 (pyF, "values", conv.PyArray_From_FloatVector(f.values));
Chris@35 342 }
Chris@35 343
Chris@35 344 PyList_SET_ITEM(pyFl, fli, pyF);
Chris@35 345 }
Chris@35 346
Chris@35 347 PyObject *pyN = PyInt_FromLong(fno);
Chris@35 348 PyDict_SetItem(pyFs, pyN, pyFl);
Chris@35 349 }
Chris@35 350 }
Chris@35 351
Chris@35 352 return pyFs;
Chris@35 353 }
Chris@35 354
Chris@20 355 static PyObject *
Chris@0 356 vampyhost_process(PyObject *self, PyObject *args)
Chris@0 357 {
Chris@0 358 PyObject *pyBuffer;
Chris@0 359 PyObject *pyRealTime;
Chris@0 360
Chris@23 361 if (!PyArg_ParseTuple(args, "OO",
Chris@0 362 &pyBuffer, // Audio data
Chris@0 363 &pyRealTime)) { // TimeStamp
Chris@0 364 PyErr_SetString(PyExc_TypeError,
Chris@17 365 "process() takes plugin handle (object), buffer (2D array of channels * samples floats) and timestamp (RealTime) arguments");
Chris@16 366 return 0; }
Chris@0 367
Chris@0 368 if (!PyRealTime_Check(pyRealTime)) {
Chris@0 369 PyErr_SetString(PyExc_TypeError,"Valid timestamp required.");
Chris@16 370 return 0; }
Chris@0 371
Chris@17 372 if (!PyList_Check(pyBuffer)) {
Chris@17 373 PyErr_SetString(PyExc_TypeError, "List of NumPy Array required for process input.");
Chris@17 374 return 0;
Chris@17 375 }
Chris@17 376
Chris@23 377 PyPluginObject *pd = getPluginObject(self);
Chris@16 378 if (!pd) return 0;
Chris@0 379
Chris@0 380 if (!pd->isInitialised) {
Chris@0 381 PyErr_SetString(PyExc_StandardError,
Chris@0 382 "Plugin has not been initialised.");
Chris@16 383 return 0;
Chris@16 384 }
Chris@0 385
Chris@12 386 int channels = pd->channels;
Chris@0 387
Chris@4 388 if (PyList_GET_SIZE(pyBuffer) != channels) {
Chris@17 389 cerr << "Wrong number of channels: got " << PyList_GET_SIZE(pyBuffer) << ", expected " << channels << endl;
Chris@4 390 PyErr_SetString(PyExc_TypeError, "Wrong number of channels");
Chris@16 391 return 0;
Chris@4 392 }
Chris@0 393
Chris@4 394 float **inbuf = new float *[channels];
Chris@0 395
Chris@29 396 VectorConversion typeConv;
Chris@17 397
Chris@12 398 vector<vector<float> > data;
Chris@4 399 for (int c = 0; c < channels; ++c) {
Chris@4 400 PyObject *cbuf = PyList_GET_ITEM(pyBuffer, c);
Chris@17 401 data.push_back(typeConv.PyValue_To_FloatVector(cbuf));
Chris@12 402 }
Chris@12 403
Chris@12 404 for (int c = 0; c < channels; ++c) {
Chris@17 405 if (data[c].size() != pd->blockSize) {
Chris@17 406 cerr << "Wrong number of samples on channel " << c << ": expected " << pd->blockSize << " (plugin's block size), got " << data[c].size() << endl;
Chris@17 407 PyErr_SetString(PyExc_TypeError, "Wrong number of samples");
Chris@17 408 return 0;
Chris@17 409 }
Chris@12 410 inbuf[c] = &data[c][0];
Chris@4 411 }
Chris@0 412
Chris@12 413 RealTime timeStamp = *PyRealTime_AsRealTime(pyRealTime);
Chris@0 414
Chris@18 415 Plugin::FeatureSet fs = pd->plugin->process(inbuf, timeStamp);
Chris@0 416
Chris@4 417 delete[] inbuf;
Chris@0 418
Chris@35 419 return convertFeatureSet(fs);
Chris@35 420 }
Chris@0 421
Chris@35 422 static PyObject *
Chris@35 423 vampyhost_getRemainingFeatures(PyObject *self, PyObject *)
Chris@35 424 {
Chris@35 425 PyPluginObject *pd = getPluginObject(self);
Chris@35 426 if (!pd) return 0;
Chris@18 427
Chris@35 428 if (!pd->isInitialised) {
Chris@35 429 PyErr_SetString(PyExc_StandardError,
Chris@35 430 "Plugin has not been initialised.");
Chris@35 431 return 0;
Chris@35 432 }
Chris@18 433
Chris@35 434 Plugin::FeatureSet fs = pd->plugin->getRemainingFeatures();
Chris@18 435
Chris@35 436 return convertFeatureSet(fs);
Chris@0 437 }
Chris@0 438
Chris@23 439 static PyObject *
Chris@37 440 vampyhost_getPreferredBlockSize(PyObject *self, PyObject *)
Chris@37 441 {
Chris@37 442 PyPluginObject *pd = getPluginObject(self);
Chris@37 443 if (!pd) return 0;
Chris@37 444 return PyInt_FromLong(pd->plugin->getPreferredBlockSize());
Chris@37 445 }
Chris@37 446
Chris@37 447 static PyObject *
Chris@37 448 vampyhost_getPreferredStepSize(PyObject *self, PyObject *)
Chris@37 449 {
Chris@37 450 PyPluginObject *pd = getPluginObject(self);
Chris@37 451 if (!pd) return 0;
Chris@37 452 return PyInt_FromLong(pd->plugin->getPreferredStepSize());
Chris@37 453 }
Chris@37 454
Chris@37 455 static PyObject *
Chris@37 456 vampyhost_getMinChannelCount(PyObject *self, PyObject *)
Chris@37 457 {
Chris@37 458 PyPluginObject *pd = getPluginObject(self);
Chris@37 459 if (!pd) return 0;
Chris@37 460 return PyInt_FromLong(pd->plugin->getMinChannelCount());
Chris@37 461 }
Chris@37 462
Chris@37 463 static PyObject *
Chris@37 464 vampyhost_getMaxChannelCount(PyObject *self, PyObject *)
Chris@37 465 {
Chris@37 466 PyPluginObject *pd = getPluginObject(self);
Chris@37 467 if (!pd) return 0;
Chris@37 468 return PyInt_FromLong(pd->plugin->getMaxChannelCount());
Chris@37 469 }
Chris@37 470
Chris@37 471 static PyObject *
Chris@23 472 vampyhost_unload(PyObject *self, PyObject *)
Chris@23 473 {
Chris@23 474 PyPluginObject *pd = getPluginObject(self);
Chris@23 475 if (!pd) return 0;
Chris@23 476
Chris@23 477 delete pd->plugin;
Chris@32 478 pd->plugin = 0; // This is checked by getPluginObject, so we avoid
Chris@32 479 // blowing up if called repeatedly
Chris@23 480
Chris@23 481 return Py_True;
Chris@23 482 }
Chris@23 483
Chris@33 484 static PyMemberDef PyPluginObject_members[] =
Chris@33 485 {
Chris@34 486 {(char *)"info", T_OBJECT, offsetof(PyPluginObject, info), READONLY,
Chris@34 487 xx_foo_doc},
Chris@34 488
Chris@34 489 {(char *)"inputDomain", T_INT, offsetof(PyPluginObject, inputDomain), READONLY,
Chris@34 490 xx_foo_doc},
Chris@34 491
Chris@34 492 {(char *)"parameters", T_OBJECT, offsetof(PyPluginObject, parameters), READONLY,
Chris@34 493 xx_foo_doc},
Chris@33 494
Chris@33 495 {0, 0}
Chris@33 496 };
Chris@33 497
Chris@21 498 static PyMethodDef PyPluginObject_methods[] =
Chris@21 499 {
Chris@37 500 {"getOutputs", getOutputs, METH_NOARGS,
Chris@37 501 xx_foo_doc},
Chris@37 502
Chris@37 503 {"getParameterValue", vampyhost_getParameter, METH_VARARGS,
Chris@23 504 xx_foo_doc}, //!!! fix all these!
Chris@23 505
Chris@37 506 {"setParameterValue", vampyhost_setParameter, METH_VARARGS,
Chris@37 507 xx_foo_doc},
Chris@37 508
Chris@37 509 {"getPreferredBlockSize", vampyhost_getPreferredBlockSize, METH_VARARGS,
Chris@37 510 xx_foo_doc}, //!!! fix all these!
Chris@37 511
Chris@37 512 {"getPreferredStepSize", vampyhost_getPreferredStepSize, METH_VARARGS,
Chris@37 513 xx_foo_doc},
Chris@37 514
Chris@37 515 {"getMinChannelCount", vampyhost_getMinChannelCount, METH_VARARGS,
Chris@37 516 xx_foo_doc}, //!!! fix all these!
Chris@37 517
Chris@37 518 {"getMaxChannelCount", vampyhost_getMaxChannelCount, METH_VARARGS,
Chris@23 519 xx_foo_doc},
Chris@33 520
Chris@23 521 {"initialise", vampyhost_initialise, METH_VARARGS,
Chris@23 522 xx_foo_doc},
Chris@23 523
Chris@23 524 {"reset", vampyhost_reset, METH_NOARGS,
Chris@23 525 xx_foo_doc},
Chris@23 526
Chris@23 527 {"process", vampyhost_process, METH_VARARGS,
Chris@23 528 xx_foo_doc},
Chris@23 529
Chris@35 530 {"getRemainingFeatures", vampyhost_getRemainingFeatures, METH_NOARGS,
Chris@35 531 xx_foo_doc},
Chris@35 532
Chris@23 533 {"unload", vampyhost_unload, METH_NOARGS,
Chris@23 534 xx_foo_doc},
Chris@23 535
Chris@21 536 {0, 0}
Chris@21 537 };
Chris@21 538
Chris@21 539 /* Doc:: 10.3 Type Objects */ /* static */
Chris@21 540 PyTypeObject Plugin_Type =
Chris@21 541 {
Chris@21 542 PyObject_HEAD_INIT(NULL)
Chris@21 543 0, /*ob_size*/
Chris@21 544 "vampyhost.Plugin", /*tp_name*/
Chris@21 545 sizeof(PyPluginObject), /*tp_basicsize*/
Chris@21 546 0, /*tp_itemsize*/
Chris@21 547 (destructor)PyPluginObject_dealloc, /*tp_dealloc*/
Chris@21 548 0, /*tp_print*/
Chris@33 549 0, /*tp_getattr*/
Chris@33 550 0, /*tp_setattr*/
Chris@21 551 0, /*tp_compare*/
Chris@21 552 0, /*tp_repr*/
Chris@21 553 0, /*tp_as_number*/
Chris@21 554 0, /*tp_as_sequence*/
Chris@21 555 0, /*tp_as_mapping*/
Chris@21 556 0, /*tp_hash*/
Chris@21 557 0, /*tp_call*/
Chris@21 558 0, /*tp_str*/
Chris@33 559 PyObject_GenericGetAttr, /*tp_getattro*/
Chris@33 560 PyObject_GenericSetAttr, /*tp_setattro*/
Chris@21 561 0, /*tp_as_buffer*/
Chris@21 562 Py_TPFLAGS_DEFAULT, /*tp_flags*/
Chris@21 563 "Plugin Object", /*tp_doc*/
Chris@21 564 0, /*tp_traverse*/
Chris@21 565 0, /*tp_clear*/
Chris@21 566 0, /*tp_richcompare*/
Chris@21 567 0, /*tp_weaklistoffset*/
Chris@21 568 0, /*tp_iter*/
Chris@21 569 0, /*tp_iternext*/
Chris@21 570 PyPluginObject_methods, /*tp_methods*/
Chris@33 571 PyPluginObject_members, /*tp_members*/
Chris@21 572 0, /*tp_getset*/
Chris@21 573 0, /*tp_base*/
Chris@21 574 0, /*tp_dict*/
Chris@21 575 0, /*tp_descr_get*/
Chris@21 576 0, /*tp_descr_set*/
Chris@21 577 0, /*tp_dictoffset*/
Chris@21 578 0, /*tp_init*/
Chris@21 579 PyType_GenericAlloc, /*tp_alloc*/
Chris@21 580 0, /*tp_new*/
Chris@21 581 PyObject_Del, /*tp_free*/
Chris@21 582 0, /*tp_is_gc*/
Chris@21 583 };
Chris@0 584