How to apply `git diff` patch without Git installed?

GitDiffPatch

Git Problem Overview


How can my client apply patch created by git diff without git installed? I have tried to use patch command but it always asks file name to patch.

Git Solutions


Solution 1 - Git

git diff > patchfile

and

patch -p1 < patchfile

work but as many people noticed in comments and other answers patch does not understand adds, deletes and renames. There is no option but git apply patchfile if you need handle file adds, deletes and renames.


EDIT December 2015

Latest versions of patch command (2.7, released in September 2012) support most features of the "diff --git" format, including renames and copies, permission changes, and symlink diffs (but not yet binary diffs) (release announcement).

So provided one uses current/latest version of patch there is no need to use git to be able to apply its diff as a patch.

Solution 2 - Git

try this:

patch -p1 < patchfile

Solution 3 - Git

Use

git apply patchfile

if possible.

patch -p1 < patchfile 

has potential side-effect.

git apply also handles file adds, deletes, and renames if they're described in the git diff format, which patch won't do. Finally, git apply is an "apply all or abort all" model where either everything is applied or nothing is, whereas patch can partially apply patch files, leaving your working directory in a weird state.

Solution 4 - Git

I use

patch -p1 --merge < patchfile

This way, conflicts may be resolved as usual.

Solution 5 - Git

Try this:

$ git apply file.diff

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionAndrey KuznetsovView Question on Stackoverflow
Solution 1 - GitAndrey KuznetsovView Answer on Stackoverflow
Solution 2 - GitsuppieView Answer on Stackoverflow
Solution 3 - GitSola YangView Answer on Stackoverflow
Solution 4 - Gitdenis.peplinView Answer on Stackoverflow
Solution 5 - GitShashiView Answer on Stackoverflow