git-annex has this peculiar thing that blobs stored in .git/annex/objects are readonly, even for the current user. Naturally, git-annex itself bypasses those restrictions in some way to create/remove/move those files from time to time, but for other tools, this can actually be a problem. For example, if a user wants to completely remove a dead repository, they will naively try to just delete it (say) in their file manager, which will fail with permission errors.

Similarly, moving a repository across filesystem boundaries will create problems, as this effectively means copying the files and removing the original copy. Normally, this should be a safe thing to do, but git-annex forbids it.

The workaround I have found is to do exactly that: copy the files and then remove the original. I used the "tar + pv" hack to get a progress bar:

tar cf - Photos | pv -s 406G | ( cd /srv ; tar xf - )

Just for good measure, I then also run fsck on the repository copy:

git -C /srv/Photos annex fsck --quiet --incremental

If that succeeds, I then remove the original repository:

sudo rm -r Photos

Notice how it's simpler for me to do sudo rm than the alternative:

chmod -R u+w Photos
\rm -r Photos

I believe that's because rm won't fail to remove files if they are readonly when running as root.

Anyways - what's the proper way of doing this? I know I could git clone the repository and git get everything, but that would create another repository with a new UUID. That's duplication I do not want.

Thanks for the advice! -- anarcat