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

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

ただいまの
回答率

88.03%

削除もcheckoutもできないブランチが存在する

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 8,647

score 455

開発環境で削除もcheckoutもできないブランチが存在して、非常に不思議な状態に陥っています。

-bash-4.1$ git branch
develop
* master
-bash-4.1$ git branch -d develop
error: branch 'develop' not found.
-bash-4.1$ git checkout develop
error: pathspec 'develop' did not match any file(s) known to git.

この状態で同名のブランチを作成することができてしまいます。

-bash-4.1$ git branch develop
-bash-4.1$ git branch
develop
develop
* master

末尾に空白が付いているというわけでもないようです。

-bash-4.1$ git branch 20150909_755\
fatal: '20150909_755 ' is not a valid branch name.
-bash-4.1$ git branch 20150909_755\ \
fatal: '20150909_755  ' is not a valid branch name.
-bash-4.1$ git branch 20150909_755\ \ \
fatal: '20150909_755   ' is not a valid branch name.
-bash-4.1$ git branch 20150909_755\ \ \ \
fatal: '20150909_755    ' is not a valid branch name.

ローカルブランチは多数ありますが、なぜかこのdevelopブランチだけがこういう状態になっています。

作業環境はCentOS 6.4、gitのバージョンは1.8.5.3です。
このブランチはなぜ発生しているのでしょうか?
そしてどうやったらこのブランチは削除できるのでしょうか。

-bash-4.1$ git --version
git version 1.8.5.3



追記

上の出力はiTermでの出力でしたが、Terminalで出力したところ以下のように表示されました。

-bash-4.1$ git branch
* develop
  deve?Llop
  master
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • pi-chan

    2015/09/09 08:23

    作業環境はmacですか?ローカルブランチは大量にあるのですか?それとも消せないブランチを含めて3つ?

    キャンセル

回答 2

checkベストアンサー

+2

回答が遅くなり申し訳ありません。。。

追記でご提供頂いた「Terminalで出力した」結果の情報は、とても重要な情報でしたね。

不具合の原因は、yubaさんのご回答でも言及されている通り、おそらく何らかの理由で通常は非表示の制御文字か何かが混入してしまったのだと思います。
その結果、「iTerm」では表示されず違いに気づかなかったためにうまく操作できなかったのでしょう。
しかし、見えないのですから、うまく入力することも難しいかも知れません。

そこで、たとえばこんな方法を試してみてはいかがでしょうか?
つまり、git branchで表示されたリストから、逆にきちんと指定可能な(名前にゴミの混入していない)ものを除外して、残ったもの(本来消したいbranch)を消すという発想です。(参考)

以下はMacで試してみた例ですが、基本的には全く同じコマンドで実行可能だと思います。
# まずは branch 名の一覧を確認
$ git branch
* b001
  b002
  b003
  master
$

# 先頭の2文字分を削除してテキストファイルへ保存
$ git branch |cut -b3- >/tmp/branch.lst

# branch 名リストの保存結果を確認
#   このとき cat コマンドに「-nv」オプションを付ける
#   そうすると、行番号と、もし非表示文字が混入していれば ^X みたいな表示になる
$ cat -nv /tmp/branch.lst
     1    b001
     2    b002
     3    b0^X03   ← ゴミの混入した名前を見つけやすい
     4    master
$

# 今の例では "3行目" が削除対象とすると、sed コマンド等でその行をリストから削除する
$ sed -i'' 3d /tmp/branch.lst
$

# リストが正しくできているか結果を確認
$ cat -nv /tmp/branch.lst
     1    b001
     2    b002
     3    master
$
# 念のため、grep コマンドで目的の branch 名だけ抽出できることを確認
$ git branch |grep -vf /tmp/branch.lst
  b003
$

# grep コマンドに「-vf」オプションを付け、ファイル内のリストを「除外」したものを
#   xargs コマンドで git branch コマンドへ渡し削除する
$ git branch |grep -vf /tmp/branch.lst |xargs git branch -D
Deleted branch b003 (was 1620929).
$

# 目的のブランチを削除できた!
$ git branch
* b001
  b002
  master
$
これで解決できることを心よりお祈りしております!

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/09/12 10:08

    丁寧なご回答ありがとうございます! 確かによくわからない制御文字が入っていたので、grepしてxargsすることで削除出来ました。

    キャンセル

+1

制御文字か何かが混入した名前であるのは間違いなさそうですね。
Tabキーで補完入力することで正確な名前を渡せるのではないでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/03 10:35

    ありがとうございます! 確かによくわからない制御文字が入っていたようでした。

    キャンセル

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

  • ただいまの回答率 88.03%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る