blob: 4f1d5cf5fc3e1d604e58160b171d4140bf5d6c0f [file] [log] [blame]
/*
* Author: George V. Neville-Neil
*/
#include "Python.h"
/* Our stuff... */
#include "timing.h"
static PyObject *
start_timing(PyObject *self, PyObject *args)
{
if (!PyArg_Parse(args, ""))
return NULL;
Py_INCREF(Py_None);
BEGINTIMING;
return Py_None;
}
static PyObject *
finish_timing(PyObject *self, PyObject *args)
{
if (!PyArg_Parse(args, ""))
return NULL;
ENDTIMING
Py_INCREF(Py_None);
return Py_None;
}
static PyObject *
seconds(PyObject *self, PyObject *args)
{
if (!PyArg_Parse(args, ""))
return NULL;
return PyInt_FromLong(TIMINGS);
}
static PyObject *
milli(PyObject *self, PyObject *args)
{
if (!PyArg_Parse(args, ""))
return NULL;
return PyInt_FromLong(TIMINGMS);
}
static PyObject *
micro(PyObject *self, PyObject *args)
{
if (!PyArg_Parse(args, ""))
return NULL;
return PyInt_FromLong(TIMINGUS);
}
static PyMethodDef timing_methods[] = {
{"start", start_timing, METH_OLDARGS},
{"finish", finish_timing, METH_OLDARGS},
{"seconds", seconds, METH_OLDARGS},
{"milli", milli, METH_OLDARGS},
{"micro", micro, METH_OLDARGS},
{NULL, NULL}
};
DL_EXPORT(void) inittiming(void)
{
(void)Py_InitModule("timing", timing_methods);
}