キーワード†
- patch
- diff
したいこと†
パッチを作成して、あてる。
どうやって†
ファイル単位†
パッチを作成する†
$ diff -u (変更前ファイル) (変更後ファイル) > (パッチファイル)
パッチをあてる(作成時と同じ相対パスで)†
$ cd (パッチを作成した時と同じ相対パス) $ patch -u -p0 < (パッチファイル)
パッチをあてる(対象ファイルのディレクトリで)†
$ 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 オプションでカレントでパッチあてできるようにするの
もがよいと思います。