1

git rebase -i $(HASH)挂着..永远不会完成。

这是命令

git rebase -i d8c0f59d5d627efb65b47264d5169e3626195839

这样做是为了压缩一些提交。由于它是交互式的 - 它要求打开编辑器的次数是预期的两倍。

然后打印类似的东西

 [detached HEAD fc62e0b3] AIRFLOW-1012 -
 add run_as_script parameter  
 Author: Tagar  
 Date: Sun Mar 19 12:50:50 2017 -0600
 2 files changed, 14 insertions(+), 3 deletions(-)

然后..什么也没发生-git rebase无限期地等待/挂起。

我在 Windows 上使用来自 GitHub 的 git-shell,最新版本。

试图追踪git rebase如下:

set -x; GIT_TRACE=2 GIT_CURL_VERBOSE=2 GIT_TRACE_PERFORMANCE=2 \
GIT_TRACE_PACK_ACCESS=2 GIT_TRACE_PACKET=2 GIT_TRACE_PACKFILE=2 \
GIT_TRACE_SETUP=2 GIT_TRACE_SHALLOW=2 \
git rebase -i d8c0f59d5d627efb65b47264d5169e3626195839

它在开始挂起之前显示最新的输出:

 20:03:58.266245 trace.c:435             performance: 13.236119523 s:
 git command:
 'C:\Users\myuser1\AppData\Local\GitHubPortableGit_f02737a78695063deace08e96d5042710d3e32db\mingw32\libexec\git-core\git.exe'
 'commit' '-n' '--amend' '-F' '.git/SQUASH_MSG' '-e' 20:03:58.293248
 run-command.c:350       trace: run_command: 'notes' 'copy'
 '--for-rewrite=rebase' 
 20:03:58.371255 trace.c:333             setup:
 git_dir: .git 
 20:03:58.372255 trace.c:334             setup:
 git_common_dir: .git 
 20:03:58.372255 trace.c:335             setup:
 worktree: C:/Users/myuser1/Documents/GitHub/incubator-airflow
 20:03:58.372255 trace.c:336             setup: cwd:
 C:/Users/myuser1/Documents/GitHub/incubator-airflow
 20:03:58.372255 trace.c:337             setup: prefix: (null)
 20:03:58.372255 git.c:371               trace: built-in: git 'notes'
 'copy' '--for-rewrite=rebase' 
 20:03:58.372255 trace.c:435            
 performance: 0.006984451 s: git command:
 'C:\Users\myuser1\AppData\Local\GitHub\PortableGit_f02737a78695063deace08e96d5042710d3e32db\mingw32\libexec\git-core\git.exe'
 'notes' 'copy' '--for-rewrite=rebase'

因此,根据跟踪(运行时间 0.0069 秒),执行的最新命令git rebase是并且它成功了。 之后什么也没有发生。git notes copy --for-rewrite=rebase

我是一个老派的 SVN 并且正在学习 git,但这对我来说似乎是 GitHub 的便携式版本 git 的错误?

PS:我正在尝试这样做strace,但是 mingw 在 Windows 下的 strace 看起来不是很有用。

4

1 回答 1

2

不要使用嵌入在 GitHub Desktop 中的便携式 Git,而是使用以下命令重试:

  • 你可以找到最新的 Windows 版 Git,比如(解压PortableGit-2.12.1-64-bit.7z.exe到任何你想要的地方,无需设置)
  • 然后在一个CMD会话中,设置你PATH的:

    set G=c:\path\to\latest\git
    set PATH=%G%\bin;%G%\usr\bin;%G%\mingw64\bin
    set PATH=%PATH%;C:\windows\system32;C:\windows\System32\Wbem;C:\windows\System32\WindowsPowerShell\v1.0\
    
  • HOME在同一个CMD会话中设置你

    set HOME=%USERPROFILE%
    
  • 最后,仍然从同一个 CMD(带有简化的 PATH),cd 到你的 Git 本地 repo,然后再次尝试你的 rebase。在重新尝试变基之前先做一个
    git rebase --quit

于 2017-03-27T04:36:16.510 回答