2
0
Fork 0

stat cache: Alloc dirlist entry array only if stat was successful

This commit is contained in:
Stefan Bühler 2009-10-05 19:42:19 +02:00
parent 4653900eca
commit df207beb6b
1 changed files with 3 additions and 2 deletions

View File

@ -138,7 +138,7 @@ static void stat_cache_entry_free(liStatCacheEntry *sce) {
g_string_free(sce->data.path, TRUE);
g_ptr_array_free(sce->vrequests, TRUE);
if (sce->type == STAT_CACHE_ENTRY_DIR) {
if (NULL != sce->dirlist) {
for (i = 0; i < sce->dirlist->len; i++) {
g_string_free(g_array_index(sce->dirlist, liStatCacheEntryData, i).path, TRUE);
}
@ -186,6 +186,8 @@ static gpointer stat_cache_thread(gpointer data) {
assert(size != (gsize)-1);
entry = g_slice_alloc(size);
sce->dirlist = g_array_sized_new(FALSE, FALSE, sizeof(liStatCacheEntryData), 32);
str = g_string_sized_new(sce->data.path->len + 64);
g_string_append_len(str, GSTR_LEN(sce->data.path));
@ -280,7 +282,6 @@ liHandlerResult li_stat_cache_get_dirlist(liVRequest *vr, GString *path, liStatC
/* cache miss, allocate new entry */
sce = stat_cache_entry_new(path);
sce->type = STAT_CACHE_ENTRY_DIR;
sce->dirlist = g_array_sized_new(FALSE, FALSE, sizeof(liStatCacheEntryData), 32);
li_stat_cache_entry_acquire(vr, sce);
li_waitqueue_push(&sc->delete_queue, &sce->queue_elem);
g_hash_table_insert(sc->dirlists, sce->data.path, sce);