1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
|
/*
* Author: George V. Neville-Neil
*/
#include "Python.h"
/* Our stuff... */
#include "timing.h"
static PyObject *
start_timing(self, args)
PyObject *self;
PyObject *args;
{
if (!PyArg_Parse(args, ""))
return NULL;
Py_INCREF(Py_None);
BEGINTIMING;
return Py_None;
}
static PyObject *
finish_timing(self, args)
PyObject *self;
PyObject *args;
{
if (!PyArg_Parse(args, ""))
return NULL;
ENDTIMING
Py_INCREF(Py_None);
return Py_None;
}
static PyObject *
seconds(self, args)
PyObject *self;
PyObject *args;
{
if (!PyArg_Parse(args, ""))
return NULL;
return PyInt_FromLong(TIMINGS);
}
static PyObject *
milli(self, args)
PyObject *self;
PyObject *args;
{
if (!PyArg_Parse(args, ""))
return NULL;
return PyInt_FromLong(TIMINGMS);
}
static PyObject *
micro(self, args)
PyObject *self;
PyObject *args;
{
if (!PyArg_Parse(args, ""))
return NULL;
return PyInt_FromLong(TIMINGUS);
}
static PyMethodDef timing_methods[] = {
{"start", start_timing},
{"finish", finish_timing},
{"seconds", seconds},
{"milli", milli},
{"micro", micro},
{NULL, NULL}
};
DL_EXPORT(void) inittiming()
{
(void)Py_InitModule("timing", timing_methods);
if (PyErr_Occurred())
Py_FatalError("can't initialize module timing");
}
|