繁体   English   中英

Jenkins:创建新分支时如何只签出新文件和修改过的文件

[英]Jenkins: How to checkout only new files and modified files when creating new branch

我在 Jenkins 中使用多分支管道。我有一些相当大的项目 - 创建新分支时,我希望 git 插件仅检出新文件或与分支相比更改的文件

有没有办法做到这一点? 我知道一旦分支存在,只要我不清理工作区,它就会签出新文件并更新文件,但是新分支呢?

假设您有两个分支,“old-branch”和“new-branch”,它们都与远程同步。

git checkout old-branch
# Create a local branch called "new-branch"
# WARNING! Could blow away commits if you added them to to an existing local branch called "new-branch"
git switch -C new-branch 
# Set the branch's HEAD without doing a checkout
git reset --soft origin/new-branch
# Un-stage staged changes
git reset

回购文件的工作副本将是我们开始之前的文件。 运行git status以查看差异。

  • 如果将新文件添加到new-branch ,它将显示为deleted
  • 如果文件在new-branch中被删除,它将显示为未跟踪。
  • 如果文件被修改,它将显示为已修改。

如果你然后运行:

git checkout .

这将撤消所有修改,并恢复所有“已删除”(根据 git)文件,但重要的是不会删除未跟踪的文件 这完成了您最初的问题所述。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM