As you may be aware, I'm working on a git remote helper to access mercurial repositories (https://github.com/glandium/git-cinnabar/). At the moment, a small part is written in C, relying on the git code base, but eventually, there would be more C. As I want to get rid of the dependency on Mercurial itself, I'm planning to implement the wire protocol parts in git-cinnabar. And while at it, I figured I'd evaluate if I can't just rely on some git internals, from C code. So I've turned to the git_connect function, that implements the niceties around GIT_SSH and GIT_SSH_COMMAND, and also handles ssh client specificities. (I'd rather not have to copy the code or reimplement it). It also turns out to be a convenient wrapper around start_command() for local urls. The git commands that git_connect is invoked for all take the repository path as their last argument. In mercurial's case, the command is: hg -R $path serve --stdio which doesn't match that pattern. So one hack I was thinking about was scan the url on my end, extract the path, replace it with "--stdio", and pass "hg -R $path serve" as command. Unfortunately, parse_connect_url is static, which means I'd either have to change connect.c to expose it, or copy it. Since I'd rather avoid copying code, I figured that since I was going to have to change connect.c, I might as well go with something less hacky, assuming it's accepted mainline. So following here are four patches that allow me to connect, via ssh, to hg.mozilla.org, and access mercurial repositories there using: git_connect(fd, url, "hg -R %s serve --stdio", CONNECT_RELATIVE_SSH | CONNECT_WANT_STDERR) And this works for local urls too, invoking `hg serve` locally. Note that what the second patch does could be done in sq_quote_buf instead, arguably. I'm certainly open to any better ideas as long as they can make it to mainline :). Mike Hommey (4): git_connect: extend to take a pseudo format string for the program to run git_connect: avoid quoting the path on the command line when it's not necessary git_connect: allow a file descriptor to be allocated for stderr git_connect: add a flag to consider the path part of ssh urls relative connect.c | 52 ++++++++++++++++++++++++++++++++++++++++++++-------- connect.h | 2 ++ 2 files changed, 46 insertions(+), 8 deletions(-) -- 2.8.1.5.g18c8a48 -- 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