teratail header banner
teratail header banner
質問するログイン新規登録
Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

シェル

シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

Q&A

解決済

1回答

471閲覧

コンフリクト修正時にどちらを採用したのか自動で判別

seadora7

総合スコア11

Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

シェル

シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

0グッド

1クリップ

投稿2017/09/09 03:33

0

1

###前提・実現したいこと
gitのコンフリクトを起こしたファイルとコンフリクトを直したファイルから,
マージ元・先のどちらのコードを採用したのかを自動で判別したいです。

具体的なコードじゃなくてよいので,こんな感じで比べたらできるよねっていうのを
教えてほしいです.

###試したこと
コンフリクト発生ファイルと修正ファイルの差分を取ったのですが
OSSなどではコンフリクトを直すときに,コンフリクト以外の箇所も修正していることがあり
その部分の差分だけをどうやって見たら良いのかわかりませんでした.

###補足情報(言語/FW/ツール等のバージョンなど)
シェルスクリプト
Python

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

原理上、難しいのではないかと思います。

コンフリクトを解決する場合、どちらのファイルから採用するのでもなく、手作業でファイルを編集して解決、という手段もありますので、極端な例では「どちらのファイルにもないコード」にしてコミットすることもできてしまいます。

コンフリクトしたうちの「ファイルAを採用」「ファイルBを採用」というのも、「コンフリクトした部分を自動でそのファイルに合わせて書き換える」だけなので、ログにもどっちを取ったかは残りません。

投稿2017/09/09 04:45

編集2017/09/09 04:52
maisumakun

総合スコア146702

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

seadora7

2017/09/09 08:48

例えば,コンフリクトを起こしているファイルのコンフリクト部分の,両ブランチのコードをsedやawkで分解して文字列として保持した後に,修正済みのファイルでどちらかが存在しているかを見ることによってどっちらかを採用したのか,両方とも消しているのかなどが分かると思います。ただこの場合,保持している文字列がコンフリクトを起こした場所とは違うところに現れたときに誤認識をしてしまいます。どちらかを採用したのか、それともどちらも採用していないのかがわかるといいのですが,やはり難しいでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.30%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問