- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
最初我有以下(简化的) repo 结构:
MyRepo
external1/MySub (git submodule)
.gitsubmodules
在哪里
$ cat .gitsubmodules
[submodule "external1/MySub"]
path = external1/MySub
url = user@repo:/remoterepo/externals/MySub.git
然后我想将 MySubmodule 移动到同一个 git 存储库中的另一个目录,例如 external2 所以结构如下:
MyRepo
external2/MySub (git submodule)
.gitsubmodules
我所做的和所想的就足够了,我只是将(通过操作系统 mv
)external1/MySub 目录移动到 external2/MySub并将 .gitsubmodules 文件编辑为:
$ cat .gitsubmodules
[submodule "external2/MySub"]
path = external2/MySub
url = user@repo:/remoterepo/externals/MySub.git
此更改后,我收到以下错误:
$ git status
fatal: Could not chdir to '../../../../../repo/external/MySub': No such file or directory
fatal: 'git status --porcelain' failed in submodule repo/external2/MySub
我错过了什么?是否需要进行任何其他更改才能使此类移动生效?
(我在 Windows 8.1 上使用 git 版本 1.8.3rc3)
最佳答案
I simply moved the external1/MySub directory to external2/MySub
按照mv
移动(unix 命令),或 git mv
(git 命令)?
您需要移动 special entry的 the index代表父仓库的子模块。
通常,(阅读 git mv
),这应该足够了:
git mv external1/MySub external2/MySub
Moving a submodule using a gitfile (which means they were cloned with a Git version 1.7.8 or newer) will update the
gitfile
andcore.worktree
setting to make the submodule work in the new location.
It also will attempt to update thesubmodule.<name>.path
setting in thegitmodules
file and stage that file (unless -n is used).
这最适合最新的 1.8.5 git(例如 msysgit for Windows 或 latest package for Unix)
If you get message
fatal: renaming '%submodule%' failed: No such file or directory
it is probably because you're adding a directory level, e.g. moving submodule "
math
" to "libs/math
".
git mv
doesn't create missing [intermediate] directories, you shouldmkdir
them yourself.
git 2.9(2016 年 6 月)将改进 git mv
对于子模块:
参见 commit a127331 (2016 年 4 月 19 日)Stefan Beller ( stefanbeller
) .
(由 Junio C Hamano -- gitster
-- merge 于 commit 9cb50a3 ,2016 年 4 月 29 日)
mv
: allow moving nested submodules"
git mv old new
" did not adjust the path for a submodule that lives as a subdirectory insideold/
directory correctly.submodules however need to update their link to the git directory as well as updates to the
.gitmodules
file.
Git 2.12(2017 年第一季度)提供了将嵌套子模块移动到父仓库的功能:
有一个新的子模块助手“ git submodule absorbgitdirs
”,可以更轻松地移动嵌入式 .git/
中的子模块目录 super 项目 .git/modules/
(并将后者指向前者已添加为“gitdir:
”文件)。
参见 commit 7c4be45 (2016 年 12 月 27 日),commit f6f8586 , commit 47e83eb , commit 1a248cf (2016 年 12 月 12 日),和 commit 6f94351 , commit 89c8626 , commit 90c0011 , commit 6f94351 , commit 89c8626 , commit 90c0011 (2016 年 12 月 8 日)Stefan Beller ( stefanbeller
) .
(由 Junio C Hamano -- gitster
-- merge 于 commit da2b74e ,2017 年 1 月 10 日)
submodule: add
absorb-git-dir
functionWhen a submodule has its
git
dir inside the working dir, the submodule support for checkout that we plan to add in a later patch will fail.Add functionality to migrate the git directory to be absorbed into the superprojects git directory.
The newly added code in this patch is structured such that other areas of Git can also make use of it. The code in the submodule--helper is a mere wrapper and option parser for the function
absorb_git_dir_into_superproject
, that takes care of embedding the submodules git directory into the superprojects git dir. That function makes use of the more abstract function for this use caserelocate_gitdir
, which can be used by e.g. the worktree code eventually to move around a git directory.
注意:仍然存在(Git 2.14.x/2.15,2017 年第 4 季度)与子模块移动相关的错误:请参阅“Git: moving submodules recursively (nested submodules)”。
Git 2.15.x/2.16(2018 年第一季度)将使移动子模块更加健壮,因为“git fetch --recurse-submodules
”现在知道子模块可以除了获得更新之外,还在 super 项目中四处走动,并找到需要相应获取的那些。
参见 commit 4b4aced , commit c68f837 (2017 年 10 月 16 日),和 commit 01ce122 (2017 年 10 月 6 日)Heiko Voigt ( hvoigt
) .
(由 Junio C Hamano -- gitster
-- merge 于 commit b4d658b ,2017 年 11 月 6 日)
implement fetching of moved submodules
We store the changed submodules paths to calculate which submodule needs fetching. This does not work for moved submodules since their paths do not stay the same in case of a moved submodules.
In case of new submodules we do not have a path in the current checkout, since they just appeared in this fetch.It is more general to collect the submodule names for changes instead of their paths to include the above cases. If we do not have a configuration for a gitlink we rely on constructing a default name from the path if a git repository can be found at its path. We skip non-configured gitlinks whose default name collides with a configured one.
请注意,在 Git 2.19(2018 年第 3 季度)之前,在使用 --recurse-submodules
获取期间,尝试查看子模块中是否需要获取的代码当子模块的路径在提交范围内更改时感到困惑 super 项目,有时显示“(null)
”。
这已得到纠正。
参见 commit c3749f6 , commit 5fc8475 (2018 年 6 月 14 日)作者:Stefan Beller ( stefanbeller
) .
(由 Junio C Hamano -- gitster
-- merge 于 commit 085d2ab ,2018 年 6 月 28 日)
submodule
: fixNULL
correctness in renamed broken submodulesWhen fetching with recursing into submodules, the fetch logic inspects the superproject which submodules actually need to be fetched.
This is tricky for submodules that were renamed in the fetched range of commits. This was implemented in c68f837 (implement fetching of moved submodules, 2017-10-16, Git v2.16.0), and this patch fixes a mistake in the logic there.
关于git - 将 git 子模块移动到另一个目录后失败,错误为 'git status --porcelain' failed in submodule,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20991138/
我有这个 html 代码: HELLO WORLD! X V HELLO WORLD! X V 我想按 X(类关闭)将父 div 的高度更改为 20px 并显示 V(类打开),但在每个 d
在会计应用程序的许多不同实现中,有两种主要的数据库设计方法来保存日志和分类帐数据。 只保留 Journal 信息,然后 Ledger 只是 Journal 的一个 View (因为 journal 总
我想在另一个子里面有一个子, sub a { sub b { } } 我想为每次调用 sub b 创建一个新的 sub a 实例。有没有办法在 Perl 中做到这一点? 当我运行上面的
我有一些代码正在查找重复项并突出显示单元格: Private Sub cmdDups_Click() Dim Rng As Range Dim cel As Range Set Rng = ThisW
可能有一个简单的解决方案,但我很难过。 我有一个包含一个 ID 字段的主表。在两个可能的字段中有一个具有该 ID 的子表。想象一个由选手 A 和选手 B 组成的 double 队。Master 表将有
假设我有一个包含对象的数组: [ { "id": "5a97e047f826a0111b754beb", "name": "Hogwarts", "parentId": "
我正在尝试对 MySQL 数据库表执行一对父/子模型的批量插入,但似乎无法使用标准的 ActiveRecord 功能来完成。所以,我尝试了 activerecord-import gem,但它也不支持
我有一个带有多个子类的父抽象类。最终,我希望通过 GUI 中的进度条显示子类中完成的进度。 我目前所做的,我意识到这是行不通的,是在父类中声明为每个子类将覆盖的虚拟方法的事件方法定义。所以像: pub
是否可以通过键数组在对象中设置变量?例如我有这个对象: var obj = {'outer': {'inner': 'value'} }; 并希望设置由键数组选择的值: var keys = ['ou
我有一个名为 companies 的 MySQL 表,如下所示: +---------+-----------+-----------+ | id_comp | comp_name | id_pare
我正在尝试使用 sublime text 在 sublime text 上的 ionic 上打开我的第一个应用程序。它给了我一个“找不到命令”的错误。如何修复? 我试过这些命令: sudo rm -r
不好意思问,但我正在使用 webapp2,我正在设计一个解决方案,以便更容易定义路由 based on this google webapp2 route function .但这完全取决于能够在子级
我有代表树的数字字符串(我不知道是否有官方名称): 012323301212 上面的例子代表了 2 棵树。根用 0 表示。根的直接子代为“1”,“1”的直接子代为“2”,依此类推。我需要将它们分组到由
是否可以在当前 Activity 之上添加 Activity 。例如,假设我单击一个按钮,然后它将第二个 Activity 添加到当前 Activity 。而第二个 Activity 只覆盖了我当前
我很难思考如何为子资源建模。 以作者的书籍为例。你可以有 N 本书,每本书只有一位作者。 /books GET /books POST /books/id PUT /books/id DELETE 到
有人可以向我解释以下内容(python 2.7) 来自已解析文件的两个字符串数字: '410.9''410.9 '(注意尾随空格) A_LIST = ['410.9 '] '410.9' in '41
背景 在 PowerShell 中构建 hash table 是很常见的通过特定属性快速访问对象,例如以 LastName 为基础建立索引: $List = ConvertFrom-Csv @' I
我真的很难弄清楚如何调用嵌套 Polymer Web 组件的函数。 这是标记: rise-distribution组件有 canPlay我想从 rise-playlist
我写了一个小工具转储(以 dot 格式)一个项目的依赖关系图,其中所有位于同一目录中的文件都聚集在一个集群中。当我尝试生成包含相应图形的 pdf 时,dot开始哭: 命令 dot -Tpdf trim
给定一个 CODE ref,是否可以: 访问该 CODE ref 的解析树 通过指定 CODE ref 的解析树来创建一个新的 CODE ref,该解析树可以包含在 1 中返回的解析树的元素 通常我们
我是一名优秀的程序员,十分优秀!