- 履歴一覧
- 差分 を表示
- 現在との差分 を表示
- ソース を表示
- シェル/パッチを作成する へ行く。
- 1 (2015-07-27 (月) 04:36:06)
- 2 (2015-07-27 (月) 05:12:37)
- 3 (2015-08-05 (水) 00:58:31)
- 4 (2016-05-31 (火) 09:52:48)
キーワード†
- patch
- diff
したいこと†
パッチを作成して、あてる。
どうやって†
ファイル単位†
パッチを作成する†
$ diff -u (変更前ファイル) (変更後ファイル) > (パッチファイル)
パッチをあてる†
$ cd (対象ファイルが存在するディレクトリ) $ patch -u < (パッチファイル)
ディレクトリ単位(対象パスが固定の場合)†
パッチを作成する†
$ diff -ur (変更前ディレクトリのフルパス) (変更後ディレクトリ) > (パッチファイル)
パッチをあてる†
$ patch -u -p0 < (パッチファイル)
ディレクトリ単位(対象パスが不定の場合)†
パッチを作成する†
$ cd (変更前ディレクトリのひとつ上の階層) $ diff -ur (変更前ディレクトリ) (変更後ディレクトリ) > (パッチファイル)
こういう感じ
$ cd /path/to/upper/ $ diff -ur asis tobe > update.patch
パッチをあてる†
$ cd (対象ディレクトリ) $ patch -u -p1 < (パッチファイル)
ノート†
パッチファイルはどこで作成してもよいが、変更前ファイルが対象ファイルと同じ名前でないと確認が入る。ので、変更前ファイルは対象ファイルと同じ名前にしてパッチファイルを作成するのが分かりやすい。
ディレクトリは階層を考えるのが少し面倒です。
- 対象ディレクトリのパスが固定の場合、フルパスでパッチを作成して -p0 オプションでパッチあてするのがよいと思います。
- 対象ディレクトリのパスが不定の場合、ひとつ上の階層でパッチを作成して -p1 オプションで1階層無視するのがよいと思います。
ひとつ上の階層にするのはパッチファイルの見栄えをよくするためだけですですwなので、
- カレントでパッチを作成して -p0 オプションでカレントでパッチあてできるようにするのもよいと思います。