| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  | #include "parts.h"
 | 
					
						
							| 
									
										
										
										
											2023-05-15 12:44:00 +09:00
										 |  |  | #include "clinic/float.c.h"
 | 
					
						
							| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-15 12:44:00 +09:00
										 |  |  | /*[clinic input]
 | 
					
						
							|  |  |  | module _testcapi | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | /*[clinic end generated code: output=da39a3ee5e6b4b0d input=6361033e795369fc]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*[clinic input]
 | 
					
						
							|  |  |  | _testcapi.float_pack | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     size: int | 
					
						
							|  |  |  |     d: double | 
					
						
							|  |  |  |     le: int | 
					
						
							|  |  |  |     / | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Test PyFloat_Pack2(), PyFloat_Pack4() and PyFloat_Pack8() | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2023-05-15 12:44:00 +09:00
										 |  |  | _testcapi_float_pack_impl(PyObject *module, int size, double d, int le) | 
					
						
							|  |  |  | /*[clinic end generated code: output=7899bd98f8b6cb04 input=52c9115121999c98]*/ | 
					
						
							| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     switch (size) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     case 2: | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         char data[2]; | 
					
						
							|  |  |  |         if (PyFloat_Pack2(d, data, le) < 0) { | 
					
						
							|  |  |  |             return NULL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return PyBytes_FromStringAndSize(data, Py_ARRAY_LENGTH(data)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     case 4: | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         char data[4]; | 
					
						
							|  |  |  |         if (PyFloat_Pack4(d, data, le) < 0) { | 
					
						
							|  |  |  |             return NULL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return PyBytes_FromStringAndSize(data, Py_ARRAY_LENGTH(data)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     case 8: | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         char data[8]; | 
					
						
							|  |  |  |         if (PyFloat_Pack8(d, data, le) < 0) { | 
					
						
							|  |  |  |             return NULL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return PyBytes_FromStringAndSize(data, Py_ARRAY_LENGTH(data)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     default: break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     PyErr_SetString(PyExc_ValueError, "size must 2, 4 or 8"); | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-15 12:44:00 +09:00
										 |  |  | /*[clinic input]
 | 
					
						
							|  |  |  | _testcapi.float_unpack | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     data: str(accept={robuffer}, zeroes=True) | 
					
						
							|  |  |  |     le: int | 
					
						
							|  |  |  |     / | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Test PyFloat_Unpack2(), PyFloat_Unpack4() and PyFloat_Unpack8() | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2023-05-15 12:44:00 +09:00
										 |  |  | _testcapi_float_unpack_impl(PyObject *module, const char *data, | 
					
						
							|  |  |  |                             Py_ssize_t data_length, int le) | 
					
						
							|  |  |  | /*[clinic end generated code: output=617059f889ddbfe4 input=c095e4bb75a696cd]*/ | 
					
						
							| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     assert(!PyErr_Occurred()); | 
					
						
							|  |  |  |     double d; | 
					
						
							| 
									
										
										
										
											2023-05-15 12:44:00 +09:00
										 |  |  |     switch (data_length) | 
					
						
							| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |     case 2: | 
					
						
							|  |  |  |         d = PyFloat_Unpack2(data, le); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case 4: | 
					
						
							|  |  |  |         d = PyFloat_Unpack4(data, le); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case 8: | 
					
						
							|  |  |  |         d = PyFloat_Unpack8(data, le); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "data length must 2, 4 or 8 bytes"); | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (d == -1.0 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return PyFloat_FromDouble(d); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyMethodDef test_methods[] = { | 
					
						
							| 
									
										
										
										
											2023-05-15 12:44:00 +09:00
										 |  |  |     _TESTCAPI_FLOAT_PACK_METHODDEF | 
					
						
							|  |  |  |     _TESTCAPI_FLOAT_UNPACK_METHODDEF | 
					
						
							| 
									
										
										
										
											2022-11-17 09:56:56 +01:00
										 |  |  |     {NULL}, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int | 
					
						
							|  |  |  | _PyTestCapi_Init_Float(PyObject *mod) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (PyModule_AddFunctions(mod, test_methods) < 0) { | 
					
						
							|  |  |  |         return -1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } |