草庐IT

git - HEAD 在原点/主站分离

coder 2023-06-24 原文

我刚刚检查了一个旧项目来修复一个错误。 git 报告:

HEAD detached at origin/master
git status报告我有一个未跟踪的文件:
<project name>.xcworkspace/xcshareddata/

我想继续并修复错误,但我不确定发生了什么。如果我尝试 git checkout master我得到:
error: The following untracked working tree files would be overwritten by checkout:
<project name>.xcworkspace/xcshareddata/

我可以删除这个文件吗?我在 master分支?如果没有,我该如何解决?

最佳答案

CommuSoft says ,你不是主人。您处于“分离头”模式。每当您明确检查不是(本地)分支名称的内容时,您都会得到:

$ git checkout origin/master    # detach to "remote branch"
或者如果有标签 v1.7 :
$ git checkout v1.7             # detach to tag
您甚至可以在使用本地分支名称时显式分离:
$ git checkout --detach master  # forcibly detach
“分离的 HEAD”意味着您不在分支上。 “在分支上”意味着您没有使用分离的 HEAD 模式。是的,这是非常循环的;见 this question及其更多详细信息的答案。
至于:

error: The following untracked working tree files would be overwritten ...


当您收到 git checkout从一个提交转移到另一个提交,它主要做两件事:
  • 选择是否处于“分离头”模式,和
  • 重新排列工作树以匹配移动的提交。

  • 第 2 步是出现问题的地方。您正在提交由 origin/master 标识的提交,并且在该提交中,没有 git 当前抱​​怨的文件的记录。您已要求切换到由 master 标识的提交。 ,这显然是一个不同的提交。1 Git 在由 master 标识的提交中看到了这一点。 , 有一些(也许只有一个)同名的文件,它们与您现在工作树中的文件或目录不同。
    为了从当前提交切换到新提交,git checkout必须删除现有的文件或目录,并用新提交中的文件或目录替换它们——您要求切换到的那个。如果这些文件或目录在当前提交中被跟踪,git 会很乐意根据需要删除和替换它们,因为 git 总是可以为您取回它们:只需切换回旧提交,它们就在那里。但它们不在当前的、要切换的、提交中。所以 git 告诉你:“嘿,如果我按照你的要求进行这个切换,我不能保证我能够恢复这些文件和/或目录。”
    现在由您而不是 git 来决定如何处理这些文件和/或目录。根据错误消息,它是一个目录,2 并切换到 master将导致该目录被删除并替换为其他内容(可能是包含某些文件的不同目录,可能只是一个文件)。你:
  • 想保存它/他们吗?
  • 如果是这样,您想将它/它们保存在提交中,还是只是将它们移开?
  • 或者你只是想把它们吹走?

  • 要保存它们,要么提交它们,要么将它们移开(例如,将它们重命名为不属于工作树的路径,或者重命名为“更安全”的其他未跟踪名称,无论是什么)。
    要简单地将它们吹走,请手动移除它们或使用 git checkout -f (force) 让 git 去做。
    由于您现在不在分支上(处于“分离的 HEAD”模式),如果您想将它们永久提交到存储库,您可以使用类似 CommuSoft 在我写这篇文章时添加的方法。 (您可以在执行“git commit”之前或之后随时创建新分支。)
    您也可以使用 git stash . Git的stash看似复杂的小脚本:它提交根本不在任何分支上的提交,稍后可以移植到分支。使用它非常简单和容易:您只需运行 git stash save并且所有挂起的跟踪更改都被保存和清理,或者运行 git stash save -u并且所有挂起的跟踪更改和未跟踪文件都将被保存和清理。它们现在都安全地 stash 在存储库中,在提交下,即使它不是在分支上提交。
    在这里做什么没有唯一的正确答案。

    1显然不同,因为如果你已经在提交你要求 git 移动到,那么文件要么在提交中并因此被跟踪,要么它不在提交中,因此你不会要求 git 破坏它。
    2这有点奇怪。如果我创建的目录会被我的 git checkout 破坏,我把它作为一个空目录,git只是继续并破坏它。这里的区别master^master是从 master^ 前进至 master创建文件 mxgroup.py (所以退一步删除它):
    $ git checkout -q master^  # file goes away, now let's mkdir...
    $ mkdir mxgroup.py; git checkout -q master
    $ file mxgroup.py
    mxgroup.py: Python script, ASCII text executable
    
    但是,如果我有一个非空目录,则会收到不同的错误消息:
    $ git checkout -q master^  # file goes away; mkdir and make file
    $ mkdir mxgroup.py; touch mxgroup.py/file; git checkout -q master
    error: Updating the following directories would lose untracked files in it:
        mxgroup.py
    
    Aborting
    
    但这是 git 2.0.2 版;也许年长的 git 没有那么聪明。

    关于git - HEAD 在原点/主站分离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25232056/

    有关git - HEAD 在原点/主站分离的更多相关文章

    1. git使用常见问题(提交代码,合并冲突) - 2

      文章目录git常用命令(简介,详细参数往下看)Git提交代码步骤gitpullgitstatusgitaddgitcommitgitpushgit代码冲突合并问题方法一:放弃本地代码方法二:合并代码常用命令以及详细参数gitadd将文件添加到仓库:gitdiff比较文件异同gitlog查看历史记录gitreset代码回滚版本库相关操作远程仓库相关操作分支相关操作创建分支查看分支:gitbranch合并分支:gitmerge删除分支:gitbranch-ddev查看分支合并图:gitlog–graph–pretty=oneline–abbrev-commit撤消某次提交git用户名密码相关配置g

    2. ruby - Dropbox 类似 git 的服务——没有 rsync 和 inotify - 2

      关于如何使用git设置类似Dropbox的服务,您有什么建议吗?您认为git是解决此问题的合适工具吗?我在考虑使用git+rush解决方案,你觉得怎么样? 最佳答案 检查这个开源项目:https://github.com/hbons/SparkleShare来自项目的自述文件:Howdoesitwork?SparkleSharecreatesaspecialfolderonyourcomputer.Youcanaddremotelyhostedfolders(or"projects")tothisfolder.Theseprojec

    3. ruby - 混帐 & ruby : How can I unset the GIT_DIR variable from inside a ruby script? - 2

      我编写了一个非常简单的“部署”脚本,作为我的裸git存储库中的post-updateHook运行。变量如下livedomain=~/mydomain.comstagingdomain=~/stage.mydomain.comgitrepolocation=~/git.mydomain.com/thisrepo.git(bare)core=~/git.mydomain.com/thisrepo.gitcore==addedremoteintoeachlive&stagegitslive和stage都初始化了gitrepos(非裸),我已经将我的裸仓库作为远程添加到它们中的每一个(名为co

    4. ruby - 让 bundler 使用 http : instead of git:? - 2

      我正在安装gitlabhq,并且在Gemfile中有对某些资源的“git://...”的引用。但是,我在公司防火墙后面,所以我必须使用http://。我可以手动编辑Gemfile,但我想知道是否有另一种方法告诉bundler使用http://作为git存储库? 最佳答案 您可以通过运行gitconfig--globalurl."https://".insteadOfgit://或通过将以下内容添加到~/.gitconfig:[url"https://"]insteadOf=git://

    5. ruby-on-rails - 安装 active admin 时 activeadmin.git (at master) is not yet checked out 错误 - 2

      Activeadmingem已添加到我的rails项目中,但每次我尝试安装railsgactive_admin:install时,我都会收到类似的错误git://github.com/activeadmin/activeadmin.git(atmaster)isnotyetcheckedout.Runbundleinstallfirst.我肯定在运行“railsgactive_admin:install”之前运行了bundle。运行“bundleshow”后,我看到我已将“*activeadmin(1.0.0.pre3f916d6)”添加到我的项目中,但不断收到此错误消息。我的gem文

    6. ruby - git:从 bitbucket 导出并导入 github(带提交) - 2

      我在bitbucket上创建了一个私有(private)git存储库并提交了代码。现在我想导出所有(提交、代码、历史记录)并将其导入github上的gitrepo。有没有办法做到这一点?谢谢 最佳答案 在本地检查所有内容到您的计算机和gitpull。创建一个github存储库将此存储库添加为您的第二个远程(“使用gitremote添加githubURL”)推送到第二个Remote 关于ruby-git:从bitbucket导出并导入github(带提交),我们在StackOverflow

    7. Unity 报错No ‘git‘ executable was found. Please install Git on your system then restart - 2

      亲测可用。Anerroroccurredwhileresolvingpackages:Projecthasinvaliddependencies: com.unity.xxx:No'git'executablewasfound.PleaseinstallGitonyour  systemthenrestartUnityandUnityHub在我们使用PackageManager时,Unity允许我们使用Git上的package(点击加号,选择addpackagefromgitURL,或者是直接在Asset/Packages/manifest.json中添加包名)。但是这种操作需要我们事先装好g

    8. 企业大数据发展面临问题之存算分离技术思考 - 2

      文章目录概述背景为何要存算分离优势**应用场景**存算分离产品技术流派华为JuiceFSHashDataXSKY概述背景Hadoop一出生就是奔存算一体设计,当时设计思想就是存储不动而计算(code也即是代码程序)动,负责调度Yarn会把计算任务尽量发到要处理数据所在的实例上,这也是与传统集中式存储最大的不同。为何当时Hadoop设计存算一体的耦合?要知道2006年服务器带宽只有100Mb/s~1Gb/s,但是HDD也即是磁盘吞吐量有50MB/s,这样带宽远远不够传输数据,网络瓶颈尤为明显,无奈之举只好把计算任务发到数据所在的位置。众观历史常言道天下分久必合合久必分,随着云计算技术的发展,数据

    9. ruby - RSpec Git Bash Windows——缺少颜色? - 2

      我在Windows上使用GitBash来完成我的大部分Rails工作,每次我运行bundleexecrspecspec它都会提醒我“你必须geminstallwin32console才能使用Windows上的颜色”,然后以纯黑色和白色运行RSpec。但是我确实安装了win32console,当我在列表中运行gemlist时,它有win32console(1.3.0x86-mingw32)。RSpec工作正常,但我希望它有一些颜色。我用谷歌搜索了这个并找到了多种解决方案,但似乎没有一个适合我。有人可以写出在GitBashforWindows上使用RSpec获取颜色的“循序渐进”方法吗?

    10. ruby - git 最好的 ruby​​ api 是什么? - 2

      我想实现一个Rake任务,自动执行一些我必须完成的任务,以便将我的更改从开发转移到生产(是的,我知道有像Capistrano这样的东西,它对我来说太多了).中间是gitadd-i等一些交互命令,以及一系列commit和push。在生产方面,将有pull和Assets任务要做。一直输入相同的命令很乏味,所以我想完全自动化。我还没有找到Git的RubyAPI。它应该在Windows7下工作,并且至少允许以下命令:gitadd、gitstatus、gitcommit、gitpush,gitpull. 最佳答案 我知道,坏习惯,但我想记录一

    随机推荐