summaryrefslogtreecommitdiff
path: root/doc/ja/user-guide/resolving_conflicts.txt
blob: 8a29bcc129bfa4228c20ea039c04460f63786e0e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
衝突の解消
===========

ワークフロー
-------------

マージプロセスの間にそれぞれの衝突を解消することを強制する他のいくつかのツール\
とは異なり、Bazaarはできる限りマージしてから衝突を報告します。
これによって衝突の解消をより扱いやすくします。
解消すべき方法を決めることを手助けするためにポストマージツリー全体の内容が\
利用可能だからです。
それぞれの解消もしくはグループがよい状態であることを確認するためにテストを\
いくつか選んで実行することもよいでしょう。

衝突の一覧を表示する
---------------------

``merge`` コマンドで報告されるのと同様に、\
突出した衝突の一覧は ``conflicts`` コマンドを使用することでいつでも表示されます。
これは ``status`` コマンドから出力の一部として含めることも可能です。

衝突を解消する
--------------

衝突に遭遇したら、 ``merge`` コマンドは解決されていない領域を表示する\
埋め込みマーカーをそれぞれのファイルに追加します。
1つの衝突を持つそれぞれのファイルに対して3つのファイルも作ります:

 * foo.BASE
 * foo.THIS
 * foo.OTHER

``foo`` は衝突したファイルの名前です。
多くの場合、問題になっているそれぞれのファイルを手作業で編集し、\
関連領域を修正し衝突マーカーを除去することで衝突を解消できます。

衝突の中のすべてのファイルを修正し、マーカーを削除した後で、
``resolve`` コマンドを使用してBazaarにそれらを解決したものとしてマークするように頼みます::

  bzr resolve

代わりに、それぞれのファイルを修正した後で、これを解消したものとしてマークできます::

  bzr resolve foo

``resolve`` コマンドは作業ツリーからBASE, THIS, OTHERファイルをクリーンナップします。

remergeコマンドを使う
---------------------

いくつかの場合、任意のファイルに対して異なるマージアルゴリズムを試したいことがあります。
これを行うためには、ファイルを次のように指定して ``remerge`` コマンドを使います::

  bzr remerge --weave foo

``foo`` はファイルで ``weave`` オプションは利用可能なマージアルゴリズムです。
いわゆる ``criss-cross`` (十字遺伝)マージが検出されたときに、
たとえば、2つのブランチが同じものをマージしてからお互いをマージするときに、\
このアルゴリズムはとりわけ便利です。
詳細については ``criss-cross`` と ``remerge`` のオンラインヘルプを参照してください。

衝突を解消するために外部ツールを利用する
-----------------------------------------

衝突を解消するためにGUIツールを利用したいのであれば、
*extmerge* プラグインをインストールしてください。次のようにインストールできます::

  bzr extmerge foo

``foo`` は衝突したファイルです。
解消するファイルの一覧を提供するよりも、すべての衝突ファイルを暗黙の内に指定するために ``--all`` オプションを利用できます。

``extmerge`` コマンドは ``bazaar.conf`` ファイルの中の ``external_merge`` 設定によって指定されるツールを使います。
設定されていなければ、 ``kdiff3`` もしくは ``opendiff`` のような人気のあるマージツールが設定されます。
後者はOS XのFileMergeのコマンドラインインターフェイスです。