From 5cb64055c4f9a10d437ca993be85d790b7df0e98 Mon Sep 17 00:00:00 2001 From: Tim Small Date: Mon, 24 Apr 2023 09:02:44 +0100 Subject: [PATCH] Reorder declarations to avoid function prototype. Prep for adding open_path Python method in #129 --- spidev_module.c | 46 ++++++++++++++++++++++------------------------ 1 file changed, 22 insertions(+), 24 deletions(-) diff --git a/spidev_module.c b/spidev_module.c index 95068fd..cf12a1d 100644 --- a/spidev_module.c +++ b/spidev_module.c @@ -1335,30 +1335,6 @@ static PyGetSetDef SpiDev_getset[] = { {NULL}, }; -static PyObject * -SpiDev_open_dev(SpiDevObject *self, char *dev_path); - -PyDoc_STRVAR(SpiDev_open_doc, - "open(bus, device)\n\n" - "Connects the object to the specified SPI device.\n" - "open(X,Y) will open /dev/spidev.\n"); - -static PyObject * -SpiDev_open(SpiDevObject *self, PyObject *args, PyObject *kwds) -{ - int bus, device; - char path[SPIDEV_MAXPATH]; - static char *kwlist[] = {"bus", "device", NULL}; - if (!PyArg_ParseTupleAndKeywords(args, kwds, "ii:open", kwlist, &bus, &device)) - return NULL; - if (snprintf(path, SPIDEV_MAXPATH, "/dev/spidev%d.%d", bus, device) >= SPIDEV_MAXPATH) { - PyErr_SetString(PyExc_OverflowError, - "Bus and/or device number is invalid."); - return NULL; - } - return SpiDev_open_dev(self, path); -} - static PyObject * SpiDev_open_dev(SpiDevObject *self, char *dev_path) { @@ -1388,6 +1364,28 @@ SpiDev_open_dev(SpiDevObject *self, char *dev_path) return Py_None; } + +PyDoc_STRVAR(SpiDev_open_doc, + "open(bus, device)\n\n" + "Connects the object to the specified SPI device.\n" + "open(X,Y) will open /dev/spidev.\n"); + +static PyObject * +SpiDev_open(SpiDevObject *self, PyObject *args, PyObject *kwds) +{ + int bus, device; + char path[SPIDEV_MAXPATH]; + static char *kwlist[] = {"bus", "device", NULL}; + if (!PyArg_ParseTupleAndKeywords(args, kwds, "ii:open", kwlist, &bus, &device)) + return NULL; + if (snprintf(path, SPIDEV_MAXPATH, "/dev/spidev%d.%d", bus, device) >= SPIDEV_MAXPATH) { + PyErr_SetString(PyExc_OverflowError, + "Bus and/or device number is invalid."); + return NULL; + } + return SpiDev_open_dev(self, path); +} + static int SpiDev_init(SpiDevObject *self, PyObject *args, PyObject *kwds) {