我正在尝试使用带有 TortoiseHg 的 git+ssh 协议在 github 上克隆我的个人 fork。它给了我一个相当奇怪的错误。这是命令
hg clone git+ssh://git@github.com:myusername/thefork.git
这是在我安装了 hg-git 模块之后,它可以很好地使用 git:// 语法进行克隆。但我相信 ssh 有问题。我得到的错误是这个。
importing Hg objects into Git
[Error 2] The system cannot find the file specified
我已经尝试像这样将 ssh 命令手动添加到 mercurial.ini 文件中
[ui]
username = email@address.com
ssh="C:\Program Files\TortoiseHg\TortoisePlink.exe" -ssh -2 -i "C:\Source\SSHPrivateKey.ppk"
但我仍然得到同样的错误。有任何想法吗?
更新 1
如果我从 Git Bash shell 运行相同的命令,它就可以正常工作。我明白了。
importing Hg objects into Git
Counting objects: 1559, done.
Compressing objects: 100% (586/586), done.
Total 1559 (delta 960), reused 1534 (delta 947)
importing Git objects into Hg
at: 0/86
updating to branch default
219 files updated, 0 files merged, 0 files removed, 0 files unresolved
我假设这是因为它可以找到 ssh.exe 并且我的密钥已经导入。我可以将 ssh.exe 的路径添加到 windows 命令提示路径,然后我得到这个错误,而不是之前的错误。
importing Hg objects into Git
Permission denied (publickey).
abort: the remote end hung up unexpectedly
尽管我在 mercurial.ini 中指定了备用 ssh 路径,但它似乎专门寻找 ssh.exe。但我的猜测是,该配置仅适用于启用 ssh 的 mercurial 服务器,不适用于 hg-git 插件。