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

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

ただいまの
回答率

89.52%

git hub 追跡という表現と削除のコマンドの使い方

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 953

blossan

score 152

御世話になります。
git hub 初心者になります。
新しく git を使ったプロジェクトを始めたのですが、開発にあたり、削除コマンドを調べることになりました。
失敗しても元通りできるので、開発しやすいと考えました。

しかし、git で削除というワードを検索すると、

rm 
reset
clean
revert

というコマンドと「追跡対象」という概念が出てきました。
「追跡対象」の扱いで、上記のコマンドの使い分けがされていると推測しています。

しかし、「追跡対象」という日本語が、イメージできず、上記のコマンドの使い分けが出来ずに困っています。
私は、「追跡対象」とは、変更した時にその変更を覚えておく対象だと考えています。

単純な解釈でわかりやすく説明していただけないでしょうか?

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

 「追跡対象」とは

ここで言う「追跡対象」とは、わかりやすく言えばバージョン管理の対象としてGitに登録してあるファイルのことです。

変更した時にその変更を覚えておく対象

という認識で問題無いと思われますが、正確には「変更した時」ではなく「コミットした時」ですね。

なお、「追跡」という言葉は「tracking」を直訳した言葉であり、「追跡ブランチ」のようにブランチに対して使われた場合「あるブランチを追いかけているブランチ」という意味になります(「masterorigin/masterを追跡している」「origin/masterはリモートoriginmasterブランチを追跡している」)。

 各コマンドの説明

 rm

指定したファイルをバージョン管理の対象から外すコマンドです。ファイルは削除され、コミットすると以後そのファイルはGitの管理対象から外されます。
おそらくGitにおいて「削除」と言ったらこれを指すのではないでしょうか。

 reset

今チェックアウトしているブランチが指すコミットを強制的に変更したり、indexの内容をチェックアウトしているコミットの内容に戻したり、作業コピーの内容をindexの内容に戻したりするコマンドです。
「たり」が多いですが、実際resetコマンドはいくつかの機能を複合したものであり、コマンドの実行方法や指定したオプションによって使われる機能が変わってきます。
もし「index」や「staging」の概念をまだ知らないのであれば、きちんと知っておいてください。他のバージョン管理システムには無いGit特有の概念です。

例えば単にgit resetすると、indexの内容のみが今チェックアウトしているコミットの内容に戻り、作業コピーの内容は変更されません。間違えてaddrmしてしまった時などにどうぞ。

--hardオプションを付けてgit reset --hardすると、上に加えて作業コピーの内容も戻され、作業コピーの内容が今いるコミットの内容に戻ります。コミットしていない変更をすべてリセットしたいときにどうぞ。

更にコミットを指定してgit reset --hard <commit>とすると、今いるブランチが指定したコミットへ強制的に移動され、さらにindex・作業コピーの内容もそれに合うように書き換えられます。origin/*以前でやっちゃダメよ。

他にも色々オプションがあるのでご自分で調べてください。

 clean

作業ディレクトリにあるバージョン管理外のファイルをお掃除するコマンドです。開発中にできたキャッシュ等のゴミファイルを削除してくれます。ただしバージョン管理対象外のファイルをすべて削除してしまうので、その中に必要なファイルが含まれないか注意してください。

従って、git reset --hard && git clean -xdfすると、作業ディレクトリの内容がチェックアウトしているコミットの内容に完全に一致します。とにかく全部リセットしたいときに使えます。

 revert

指定したコミットの逆コミットを作るコマンドです(「逆コミット」は今勝手に考えた言葉です)。上の3つとは違い、新たにコミットが作られます。

以前行ったコミットを取り消したいと思ったとき、そのコミットをrevertすると、そのコミットの変更を逆にしたコミットを作成してくれます。失われる歴史が無いので安心して使えます。ただしもちろん、そのコミットと同じ行を何度か編集していた場合は競合が起こります。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/10/27 16:07

    分かりやすい回答をありがとうございます。

    キャンセル

0

複数のサイトを確認されることをお勧めします。
「git で削除」で検索したらちゃんと解説されているサイトが見つかります。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

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