LibGit2Sharp 查找拉取后更新/添加/删除的文件
本文关键字:添加 删除 文件 更新 查找 LibGit2Sharp | 更新日期: 2023-09-27 17:57:15
运行repo.Network.Pull()
命令后,我希望能够看到哪些文件被添加到存储库中,在存储库中更改了哪些文件,从存储库中删除了哪些文件。我所需要的只是文件的文件路径,以及它是添加/更新还是删除。
有没有简单的方法可以做到这一点?我尝试过研究Diff.Compare()
但我不确定这是否是正确的方法。
LibGit2Sharp 0.21.0.176
下面是一个 libGit2 示例,用于遍历当前的提交树并获取更改的文件和更改类型。
Git 版本:
git log --name-status --pretty=oneline
1d9d4bb881f97f5d3b67741a893f238e7221e2b1 Updated readme with fork info
M README.md
58cc5c41963d5ff68556476158c9c0c2499e061c Update Makefile for PE32+ (platform:x64) assemblies
M Makefile
M README.md
a7823c1c0a737c5218d33691f98828c78d52130b Fix Makefile for 64-bit native lib and add README.md
M Makefile
A README.md
ea7e6722f67569cb9d7a433ff2c036fc630d8561 Update solution files.
M mono-curses.csproj
M mono-curses.sln
05dbe6e18895d1037ce333b0a1f652eeae3f8b33 Fix resize handling.
M attrib.c
M gui.cs
libGit2 版本:
var repo = new LibGit2Sharp.Repository ("/your/repo/path");
foreach (Commit commit in repo.Commits) {
foreach (var parent in commit.Parents) {
Console.WriteLine ("{0} | {1}", commit.Sha, commit.MessageShort);
foreach (TreeEntryChanges change in repo.Diff.Compare<TreeChanges>(parent.Tree,
commit.Tree)) {
Console.WriteLine ("{0} : {1}", change.Status, change.Path);
}
}
}
输出:
1d9d4bb881f97f5d3b67741a893f238e7221e2b1 | Updated readme with fork info
Modified : README.md
58cc5c41963d5ff68556476158c9c0c2499e061c | Update Makefile for PE32+ (platform:x64) assemblies
Modified : Makefile
Modified : README.md
a7823c1c0a737c5218d33691f98828c78d52130b | Fix Makefile for 64-bit native lib and add README.md
Modified : Makefile
Added : README.md
ea7e6722f67569cb9d7a433ff2c036fc630d8561 | Update solution files.
Modified : mono-curses.csproj
Modified : mono-curses.sln
05dbe6e18895d1037ce333b0a1f652eeae3f8b33 | Fix resize handling.
Modified : attrib.c
Modified : gui.cs
在直接回答您的问题时,只需从提交枚举器中获取第一个提交并将其树与其父级(由于合并而可能有多个父级)进行比较,而不是我在当前分支中循环所有提交的示例。