LoginSignup
1
0

More than 3 years have passed since last update.

ブランチを全部消してしまってもいいの?

Posted at

image.png
photo by Bridget McKenzie

Gitを使ったことがある人ならば、Gitにはブランチ(Branch)という便利な機能があるというのは誰もが知っていることだと思う。ただし、本当にブランチの概念を正確に理解出来ているのかについては疑問符が付く人もいることだろう。そこで、ブランチの削除に関するおバカ問題を3つ用意してみた。まずはちょっと下の問題について考えてみてほしい:

  1. デフォルトのmasterブランチって削除してもいいの?
  2. どのブランチを消しちゃっても差し障りない?
  3. じゃあ全部のブランチを完全に消しちゃってもいいの?

そもそもブランチって何?

ブランチの削除について話す前に、まずはブランチとは何かを理解しなければならないだろう。一部の人はブランチというのは、ディレクトリをコピーしてくるようなものだと思っていて、だから修正をしても大元のブランチの内容には影響を及ぼさないと思っているようなのだが、実際のところブランチというのは小さな小さなファイルに過ぎず、言うなれば一枚の付箋のようなものであって、単にとあるコミット上に貼られているに過ぎない。

image.png

この例でいえば、今のところdogcatとデフォルトのmaster3つのブランチは、それぞれ053fb21b174a5a及びe12d8efという3つのコミット上に貼られている。

(ブランチの使い方について、もっと詳しく知りたいという方は「やりたいことが
今すぐわかる逆引きGit入門
」のブランチの章をご参照下さい。)

じゃあブランチを消してしまったら…?

ブランチというのはとあるコミット上に貼られた付箋のような存在に過ぎないので、ブランチを削除するというのは付箋を剥がすようなものだと思ってもらって構わない。だから、付箋は剥がされてしまったからといって、元々のコミット自体が消えてしまうようなことにはならない。単に姿が見えなくなってしまったというだけで、実はひっそりとGitの海を漂っていて、見つかりにくい存在になってしまっただけなのだ。

(もし消してしまったブランチを救い出してあげたい時には、「やりたいことが
今すぐわかる逆引きGit入門
」の【どーする?】うっかりマージしてないブランチを消しちゃったんだけど、助かる方法ありますか? 」の章を参照して下さい。)

と、ここまで書いてきたのだが、ここまででブランチに対する正確な概念を理解することが出来たのであれば、きっと「救い出す」という言い方では正確さに欠けることに気づいたのではないだろうか。正確に言えば「もともとブランチという付箋を貼り付けていた某コミットを探し出してくる」というような言い回しになるだろう。

デフォルトのブランチ

masterブランチというのはGitにおけるデフォルトのブランチだ。だが、実のところこのブランチ、その正体は普通のブランチに過ぎず、ただ単にmasterと呼ばれているだけだったする。ということは、masterと呼ばれていること以外に特別なことは何もないので、名前を変更しようが消してしまおうが、何も問題はない。
ということは、どんなブランチでも削除しちゃっていいってこと?

これは…状況によりけりだろう。例えば、自分が今いるブランチは消せないように、とある状況下では幾つかのブランチはどうしても消せないということが起こり得る:

$ git branch
  cat
  dog
* master

ちょうど今masterブランチにいるので、もし無理やり削除してしまった場合、このようなエラーメッセージが出てくるだろう:

$ git branch -D master
error: Cannot delete branch 'master' checked out at '/tmp/git-practice'

例えて言うならば、ちょうど今master上に足を置いているので、もしこのmasterを外してしまうと自分の足場が無くなって立てなくなってしまうというようなイメージだ。ただそ、だからこのmasterブランチは消せないのかと言えば、そういうわけではない。単にブランチを切り換えてしまえばいいだけのことなのだ:

$ git checkout cat
Switched to branch 'cat'

$ git branch
* cat
  dog
  master

$ git branch -D master
Deleted branch master (was e12d8ef).

先にブランチを切り換えておいて、後は刀を片手に振り向いて、バサッと!

全部消してしまえ~!

ブランチがどういうものかわかってくると、どんなブランチでも消してしまえることが分かってきたのではないだろうか。と、ここで最初に出した問題のうちの最後の一つ「じゃあ全部のブランチを完全に消してしまってもいいの?」という微妙なテーマについて見ていこう。

まあ、先に答えを言ってしまうと、うん…まあ削除してしまってもいいよ。ということになるだろう。ただし、消していくと最後に「今現在いるブランチは消すことが出来ない」という状況が起こるので、そこまで来たらブランチのないコミットにCheckoutして削除を実行すればいい。(この時「detached HEAD」状態になる)上の例でいえば直接053fb21というコミットに切り替えて削除を実行すればいい(元々 dog ブランチと名付けられていたコミットのこと):

$ git checkout 053fb21
Note: checking out '053fb21'.

You are in 'detached HEAD' state. You can look around, make experimental 
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:

  git checkout -b <new-branch-name>

HEAD is now at 053fb21... add dog 2

すると、このようなメッセージが表示されるのだが、これは決してエラーメッセージではないので怖がらなくて大丈夫。 detached HEAD 状態については「【豆知識】detached HEADってどういうこと?」の章を参照してもらいたい。

さて、これでブランチがどうなったのかというと:

$ git branch
* (HEAD detached at 053fb21)
cat
dog

catブランチにもdogブランチにもいない。masterも削除してしまったのでない。ということで、ここで大技!:

$ git branch -D cat dog
Deleted branch cat (was b174a5a).
Deleted branch dog (was 053fb21).

さて結果を見てみよう:

$ git branch
* (HEAD detached at 053fb21)

これで全てを削除することが出来た!

っていうか、なんでブランチ全部消してんの?これって何か意味あるの?

意味ですか?意味なんてありません。単なるおふざけです!(えー!)

メッセージ大歓迎です

Git に関する難問疑問、こういうケースだとどうなる?というような応用問題、どんなことでも構いません、メール・メッセージで、どんどん聞いて下さい。もし、メッセージ欄では答えきれないという場合は、後日整理して新しい記事をアップしていきたいと思っています :)

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0