- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
future 有一些子项目:“项目1”、“项目2”等。
此外,还有一个名为“Base Project”的项目,它是其他项目的基础。 “Base Project”是一个内容管理系统 (CMS)。
所有项目都有自己的 git 存储库。
“项目一”、“项目二”等使用“基地项目”发展壮大。
git 中有一些方法,如 submodule 或 subtreemerge。但似乎不适合这里。“基础项目”不应克隆到子目录中。它在根目录中。它在“项目 1”或“项目 2”中增长...
当我在子项目中工作时,我必须能够将“基础项目”更改单独推送到它自己的存储库以获取其他子项目。
我能做什么?
最佳答案
子树 merge 或子模块用于 component-based development :两个不同但连贯的文件组合在一起。
每组文件都在自己的目录中,因为它们可以独立分支或标记(子模块),也可以一起(子树 merge ,同时保留取回它们自己的历史记录的能力)。
不过,两者都需要一个单独的目录。
但是您所描述的(“Base Project
”在根目录中,在“project 1
”或“project 2
”中增长) 是关于 system-based approach :所有组件 merge 为一个大组件:一大组文件,作为一个单元始终一起进化。
因此,每个项目可以有一个分支:branch1
用于 CMS-projet1
,branch2
用于 CMS-project2
,以及等等。
但是,如果您需要将特定于 projectx
的修改或特定于 CMS 的修改报告回其原始(和单独的)存储库,则在专用分支中进行所述特定更改,然后 merge 这些变化:
branchp1
将用于影响 project1
branchc1
将用于影响 CMS
branch1
将是 branchp1
和 branchc1
(branch2
也是一样)
然后您可以将这些更改作为补丁导出:
branchp1
到 project1
repo branchc1
到 CMS
仓库不方便的是 Git 不会记住已经 merge 回原始存储库的内容,但这将允许您报告在 CMS-projectx
文件集中开发的共同历史到您的原始 CMS
和 projectx
存储库。
注意:如果您不想管理 2 个额外的分支,另一种解决方案是:
[CMS] 我的 CMS 修改评论...
”,或“[Project1] 我的项目 1 修改评论...
”git-extract-patches
仅将正确的提交导出为补丁。关于git - merge 在 git 存储库中的子项目中增长的基础项目,除了 git 子模块或子树 merge 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13539636/
我正在开发几个不同的 Joomla 附加组件,但希望将它们保留为单独的 git 存储库,因为它们有不同的开发团队(甚至组织)。但是,我也想将它们作为共享相同 Joomla 基础(被 .gitignor
最近,由于行销人员的要求,我已将Optimobile SDK添加到我正在工作的项目中。 在将其添加并在设备上安装新的apk之后。我注意到,我的应用程序中添加了两个新权限,即无需用户交互即可发送SMS的
我遇到了gradle plugin帮助我处理带点的属性名称。像这样使用时,它在单个项目中工作正常: apply plugin: 'config' buildscript { repositor
我很难设置一组相互依赖的相关 Maven 项目。 这是我的简化案例: pom.xml -- parent pom \base\ pom.xml src\main\java\Ba
我正在研究 Apache Ant 项目的发展,以使用 Gradle 对其进行编译,并且我有不同的子项目集。 我的目标是将主项目的输出用作某些子项目的依赖项。全局配置如下: MainProject:
对于每个用户帐户,我尝试计算他们今天有多少个事件。 我的数据结构如下: accounts - { "-KaxcGWx1-a8s7dhsjhsd" : { "name" : "Bill", "ev
我有两个项目: workspace Project1 |--build.gradle |--settings.gradle |--Subproject1 | |--build.
我们有一个 Maven 多模块项目,我们希望逐步迁移到一个 gradle 项目。 对于初学者,我只想将几个子项目迁移到 gradle,但将它们作为子项目保留到父 maven-project 构建。 有
我的 gradle 项目结构如下所示: geode-core geode-lucene extensions/geode-modules extensions/geode-modules-sessio
我有一个基于 CMake 的项目,具有以下“设计”: add_subdirectory(first_lib) add_subdirectory(second_lib) add_subdirectory
我创建了一个表单,其中有 2 个部分,一个是标题(父级),另一个是子级。在标题部分,我创建了一个字段,如项目(下拉),如 netsuite、SFDC 等,在子部分,我创建了另一个字段,如子项目。当我根
我正在创建一个新的应用程序 MyApp,我决定将应用程序的某些部分放在一个单独的框架 MyFramework 中,而不是应用程序本身,以使其可重用在其他项目中。该框架有自己的项目 (MyFramewo
想象一个包含多个组件的整体项目: 基本 我 网络 app-a app-b app-c 现在,假设 web 依赖于依赖于 basic 的 io,所有这些东西都在一个 repo 中,并且有一个 CMake
我有一个 SBT 项目,特别是 Play Framework 2.1 项目,它在配置中指定了许多子项目。编译时依赖项似乎工作正常,但“清理”似乎只清理当前选定的项目,不包括其依赖项。有什么方法可以清理
我有一个工作的多模块 Play 2.2 应用程序,它的组织方式是这样的...... myApp + app + conf + project + build.propertie
我无法理解模块和子项目之间的区别。有什么区别,哪个应该用于模块应用程序。 最佳答案 使用这两种方法,您都可以单独编译、运行和测试代码。 使用子项目,您可以共享设置,并且它通过源代码连接到依赖它的项目:
我有一个使用 Scala 2.10 的项目和一个使用 Scala 2.11 的项目。它们依赖于一个可以同时编译的通用项目。 lazy val foo = (project in file("foo")
如何让 gradle 克隆一个 git 存储库(到当前存储库的子存储库)并将其构建为子项目? 目前我有以下内容: settings.gradle: include 'contrib/dependenc
我在我的 gradle 项目中添加了一个子项目,现在每当我执行目标 check ,它还在我的子项目上运行测试。 我希望我可以运行 check - 主项目上的任务,将其指定为绝对任务 gradle :c
假设您有 2 个 gradle 项目。第一个是一个包含 2 个 java 子项目的多项目: rootProject :my:subProject1 :myother:subProjec
我是一名优秀的程序员,十分优秀!