| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Author: George V. Neville-Neil | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | #include "Python.h"
 | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Our stuff... */ | 
					
						
							|  |  |  | #include "timing.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2000-07-10 12:04:18 +00:00
										 |  |  | start_timing(PyObject *self, PyObject *args) | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	if (!PyArg_Parse(args, "")) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	Py_INCREF(Py_None); | 
					
						
							|  |  |  | 	BEGINTIMING; | 
					
						
							|  |  |  | 	return Py_None; | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2000-07-10 12:04:18 +00:00
										 |  |  | finish_timing(PyObject *self, PyObject *args) | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	if (!PyArg_Parse(args, "")) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	ENDTIMING     | 
					
						
							|  |  |  | 	Py_INCREF(Py_None); | 
					
						
							|  |  |  | 	return Py_None; | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2000-07-10 12:04:18 +00:00
										 |  |  | seconds(PyObject *self, PyObject *args) | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	if (!PyArg_Parse(args, "")) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	return PyInt_FromLong(TIMINGS); | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2000-07-10 12:04:18 +00:00
										 |  |  | milli(PyObject *self, PyObject *args) | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	if (!PyArg_Parse(args, "")) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	return PyInt_FromLong(TIMINGMS); | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2000-07-10 12:04:18 +00:00
										 |  |  | micro(PyObject *self, PyObject *args) | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	if (!PyArg_Parse(args, "")) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	return PyInt_FromLong(TIMINGUS); | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | static PyMethodDef timing_methods[] = { | 
					
						
							| 
									
										
										
										
											2002-01-17 23:15:58 +00:00
										 |  |  | 	{"start",   start_timing, METH_OLDARGS}, | 
					
						
							|  |  |  | 	{"finish",  finish_timing, METH_OLDARGS}, | 
					
						
							|  |  |  | 	{"seconds", seconds, METH_OLDARGS}, | 
					
						
							|  |  |  | 	{"milli",   milli, METH_OLDARGS}, | 
					
						
							|  |  |  | 	{"micro",   micro, METH_OLDARGS}, | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	{NULL,      NULL} | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-07-21 06:00:07 +00:00
										 |  |  | DL_EXPORT(void) inittiming(void) | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-13 22:57:42 +00:00
										 |  |  | 	(void)Py_InitModule("timing", timing_methods); | 
					
						
							| 
									
										
										
										
											1994-01-02 23:22:21 +00:00
										 |  |  | } |