Kaydet (Commit) 79710cde authored tarafından Eric Smith's avatar Eric Smith

Changed STRINGLIB_CMP from an inline function to a macro in order to avoid a…

Changed STRINGLIB_CMP from an inline function to a macro in order to avoid a 'defined but not used' warning.
üst 3d5cb225
...@@ -21,6 +21,8 @@ ...@@ -21,6 +21,8 @@
#define STRINGLIB_CHECK PyUnicode_Check #define STRINGLIB_CHECK PyUnicode_Check
#define STRINGLIB_TOSTR PyObject_Unicode #define STRINGLIB_TOSTR PyObject_Unicode
/* STRINGLIB_CMP was defined as:
Py_LOCAL_INLINE(int) Py_LOCAL_INLINE(int)
STRINGLIB_CMP(const Py_UNICODE* str, const Py_UNICODE* other, Py_ssize_t len) STRINGLIB_CMP(const Py_UNICODE* str, const Py_UNICODE* other, Py_ssize_t len)
{ {
...@@ -29,4 +31,13 @@ STRINGLIB_CMP(const Py_UNICODE* str, const Py_UNICODE* other, Py_ssize_t len) ...@@ -29,4 +31,13 @@ STRINGLIB_CMP(const Py_UNICODE* str, const Py_UNICODE* other, Py_ssize_t len)
return memcmp((void*) str, (void*) other, len * sizeof(Py_UNICODE)); return memcmp((void*) str, (void*) other, len * sizeof(Py_UNICODE));
} }
but unfortunately that gives a error if the function isn't used in a file that
includes this file. So, reluctantly convert it to a macro instead. */
#define STRINGLIB_CMP(str, other, len) \
(((str)[0] != (other)[0]) ? \
1 : \
memcmp((void*) (str), (void*) (other), (len) * sizeof(Py_UNICODE)))
#endif /* !STRINGLIB_UNICODEDEFS_H */ #endif /* !STRINGLIB_UNICODEDEFS_H */
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