这就是我想要做的事情:
这就是我所看到的:
让我举个例子,也许有人可以告诉我哪里出错了。
C:\GIT\remote
的目录,其中包含一个名为readme.txt
的文件,其中包含字符串Hello World!
我将其转换为Git存储库,我暂存readme.txt
文件,它显示:
new file mode 100644
@@ -0,0 +1 @@
+Hello World!
我在远程存储库中提交此更改。远程存储库不包含未分级的更改
启动Eclipse,import->Projects from Git->Clone URI
。位置URI = C:\GIT\remote
,Next
,Next
,目标目录:C:\GIT\local
,Next
,Import as General Project
,Next
,{{ 1}}
这将在Finish
中创建一个git存储库,其中包含C:\GIT\local
文件和.project文件。正如所料。
在Eclipse中,我打开readme.txt
文件并对其进行编辑以说出readme.txt
。保存。
右键单击Project Explorer中的项目,然后:Goodbye World!
要更改的文件有:Team->Commit
和readme.txt
。我输入提交消息“进行了更改”,然后点击.project
。
Eclipse现在显示本地存储库在远程存储库之前是1次提交。 (我是对的吗?)
Commit
,它显示我的评论和远程存储库详细信息:
它显示需要删除Team->Push to Upstream
文件(而不是添加),并且对.project
文件的更改应该与我刚才所做的更改相反:
readme.txt
@@ -1 +1 @@
-Goodbye World!
+Hello World!
文件包含字符串“Hello World!”。根据文件的内容,分阶段补丁甚至没有意义。
我很困惑。
答案 0 :(得分:2)
不,这些是远程的分阶段变化。不是提交历史记录(git日志)。这是两件不同的事情。
“Git GUI”向您展示了直接提交到远程存储库以使其与远程存储库的工作目录保持同步所需的更改,该工作目录仍处于旧状态 - 已过期。
为了避免这种混淆,开发人员经常使远程存储库成为一个裸存储库 - 一个没有工作目录的存储库。然后它只能被推入和拉出 - 不直接承诺。