Tag: remove the obsolete "bulk" mode

Methods BeginAdd() and EndAdd() have been replaced by class
TagBuilder.
This commit is contained in:
Max Kellermann 2013-09-05 19:08:22 +02:00
parent 662bed6a00
commit 8dca38e979
2 changed files with 3 additions and 88 deletions

View File

@ -27,19 +27,6 @@
#include <assert.h> #include <assert.h>
#include <string.h> #include <string.h>
/**
* Maximum number of items managed in the bulk list; if it is
* exceeded, we switch back to "normal" reallocation.
*/
#define BULK_MAX 64
static struct {
#ifndef NDEBUG
bool busy;
#endif
TagItem *items[BULK_MAX];
} bulk;
enum tag_type enum tag_type
tag_name_parse(const char *name) tag_name_parse(const char *name)
{ {
@ -87,14 +74,7 @@ Tag::Clear()
tag_pool_put_item(items[i]); tag_pool_put_item(items[i]);
tag_pool_lock.unlock(); tag_pool_lock.unlock();
if (items == bulk.items) {
#ifndef NDEBUG
assert(bulk.busy);
bulk.busy = false;
#endif
} else
g_free(items); g_free(items);
items = nullptr; items = nullptr;
num_items = 0; num_items = 0;
} }
@ -106,12 +86,6 @@ Tag::~Tag()
tag_pool_put_item(items[i]); tag_pool_put_item(items[i]);
tag_pool_lock.unlock(); tag_pool_lock.unlock();
if (items == bulk.items) {
#ifndef NDEBUG
assert(bulk.busy);
bulk.busy = false;
#endif
} else
g_free(items); g_free(items);
} }
@ -209,40 +183,6 @@ Tag::HasType(tag_type type) const
return GetValue(type) != nullptr; return GetValue(type) != nullptr;
} }
void
Tag::BeginAdd()
{
assert(!bulk.busy);
assert(items == nullptr);
assert(num_items == 0);
#ifndef NDEBUG
bulk.busy = true;
#endif
items = bulk.items;
}
void
Tag::EndAdd()
{
if (items == bulk.items) {
assert(num_items <= BULK_MAX);
if (num_items > 0) {
/* copy the tag items from the bulk list over
to a new list (which fits exactly) */
items = (TagItem **)
g_malloc(items_size(*this));
memcpy(items, bulk.items, items_size(*this));
} else
items = nullptr;
}
#ifndef NDEBUG
bulk.busy = false;
#endif
}
void void
Tag::AddItemInternal(tag_type type, const char *value, size_t len) Tag::AddItemInternal(tag_type type, const char *value, size_t len)
{ {
@ -256,18 +196,7 @@ Tag::AddItemInternal(tag_type type, const char *value, size_t len)
num_items++; num_items++;
if (items != bulk.items) items = (TagItem **)g_realloc(items, items_size(*this));
/* bulk mode disabled */
items = (TagItem **)
g_realloc(items, items_size(*this));
else if (num_items >= BULK_MAX) {
/* bulk list already full - switch back to non-bulk */
assert(bulk.busy);
items = (TagItem **)g_malloc(items_size(*this));
memcpy(items, bulk.items,
items_size(*this) - sizeof(TagItem *));
}
tag_pool_lock.lock(); tag_pool_lock.lock();
items[i] = tag_pool_get_item(type, value, len); items[i] = tag_pool_get_item(type, value, len);

View File

@ -103,20 +103,6 @@ struct Tag {
*/ */
void Clear(); void Clear();
/**
* Gives an optional hint to the tag library that we will now
* add several tag items; this is used by the library to
* optimize memory allocation. Only one tag may be in this
* state, and this tag must not have any items yet. You must
* call tag_end_add() when you are done.
*/
void BeginAdd();
/**
* Finishes the operation started with tag_begin_add().
*/
void EndAdd();
/** /**
* Appends a new tag item. * Appends a new tag item.
* *