Hi Jed, all,
On 28.01.2013, at 06:19, Jed Brown wrote:
I'm working on an hg remote helper that uses git notes for the sha1
revision, so that git users can more easily refer to specific commits
when communicating with hg users.
For the record, I am also working on that very same thing; it is yet another
git-remote-hg alternative, based on Felipe's code but with many improvements.
You can find it here: https://github.com/buchuki/gitifyhg.
Anyway, back to Jed's (and also my) question:
Since there may be multiple
concurrent fast-import streams, I write the notes to a private ref
(refs/notes/hg-REMOTE), to be merged eventually using
git notes --ref hg merge hg-REMOTE*
There will never be conflicts because each hg commit translates to a
unique git commit, thus even if multiple concurrent remotes process the
same commit, the corresponding note will match.
Unfortunately, I couldn't find a safe way to get this run after a fetch
or clone. Of course I can ask the user to arrange to have this command
run, but it would be a better interface to have it run automatically
since it is a natural responsibility of the remote helper. Am I missing
a way to do this or a viable alternative approach?
One idea we (well, Jed :-) had when brain storming about this was that perhaps
one could (or even should?) (ab)use the checkpoint feature for that.
Basically, when the remote-helper is almost done with everything, issue a
checkpoint command, to flush out everything we just imported to the HD.
Then once this completed, we can perform the notes merge. The main remaining
problem with that is: How would we know when the checkpoint actually
completed? Any ideas?
Perhaps a way to do that would be to make use of the new bidi-import remote
helper capability -- if I understand it right, then this effectively connects
the fast-import stdout to the stdin of the remote helper. Thus, if one were to
follow the checkpoint by a progress command, then by waiting for that
progress command's output to appear back on stdin, the remote helper could
determine whether the import succeeded, and perform finalization actions (like
merging notes, as in our case).
Does that sound viable? Crazy? Anybody got better a idea?
Cheers,
Max--
To unsubscribe from this list: send the line unsubscribe git in
the body of a message to majord...@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html