- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我有一个 Web 应用程序,它以特定方式探索其他 Web 应用程序。它在 demos
文件夹中包含一些网络演示,其中一个演示现在应该拥有自己的存储库。我想为这个演示应用程序创建一个单独的存储库,并使其成为一个子包 submodule来自主存储库而不丢失其提交历史。
是否可以保留存储库文件夹中文件的提交历史并从中创建存储库并将其用作 submodule相反?
最佳答案
See the note at the end of this answer (last paragraph) for a quick alternative to git submodules using npm ;)
在下面的回答中,您将了解如何从存储库中提取文件夹并从中创建一个 git 存储库,然后将其包含为 submodule。而不是文件夹。
灵感来自 Gerg Bayer 的文章 Moving Files from one Git Repository to Another, Preserving History
一开始,我们有这样的东西:
<git repository A>
someFolders
someFiles
someLib <-- we want this to be a new repo and a git submodule!
some files
在下面的步骤中,我将引用这个 someLib
作为<directory 1>
.
最后,我们会有这样的东西:
<git repository A>
someFolders
someFiles
@submodule --> <git repository B>
<git repository B>
someFolders
someFiles
获取要拆分的存储库的新副本。
git clone <git repository A url>
cd <git repository A directory>
当前文件夹将成为新的存储库,因此删除当前的远程文件夹。
git remote rm origin
提取所需文件夹的历史记录并提交
git filter-branch --subdirectory-filter <directory 1> -- --all
您现在应该拥有一个包含来自 directory 1
的文件的 git 存储库在你的 repo 的根目录中,包含所有相关的提交历史。
创建您的在线存储库并推送您的新存储库!
git remote add origin <git repository B url>
git push
您可能需要设置 upstream
第一次推送的分支
git push --set-upstream origin master
<git repository A>
(可选,见评论)我们要删除 <git repository B>
的痕迹(文件和提交历史记录)来自 <git repository A>
所以这个文件夹的历史只有一次。
这是基于Removing sensitive data来自 github。
转到一个新文件夹并
git clone <git repository A url>
cd <git repository A directory>
git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch <directory 1> -r' --prune-empty --tag-name-filter cat -- --all
替换<directory 1>
按要删除的文件夹。 -r
将在指定目录内递归执行它:)。现在推到origin/master
与 --force
git push origin master --force
创建一个 submodule来自 <git repository B>
进入<git repository A>
git submodule add <git repository B url>
git submodule update
git commit
验证一切是否按预期工作并且push
git push origin master
完成所有这些之后,我意识到在我的案例中使用 npm 更合适而是管理我自己的依赖项。我们可以指定 git url 和版本,参见 package.json git urls as dependencies .
如果您这样做,您想要用作需求的存储库必须是一个npm 模块,因此它必须包含一个package.json
。文件,否则您将收到此错误:Error: ENOENT, open 'tmp.tgz-unpack/package.json'
.
您可能会发现使用 npm 更容易和 manage dependencies with git urls :
npm init
在两个存储库中npm install --save git://github.com/user/project.git#commit-ish
您希望安装依赖项的位置关于git - 从文件夹创建子模块存储库并保留其 git 提交历史,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17413493/
我在使用NetBeans 6.8时遇到以下问题。我通过项目属性->库->编译选项卡->添加JAR /文件夹添加带有jar的文件夹。在下一个窗口中,我选择文件夹,然后选择“复制到库文件夹”。但是,我仍然
我的网站有一个域别名。我想知道如何将 domainA.ext 的请求重定向到 https://domainA.ext/folderA和对 domainB.ext 的请求到 http://domainB
我应该在 Eclipse 中构建的 Android 项目中创建自己的自定义菜单文件夹吗?例如,我想创建一种出现在所有 Activity 中的标题。我知道菜单应该在 res/menu 文件夹中的 XML
我正在使用 VS2008 和 .net 3.5。我在我的解决方案中创建了一个类库(Myproject.Controllers)。在这个类下,我添加了一个 Controllers 文件夹。在文件夹中我添
我有一个包含生成后步骤的 Visual Studio 2012 扩展项目,我想在其中将 .dll 和 .AddIn 文件复制到当前用户的 Visual Studio 2012 AddIns 文件夹中。
我在专有的 linux 发行版中有一些自动下载。 他们去临时暂存盘。我想在它们完成后将它们 move 到主 RAID 阵列。我能看到的最好方法是检查磁盘上的文件夹,看看内容是否在最后一分钟发生了变化。
我目前正在使用 SVN 对我的软件项目进行版本控制。在一个正在进行的项目中,我有主干,用于客户的共同功能和规范以及分支,用于客户特定的。 有没有办法在每次执行此类操作时标记一些不应合并到分支中的文
这个问题在这里已经有了答案: How to exclude a directory in find . command (45 个回答) 8 年前关闭。 如何删除文件夹中的所有内容并排除特定文件夹和文
如何在特定目录中创建具有当前日期和时间的文件夹或文件? DateTimeFormatter f = DateTimeFormatter.ofPattern("uuuuMMdd HHmmss") ; L
有没有办法在系统文件资源管理器的左侧“文件夹”栏中打开文件或文件夹?如果没有这个,我必须打开文件资源管理器并一直导航到该文件夹所在的位置才能操作文件,这确实很不方便。对于大多数带有这样导航栏的工具
预期:我使用 go get 安装包,它在 src 文件夹中创建了所有必要的文件夹,但它们只出现在 pkg/mod 文件夹中,我不能使用它们。 现实:它说它正在下载,完成,然后什么都没有。 一切都在 W
说 foo.zip包含: a b c |- c1.exe |- c2.dll |- c3.dll 哪里a, b, c是文件夹。 如果我 Expand-Archive .\foo.zip -Destin
不久前我正在删除 var 文件夹中 Magento 的缓存。我可能是错的,但我认为我犯了一个错误,而不是删除 var/cache 中的所有内容,而是意外删除了 var 中的所有内容。 Magento
我在 svn 存储库的单独文件夹中有一些代码项目。 现在我在删除文件时遇到一些问题:大多数时候一切顺利,但有时当我从磁盘删除文件或文件夹时, checkin 过程会出现各种错误。 所以我想知道:在sv
有没有什么方法可以用很少的R命令行自动删除所有文件或文件夹?我知道 unlink() 或 file.remove() 函数,但对于这些函数,您需要定义一个字符向量,其中包含您想要的文件的所有名称删除。
用于在文件夹中查找不符合Get-Childitem的LastWriteTime过滤器日期范围标准的文件的powershell命令是什么? 因此,请检查目录中是否包含不包含在01/10/2012(十月1
我正在为我工作的公司内部使用的应用程序之一编写 NSIS 安装程序,安装过程工作正常,所有 REG 键都已创建,文件夹和服务也没有问题,该应用程序使用。出于某种我无法理解的原因,卸载过程不起作用。
我有一个 Excel 文件,并且在同一文件夹中还有一个包含我想要包含的 CSV 文件的文件夹。使用“来自文件夹”查询,第一步将给出以下查询: = Folder.Files("D:\OneDrive\D
我在docker中玩ScyllaDB。为了使ScyllaDB在docker生产设置中最有效地运行,它需要一个XFS格式的磁盘。 您知道如何在Linux和MacO中创建XFS容器卷,磁盘文件吗? 谢谢
我应该编写一个函数,其中包含之前每次与该数字相乘的乘积 基本上是这样的: > productFromLeftToRight [2,3,4,5] [120,60,20,5] 我应该使用高阶函数,例如折叠
我是一名优秀的程序员,十分优秀!