From dbce3eaafc7c3dceff97b7ab4de9308eb77f5795 Mon Sep 17 00:00:00 2001 From: Andy Fiddaman Date: Sun, 19 Jan 2020 10:41:22 +0000 Subject: 12215 pyzfs module does not build with python 3.7 Reviewed by: Marcel Telka Reviewed by: Paul Winder Reviewed by: Alexander Pyhalov Approved by: Dan McDonald --- usr/src/lib/pyzfs/common/ioctl.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'usr/src/lib/pyzfs/common/ioctl.c') diff --git a/usr/src/lib/pyzfs/common/ioctl.c b/usr/src/lib/pyzfs/common/ioctl.c index a931a7bb69..c6d8d32b9a 100644 --- a/usr/src/lib/pyzfs/common/ioctl.c +++ b/usr/src/lib/pyzfs/common/ioctl.c @@ -143,10 +143,11 @@ dict2nvl(PyObject *d) assert(err == 0); while (PyDict_Next(d, &pos, &key, &value)) { + const char *keystr; #if PY_MAJOR_VERSION >= 3 - char *keystr = PyUnicode_AsUTF8(key); + keystr = PyUnicode_AsUTF8(key); #else - char *keystr = PyString_AsString(key); + keystr = PyString_AsString(key); #endif if (keystr == NULL) { PyErr_SetObject(PyExc_KeyError, key); @@ -165,10 +166,11 @@ dict2nvl(PyObject *d) #else } else if (PyString_Check(value)) { #endif + const char *valstr; #if PY_MAJOR_VERSION >= 3 - char *valstr = PyUnicode_AsUTF8(value); + valstr = PyUnicode_AsUTF8(value); #else - char *valstr = PyString_AsString(value); + valstr = PyString_AsString(value); #endif err = nvlist_add_string(nvl, keystr, valstr); } else if (PyLong_Check(value)) { -- cgit v1.2.3