1 #include "aubio-types.h"
14 static char Py_sink_doc[] = ""
15 " __new__(path, samplerate = 44100, channels = 1)\n"
17 " Create a new sink, opening the given path for writing.\n"
22 " Create a new sink at 44100Hz, mono:\n"
24 " >>> sink('/tmp/t.wav')\n"
26 " Create a new sink at 8000Hz, mono:\n"
28 " >>> sink('/tmp/t.wav', samplerate = 8000)\n"
30 " Create a new sink at 32000Hz, stereo:\n"
32 " >>> sink('/tmp/t.wav', samplerate = 32000, channels = 2)\n"
34 " Create a new sink at 32000Hz, 5 channels:\n"
36 " >>> sink('/tmp/t.wav', channels = 5, samplerate = 32000)\n"
38 " __call__(vec, write)\n"
39 " x(vec,write) <==> x.do(vec, write)\n"
41 " Write vector to sink.\n"
48 static char Py_sink_do_doc[] = ""
49 "x.do(vec, write) <==> x(vec, write)\n"
51 "write monophonic vector to sink";
53 static char Py_sink_do_multi_doc[] = ""
54 "x.do_multi(mat, write)\n"
56 "write polyphonic vector to sink";
58 static char Py_sink_close_doc[] = ""
61 "close this sink now";
64 Py_sink_new (PyTypeObject * pytype, PyObject * args, PyObject * kwds)
68 uint_t samplerate = 0;
70 static char *kwlist[] = { "uri", "samplerate", "channels", NULL };
72 if (!PyArg_ParseTupleAndKeywords (args, kwds, "|sII", kwlist,
73 &uri, &samplerate, &channels)) {
77 self = (Py_sink *) pytype->tp_alloc (pytype, 0);
88 self->samplerate = Py_aubio_default_samplerate;
89 if (samplerate != 0) {
90 self->samplerate = samplerate;
95 self->channels = channels;
98 return (PyObject *) self;
102 Py_sink_init (Py_sink * self, PyObject * args, PyObject * kwds)
104 self->o = new_aubio_sink ( self->uri, 0 );
105 if (self->o == NULL) {
106 // error string was set in new_aubio_sink
109 if (aubio_sink_preset_channels(self->o, self->channels) != 0) {
110 // error string was set in aubio_sink_preset_channels
113 if (aubio_sink_preset_samplerate(self->o, self->samplerate) != 0) {
114 // error string was set in aubio_sink_preset_samplerate
118 self->samplerate = aubio_sink_get_samplerate ( self->o );
119 self->channels = aubio_sink_get_channels ( self->o );
125 Py_sink_del (Py_sink *self, PyObject *unused)
127 del_aubio_sink(self->o);
128 free(self->mwrite_data.data);
129 Py_TYPE(self)->tp_free((PyObject *) self);
132 /* function Py_sink_do */
134 Py_sink_do(Py_sink * self, PyObject * args)
136 /* input vectors python prototypes */
137 PyObject * write_data_obj;
139 /* input vectors prototypes */
143 if (!PyArg_ParseTuple (args, "OI", &write_data_obj, &write)) {
147 /* input vectors parsing */
148 if (!PyAubio_ArrayToCFvec(write_data_obj, &(self->write_data))) {
153 /* compute _do function */
154 aubio_sink_do (self->o, &(self->write_data), write);
159 /* function Py_sink_do_multi */
161 Py_sink_do_multi(Py_sink * self, PyObject * args)
163 /* input vectors python prototypes */
164 PyObject * write_data_obj;
166 /* input vectors prototypes */
170 if (!PyArg_ParseTuple (args, "OI", &write_data_obj, &write)) {
175 /* input vectors parsing */
176 if (!PyAubio_ArrayToCFmat(write_data_obj, &(self->mwrite_data))) {
180 /* compute _do function */
181 aubio_sink_do_multi (self->o, &(self->mwrite_data), write);
185 static PyMemberDef Py_sink_members[] = {
186 {"uri", T_STRING, offsetof (Py_sink, uri), READONLY,
187 "path at which the sink was created"},
188 {"samplerate", T_INT, offsetof (Py_sink, samplerate), READONLY,
189 "samplerate at which the sink was created"},
190 {"channels", T_INT, offsetof (Py_sink, channels), READONLY,
191 "number of channels with which the sink was created"},
196 Pyaubio_sink_close (Py_sink *self, PyObject *unused)
198 aubio_sink_close (self->o);
202 static PyMethodDef Py_sink_methods[] = {
203 {"do", (PyCFunction) Py_sink_do, METH_VARARGS, Py_sink_do_doc},
204 {"do_multi", (PyCFunction) Py_sink_do_multi, METH_VARARGS, Py_sink_do_multi_doc},
205 {"close", (PyCFunction) Pyaubio_sink_close, METH_NOARGS, Py_sink_close_doc},
206 {NULL} /* sentinel */
209 PyTypeObject Py_sinkType = {
210 PyVarObject_HEAD_INIT (NULL, 0)
214 (destructor) Py_sink_del,
224 (ternaryfunc)Py_sink_do,
245 (initproc) Py_sink_init,