[解決済み] SVN 2つのブランチにファイルが追加された場合の新しいツリーの競合を解決する方法
質問
ファイルが両方のブランチに追加された (そして、それらの別々のブランチで作業された) いくつかのブランチを (SVN 1.6.1 を使用して) マージするとき、新しいツリーの競合の 1 つが発生します。
C foo.txt
> local obstruction, incoming add upon merge
両方のブランチからの変更が必要ですが、ツリーの競合によって、通常の .working, .merge-left & .merge-right ファイルが得られません -- これは競合の性質上、理解できることです。これらの競合はかなり多く、同じファイルの削除が各ブランチで発生したものもありますが、解決するのは簡単です。
この問題を解決するにはどうすればよいのでしょうか。SVN redbean book (1.6 用) はこの状況をカバーしていません。
どのように解決するのですか?
古いバージョン(2009年)で言及されていたように ツリー コンフリクトのデザインについて のドキュメントに記載されています。
バージョン管理されたファイルへの追加マージによる XFAIL の衝突
このテストは、次のようなマージを行います。 履歴のないファイルへの追加を 既存のバージョン管理されたファイル .
のファイルにツリーコンフリクトが発生するはずです。local obstruction, incoming add upon merge
'品種になります。r35341 で期待値を修正しました。
(ちなみにこれは ClearCase では "evil twins" とも呼ばれます)。
ファイルが 2 つの異なるブランチで 2 回作成され(ここでは "added" が 2 回)、2 つの異なる要素に対して 2 つの異なる履歴が作成されますが、名前は同じです。
理論的な解決策は、これらのファイルを (外部の diff ツールで) 手動でマージして、宛先ブランチである '
B2
'.
まだソースブランチで作業している場合、理想的なシナリオは、ソースブランチからそのファイルを削除することです。
B1
からマージして
B2
から
B1
でそのファイルが見えるようにするために
B1
に表示されるようにします (その後、同じ要素で作業することになります)。
からしかマージが発生しないため、マージバックが不可能な場合。
B1
から
B2
に変更する場合、手動でのマージが必要になります。
B1->B2
のマージが必要です。
関連
-
[解決済み] ツリーの衝突を解決する
-
[解決済み] svn diff で2つのリビジョン間の非空白行の変更点のみを表示させる方法
-
[解決済み] ブランチをトランクにマージする場合、「svn merge --reintegrate」と「svn merge without reintegrate」はどう違うのですか?
-
[解決済み] 履歴のある SVN リポジトリを新しい Git リポジトリに移行するにはどうすればよいですか?
-
[解決済み] gitのマージ戦略を使い分けるとしたら、どんなとき?
-
[解決済み] gitの「ours」「theirs」の正確な意味を教えてください。
-
[解決済み] 既存のGitリポジトリをSVNにプッシュする
-
[解決済み] あるSubversionのリポジトリから別のリポジトリに1つのフォルダを移動するにはどうしたらいいですか?
-
[解決済み】どのようなGitブランチングモデルが有効ですか?
-
[解決済み] SVNから削除されたファイルを復元する正しい方法を教えてください。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] svn log -v' のように 'git log' にファイル名を表示させる方法
-
[解決済み] なぜGitはSubversionよりも優れているのですか?
-
[解決済み] SVN:externalsはGitで同等?
-
[解決済み] TortoiseSVNでブランチやマージを行うにはどうしたらいいですか?[クローズド]
-
[解決済み] svn には `revert-all` コマンドがありますか?
-
[解決済み] 作業コピーのバージョン管理されていないファイルやフォルダーをすべて削除するにはどうすればよいですか?
-
[解決済み] 新しいブランチを作成するにはどうすればよいですか?
-
[解決済み] 家庭用開発でバージョン管理を使う?
-
[解決済み] ファイルを削除せずにバージョン管理から削除するには?
-
[解決済み] SVN 405 メソッドが許可されていない