summaryrefslogtreecommitdiff
path: root/libgphoto2/gphoto2-filesys.c
diff options
context:
space:
mode:
authorMarcus Meissner <marcus@jet.franken.de>2007-01-21 20:20:04 +0000
committerMarcus Meissner <marcus@jet.franken.de>2007-01-21 20:20:04 +0000
commit08cba5167b077f09ea210ba44187a790b1e67989 (patch)
tree6f73793674bdd0849308537d3fc7c1e3d3716bd0 /libgphoto2/gphoto2-filesys.c
parent35ebdb79e9b2f9ef045dc528ad9444a7842dd9e0 (diff)
downloadlibgphoto2-08cba5167b077f09ea210ba44187a790b1e67989.tar.gz
bugfixes in LRU handling.
git-svn-id: https://svn.code.sf.net/p/gphoto/code/trunk/libgphoto2@9923 67ed7778-7388-44ab-90cf-0a291f65f57c
Diffstat (limited to 'libgphoto2/gphoto2-filesys.c')
-rw-r--r--libgphoto2/gphoto2-filesys.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/libgphoto2/gphoto2-filesys.c b/libgphoto2/gphoto2-filesys.c
index 97f33034e..0a7c5a1f1 100644
--- a/libgphoto2/gphoto2-filesys.c
+++ b/libgphoto2/gphoto2-filesys.c
@@ -500,6 +500,8 @@ append_file (CameraFilesystem *fs, int x, CameraFile *file, GPContext *context)
strcpy (fs->folder[x].file[fs->folder[x].count - 1].name, name);
fs->folder[x].file[fs->folder[x].count - 1].info_dirty = 1;
fs->folder[x].file[fs->folder[x].count - 1].normal = file;
+ fs->folder[x].file[fs->folder[x].count - 1].lru_prev = NULL;
+ fs->folder[x].file[fs->folder[x].count - 1].lru_next = NULL;
gp_file_ref (file);
return (GP_OK);
@@ -1901,6 +1903,9 @@ gp_filesystem_lru_remove_one (CameraFilesystem *fs, CameraFilesystemFile *item)
if (item->lru_prev == NULL)
return (GP_ERROR);
+ /* Update the prev and next pointers. */
+ if (item->lru_prev) item->lru_prev->lru_next = item->lru_next;
+ if (item->lru_next) item->lru_next->lru_prev = item->lru_prev;
if (fs->lru_last == item) {
if (fs->lru_first == item) {
@@ -1910,22 +1915,17 @@ gp_filesystem_lru_remove_one (CameraFilesystem *fs, CameraFilesystemFile *item)
*/
fs->lru_last = NULL;
fs->lru_first = NULL;
-
} else {
/* Case 2: ITEM is the last in the list. */
fs->lru_last = item->lru_prev;
-
}
} else if (fs->lru_first == item) {
/* Case 3: ITEM is the first in the list. */
fs->lru_first = item->lru_next;
-
- } else {
-
- /* Case 4: ITEM is in the middle of the list. */
- item->lru_prev->lru_next = item->lru_next;
+ /* the first item prev links back to itself */
+ fs->lru_first->lru_prev = fs->lru_first;
}
/* Clear the pointers */
@@ -1973,7 +1973,7 @@ gp_filesystem_lru_free (CameraFilesystem *fs)
gp_file_unref (ptr->audio);
ptr->audio = NULL;
}
-
+ ptr->lru_next = ptr->lru_prev = NULL;
return (GP_OK);
}
@@ -2093,6 +2093,7 @@ gp_filesystem_lru_update (CameraFilesystem *fs, const char *folder,
fs->folder[x].file[y].lru_prev = &fs->folder[x].file[y];
} else {
+ fs->folder[x].file[y].lru_next = NULL;
fs->folder[x].file[y].lru_prev = fs->lru_last;
fs->lru_last->lru_next = &fs->folder[x].file[y];
fs->lru_last = &fs->folder[x].file[y];