ref: 1a121ca40a99fb3b9f78aa503f2726ee939ea240
parent: 31a5c405338cad0dd084411e6c9b6eeece8bae20
	author: Paul Brossier <piem@piem.org>
	date: Sun Feb 23 12:32:49 EST 2014
	
python/ext/py-sink.c: add channels and do_multi
--- a/python/ext/py-sink.c
+++ b/python/ext/py-sink.c
@@ -6,6 +6,7 @@
aubio_sink_t * o;
char_t* uri;
uint_t samplerate;
+ uint_t channels;
} Py_sink;
static char Py_sink_doc[] = "sink object";
@@ -16,10 +17,11 @@
Py_sink *self;
char_t* uri = NULL;
uint_t samplerate = 0;
-  static char *kwlist[] = { "uri", "samplerate", NULL };+ uint_t channels = 0;
+  static char *kwlist[] = { "uri", "samplerate", "channels", NULL };- if (!PyArg_ParseTupleAndKeywords (args, kwds, "|sI", kwlist,
-          &uri, &samplerate)) {+ if (!PyArg_ParseTupleAndKeywords (args, kwds, "|sII", kwlist,
+          &uri, &samplerate, &channels)) {return NULL;
}
@@ -43,15 +45,42 @@
return NULL;
}
+ self->channels = 1;
+  if ((sint_t)channels > 0) {+ self->channels = channels;
+  } else if ((sint_t)channels < 0) {+ PyErr_SetString (PyExc_ValueError,
+ "can not use negative or null value for channels");
+ return NULL;
+ }
+
return (PyObject *) self;
}
-AUBIO_INIT(sink , self->uri, self->samplerate)
+static int
+Py_sink_init (Py_sink * self, PyObject * args, PyObject * kwds)
+{+  if (self->channels == 1) {+ self->o = new_aubio_sink ( self->uri, self->samplerate );
+  } else {+ self->o = new_aubio_sink ( self->uri, 0 );
+ aubio_sink_preset_channels ( self->o, self->channels );
+ aubio_sink_preset_samplerate ( self->o, self->samplerate );
+ }
+  if (self->o == NULL) {+ PyErr_SetString (PyExc_StandardError, "error creating sink with this uri");
+ return -1;
+ }
+ self->samplerate = aubio_sink_get_samplerate ( self->o );
+ self->channels = aubio_sink_get_channels ( self->o );
+ return 0;
+}
+
AUBIO_DEL(sink)
/* function Py_sink_do */
-static PyObject *
+static PyObject *
Py_sink_do(Py_sink * self, PyObject * args)
 {/* input vectors python prototypes */
@@ -74,10 +103,10 @@
return NULL;
}
-
-
+
+
/* compute _do function */
aubio_sink_do (self->o, write_data, write);
@@ -84,9 +113,43 @@
Py_RETURN_NONE;
}
+/* function Py_sink_do */
+static PyObject *
+Py_sink_do_multi(Py_sink * self, PyObject * args)
+{+ /* input vectors python prototypes */
+ PyObject * write_data_obj;
+
+ /* input vectors prototypes */
+ fmat_t * write_data;
+ uint_t write;
+
+
+  if (!PyArg_ParseTuple (args, "OI", &write_data_obj, &write)) {+ return NULL;
+ }
+
+
+ /* input vectors parsing */
+ write_data = PyAubio_ArrayToCFmat (write_data_obj);
+
+  if (write_data == NULL) {+ return NULL;
+ }
+
+
+
+
+
+ /* compute _do function */
+ aubio_sink_do_multi (self->o, write_data, write);
+ Py_RETURN_NONE;
+}
+
AUBIO_MEMBERS_START(sink)
   {"uri", T_STRING, offsetof (Py_sink, uri), READONLY, ""},   {"samplerate", T_INT, offsetof (Py_sink, samplerate), READONLY, ""},+  {"channels", T_INT, offsetof (Py_sink, channels), READONLY, ""},AUBIO_MEMBERS_STOP(sink)
static PyObject *
@@ -97,8 +160,20 @@
}
 static PyMethodDef Py_sink_methods[] = {-  {"close", (PyCFunction) Pyaubio_sink_close,- METH_NOARGS, ""},
+  {"__call__", (PyCFunction) Py_sink_do, METH_VARARGS,+ "x.__call__(vec, write)\n"
+ "write monophonic vector to sink"
+ ""},
+  {"do", (PyCFunction) Py_sink_do, METH_VARARGS,+ "x.do(vec, write)\n"
+ "write monophonic vector to sink"
+ ""},
+  {"do_multi", (PyCFunction) Py_sink_do_multi, METH_VARARGS,+ "x.do_multi(mat, write)\n"
+ "write polyphonic vector to sink"},
+  {"close", (PyCFunction) Pyaubio_sink_close, METH_NOARGS,+ "x.close()\n"
+ "close this sink now"},
   {NULL} /* sentinel */};
--
⑨