From eef99dee6096bc0ff47f17735f179cd6b315758e Mon Sep 17 00:00:00 2001 From: anarcat Date: Mon, 27 Mar 2017 19:50:43 +0000 Subject: [PATCH] add annex-sync setting sample --- doc/tips/semi-synchronized_remotes.mdwn | 38 ++++++++++++++++++++----- 1 file changed, 31 insertions(+), 7 deletions(-) diff --git a/doc/tips/semi-synchronized_remotes.mdwn b/doc/tips/semi-synchronized_remotes.mdwn index c38177bf05..c91eabf12d 100644 --- a/doc/tips/semi-synchronized_remotes.mdwn +++ b/doc/tips/semi-synchronized_remotes.mdwn @@ -77,8 +77,10 @@ I need some special setting. There are the options I considered, in [.gitconfig](https://manpages.debian.org/git-config.1.en.html) or [[git-annex]]'s config options: * `remote..annex-ignore=true`: `sync` and `assistant` will not - sync to the repository, but explicit `get --from=repoB` will still - work. unclear if `sync repoB` will also push. + sync *content* to the repository, but explicit `get --from=repoB` + will still work. + * `remote..annex-sync=false`: `sync` (and `assistant`?) will + not sync the git repository with the remote * `remote..push=nothing`: git won't push by default, unless branches are explicitly given, which may actually be the case for git-annex, so unlikely to work. @@ -94,12 +96,34 @@ I need some special setting. There are the options I considered, in instead. crude hack and may confuse the hell out of git-annex, but at least doesn't yield errors. -I've settled for the `pushurl=/dev/null` hack for now. A similar -approach is to make `repoB` read-only to the user. This however, may -trigger the activation of `annex-ignore` by git-annex and will -otherwise yield the same warnings as the `pushurl=/dev/null` hack. +A similar approach to hacking the `pushurl` is to make `repoB` +read-only to the user. This however, may trigger the activation of +`annex-ignore` by git-annex and will otherwise yield the same warnings +as the `pushurl=/dev/null` hack. -Therefore, the best approach may be to have git-annex respect the +Right now, I am using `annex-sync = false` in `.git/config`. I have +also configured the repository to be in the "manual" [[standard +group|preferred_content/standard_groups]] which will avoid copying +files into that repository: + + $ git annex group repoB manual + group repoB ok + (recording state in git...) + $ git annex wanted repoB standard + wanted repoB ok + (recording state in git...) + +This is roughly equivalent to setting `annex-ignore = true`, yet it +allows for more flexibility. I could, for example, create custom +content expressions to sync certain folders automatically. + +A disadvantage of the `annex-sync` settings is that it affects both +ways (push and pull), not just push, which is what I am interested +in. Although it could be argued that restricting both is fine here +because we want to manually review changes when we pull changes from +those remotes anyways. + +The best approach may be to have git-annex respect the `remote..push=nothing` setting. Another approach would be to add `remote..annex-push` and `remote..annex-pull` settings that would match the `sync --[no-]push --[no-]pull` flags.