2023-10-17 14:30:31 +02:00
|
|
|
// clinic/float.c.h uses internal pycore_modsupport.h API
|
|
|
|
#define PYTESTCAPI_NEED_INTERNAL_API
|
|
|
|
|
2022-11-17 09:56:56 +01:00
|
|
|
#include "parts.h"
|
2023-11-05 08:20:12 +01:00
|
|
|
#include "util.h"
|
2023-05-15 05:44:00 +02:00
|
|
|
#include "clinic/float.c.h"
|
2022-11-17 09:56:56 +01:00
|
|
|
|
|
|
|
|
2023-05-15 05:44:00 +02: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 05:44:00 +02: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 05:44:00 +02: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 05:44:00 +02: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 05:44:00 +02: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 05:44:00 +02: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;
|
|
|
|
}
|