- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有两个独立的存储库 - 后端和前端。我想将它们结合起来,所以我正在考虑类似的事情:
git clone git@server.com:backend.git
git clone git@server.com:frontend.git
cd frontend
mkdir frontend
git mv !(frontend) frontend
git commit -a -S -m "Moving frontend into its own subdirectory"
cd ../backend
git remote add frontend ../frontend
git fetch frontend
git checkout -b feature/merge-front-back
git merge -S --allow-unrelated-histories frontend/master
git push origin feature/merge-front-back
git remote rm frontend
git checkout master
git merge feature/merge-front-back
最佳答案
is it good plan? do you see any flaws or better way?
what about frontend branches?
fetch
来自
frontend
,您的 merge repo 将为每个
frontend
获得“远程跟踪引用”分支机构。所以对于
frontend
分公司
master
你会得到
remotes/frontend/master
.
remove
时,这些将被删除。 Remote 。对于
master
这不一定重要(因为您已将
frontend/master
merge 到
master
中)。对于其他分支,您需要告诉 git 为它们保留一个 ref - 当然,如果它保留的 ref 是一个分支,那将很方便。一种方法是
git fetch frontend refs/heads/*:refs/heads/frontend/*
frontend
分支的命名空间,并添加来自
frontend
的所有分支进入那个命名空间。 (只要您在后端存储库中还没有名为
frontend
的分支或已经存在的
frontend
分支命名空间,就可以了。如果您出于某种原因确实拥有其中一个,则必须为命名空间使用不同的名称。)
refs/heads
下因此它们将被视为正确的分支(而不是远程跟踪引用),并且在您删除原点时它们不会被删除。从那时起,它们与您的后端分支没有什么不同。
frontend
时可能会遇到问题分支到
master
将来,或者你可能不会。
git
将尝试解决所有文件移动引起的冲突;但请记住,git 并没有真正跟踪文件移动——而是在事后启发式地重建它们——所以这种机制并不完美。
frontend/*
的历史记录。分支看起来像
frontend/
下的文件“一直是”文件夹。如果我要这样做,我会在 merge 存储库之前这样做;即克隆后立即
frontend
我会重写克隆的历史,而不是创建一个新的提交来移动文件。
master
上执行的过程类型。我不相信这会很好,尽管您可以对其进行测试。问题是虽然
master
正在作为 merge 处理对于不相关的历史,来自其他
frontend
分支的后续 merge 将不会。为了使这些 merge 正常工作,git 仍然必须正确解释文件移动 - 实际上必须在 merge 。)
frontend
历史上,最直接的方法是使用
git filter-branch
与
--tree-filter
将文件移动到子目录的脚本。见
git filter-branch
文档以获取详细信息。 (
https://git-scm.com/docs/git-filter-branch)
关于git - 将两个存储库合二为一,都有分支,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52115444/
任何人都知道如何将内容从一个 Magnolia CMS 存储库(Jackrabbit 存储库)传输/迁移到我们的应用程序使用的另一个自定义 jacrabbit 存储库? 最佳答案 正如另一张海报所建议
Git 是否支持任何允许我直接从本地/工作树提交到远程存储库的命令?正常的工作流程至少需要一个“git add”来用文件内容的副本等填充对象数据库。 我知道这不是正常的、预期的 Git 工作流程。但我
我们正在将 Git 存储库移动到新服务器。迁移后我们显然可以只删除旧的存储库,所以当人们尝试推送或 pull 时他们会得到一个错误并在 wiki 上查找新的存储库 URL,但是是否有可能阻止 pull
我们有两个 Subversion 存储库,每个存储库都有一个项目。所以: svn://server/svn/project_a svn://server/svn/project_b 它们是独立的项目,
使用 maven/tycho 构建 Nodeclipse Eclipse 插件每个版本都有新的 p2 存储库。 发布是在 Bintray 上完成的不允许更新文件。所以每个版本都在它的文件夹中。 Bas
这听起来有点复杂,让我解释一下: Project_A 在它自己的 Mercurial 存储库中已经存在了一段时间。 Project_A 现在被 merge 到一个新的 super 项目 Super-P
这听起来有点复杂,所以让我解释一下: Project_A 已在其自己的 Mercurial 存储库中存在了一段时间。 Project_A 现在正在 merge 到一个新的 super 项目 Super
我想将我的所有文件从 Git Repo A 移动到 Git Repo B 并具有完整的历史记录。 Git B 已经包含另一个项目文件。我尝试了几种方法,例如 How to move files fro
我从 github 中托管的公共(public) git 存储库创建了一个裸存储库 (MY_LOCAL_REP): ~$ git clone --bare github 存储库已更新(创建了一个分支
工作 SVN 库 我正在启动一个 git 存储库来与 svn 存储库进行交互。 svn 存储库已设置并且工作正常,其中包含一个基本 README 文件的单次提交。 检查它工作正常: tchalvak:
我正在使用 spring boot 1.5.2 和 spring boot data redis 1.8。 我有两个@Id 注解,一个用于JPA,另一个用于redis hash。这里我想使用 JPA
我是 maven 的新手。我仍然无法理解它的概念。 例如,我正在寻找 com.extjs:gxt:jar:2.2.5 或 org.syslog4j:syslog4j:jar:0.9.46。我在任何 r
我已经阅读了很多关于存储库模式和服务层的作用的书,我(我认为)很清楚这两者之间的区别。但是现在有一个简单的问题让我挠头了一段时间。 我知道数据访问层如何负责...访问数据,因此典型的存储库可能具有插入
我是 Git/Smartgit 的新手。现在我不得不在 WIN 10 下配置一台新 PC。请问我如何将设置和存储库从旧 PC 导出/导入到新 PC? 非常感谢,问候, 本德 最佳答案 SmartGit
所以我最近开始在我的工作项目中使用存储库模式。我一直遇到同样的问题,我似乎无法找到答案: 可以将另一个存储库注入(inject)现有存储库吗?这样做有什么负面影响? 例如 : class Crawls
我有一个应用程序容器推送到 gitlab 容器注册表。我正在尝试将其作为容器部署到 azure web 应用程序服务中。我根据azure的文档尽我所能地进行了配置。但我不明白我错过了什么,因为 azu
我使用java框架来开发crud应用程序。这个框架被称为:“Cuba.Platform”。 我的问题是,我无法在古巴打开该项目。当我尝试在那里打开我的项目时,我遇到了这个问题: “存储库包含 http
我在我的数据层中有几个对数据库执行 CRUD 操作的存储库类。我不确定这种设计,因为大多数表都需要每个存储库一个专用类,一段时间后我最终会为数据库中存在的每个表得到很多存储库。我这样做是因为,当然,我
我正在重构一些代码,并将一些执行数据库 CRUD 操作的方法提取到它们自己的存储库类中。 我有几个问题,鉴于以下两种类型的对象存储在数据库中:用户和角色 我应该创建 IUserRepository 和
尝试在这里创建一个非常简单的存储库和服务层模式。 (.NET 4、C#、LINQ,尽管这个问题部分与语言无关)。注意:这只是研发。 我的目标是尽量减少服务层中方法定义的数量。 这是我的存储合约: in
我是一名优秀的程序员,十分优秀!