質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.50%
Git

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

BitBucket

BitBucketは無料のリポジトリ管理ホスティングサービスです。 MercurialとGitのVCSに対応しています。プライベートリポジトリを、制限なく作成することが可能です。

Q&A

2回答

1770閲覧

Git:pullする前に強制プッシュして直前のmerge履歴を消してしまった。

kazuhihi

総合スコア20

Git

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

BitBucket

BitBucketは無料のリポジトリ管理ホスティングサービスです。 MercurialとGitのVCSに対応しています。プライベートリポジトリを、制限なく作成することが可能です。

0グッド

0クリップ

投稿2019/07/13 10:07

Gitの作業中に、間違ってpullする前に強制プッシュを行い、merge履歴が消えてしまいました。
最後にpullした情報にはmerge履歴がなく、私がrebase作業中だったのですが、誤って強制プッシュをしてしまいました。
どうすれば復元できますでしょうか?

※リモートのBitBucketのサイト内でmerge作業したブランチです。

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

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

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

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

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

guest

回答2

0

こんにちは。
BitBucket はまともに使ったことがないため、ドキュメントを眺めての回答です。

リモートにのみマージコミットが存在していたということは、WebUI からマージしたものと思いますが、それなら PullRequest や Issue などにコミット ID が残っているはずなので、まずはそれを見つけてください。これが見つからない場合は諦めるしかないです。ブラウザの履歴等もワンチャンあります。

次に、BitBucket API を利用して、先ほど見つけたコミット ID に ref を張ります。
おそらくはこれ (Bitbucket API: repositories > {username} > {repo_slug} > refs > branches) を使えば良いでしょう。
要は、辿れなくなったコミットに無理矢理任意のブランチ名を付けることでサルベージするわけです。

これで必要なコミットにブランチラベルが付くので、clone し直すことでローカルで扱えるようになるので、あとは好きなようにラベルを付け替えて再度 push -f すれば直せます。

投稿2019/07/13 14:14

編集2019/07/13 14:16
tamoto

総合スコア4103

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

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

0

最後のpushを元に戻すだけなので、これではダメでしょうか?

git reset HEAD~

投稿2019/07/13 10:41

bamboo-nova

総合スコア1408

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問