- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
基本问题
我刚刚从项目中的文件中删除了所有代码,并将更改提交到我的本地 git(故意)。我做了
git pull upstream master
Branch master set up to track remote branch master from upstream.
git branch -vv
产量:
* master 7cfcb29 [upstream/master: ahead 9] deletion test
最佳答案
我认为您在这里的基本问题是您误解和/或误解了 git 的作用以及它为什么这样做。
当您克隆某个其他存储库时,git 会复制“那边”的任何内容。它还需要“他们的”分支标签,例如 master
,并复制该标签的副本,该标签在您的 git 树中的“全名”是(通常)remotes/origin/master
(但在你的情况下, remotes/upstream/master
)。大多数情况下,您可以省略 remotes/
部分也是如此,因此您可以将该原始副本称为 upstream/master
.
如果您现在对某些文件进行并提交一些更改,则您是唯一进行这些更改的人。与此同时,其他人可能会使用原始存储库(您从中制作克隆)来制作其他克隆并更改这些克隆。当然,他们是唯一有变化的人。但最终,有人可能会将更改发送回原始所有者(通过“推送”或补丁或其他方式)。git pull
命令主要是 git fetch
的简写其次是 git merge
.这很重要,因为这意味着您需要了解这两个操作的实际作用。git fetch
命令说返回到你克隆的任何地方(或以其他方式设置为从中获取的地方)并找到“其他人添加、更改或删除的新内容”。这些更改被复制并应用到您之前从它们那里获得的副本。它们不适用于您自己的工作,仅适用于他们的工作。git merge
命令更复杂,这就是你出错的地方。它所做的稍微简单化了一点,就是将“您在副本中更改的内容”与“您从其他人那里获取的更改内容添加到您的其他人的工作副本中”进行比较。如果您的更改和它们的更改似乎没有冲突,merge
操作将它们混合在一起并为您提供“merge 提交”,将您的开发和它们的开发联系在一起(尽管有一种非常常见的“简单”情况,您没有更改并且您会得到“快进”)。
您现在遇到的情况是您进行了更改并进行了更改——实际上是 9 次,因此是“前进 9”——而他们没有进行任何更改。所以,fetch
尽职尽责地什么也不取,然后 merge
接受他们缺乏变化,也不做任何事情。
您想要的是查看或什至“重置”到“他们的”代码版本。
如果你只是想看看它,你可以简单地查看那个版本:
git checkout upstream/master
remotes/upstream/master
的分支。 .您将看到上次运行时的代码
git fetch
并得到了他们的最新代码。
master
,应命名。目前它命名你最近的提交。如果你回到那个分支:
git checkout master
git reset
命令将允许您“移动标签”,就像它一样。唯一剩下的问题(假设你真的准备放弃你所做的一切)是找到标签应该指向的地方。
git log
会让你找到数字名称——比如
7cfcb29
之类的东西——它们是永久的(永远不会改变的)名字,还有很多其他的方法来命名它们,但在这种情况下,你只想要名字
upstream/master
.
git reset --hard upstream/master
--hard
告诉 git 清除你一直在做的事情,移动当前的分支标签,然后检查给定的提交。
git reset --hard
并抹去一堆工作。一种更安全的方法(如果您认为其中的一些工作是值得的,那么恢复工作会更容易)是重命名现有分支:
git branch -m master bunchofhacks
master
的新本地分支那个“跟踪”(我真的不喜欢这个词,因为我认为它让人们感到困惑,但那是 git 术语 :-) )起源(或上游)大师:
git branch -t master upstream/master
git checkout master
C0 - "remotes/upstream/master"
\
\- C1 --- C2 --- C3 --- C4 --- C5 --- C6 --- C7 --- C8 --- C9 "master"
git branch -m
:
C0 - "remotes/upstream/master"
\
\- C1 --- C2 --- C3 --- C4 --- C5 --- C6 --- C7 --- C8 --- C9 "bunchofhacks"
git branch -t master upstream/master
:
C0 - "remotes/upstream/master", "master"
\
\- C1 --- C2 --- C3 --- C4 --- C5 --- C6 --- C7 --- C8 --- C9 "bunchofhacks"
C0
是您第一次做
git clone
时得到的最新提交(完整的源代码树)。 . C1 到 C9 是你的提交。
git checkout bunchofhacks
然后
git reset --hard HEAD^^
,这会将最后一张图片更改为:
C0 - "remotes/upstream/master", "master"
\
\- C1 --- C2 --- C3 --- C4 --- C5 --- C6 --- C7 - "bunchofhacks"
\
\- C8 --- C9
HEAD^^
将修订版命名为从当前分支的头部开始(在重置之前是
bunchofhacks
)和
reset --hard
然后移动标签。提交 C8 和 C9 现在大部分是不可见的(你可以使用诸如 reflog 和
git fsck
之类的东西来找到它们,但这不再是微不足道的了)。您的标签可以随心所欲地移动。
fetch
命令处理以
remotes/
开头的那些.通常将“你的”与“他们的”匹配(所以如果他们有
remotes/origin/mauve
,你也可以命名你的
mauve
),但你可以在任何时候输入“他们的”,只要你想命名/查看你得到的提交“从他们”。 (请记住,“一次提交”是一整个源代码树。您可以从一次提交中挑选出一个特定的文件,例如
git show
,如果需要的话。)
关于git - 为什么 Git 说我的主分支是 "already up to date"即使它不是?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15376241/
我使用 Git 有一段时间了,但尽管在博客和教程上花了很多时间,但我仍然无法理解某些功能...:) 我正在与其他人合作一个项目,我的老板为此在 bitBucket 上创建了一个存储库。 我在本地克隆了
有时我会遇到以下问题: 在功能分支中添加一些提交。 从上游更新 master。 想要查看功能分支和 master 之间的差异,但是 git diff master 显示了在 master 中添加/删除
我使用的是 Gerrit 2.4.2 版。我有一个分支 master,我创建了一个名为 newbranch 的新分支。然后我将一些更改推送到远程(Gerrit 的)newbranch。在 Gerrit
假设我们有一个远程存储库并在本地克隆它。 我们 checkout master 分支,所以现在我们有本地 master 和一个 Remote remotes/origin/master . 然后我必须
我有一个项目,其中开发分支使用 CocoaPods,但其中一位开发人员决定删除它并改用 Carthage。 feature 分支使用的是 CocoaPods,因为它是在 develop 分支转换之前一
我有一个有问题的 master 分支需要调试。为此,我想插入一堆调试程序(例如,打印变量),查明错误并应用修复程序。稍后,我想将修复 merge 到 master 分支中,但我不想跳过调试更改。 #
我有一个 master 分支,我正在其中 push 我的最新开发。 现在在某个时候,我确实从 master 分支发布并创建了名为 release1 的新分支。 现在我在master分支上做新的开发 与
我正在尝试使我的一些标准工作流程自动化,我发现自己经常做的一件事是将对远程 master 分支的更改 merge 到我自己的本地分支并推送结果。 所以步骤如下: 转为大师 从远程 pull 更改 切换
使用 Gerrit 很容易意外地将开发分支中的不稳定代码 merge 到稳定分支中: $ git checkout develop $ commit $ git push origin HEAD:re
我有一个正在进行的项目,我正在雇用承包商来帮助我处理代码的某些部分。问题是我不想让任何一个承包商看到所有这些。 我可以在 GitHub 上为他们分配私有(private)存储库下的分支吗?这需要命令行
SVN 分支 Branch 选项会给开发者创建出另外一条线路。当有人希望开发进程分开成两条不同的线路时,这个选项会非常有用。我们先假设你已经发布了一个产品的 1.0 版本,你可能想创建一个新的分支,
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 提供事实和引用来回答它. 2年前关闭。 Improve this
有没有办法从特定的修订版中创建(svn)分支, 因为我想跳过提交历史中的一些修订(在新分支中)。 例如,我有从 1 到 1590 的修订,我想创建一个新分支并跳过提交(从 1504 到 1574 )和
到目前为止我看到的所有 svn 分支的例子都是这样的 svn cp -m 'Making test branch' svn://svnrepo/hellosite svn://svnrepo/hell
当我尝试使用 Sonar 扫描仪分析我的项目时,扫描失败并显示以下错误消息: Caused by: Branch does not exist on server: develop 显然,这只发生在它
在我的 Mercurial 存储库中,不知何故,有人输入了空白分支名称: 如果我hg id -r 2004,我确实得到空白文本。现在的问题是,这会导致我们的Redmine安装出现问题,因为它无法同步存
我有以下代码片段: srcaddr >= inet_ntoa . fromJust dstaddr >= inet_ntoa . fromJust -- I want to perform actio
在我的项目中,我有用于工作的本地分支和网络驱动器上的分支我在本地一号和网络一号之间做了“绑定(bind)分支”我的想法是使用绑定(bind)选项自动备份每个本地提交。 我在本地分支提交文件后,我在网络
我想创建一个脚本,根据变量的状态使用不同的表和命令执行不同的操作。在 T-SQL 中,我会这样做: DECLARE @whatToDo INT = 1; IF @whatToDo = 1 BEGIN
Write a program that reads input up to # and reports the number of times that the sequence ei occurs
我是一名优秀的程序员,十分优秀!