Dan Farina <drfarina@xxxxxxxxx> writes: > I did look at prune and update, but my problem is the opposite: I want > something that will remove branches from the remote repo when they no > longer exist locally. As-is over time I will proliferate little local > branches unless I occasionally sit down and delete branches by operating > directly on the bare backup repository. (and then use prune on the > remote nodes) The "git remote add --mirror" setup is about setting up the local repository _AS_ the backup of the remote. In other words, the contents come from the remote by fetching from it and safely kept away from disaster on the local side. And for that, "remote prune" is a perfect thing to do. I think what you are asking for is an opposite, a backup remote site you would push into. That is not what "remote add --mirror" is about. You can almost do it with git push --all $remote except there is no way to automagically remove the branch you removed from the local repository. For that, we would need a new --mirror option to "git-push". I think it is trivial to do for native transports, as we first get the list of all refs from the remote side before starting the transfer. You need to change the last parameter called 'all' to remote.c::match_refs() into an enum ('push_all' being one of choices), introduce another enum 'push_mirror', and teach it to "match" the remote (i.e. dst) ref that does not have corresponding entry on our side (i.e. src) with an empty object name to mark it removed. Then the part marked as "Finally, tell the other end!" in send-pack.c::send_pack() will take care of the actual removal. - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html