summaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
authorGravatar https://launchpad.net/~stephane-gourichon-lpad <stephane-gourichon-lpad@web>2016-10-01 17:25:47 +0000
committerGravatar admin <admin@branchable.com>2016-10-01 17:25:47 +0000
commit643b3b9fe1ba86d8d0127b506e7b6846bc45b836 (patch)
treeb6ac7c0d8a35ba056bd77a2d2d3e898e15bf5c93 /doc
parent3c3faa7a940a4e41ee067a0cb7d2e0fb359f7349 (diff)
Added a comment: Sketch of implementation, request for comment
Diffstat (limited to 'doc')
-rw-r--r--doc/forum/Blacklisting_files___40__so_that_they_get_removed_any_time_a_copy_is_found__41__/comment_1_a224bf8ed9502053e9b95317db7b4bfa._comment24
1 files changed, 24 insertions, 0 deletions
diff --git a/doc/forum/Blacklisting_files___40__so_that_they_get_removed_any_time_a_copy_is_found__41__/comment_1_a224bf8ed9502053e9b95317db7b4bfa._comment b/doc/forum/Blacklisting_files___40__so_that_they_get_removed_any_time_a_copy_is_found__41__/comment_1_a224bf8ed9502053e9b95317db7b4bfa._comment
new file mode 100644
index 000000000..46e78c2a8
--- /dev/null
+++ b/doc/forum/Blacklisting_files___40__so_that_they_get_removed_any_time_a_copy_is_found__41__/comment_1_a224bf8ed9502053e9b95317db7b4bfa._comment
@@ -0,0 +1,24 @@
+[[!comment format=mdwn
+ username="https://launchpad.net/~stephane-gourichon-lpad"
+ nickname="stephane-gourichon-lpad"
+ subject="Sketch of implementation, request for comment"
+ date="2016-10-01T17:25:46Z"
+ content="""
+From forum entry [git annex drop not freeing space on filesystem](http://git-annex.branchable.com/forum/git_annex_drop_not_freeing_space_on_filesystem/) I understand that:
+
+* removing a file from the tree hierarchy (with `git rm`, maybe other ways) opens the possibility of freeing space locally
+* syncing with remotes propagates this possibility
+* `git annex dropunused --force` can free space
+
+So, if we have a way to remove files by content (through git, git annex, etc), e.g. starting from http://stackoverflow.com/questions/460331/git-finding-a-filename-from-a-sha1 , we can sketch a naive implementation:
+
+* (option 1, provides Q1 and Q2 above) run `git ls-tree` and filter output for blacklisted hashes (anyone knows a way to efficiently filter lines matching a pattern from a potentially big collection?), run git rm on the paths obtained
+* (option 2, provides Q3 above) run `git gilter-branch` with a filter spec that removes files by hash (is that possible?)
+* git sync with remotes
+* on each remote `git annex dropunused --force`
+
+Does that make sense?
+
+Thank you.
+
+"""]]