我刚刚检查了一个旧项目来修复一个错误。 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从一个提交转移到另一个提交,它主要做两件事:origin/master 标识的提交,并且在该提交中,没有 git 当前抱怨的文件的记录。您已要求切换到由 master 标识的提交。 ,这显然是一个不同的提交。1 Git 在由 master 标识的提交中看到了这一点。 , 有一些(也许只有一个)同名的文件,它们与您现在工作树中的文件或目录不同。git checkout必须删除现有的文件或目录,并用新提交中的文件或目录替换它们——您要求切换到的那个。如果这些文件或目录在当前提交中被跟踪,git 会很乐意根据需要删除和替换它们,因为 git 总是可以为您取回它们:只需切换回旧提交,它们就在那里。但它们不在当前的、要切换的、提交中。所以 git 告诉你:“嘿,如果我按照你的要求进行这个切换,我不能保证我能够恢复这些文件和/或目录。”master将导致该目录被删除并替换为其他内容(可能是包含某些文件的不同目录,可能只是一个文件)。你:git checkout -f (force) 让 git 去做。git stash . Git的stash看似复杂的小脚本:它提交根本不在任何分支上的提交,稍后可以移植到分支。使用它非常简单和容易:您只需运行 git stash save并且所有挂起的跟踪更改都被保存和清理,或者运行 git stash save -u并且所有挂起的跟踪更改和未跟踪文件都将被保存和清理。它们现在都安全地 stash 在存储库中,在提交下,即使它不是在分支上提交。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常用命令(简介,详细参数往下看)Git提交代码步骤gitpullgitstatusgitaddgitcommitgitpushgit代码冲突合并问题方法一:放弃本地代码方法二:合并代码常用命令以及详细参数gitadd将文件添加到仓库:gitdiff比较文件异同gitlog查看历史记录gitreset代码回滚版本库相关操作远程仓库相关操作分支相关操作创建分支查看分支:gitbranch合并分支:gitmerge删除分支:gitbranch-ddev查看分支合并图:gitlog–graph–pretty=oneline–abbrev-commit撤消某次提交git用户名密码相关配置g
关于如何使用git设置类似Dropbox的服务,您有什么建议吗?您认为git是解决此问题的合适工具吗?我在考虑使用git+rush解决方案,你觉得怎么样? 最佳答案 检查这个开源项目:https://github.com/hbons/SparkleShare来自项目的自述文件:Howdoesitwork?SparkleSharecreatesaspecialfolderonyourcomputer.Youcanaddremotelyhostedfolders(or"projects")tothisfolder.Theseprojec
我编写了一个非常简单的“部署”脚本,作为我的裸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
我正在安装gitlabhq,并且在Gemfile中有对某些资源的“git://...”的引用。但是,我在公司防火墙后面,所以我必须使用http://。我可以手动编辑Gemfile,但我想知道是否有另一种方法告诉bundler使用http://作为git存储库? 最佳答案 您可以通过运行gitconfig--globalurl."https://".insteadOfgit://或通过将以下内容添加到~/.gitconfig:[url"https://"]insteadOf=git://
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文
我在bitbucket上创建了一个私有(private)git存储库并提交了代码。现在我想导出所有(提交、代码、历史记录)并将其导入github上的gitrepo。有没有办法做到这一点?谢谢 最佳答案 在本地检查所有内容到您的计算机和gitpull。创建一个github存储库将此存储库添加为您的第二个远程(“使用gitremote添加githubURL”)推送到第二个Remote 关于ruby-git:从bitbucket导出并导入github(带提交),我们在StackOverflow
亲测可用。Anerroroccurredwhileresolvingpackages:Projecthasinvaliddependencies: com.unity.xxx:No'git'executablewasfound.PleaseinstallGitonyour systemthenrestartUnityandUnityHub在我们使用PackageManager时,Unity允许我们使用Git上的package(点击加号,选择addpackagefromgitURL,或者是直接在Asset/Packages/manifest.json中添加包名)。但是这种操作需要我们事先装好g
文章目录概述背景为何要存算分离优势**应用场景**存算分离产品技术流派华为JuiceFSHashDataXSKY概述背景Hadoop一出生就是奔存算一体设计,当时设计思想就是存储不动而计算(code也即是代码程序)动,负责调度Yarn会把计算任务尽量发到要处理数据所在的实例上,这也是与传统集中式存储最大的不同。为何当时Hadoop设计存算一体的耦合?要知道2006年服务器带宽只有100Mb/s~1Gb/s,但是HDD也即是磁盘吞吐量有50MB/s,这样带宽远远不够传输数据,网络瓶颈尤为明显,无奈之举只好把计算任务发到数据所在的位置。众观历史常言道天下分久必合合久必分,随着云计算技术的发展,数据
我在Windows上使用GitBash来完成我的大部分Rails工作,每次我运行bundleexecrspecspec它都会提醒我“你必须geminstallwin32console才能使用Windows上的颜色”,然后以纯黑色和白色运行RSpec。但是我确实安装了win32console,当我在列表中运行gemlist时,它有win32console(1.3.0x86-mingw32)。RSpec工作正常,但我希望它有一些颜色。我用谷歌搜索了这个并找到了多种解决方案,但似乎没有一个适合我。有人可以写出在GitBashforWindows上使用RSpec获取颜色的“循序渐进”方法吗?
我想实现一个Rake任务,自动执行一些我必须完成的任务,以便将我的更改从开发转移到生产(是的,我知道有像Capistrano这样的东西,它对我来说太多了).中间是gitadd-i等一些交互命令,以及一系列commit和push。在生产方面,将有pull和Assets任务要做。一直输入相同的命令很乏味,所以我想完全自动化。我还没有找到Git的RubyAPI。它应该在Windows7下工作,并且至少允许以下命令:gitadd、gitstatus、gitcommit、gitpush,gitpull. 最佳答案 我知道,坏习惯,但我想记录一