blob: f8fd384a372bddb6f7cbb6553576d12b6db763eb [file] [log] [blame]
Christian Heimes0ded5b52007-12-10 15:50:56 +00001/* Fast unicode equal function optimized for dictobject.c and setobject.c */
2
3/* Return 1 if two unicode objects are equal, 0 if not.
4 * unicode_eq() is called when the hash of two unicode objects is equal.
5 */
6Py_LOCAL_INLINE(int)
7unicode_eq(PyObject *aa, PyObject *bb)
8{
Antoine Pitrou9ed5f272013-08-13 20:18:52 +02009 PyUnicodeObject *a = (PyUnicodeObject *)aa;
10 PyUnicodeObject *b = (PyUnicodeObject *)bb;
Christian Heimes0ded5b52007-12-10 15:50:56 +000011
Martin v. Löwisd63a3b82011-09-28 07:41:54 +020012 if (PyUnicode_READY(a) == -1 || PyUnicode_READY(b) == -1) {
13 assert(0 && "unicode_eq ready fail");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000014 return 0;
Martin v. Löwisd63a3b82011-09-28 07:41:54 +020015 }
16
17 if (PyUnicode_GET_LENGTH(a) != PyUnicode_GET_LENGTH(b))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000018 return 0;
Martin v. Löwisd63a3b82011-09-28 07:41:54 +020019 if (PyUnicode_GET_LENGTH(a) == 0)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000020 return 1;
Martin v. Löwisd63a3b82011-09-28 07:41:54 +020021 if (PyUnicode_KIND(a) != PyUnicode_KIND(b))
22 return 0;
Martin v. Löwisd63a3b82011-09-28 07:41:54 +020023 return memcmp(PyUnicode_1BYTE_DATA(a), PyUnicode_1BYTE_DATA(b),
Martin v. Löwisc47adb02011-10-07 20:55:35 +020024 PyUnicode_GET_LENGTH(a) * PyUnicode_KIND(a)) == 0;
Christian Heimes0ded5b52007-12-10 15:50:56 +000025}