Kaydet (Commit) 0c0e229d authored tarafından Benjamin Peterson's avatar Benjamin Peterson

simplify string comparison of from_bytes/to_bytes

üst 8667a9b6
...@@ -4325,10 +4325,9 @@ long_to_bytes(PyLongObject *v, PyObject *args, PyObject *kwds) ...@@ -4325,10 +4325,9 @@ long_to_bytes(PyLongObject *v, PyObject *args, PyObject *kwds)
int little_endian; int little_endian;
int is_signed; int is_signed;
PyObject *bytes; PyObject *bytes;
static PyObject *little_str = NULL, *big_str = NULL;
static char *kwlist[] = {"length", "byteorder", "signed", NULL}; static char *kwlist[] = {"length", "byteorder", "signed", NULL};
if (!PyArg_ParseTupleAndKeywords(args, kwds, "nO|O:to_bytes", kwlist, if (!PyArg_ParseTupleAndKeywords(args, kwds, "nU|O:to_bytes", kwlist,
&length, &byteorder_str, &length, &byteorder_str,
&is_signed_obj)) &is_signed_obj))
return NULL; return NULL;
...@@ -4338,16 +4337,10 @@ long_to_bytes(PyLongObject *v, PyObject *args, PyObject *kwds) ...@@ -4338,16 +4337,10 @@ long_to_bytes(PyLongObject *v, PyObject *args, PyObject *kwds)
"'signed' is a keyword-only argument"); "'signed' is a keyword-only argument");
return NULL; return NULL;
} }
if (little_str == NULL) {
little_str = PyUnicode_InternFromString("little");
big_str = PyUnicode_InternFromString("big");
if (little_str == NULL || big_str == NULL)
return NULL;
}
if (PyObject_RichCompareBool(byteorder_str, little_str, Py_EQ)) if (!PyUnicode_CompareWithASCIIString(byteorder_str, "little"))
little_endian = 1; little_endian = 1;
else if (PyObject_RichCompareBool(byteorder_str, big_str, Py_EQ)) else if (!PyUnicode_CompareWithASCIIString(byteorder_str, "big"))
little_endian = 0; little_endian = 0;
else { else {
PyErr_SetString(PyExc_ValueError, PyErr_SetString(PyExc_ValueError,
...@@ -4414,10 +4407,9 @@ long_from_bytes(PyTypeObject *type, PyObject *args, PyObject *kwds) ...@@ -4414,10 +4407,9 @@ long_from_bytes(PyTypeObject *type, PyObject *args, PyObject *kwds)
PyObject *obj; PyObject *obj;
PyObject *bytes; PyObject *bytes;
PyObject *long_obj; PyObject *long_obj;
static PyObject *little_str = NULL, *big_str = NULL;
static char *kwlist[] = {"bytes", "byteorder", "signed", NULL}; static char *kwlist[] = {"bytes", "byteorder", "signed", NULL};
if (!PyArg_ParseTupleAndKeywords(args, kwds, "OO|O:from_bytes", kwlist, if (!PyArg_ParseTupleAndKeywords(args, kwds, "OU|O:from_bytes", kwlist,
&obj, &byteorder_str, &obj, &byteorder_str,
&is_signed_obj)) &is_signed_obj))
return NULL; return NULL;
...@@ -4427,16 +4419,10 @@ long_from_bytes(PyTypeObject *type, PyObject *args, PyObject *kwds) ...@@ -4427,16 +4419,10 @@ long_from_bytes(PyTypeObject *type, PyObject *args, PyObject *kwds)
"'signed' is a keyword-only argument"); "'signed' is a keyword-only argument");
return NULL; return NULL;
} }
if (little_str == NULL) {
little_str = PyUnicode_InternFromString("little");
big_str = PyUnicode_InternFromString("big");
if (little_str == NULL || big_str == NULL)
return NULL;
}
if (PyObject_RichCompareBool(byteorder_str, little_str, Py_EQ)) if (!PyUnicode_CompareWithASCIIString(byteorder_str, "little"))
little_endian = 1; little_endian = 1;
else if (PyObject_RichCompareBool(byteorder_str, big_str, Py_EQ)) else if (!PyUnicode_CompareWithASCIIString(byteorder_str, "big"))
little_endian = 0; little_endian = 0;
else { else {
PyErr_SetString(PyExc_ValueError, PyErr_SetString(PyExc_ValueError,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment