libgit2sharp icon indicating copy to clipboard operation
libgit2sharp copied to clipboard

Getting patch with unicode characters confuses git apply

Open tapika opened this issue 2 years ago • 1 comments

var patches = repo0.Diff.Compare<Patch>(commit1?.Tree, commit2.Tree, Enumerable.Repeat(change.Path, 1), compareOptions: compareOptions);

Getting patches + applying them to file does not seems to work if there are unicode characters in file itself.

Have tried to save it in utf8, but problem still persists.

As a walkaround to this problem, I have added extra comparison that there aren't any unicode characters.

// If we have some unicode characters, then cannot be handled as text diff.
canBeHandledAsTextPatch = strpatches.All(c => c <= 255);

But, libgit itself has built in support for patching, See https://libgit2.org/libgit2/#HEAD, git_apply* function calls - but none of these operations seems to be supported in libgit2sharp.

tapika avatar Jun 09 '22 13:06 tapika

hi @tapika looks like a similiar issue to mine There is no way to make Diff Patch contain any binary deltas. I've submitted a PR !1967.

jburggraaf avatar Jun 27 '22 18:06 jburggraaf