diff options
Diffstat (limited to 'sys-fs/copyfs/files')
-rw-r--r-- | sys-fs/copyfs/files/copyfs-1.0-unlink.patch | 125 |
1 files changed, 92 insertions, 33 deletions
diff --git a/sys-fs/copyfs/files/copyfs-1.0-unlink.patch b/sys-fs/copyfs/files/copyfs-1.0-unlink.patch index c63f7cc29715..9e6614f54271 100644 --- a/sys-fs/copyfs/files/copyfs-1.0-unlink.patch +++ b/sys-fs/copyfs/files/copyfs-1.0-unlink.patch @@ -1,25 +1,21 @@ +Only in copyfs-1.0: Makefile diff -u --recursive copyfs-1.0-orig/cache.c copyfs-1.0/cache.c ---- copyfs-1.0-orig/cache.c 2004-12-16 21:07:38.953286336 +0000 -+++ copyfs-1.0/cache.c 2004-12-16 22:00:40.158056066 +0000 -@@ -94,6 +94,50 @@ +--- copyfs-1.0-orig/cache.c 2004-12-10 13:34:08.000000000 +0000 ++++ copyfs-1.0/cache.c 2004-12-18 20:30:17.945445677 +0000 +@@ -94,6 +94,61 @@ } /* + * Remove metadata from the cache + */ -+void cache_remove_metadata(const char *vpath) ++void cache_remove_metadata(metadata_t *metadata) +{ -+ bucket_t *bucket; -+ metadata_t *metadata; ++ version_t * version; ++ + int atHead = 1; + int atTail = 1; + -+ /* Lookup the item */ -+ bucket = &cache_hash_table[CACHE_HASH(vpath)]; -+ metadata = bucket->b_contents; -+ while (metadata && strcmp(metadata->md_vfile, vpath)) -+ metadata = metadata->md_next; -+ if (!metadata) ++ if (NULL == metadata) + return ; + + /* Disconnect it from the list */ @@ -37,13 +33,29 @@ diff -u --recursive copyfs-1.0-orig/cache.c copyfs-1.0/cache.c + + if (atHead) + { -+ bucket->b_contents = metadata->md_next; -+ bucket->b_contents->md_previous = NULL; ++ metadata->md_bucket->b_contents = metadata->md_next; ++ if (metadata->md_next != NULL) ++ metadata->md_next->md_previous = NULL; ++ } ++ ++ metadata->md_bucket->b_count--; ++ if (metadata->md_bucket->b_count == 0) ++ metadata->md_bucket->b_contents = NULL; ++ ++ version = metadata->md_versions; ++ ++ while (NULL != version) ++ { ++ metadata->md_versions = version->v_next; ++ free(version); ++ version = metadata->md_versions; + } + -+ bucket->b_count--; -+ if (bucket->b_count == 0) -+ bucket->b_contents = NULL; ++ if (metadata->md_vfile != NULL) ++ free (metadata->md_vfile); ++ ++ if (metadata->md_vpath != NULL) ++ free (metadata->md_vpath); + + free(metadata); +} @@ -52,24 +64,28 @@ diff -u --recursive copyfs-1.0-orig/cache.c copyfs-1.0/cache.c * Clean the older items out of the cache to free space. The goal is to * half the number of items, so that we don't get called constantly. */ +@@ -122,6 +177,7 @@ + bucket = &cache_hash_table[CACHE_HASH(metadata->md_vfile)]; + metadata->md_previous = NULL; + metadata->md_next = bucket->b_contents; ++ metadata->md_bucket = bucket; + if (bucket->b_contents) + bucket->b_contents->md_previous = metadata; + bucket->b_contents = metadata; diff -u --recursive copyfs-1.0-orig/cache.h copyfs-1.0/cache.h ---- copyfs-1.0-orig/cache.h 2004-12-16 21:07:38.953286336 +0000 -+++ copyfs-1.0/cache.h 2004-12-16 22:00:28.463400204 +0000 +--- copyfs-1.0-orig/cache.h 2004-12-10 13:34:08.000000000 +0000 ++++ copyfs-1.0/cache.h 2004-12-18 20:04:32.072307652 +0000 @@ -11,6 +11,7 @@ void cache_initialize(void); void cache_finalize(void); metadata_t *cache_get_metadata(const char *vpath); -+void cache_remove_metadata(const char *vpath); ++void cache_remove_metadata(metadata_t *metadata); void cache_add_metadata(metadata_t *metadata); int cache_find_maximal_match(char **array, metadata_t **result); -Only in copyfs-1.0: config.cache -Only in copyfs-1.0: config.log -Only in copyfs-1.0: config.status -Only in copyfs-1.0: fcopyfs-daemon diff -u --recursive copyfs-1.0-orig/interface.c copyfs-1.0/interface.c ---- copyfs-1.0-orig/interface.c 2004-12-16 21:07:38.953286336 +0000 -+++ copyfs-1.0/interface.c 2004-12-16 22:01:40.393756516 +0000 +--- copyfs-1.0-orig/interface.c 2004-12-18 20:04:21.560474299 +0000 ++++ copyfs-1.0/interface.c 2004-12-18 20:17:22.367357210 +0000 @@ -137,6 +137,7 @@ file = helper_build_composite("-S", "/", entry->d_name + strlen(METADATA_PREFIX)); @@ -78,12 +94,43 @@ diff -u --recursive copyfs-1.0-orig/interface.c copyfs-1.0/interface.c free(file); if (metadata && !metadata->md_deleted) { -@@ -181,13 +182,16 @@ - return -errno; - if (S_ISDIR(st_rfile.st_mode)) - return -EISDIR; -+ if (unlink(version->v_rfile) == -1) -+ return -errno; +@@ -176,18 +177,42 @@ + metadata = rcs_translate_to_metadata(path, rcs_version_path); + if (!metadata || metadata->md_deleted) + return -ENOENT; +- version = rcs_find_version(metadata, LATEST, LATEST); +- if (lstat(version->v_rfile, &st_rfile) == -1) +- return -errno; +- if (S_ISDIR(st_rfile.st_mode)) +- return -EISDIR; ++ ++ /* remove all of the versions that we know about */ ++ ++ version = metadata->md_versions; ++ ++ while (NULL != version) ++ { ++ /* if we can't stat the file, we assume it's already toast */ ++ ++ if (lstat(version->v_rfile, &st_rfile) == 0) ++ { ++ if (S_ISDIR(st_rfile.st_mode)) ++ { ++ return -EISDIR; ++ } ++ ++ if (unlink(version->v_rfile) == -1) ++ return -errno; ++ } ++ ++ /* move on to the next version */ ++ metadata->md_versions = version->v_next; ++ free(version); ++ ++ version = metadata->md_versions; ++ } ++ ++ /* if we get to here, we've released all the versions */ metadata->md_deleted = 1; metafile = create_meta_name(metadata->md_vfile, "metadata"); - if (write_metadata_file(metafile, metadata) == -1) { @@ -93,8 +140,20 @@ diff -u --recursive copyfs-1.0-orig/interface.c copyfs-1.0/interface.c - } free(metafile); + -+ cache_remove_metadata(version->v_rfile); ++ cache_remove_metadata(metadata); + return 0; } +diff -u --recursive copyfs-1.0-orig/structs.h copyfs-1.0/structs.h +--- copyfs-1.0-orig/structs.h 2004-12-10 13:34:08.000000000 +0000 ++++ copyfs-1.0/structs.h 2004-12-18 20:04:32.073307446 +0000 +@@ -38,6 +38,8 @@ + + metadata_t *md_next; /* Next file in bucket */ + metadata_t *md_previous; /* Previous " */ ++ ++ bucket_t *md_bucket; /* Our container */ + }; + + struct bucket_t |