- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我对 Git 比较陌生,但我想尝试一下(与 SVN 和 Bazaar 相比)。
任何人都可以为我推荐一个类似于以下情况的工作流程:
我的想法是,在“src”中我需要 checkout 项目 A,有时需要 checkout 项目 B。这两个项目都有多个分支。
目前,我已经制作了 2 个 SVN 存储库的 git 克隆,每个项目一个。 (我更喜欢 --bare repos,但它不适用于 git svn clone
)
然后,我在“src”中创建了一个git repo,并且git remote add projA ..a_repo_git
, "git remote add projB ..b_repo_git
"。
现在,我可以使用“git remote”从“src”看到它们,我可以使用“git remote show projA”看到它们的分支
现在麻烦了..
我确实在 src 中尝试过:git checkout --track -b work_branch projA branch_in_A
经过一番摆弄“获取”之后,我设法得到了东西。但是后来,我在将它推回 a_repo_git
时遇到了问题。 ,然后到SVN。这主要是反复试验。
不得不承认,远程分支我还是有问题! (当我必须使用“origin local_branch:origin_branch
”或“origin origin_branch:local_branch
”,或“origin origin_branch
”或“origin/origin_branch
”时,我迷路了!返回 Git 手册以进行更多阅读。)
最佳答案
我没有更新问题,因为在过去的几天里,在我的新 repo 的帮助下,我能够非常轻松地工作 :)
这是我最后做的:
在同一个目录下初始化两个SVN repos。 (我现在不记得了,但可能之前在同一个目录中完成了“git init”:
mkdir src && cd src(not sure about this: git init)git svn init --stdlayout --prefix=projA/ -RprojA file:///path/to/svn/repo/Agit svn init --stdlayout --prefix=projB/ -RprojB file:///path/to/svn/repo/B
“--stdlayout”表示SVN仓库是标准格式,主干、分支和标签在同一层。
“--prefix”用于分支名称。当我们执行“git branch -a”时,项目 A 的所有 SVN 分支都有前缀“projA”(例如:projA/branch_name_of_A)。 B也是一样。
-R 选项在 Git 存储库内部设置 SVN 存储库的名称(这是我们在引用 SVN 存储库/项目时与 Git 一起使用的名称)
在本例中,file:///path 是 SVN 存储库的路径,也是存储库中项目的路径。我使用“file://”是因为我使用的是平面文件存储库,没有服务器。对于 SVN 服务器,我确信它也可以与 http://一起工作。
在这一步之后,出于好奇我查看了文件 src/.git/config。上面的两个命令创建了几个“svn-remote”部分,一个用于每个项目(-R 选项),一个通用部分称为“svn”。我已经修改了条目,所以只有对项目的引用。每个引用都有 repo 路径(获取)和标签/分支/主干的条目。如果您查看该文件,就会了解需要更改的内容。
在此之后,我使用
获取了每个项目的内容git svn fetch projA #the contents of project A repo are downloadedgit svn fetch projB #the contents of project B repo are downloaded
现在,runnig "git branch -a"显示了两个仓库的所有分支,以及主分支(本地)。 “git branch -r”没有显示任何分支;可能是因为它们是“svn-remote”而不是“remote”
当前的“master”分支指向第二个项目的主干。我决定摆脱它,因为它会在从一个项目切换到另一个项目时引起问题。
我创建了两个新分支指向每个项目的主干,然后删除了“master”分支:
git checkout -b master_project_A projA/trunkgit checkout -b master_project_B projB/trunkgit branch -D master
现在,对于“工作流程”;在项目 A 上工作:
git checkout master_project_A #switch to project Agit svn rebase #check for any updates on SVN repogit checkout -b work_on_A master_project_A #create a branch starting from the master of project Awork work work on work_on_A; commit, etcgit checkout master_project_A #go back to master of project Agit svn rebase #check again for any update on SVN repogit checkout work_on_A #go back to the work branchgit rebase master_project_A #update branch with any changes from the master of project Agit checkout master_project_A #go back to the master of project Agit merge work_on_A #merge to the master of project A the changes from the work branchgit svn dcommit #commit changes to the SVN repo, in trunk, because master_project_A was pointing to its trunk
如果我想从 SVN check out 一个现有的分支,我可以这样做:
git checkout -b work_on_branch projA/branch_namework work workgit svn rebase #update any changes from projA/branch_namegit svn dcommit #commit updates back to the branch in the SVN repo
对于项目 B,我可以做完全相同的事情。最后,我可以在同一个目录“src”中拥有项目 A 或 B 的内容,并可以从同一个 Git 存储库访问 SVN 存储库中的两个项目! :D
我仍然没有弄清楚如何创建本地分支然后将其推送到 SVN 存储库 - 我已经接近了,但没有成功。
此外,了解命令“reset”(“git reset --hard projPrefix/branch”)可能会有用,但我用它破坏了一些东西,所以最好把它留到其他时间。
关于git - 如何在一个工作目录中使用两个 SVN 项目和相应的 git-svn 分支?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/609872/
我正在为我的程序编写安装脚本,它应该在 Linux/Unix 操作系统上运行。以下文件的默认目录是什么: 可执行文件(程序)。程序应通过从命令行键入其名称来执行。 共享库。 第三方共享库(程序未开源,
我有一堆用户、组和应用程序注册,我的 MVC 应用程序使用 AAD 数据进行身份验证和授权。是否可以将 Azure Active Directory 从一个租户(目录)迁移到另一个租户(目录)?如果可
查看 cljsbuild 文档 https://github.com/emezeske/lein-cljsbuild :cljsbuild { :builds [{ ; The
忽略已经版本控制的文件 如果你不小心添加了一些应该被忽略的文件,你如何将它们从版本控制中去除而不会丢失它们?或许你有自己的IDE配置文件,不是项目的一部分,但将会花费很多时间使之按照自己的方式工作。
我想使用\tableofcontents 命令,但没有目录从新页面开始或在末尾创建新页面,并且所有内容都是单倍行距。我怎样才能做到这一点?我假设使用 tocloft,但有哪些选择? 谢谢 最佳答案 试
我有一些 javascript 菜单代码,可以在单独的目录中正常工作。但是,当我尝试从同一目录中调用相同的 .js 文件时,它不会看到这些文件。 以下内容来自另一个目录: script type="t
我有这样的路径: /my/path/to/important_folder 在同一级别上,我还有其他文件和文件夹想要在达到与 important_folder 相同的级别时列出。 我的文件夹可能更深,
1、获取文件路径实现 1.1 获取当前文件路径 ? 1
我正在使用最新版本的 NTEmacs。 我写了一个名为“.dir-locals.el”的文件,如下所示。 ((nil . ((tab-width . 8) (fill-column .
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
在我的 .vimrc 中有这些行 :set foldmethod=marker :set foldmarker=SECTION:,ENDSECTION: 用于自定义代码折叠。在我的文件中,相关语言的注
在 fish 中: for x in * echo $x end *这里包括所有目录和文件,如何只列出文件(或目录)? 最佳答案 fish 没有很多花哨的通配语法。但是,目录可以像这样迭代: f
这是我的目录结构: ├── src │ ├── helpers │ │ ├── __init__.py │ │ ├── foo.py │ │ └── bar.py │
我想递归重命名文件夹/目录名称并找到 this solution所以。但是这个命令没有效果 find . -type f -exec rename 's/old/new/' '{}' \; 这是一个正
我想在相册中创建一个文件夹,并希望将图像保存在创建的相册中。 这可能吗?有什么办法可以做到这一点吗? 我已经搜索过,大多数人都说这是不可能的。 感谢您的帮助。 最佳答案 您也许可以使用AssetsLi
如何在python中使用用户定义的名称创建临时文件/目录。我知道 tempfile .但是我看不到任何以文件名作为参数的函数。 注意:我需要这个来对包含临时文件的临时目录上的 glob(文件名模式匹配
我在项目中使用JaCoCo Gradle插件。 作为问题的一个示例,我的大部分代码都在com.me.mysoftware包下。 我正在使用代码生成器来生成build/generated/java/..
我正在尝试使用 Gradle 开始运行 jar 文件 我的任务如下所示: task startServer(type: Exec) { workingDir file("${buildDir}/a
如何在 Ant 中定义一个目录集,其中包括两个目录:项目的基目录和子目录“test”? 看起来您无法使用“/”、“.”或“”专门包含目录集的根目录。例如,这包括“./test”,但不包括“.”:
我正在使用 CTAGs 包,它使用 Sublime Text 2 生成两个文件 .tags 和 .tags_sorted_by_file。 那么当我进行项目搜索(CMD + SHIFT + F)时,如
我是一名优秀的程序员,十分优秀!