5.2 KiB
同期のとれていない git ブランチの再同期
仮にあなたの master
ブランチにあなたのコミットを行い、そしてあなたの QMK
リポジトリの更新が必要になったとします。 (フォーク元の) QMK の
master ブランチをあなたの master ブランチに
git pull することもできますが、GitHub
は、あなたのブランチが qmk:master
より何コミットか先行していると通知します、この状態で QMK
にプルリクエストを行う場合、問題が発生する可能性があります。
(訳注:この通知は、GitHub のあなたのリポジトリの code
ペインのブランチ選択メニューの下のあたりで
This branch is 3 commit ahead of qmk:master
という様な文面で表示されています。)
?> このドキュメントは あなたのフォークの
master ブランチ: 更新は頻繁に、コミットはしないこと
で詳述されている概念に基づいています。その概念に慣れていない場合は、まずそれを読んでから、ここに戻ってください。
(訳注:この文書で言う、「同期のとれていない git ブランチ」とは、master
ブランチに関する、この「コミットしない」方針を逸脱して、QMK の master
リポジトリに存在しないコミットがあなたのフォークの master
ブランチに入っている状態を指します。)
あなた自身の
master ブランチでの変更のバックアップ(オプション)
救えるものなら自分の行った変更を失いたくはないでしょう。 あなたの
master
ブランチに既に加えた変更を保存したい場合、最も簡単な方法は、単に「ダーティな」master
ブランチの複製を作成することです:
git branch old_master masterこれで、 master ブランチの複製である
old_master という名前のブランチができました。
あなたのブランチの再同期
さあ、master ブランチを再同期します。 この手順では、QMK
のリポジトリを git のリモートリポジトリとして設定する必要があります。
設定済みのリモートリポジトリを確認するには、git remote -v
を実行し、次のような結果が返されなければなりません。
QMKuser ~/qmk_firmware (master)
$ git remote -v
origin https://github.com/<your_username>/qmk_firmware.git (fetch)
origin https://github.com/<your_username>/qmk_firmware.git (push)
upstream https://github.com/qmk/qmk_firmware.git (fetch)
upstream https://github.com/qmk/qmk_firmware.git (push)もし、上記のようにならずに以下のように参照されるフォークが、1つだけ表示される場合:
QMKuser ~/qmk_firmware (master)
$ git remote -v
origin https://github.com/qmk/qmk_firmware.git (fetch)
origin https://github.com/qmk/qmk_firmware.git (push)新しいリモートリポジトリを追加します:
git remote add upstream https://github.com/qmk/qmk_firmware.git次に、origin
リモートリポジトリを、あなた自身のフォークにリダイレクトします:
git remote set-url origin https://github.com/<あなたのユーザ名>/qmk_firmware.git両方のリモートリポジトリが設定されたので、次を実行して、QMK である
upstream リポジトリの参照を更新する必要があります。
git fetch upstreamこの時点で、次を実行してあなたの(訳注:master)ブランチを QMK
のブランチに再同期します。 (訳注: 今現在 master
ブランチがチェックアウトされていなければなりません。
そうなってなければ、git checkout master
を先に実行しておく必要があります。)
git reset --hard upstream/masterこれらの手順により、あなたのコンピュータ上のリポジトリが更新されますが、あなたの GitHub 上のフォークはまだ同期されていません。 GitHub 上のフォークを再同期するには、あなたのフォークにプッシュして、ローカルリポジトリに反映されていないリモート変更をオーバーライドするように Git に指示する必要があります。 これを行うには、次を実行します:
git push --force-with-lease!> 他のユーザーがコミットを投稿するフォークで
git push --force-with-lease
を実行しないでください。これをすると、かれらのコミットが消去されてしまいます。
これで、あなたの GitHub フォーク、あなたのローカルファイル、および QMK のリポジトリはすべて同じになりました。 ここから、ブランチを使ってさらに必要な変更を加え、通常どおりそれらを投稿できます。