tag_pool: use memcmp() instead of strcmp() for non-terminated string

The strings passed to tag_pool_get_item() are not null-terminated, and
the caller passes the string length.  Don't assume it is
null-terminated anyway by using strcmp().
This commit is contained in:
Max Kellermann 2009-03-27 19:36:24 +01:00
parent 51894725ec
commit 86827fc63e

View File

@ -101,7 +101,9 @@ tag_pool_get_item(enum tag_type type, const char *value, size_t length)
slot_p = &slots[calc_hash_n(type, value, length) % NUM_SLOTS]; slot_p = &slots[calc_hash_n(type, value, length) % NUM_SLOTS];
for (slot = *slot_p; slot != NULL; slot = slot->next) { for (slot = *slot_p; slot != NULL; slot = slot->next) {
if (slot->item.type == type && if (slot->item.type == type &&
strcmp(value, slot->item.value) == 0 && slot->ref < 0xff) { length == strlen(slot->item.value) &&
memcmp(value, slot->item.value, length) == 0 &&
slot->ref < 0xff) {
assert(slot->ref > 0); assert(slot->ref > 0);
++slot->ref; ++slot->ref;
return &slot->item; return &slot->item;