PyObject *p;
PyObject *q;
- if (!_PyArg_ParseStack(args, nargs, "O!O!:dist",
- &PyTuple_Type, &p, &PyTuple_Type, &q)) {
+ if (!_PyArg_UnpackStack(args, nargs, "dist",
+ 2, 2,
+ &p, &q)) {
goto exit;
}
return_value = math_dist_impl(module, p, q);
exit:
return return_value;
}
-/*[clinic end generated code: output=d936137c1189b89b input=a9049054013a1b77]*/
+/*[clinic end generated code: output=239c51a5acefbafb input=a9049054013a1b77]*/
/*[clinic input]
math.dist
- p: object(subclass_of='&PyTuple_Type')
- q: object(subclass_of='&PyTuple_Type')
+ p: object
+ q: object
/
Return the Euclidean distance between two points p and q.
static PyObject *
math_dist_impl(PyObject *module, PyObject *p, PyObject *q)
-/*[clinic end generated code: output=56bd9538d06bbcfe input=937122eaa5f19272]*/
+/*[clinic end generated code: output=56bd9538d06bbcfe input=8c83c07c7a524664]*/
{
PyObject *item;
double max = 0.0;
double diffs_on_stack[NUM_STACK_ELEMS];
double *diffs = diffs_on_stack;
+ if (!PyTuple_Check(p) || !PyTuple_Check(q)) {
+ PyErr_SetString(PyExc_TypeError, "dist argument must be a tuple");
+ return NULL;
+ }
+
m = PyTuple_GET_SIZE(p);
n = PyTuple_GET_SIZE(q);
if (m != n) {