From 2413e9cbad620ca20b3aaffeb9cf4bb132e6113f Mon Sep 17 00:00:00 2001 From: johannst Date: Thu, 20 Feb 2025 23:05:55 +0000 Subject: deploy: 8167ecb83a8cc75da42a0b398c750d8f3aa4c44b --- development/git.html | 39 ++++++++++++++++++++++++++++++++++++--- 1 file changed, 36 insertions(+), 3 deletions(-) (limited to 'development/git.html') diff --git a/development/git.html b/development/git.html index e5e0e62..4dbf81b 100644 --- a/development/git.html +++ b/development/git.html @@ -159,13 +159,15 @@

Working areas

+-------------------+ --- stash -----> +-------+
 | working directory |                  | stash |  // Shelving area.
-+-------------------+ <-- stash pop -- +-------+
+|     (worktree)    | <-- stash pop -- +-------+
++-------------------+
       |       ^
      add      |
       |     reset
       v       |
 +-------------------+
 |   staging area    |
+|      (index)      |
 +-------------------+
       |
     commit
@@ -324,8 +326,39 @@ the same repository (shared .git folder).

tracked files in the working tree since <commit> are lost git reset HEAD <file> .......... remove file from staging - git reset --soft HEAD~1 ........ delete most recent commit but keep work - git reset --hard HEAD~1 ........ delete most recent commit and delete work + git reset --soft HEAD~1 ........ delete most recent commit; dont revert index & worktree + git reset --mixed HEAD~1 ....... delete most recent commit; revert index; dont revert worktree + git reset --hard HEAD~1 ........ delete most recent commit; revert index & worktree +
+

Assuming an initial history A - B - C - D where HEAD currently points at +D, the different reset operations work as shown below.

+

Soft reset.

+
git reset --soft HEAD~2
+
+history:    A - B
+                ^HEAD
+
+-> local history is reverted, HEAD moved to B.
+-> changes from C + D are still in the worktree & index (appear as staged changes).
+
+

Mixed reset.

+
git reset --mixed HEAD~2
+
+history:    A - B
+                ^HEAD
+
+-> local history is reverted, HEAD moved to B.
+-> changed from C + D are reverted in the index.
+-> changes from C + D are still in the worktree (appear as unstaged changes).
+
+

Hard reset.

+
git reset --head HEAD~2
+
+history:    A - B
+                ^HEAD
+
+-> local history is reverted, HEAD moved to B.
+-> changes from C + D also reverted in the worktree & index (no pending changes).
 

Submodules

  git submodule add <url> [<path>] .......... add new submodule to current project
-- 
cgit v1.2.3