码迷,mamicode.com
首页 > 其他好文 > 详细

GIT 如何合并另一个远程Git仓库的文件到本地仓库里某个指定子文件夹并不丢失远程提交记录?

时间:2015-08-18 21:00:28      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:

问题背景:
    最近在重新整理手中的一个项目,目前该项目分为PC项目,手机项目,某第三方接口项目,第三方接口服务项目和手机项目
    因为之前规划的原因,原来的四个项目是分两个解决方案来管理的
    PC解决方案:
#PC解决方案,2015年从Vss迁移到Git 一共三个项目
#F:\WWW\F.COM\WWW
Flight.sln
Flight.suo
Web #PC项目

Qr #第三方接口项目 2015年新增项目,也使用PC解决方案但用分支进行管理,维护单独的通用项目,目前已经将通用项目分离到单独的分支进行单独维护(仅添加要引用的Dll即可) 
QunarTTS #第三方接口服务项目2015年新增项目,也使用PC解决方案但用分支进行管理,维护单独的通用项目,目前已经将通用项目分离到单独的分支进行单独维护(仅添加要引用的Dll即可)

#所有通用项目,仅 PC&手机&第三方项目提供统一的支持
BLL
Model
Common 
WebHelp 
SqlServerDAL
DBUtility
Languages
FlightAPI #机票Api

Mobile #手机项目,需要从另一解决方案合并过来

  

 
手机解决方案:
#手机解决方案,所有DLL都会引用PC通用项目的DLL
#因为当时考虑手机跟PC的View和大部分功能不一样,所以单独一个解决方案来做
#F:\WWW\F.COM\Mobile
WebApp
WebApp.csproj #手机项目
WebApp.sln #解决方案
WebApp.suo

  

 
因为最近客户的业务有所调整,所以涉及到以上四个全部的项目,在处理的时候出现了以下问题
  1. 因为 PC,第三方接口,接口服务都共同维护了通用项目,所以导致我频繁在这三个项目之前切换合并(保存通用项目文件一致) 已解决
  2. 手机解决方案同其他项目一样,都使用同一通用项目的Dll但不单独维护,为什么要独立一个解决方案,决定合并到PC解决方案以分支的方式管理
于是我就开始尝试对以上问题进行解决
  1. 将PC,第三方接口,接口服务等所有通用项目从三个分支里分离到单独的分支里统一管理
    其他项目如果要更改通用文件必须切换到分支然后生成再切换回来重新添加新的Dll即可(确保通用项目文件一致性)
  2. 将手机解决方案中的项目合并到PC解决方案里,然后以新的分支Mobile进行维护
问题1已经解决,当我在把手机解决方案的项目合并到PC解决方案里,遇到此问题:
GIT 如何合并另一个远程Git仓库的文件到本地仓库里某个指定子文件夹并不丢失远程提交记录?
 
我这样获取远程Git的信息"git pull remote-address"时,手机项目文件是在PC仓库的根目录"F:\WWW\F.COM\WWW" 而我希望手机项目文件是在该根目录下Mobile目录下的“F:\WWW\F.COM\WWW\Mobile
经过我反复测试和使用其他命令fetch等都没有解决,于是把自己的问题发在了群里,在跟群友沟通了N个小时后也没有解决我的问题,不过某个群友说可以使用subtree子目录的方式试试
于是在网上找各种资料做各种测试,终于经过二天的时间完成解决问题
 
合并必须满足以下条件:
1.必须完整的合并远程仓库(手机项目)的所有文件和提交记录本地仓库(PC项目)
2.远程的所有文件必须是在本地指定的目录F:\WWW\F.COM\WWW\Mobile”而不是在本地仓库的根目录
3.合并后只有一个git仓库(将远程提交合并到本地提交)F:\WWW\F.COM\WWW\.git
 
以下为真实测试的信息:
 
技术分享
 
感谢群里的朋友和网上的资料!
 
参考:
     使用 git-subtree 以子目录形式引入外部项目
    Git submodule VS Git Subtree
    Git Subtree命令剖析
    使用 git subtree 來分拆子目錄成獨立的新 repo
 





GIT 如何合并另一个远程Git仓库的文件到本地仓库里某个指定子文件夹并不丢失远程提交记录?

标签:

原文地址:http://www.cnblogs.com/huangtailang/p/4740397.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!