gpt4 book ai didi

git - 如何识别git提交之间哪些文件已更改

转载 作者:行者123 更新时间:2023-12-01 22:17:06 24 4
gpt4 key购买 nike

我们如何使用go-git生成两次提交之间类似于git diff --name-only commit1 commit2更改的所有文件的列表?
对于上下文,我们有一个git monorepo,它包含一个根go.mod根文件,但包含多个Go应用程序。当开发人员将提交推送到分支时,我们希望获得在两个git commit(git diff --name-only)之间更改的所有文件的列表,并将其过滤到应用程序目录列表​​中,同时排除某些目录。我们的最终目标是使我们可以构建,部署和测试仅在monorepo内部已更改的应用程序。我们有一个bash script similar to this one from shippable可以做到这一点,但是我们想使用纯go和go-git。

最佳答案

似乎change.Files()仅给出了带有to.Name的文件的名称,而没有存储库中的路径,但是change.toString()给出了完整的路径。

因此,如果要使用Tree.Diff,则必须获得如下路径:

func getChangeName(change *object.Change) string {
var empty = object.ChangeEntry{}
if change.From != empty {
return change.From.Name
}

return change.To.Name
}

这样看来,您可以根据需要选择 Tree.DiffPatch.Stats:
    currentTree, err := commit.Tree()
CheckIfError(err)

prevTree, err := prevCommit.Tree()
CheckIfError(err)

patch, err := currentTree.Patch(prevTree)
CheckIfError(err)
fmt.Println("----- Patch Stats ------")

var changedFiles []string
for _, fileStat := range patch.Stats() {
fmt.Println(fileStat.Name)
changedFiles = append(changedFiles,fileStat.Name)
}

changes, err := currentTree.Diff(prevTree)
CheckIfError(err)
fmt.Println("----- Changes -----")
for _, change := range changes {
// Ignore deleted files
action, err := change.Action()
CheckIfError(err)
if action == merkletrie.Delete {
//fmt.Println("Skipping delete")
continue
}
// Get list of involved files
name := getChangeName(change)
fmt.Println(name)
}

Patch.Stats将跳过二进制文件,而 Tree.Diff将使您忽略删除。

关于git - 如何识别git提交之间哪些文件已更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58905690/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com