自分用にGitの基本コマンドまとめました。
前回の記事でクローンした場所(~/sample
)に移動します。
$ cd ~/sample
現在のいるブランチを確認
$ git branch * master
*
が付いている場所に現在います。
チェックアウト
ブランチを作成して、作成できているかを確認します。
その後チェックアウトします。
// 作成 $ git branch feature/init // 確認 $ git branch feature/init * master // ブランチが増えました。 // チェックアウト $ git checkout feature/init Switched to branch 'feature/init' // 確認 $ git branch * feature/init master // ブランチが移動しているのがわかります。git status
ファイルを追加・修正する
sample/
ディレクトリ配下に、いくつかファイルを作成してみます。
また、.gitignore
を少し変更しました。
変更した状態をみる
$ git status On branch feature/init Changes not staged for commit: (use "git add ..." to update what will be committed) (use "git checkout -- ..." to discard changes in working directory) modified: .gitignore Untracked files: (use "git add ..." to include in what will be committed) gulpfile.js package-lock.json package.json src/ no changes added to commit (use "git add" and/or "git commit -a")
modified
: 修正したファイルUntracked files
: 新規作成したファイル
変更点をみる
+
の部分が追加されたところです。
今回は追加しかしていないので、+
しか表示しれていませんが、変更したり、削除した行があれば、-
と表示されます。
$ git diff diff --git a/.gitignore b/.gitignore index 159f515..2f52cfc 100644 --- a/.gitignore +++ b/.gitignore @@ -2,3 +2,5 @@ *.css.map *.sass.map *.scss.map +/node_modules/ +.DS_Store
一括でステージにあげる
コミットする前に、コミットしたいファイルをまとめて、ステージングします。
$ git add . // ステージングされているか確認する $ git status On branch feature/init Changes to be committed: (use "git reset HEAD ..." to unstage) modified: .gitignore new file: gulpfile.js new file: package-lock.json new file: package.json new file: src/scss/style.scss
Changes to be committed:
の下に、緑色でファイルが表示されていたらOK。
ファイルひとつずつadd
する場合は、
$ git add .gitignore
ディレクトリごとadd
する場合は、
$ git add src/
ステージから下げる
一括で下げる時は、
$ git reset
ファイルひとつずつ下げる場合は、
$ git resest .gitignore
ディレクトリごと下げる場合は、
$ git resest src/
コミット
メッセージを二行入れてコミットしてみます。
$ git commit -m "init: gulp, base source codes" -m "gulpの環境と土台のソース準備"
コミットを戻す
直前のコミットを取り消す時は、HEAD^
をつける。
コミットといインデックスを戻して、ファイルの変更は残す時。
オプションをつけない時は、これが適用される。
$ git reset --mixed HEAD^
コミットだけを戻して、インデックス、ファイルの変更は残す時。
$ git reset --soft HEAD^
コミット、インデックス、ファイルの変更を戻す時。
--hard
はかなり強力なので、極力使わないようにしています。
$ git reset --hard HEAD^
今回は、ソフトを使ってみます。
$ git reset --soft HEAD^ $ git status On branch feature/init Changes to be committed: (use "git reset HEAD ..." to unstage) modified: .gitignore new file: gulpfile.js new file: package-lock.json new file: package.json new file: src/scss/style.scss
ログを見る
再度コメント付きでコミットし、確認してみます。
$ git log commit xxxxxxxx (HEAD -> feature/init) Author: [名前] Date: Mon Dec 21 16:13:41 2019 +0900 init: gulp, base source codes gulpの環境と土台のソース準備。
リモートへプッシュする
$ git push origin feature/init Enumerating objects: 34, done. Counting objects: 100% (34/34), done. Delta compression using up to 8 threads Compressing objects: 100% (26/26), done. Writing objects: 100% (32/32), 65.34 KiB | 4.36 MiB/s, done. Total 32 (delta 2), reused 0 (delta 0) remote: Resolving deltas: 100% (2/2), done. remote: remote: Create a pull request for 'feature/init' on GitHub by visiting: remote: https://github.com/sample/sample/pull/new/feature/init remote: To github.com.sub:sample/sample.git
Githubを開いて確認すると、ちゃんとプッシュされています。
マージする
ローカルマージする時は、コマンドで。
// マスターブランチに戻る $ git checkout master Switched to branch 'master' Your branch is up to date with 'origin/master'. // 今いるブランチに指定したブランチをマージします。 // masterにfeature/initをマージ $ git merge feature/init Updating xxxxxxx Fast-forward .gitignore | 2 + gulpfile.js | 72 ++ package-lock.json | 7070 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ package.json | 26 + src/scss/style.scss | 3 + 24 files changed, 7369 insertions(+) create mode 100644 gulpfile.js create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 src/scss/style.scss // ローカルでマージしたものをリモートにプッシュする $ git push origin master
ブランチを確認する
// ローカルのブランチを確認する $ git branch feature/init * master // リモートのブランチを確認する $ git branch --remote origin/HEAD -> origin/master origin/feature/init origin/master // ローカルリモートまとめて確認する $ git branch --all feature/init * master remotes/origin/HEAD -> origin/master origin/feature/init remotes/origin/master
ブランチを削除する
ローカルブランチを削除する
--delete
オプションは、HEADにマージしてあればを削除
-D
オプションは、マージしなくても強制的に削除
// 削除 $ git branch --delete feature/init Deleted branch feature/init (was xxxxx).
リモートのブランチを削除する
// 削除 $ git push --delete origin feature/init To github.com.sub:sample/sample.git - [deleted] feature/init
参考サイト
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-afbab5eb44e0b055cce1258705637a91.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLXByb2ZpbGUtaW1hZ2VzLmltZ2l4Lm5ldC9odHRwcyUzQSUyRiUyRnFpaXRhLWltYWdlLXN0b3JlLnMzLmFtYXpvbmF3cy5jb20lMkYwJTJGNTIzMzUlMkZwcm9maWxlLWltYWdlcyUyRjE1MDA0Nzc4MDg_aXhsaWI9cmItNC4wLjAmYXI9MSUzQTEmZml0PWNyb3AmbWFzaz1lbGxpcHNlJmZtPXBuZzMyJnM9NDUxZmMyYTdjNjMwZjk3ZDk5MTljMjc5YTgxM2QzZjI%26blend-x%3D120%26blend-y%3D467%26blend-w%3D82%26blend-h%3D82%26blend-mode%3Dnormal%26s%3D216b637772d41878cec492f3edac0b0c?ixlib=rb-4.0.0&w=1200&fm=jpg&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk2MCZoPTMyNCZ0eHQ9Z2l0JTIwJUUzJTgyJTkyJUU1JTg4JTlEJUUzJTgyJTgxJUUzJTgxJUE2JUU0JUJEJUJGJUUzJTgxJTg2JUU2JTk5JTgyJTIwJUUzJTgyJUIzJUUzJTgzJTlGJUUzJTgzJTgzJUUzJTgzJTg4JUUyJTg2JTkyJUUzJTgzJTk3JUUzJTgzJTgzJUUzJTgyJUI3JUUzJTgzJUE1JUUyJTg2JTkyJUUzJTgzJTlFJUUzJTgzJUJDJUUzJTgyJUI4JUUzJTgwJTgwJUUzJTgxJUFFJUU2JUI1JTgxJUUzJTgyJThDJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnR4dC1jb2xvcj0lMjMxRTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LXBhZD0wJnM9YTEyYzZkNWZjMjYzNGExNzA1ZjJlYTBiNDVhNjkwZDM&mark-x=120&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTgzOCZoPTU4JnR4dD0lNDB5dWtpeW9zaGltdXJhJnR4dC1jb2xvcj0lMjMxRTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LXBhZD0wJnM9NTdjNTQ1YTcxNGMzMzc1NGZhODE4NmIxZThiMzU2MDA&blend-x=242&blend-y=480&blend-w=838&blend-h=46&blend-fit=crop&blend-crop=left%2Cbottom&blend-mode=normal&s=7361084d09f4624439342f342a3c5b49)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-afbab5eb44e0b055cce1258705637a91.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLXByb2ZpbGUtaW1hZ2VzLmltZ2l4Lm5ldC9odHRwcyUzQSUyRiUyRnMzLWFwLW5vcnRoZWFzdC0xLmFtYXpvbmF3cy5jb20lMkZxaWl0YS1pbWFnZS1zdG9yZSUyRjAlMkY5MDYwNyUyRmU0MjY0ZDIxYzIzOGUyMjg3YmIxOThkNWQ1OGVkNjk2YjVhZWRmNGElMkZ4X2xhcmdlLnBuZyUzRjE3MDk4MDM4ODk_aXhsaWI9cmItNC4wLjAmYXI9MSUzQTEmZml0PWNyb3AmbWFzaz1lbGxpcHNlJmZtPXBuZzMyJnM9MjUyNTU4ZjgyNjdlNmNiYjc2NjhlNDQzNDI1MTdmNzM%26blend-x%3D120%26blend-y%3D467%26blend-w%3D82%26blend-h%3D82%26blend-mode%3Dnormal%26s%3D898bb891076dde1e641995e885b7b22a?ixlib=rb-4.0.0&w=1200&fm=jpg&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk2MCZoPTMyNCZ0eHQ9R2l0JTIwJTdDJTIwJUU0JUI4JTgwJUU2JThCJUFDJUUzJTgxJUE3JTIwYWRkJTIwJUUzJTgxJTk5JUUzJTgyJThCJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnR4dC1jb2xvcj0lMjMxRTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LXBhZD0wJnM9MGZiMzk3MmFkYzI2NGZiOTg5OTAxYzZjYTljNDQ1NWY&mark-x=120&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTgzOCZoPTU4JnR4dD0lNDBZaW5hdXJhJnR4dC1jb2xvcj0lMjMxRTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LXBhZD0wJnM9ZjRlYjczNDUxZDlmMDhkZTdlNmQ4ZTk1ZDY4NGNiYWI&blend-x=242&blend-y=480&blend-w=838&blend-h=46&blend-fit=crop&blend-crop=left%2Cbottom&blend-mode=normal&s=47e175e27dca18d491de26eb6f630c51)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-afbab5eb44e0b055cce1258705637a91.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLXByb2ZpbGUtaW1hZ2VzLmltZ2l4Lm5ldC9odHRwcyUzQSUyRiUyRnFpaXRhLWltYWdlLXN0b3JlLnMzLmFtYXpvbmF3cy5jb20lMkYwJTJGNDg5OTAlMkZwcm9maWxlLWltYWdlcyUyRjE1NDk5ODc3NTI_aXhsaWI9cmItNC4wLjAmYXI9MSUzQTEmZml0PWNyb3AmbWFzaz1lbGxpcHNlJmZtPXBuZzMyJnM9ZGU2ZjJmNjY1YTdiY2QxMzM5MTRjNTc2NDI0ZjVkNTU%26blend-x%3D120%26blend-y%3D467%26blend-w%3D82%26blend-h%3D82%26blend-mode%3Dnormal%26s%3D7a4b04cde611b24e67641341ffdd9753?ixlib=rb-4.0.0&w=1200&fm=jpg&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk2MCZoPTMyNCZ0eHQ9R2l0JUUzJTgxJUFFJUUzJTgyJUIzJUUzJTgzJTlGJUUzJTgzJTgzJUUzJTgzJTg4JUUzJTgzJUExJUUzJTgzJTgzJUUzJTgyJUJCJUUzJTgzJUJDJUUzJTgyJUI4JUUzJTgxJUFFJUU2JTlCJUI4JUUzJTgxJThEJUU2JTk2JUI5JnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnR4dC1jb2xvcj0lMjMxRTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LXBhZD0wJnM9MmM3Y2I0MDJlMzkwYjg1ZTcxMTg5MWJlMGM1YWI2NTE&mark-x=120&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTgzOCZoPTU4JnR4dD0lNDBpdG9zaG8mdHh0LWNvbG9yPSUyMzFFMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtcGFkPTAmcz0xNWYzYjkzOWY3N2JlYTkzY2Y2MTU5YjYwODQ3NWE2Ng&blend-x=242&blend-y=480&blend-w=838&blend-h=46&blend-fit=crop&blend-crop=left%2Cbottom&blend-mode=normal&s=9fbd192001e8738dc381cfbb201e524c)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-afbab5eb44e0b055cce1258705637a91.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLXByb2ZpbGUtaW1hZ2VzLmltZ2l4Lm5ldC9odHRwcyUzQSUyRiUyRnFpaXRhLWltYWdlLXN0b3JlLnMzLmFtYXpvbmF3cy5jb20lMkYwJTJGNjYwNiUyRnByb2ZpbGUtaW1hZ2VzJTJGMTQ3MzY4MzAxOT9peGxpYj1yYi00LjAuMCZhcj0xJTNBMSZmaXQ9Y3JvcCZtYXNrPWVsbGlwc2UmZm09cG5nMzImcz0wMzY4NTI0MTBiM2U1MDU4YTc5ZTdhMDRkM2E1YzQ1MQ%26blend-x%3D120%26blend-y%3D467%26blend-w%3D82%26blend-h%3D82%26blend-mode%3Dnormal%26s%3D247d3f96a8e1b064fcea2556e9e1faf6?ixlib=rb-4.0.0&w=1200&fm=jpg&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk2MCZoPTMyNCZ0eHQ9R2l0JTIwJUUzJTgxJUE3JUU0JUI4JThEJUU4JUE2JTgxJUUzJTgxJUFCJUUzJTgxJUFBJUUzJTgxJUEzJUUzJTgxJTlGJUUzJTgzJUFEJUUzJTgzJUJDJUUzJTgyJUFCJUUzJTgzJUFCJUUzJTgzJTk2JUUzJTgzJUE5JUUzJTgzJUIzJUUzJTgzJTgxJUUzJTgzJUJCJUUzJTgzJUFBJUUzJTgzJUEyJUUzJTgzJUJDJUUzJTgzJTg4JUUzJTgzJTk2JUUzJTgzJUE5JUUzJTgzJUIzJUUzJTgzJTgxJUUzJTgyJTkyJUU1JTg5JThBJUU5JTk5JUE0JUUzJTgxJTk5JUUzJTgyJThCJUU2JTk2JUI5JUU2JUIzJTk1JnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnR4dC1jb2xvcj0lMjMxRTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LXBhZD0wJnM9NGM0MzMxMzliMGViNTY4NWU3Y2I2MjgwN2JiZGRkNjQ&mark-x=120&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTgzOCZoPTU4JnR4dD0lNDBpb3Jpb25kYSZ0eHQtY29sb3I9JTIzMUUyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTM2JnR4dC1wYWQ9MCZzPWI4YzIxMjgyODM3OGU3OWUwMTcwOWIyODQwMWE4ODI2&blend-x=242&blend-y=480&blend-w=838&blend-h=46&blend-fit=crop&blend-crop=left%2Cbottom&blend-mode=normal&s=9a176bc01ad4daeb5d77209700f6be2e)
コメント