git管理下の開発環境での修正をまとめて、git管理してない本番環境へ適用したかったのでpatchファイルを作って見ました
サンプルとしてこんなディレクトリ構成として
$ tree
.
├── 1
│ ├── 1-1
│ │ └── 1.1.text
│ ├── 1.txt
│ ├── 2.txt
│ └── 3.txt
└── 2
├── 1-1
│ └── 1.1.text
├── 1.txt
└── 2.txt
ちょこっとファイルを修正してcommitして
$ git diff -u HEAD^ > diff.patch
$ cat diff.patch
diff --git a/1/1-1/1.1.text b/1/1-1/1.1.text
index d7cd238..f4cb53a 100644
--- a/1/1-1/1.1.text
+++ b/1/1-1/1.1.text
@@ -1 +1,2 @@
+1-1
2-1
diff --git a/1/1.txt b/1/1.txt
index 5f2f16b..092362d 100644
--- a/1/1.txt
+++ b/1/1.txt
@@ -1 +1 @@
-1111
+this is 1.
と、git diffの結果を出力してあげます
注意するのは、実際のディレクトリの前にa、bがついています(差の比較のための印)
本番環境へgit diffを出力したのと同じ階層のディレクトリにdiff.patchを移動させて、patchコマンドで取り込みます
そのままpatchコマンドであてると、ディレクトリがないと怒られます
$ patch < diff.patch
can't find file to patch at input line 5
Perhaps you should have used the -p or --strip option?
The text leading up to this was:
--------------------------
|diff --git a/1/1-1/1.1.text b/1/1-1/1.1.text
|index d7cd238..f4cb53a 100644
|--- a/1/1-1/1.1.text
|+++ b/1/1-1/1.1.text
--------------------------
File to patch:
a、bディレクトリ分の1階層を無視してあてます
$ patch -p1 < diff.patch
patching file 1/1-1/1.1.text
patching file 1/1.txt
これで差分があたりました
実際はあてる前に、patch –dry-run -p1 < diff.patch として確かめてからあてたほうがいいです
(これだと、結果は出してくれるが、実際は更新されない)
また、git diffのときに–no-prefixをつけると
$ git diff -u --no-prefix HEAD^ > diff.patch
$ cat diff.patch
diff --git 1/1-1/1.1.text 1/1-1/1.1.text
index d7cd238..f4cb53a 100644
--- 1/1-1/1.1.text
+++ 1/1-1/1.1.text
@@ -1 +1,2 @@
+1-1
2-1
diff --git 1/1.txt 1/1.txt
index 5f2f16b..092362d 100644
--- 1/1.txt
+++ 1/1.txt
@@ -1 +1 @@
-1111
+this is 1.
と、a、bがつかなくなるので、patchコマンド時にそのままあてられます