Commit 0ce54bd5 authored by Russell Dickenson's avatar Russell Dickenson

Merge branch 'selhorn-undo-git-1' into 'master'

Edited for CTRT

See merge request gitlab-org/gitlab!61172
parents 7229273e 4984fdea
...@@ -5,139 +5,134 @@ info: To determine the technical writer assigned to the Stage/Group associated w ...@@ -5,139 +5,134 @@ info: To determine the technical writer assigned to the Stage/Group associated w
type: howto type: howto
--- ---
# Numerous undo possibilities in Git **(FREE)** # Undo possibilities in Git **(FREE)**
This tutorial shows you different ways of undoing your work in Git. [Nothing in Git is deleted](https://git-scm.com/book/en/v2/Git-Internals-Maintenance-and-Data-Recovery),
We assume you have a basic working knowledge of Git. Check the GitLab so when you work in Git, you can undo your work.
[Git documentation](../index.md) for reference.
We only provide some general information about the commands to get you started. All version control systems have options for undoing work. However,
For more advanced examples, refer to the [Git book](https://git-scm.com/book/en/v2). because of the de-centralized nature of Git, these options are multiplied.
The actions you take are based on the
[stage of development](https://git-scm.com/book/en/v2/Git-Basics-Recording-Changes-to-the-Repository)
you are in.
A few different techniques exist to undo your changes, based on the stage For more information about working with Git and GitLab:
of the change in your current development. Remember that
[nothing in Git is really deleted](https://git-scm.com/book/en/v2/Git-Internals-Maintenance-and-Data-Recovery).
Until Git cleans detached commits - commits that cannot be accessed by branch or tag -
you can view them with `git reflog` command, and access them with direct commit ID.
Read more about [redoing the undo](#redoing-the-undo) in the section below.
> For more information about working with Git and GitLab: - <i class="fa fa-youtube-play youtube" aria-hidden="true"></i>&nbsp;Learn why [North Western Mutual chose GitLab](https://youtu.be/kPNMyxKRRoM) for their enterprise source code management.
> - Learn how to [get started with Git](https://about.gitlab.com/resources/whitepaper-moving-to-git/).
> - <i class="fa fa-youtube-play youtube" aria-hidden="true"></i>&nbsp;Learn why [North Western Mutual chose GitLab](https://youtu.be/kPNMyxKRRoM) for their Enterprise source code management. - For more advanced examples, refer to the [Git book](https://git-scm.com/book/en/v2).
> - Learn how to [get started with Git](https://about.gitlab.com/resources/whitepaper-moving-to-git/).
## Introduction ## When you can undo changes
This guide is organized depending on the [stage of development](https://git-scm.com/book/en/v2/Git-Basics-Recording-Changes-to-the-Repository): In the standard Git workflow:
- Where do you want to undo your changes from? 1. You create or edit a file. It starts in the unstaged state. If it's new, it is not yet tracked by Git.
- Were they shared with other developers? 1. You add the file to your local repository (`git add`), which puts the file into the staged state.
1. You commit the file to your local repository (`git commit`).
1. You can then share the file with other developers, by committing to a remote repository (`git push`).
Because Git tracks changes, a created or edited file is in the unstaged state You can undo changes at any point in this workflow:
(if created it is untracked by Git). After you add it to a repository (`git add`) you put
a file into the **staged** state, which is then committed (`git commit`) to your
local repository. After that, file can be shared with other developers (`git push`).
This tutorial covers:
- [Undo local changes](#undo-local-changes) which were not pushed to a remote repository: - [When you're working locally](#undo-local-changes) and haven't yet pushed to a remote repository.
- When you have already pushed to a remote repository and you want to:
- [Keep the history intact](#undo-remote-changes-without-changing-history) (preferred).
- [Change the history](#undo-remote-changes-with-modifying-history) (requires
coordination with team and force pushes).
- Before you commit, in both unstaged and staged state. ## Undo local changes
- After you committed.
- Undo changes after they are pushed to a remote repository: Until you push your changes to a remote repository, changes
you make in Git are only in your local development environment.
- [Without history modification](#undo-remote-changes-without-changing-history) (preferred way). ### Undo unstaged local changes before you commit
- [With history modification](#undo-remote-changes-with-modifying-history) (requires
coordination with team and force pushes).
- [Use cases when modifying history is generally acceptable](#where-modifying-history-is-generally-acceptable).
- [How to modify history](#how-modifying-history-is-done).
- [How to remove sensitive information from repository](#deleting-sensitive-information-from-commits).
### Branching strategy When you make a change, but have not yet staged it, you can undo your work.
[Git](https://git-scm.com/) is a de-centralized version control system. Beside regular 1. Confirm that the file is unstaged (that you did not use `git add <file>`) by running `git status`:
versioning of the whole repository, it has possibilities to exchange changes
with other repositories.
To avoid chaos with ```shell
[multiple sources of truth](https://git-scm.com/about/distributed), various $ git status
development workflows have to be followed. It depends on your internal On branch main
workflow how certain changes or commits can be undone or changed. Your branch is up-to-date with 'origin/main'.
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
[GitLab Flow](https://about.gitlab.com/topics/version-control/what-is-gitlab-flow/) provides a good modified: <file>
balance between developers clashing with each other while no changes added to commit (use "git add" and/or "git commit -a")
developing the same feature and cooperating seamlessly. However, it does not enable ```
joined development of the same feature by multiple developers by default.
When multiple developers develop the same feature on the same branch, clashing 1. Choose an option and undo your changes:
with every synchronization is unavoidable. However, a proper or chosen Git Workflow
prevents lost or out-of-sync data when the feature is complete.
You can also - To overwrite local changes:
read through this blog post on [Git Tips & Tricks](https://about.gitlab.com/blog/2016/12/08/git-tips-and-tricks/)
to learn how to do things in Git.
## Undo local changes ```shell
git checkout -- <file>
```
Until you push your changes to any remote repository, they only affect you. - To save local changes so you can [re-use them later](#quickly-save-local-changes):
That broadens your options on how to handle undoing them. Still, local changes
can be on various stages and each stage has a different approach on how to tackle them.
### Unstaged local changes (before you commit) ```shell
git stash
```
When a change is made, but not added to the staged tree, Git - To discard local changes to all files, permanently:
proposes a solution to discard changes to the file.
Suppose you edited a file to change the content using your favorite editor: ```shell
git reset --hard
```
```shell ### Undo staged local changes before you commit
vim <file>
```
Because you did not `git add <file>` to staging, it should be under unstaged files (or If you added a file to staging, you can undo it.
untracked if file was created). You can confirm that with:
```shell 1. Confirm that the file is staged (that you used `git add <file>`) by running `git status`:
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: <file> ```shell
no changes added to commit (use "git add" and/or "git commit -a") $ git status
``` On branch main
Your branch is up-to-date with 'origin/main'.
Changes to be committed:
(use "git restore --staged <file>..." to unstage)
At this point there are 3 options to undo the local changes you have: new file: <file>
```
- Discard all local changes, but save them for possible re-use [later](#quickly-save-local-changes): 1. Choose an option and undo your changes:
- To unstage the file but keep your changes:
```shell ```shell
git stash git restore --staged <file>
``` ```
- Discarding local changes (permanently) to a file: - To unstage everything but keep your changes:
```shell ```shell
git checkout -- <file> git reset
``` ```
- Discard all local changes to all files permanently: - To unstage the file to current commit (HEAD):
```shell ```shell
git reset --hard git reset HEAD <file>
```
- To discard all local changes, but save them for [later](#quickly-save-local-changes):
```shell
git stash
``` ```
Before executing `git reset --hard`, keep in mind that there is also a way to - To discard everything permanently:
just temporary store the changes without committing them using `git stash`.
This command resets the changes to all files, but it also saves them in case ```shell
you would like to apply them at some later time. You can read more about it in git reset --hard
[section below](#quickly-save-local-changes). ```
### Quickly save local changes ### Quickly save local changes
You are working on a feature when a boss drops by with an urgent task. Because your You are working on a feature when someone drops by with an urgent task. Because your
feature is not complete, but you need to swap to another branch, you can use feature is not complete, but you need to swap to another branch, you can use
`git stash` to: `git stash` to:
...@@ -159,60 +154,7 @@ additional options like: ...@@ -159,60 +154,7 @@ additional options like:
- `git stash pop`, which redoes previously stashed changes and removes them from stashed list - `git stash pop`, which redoes previously stashed changes and removes them from stashed list
- `git stash apply`, which redoes previously stashed changes, but keeps them on stashed list - `git stash apply`, which redoes previously stashed changes, but keeps them on stashed list
### Staged local changes (before you commit) ## Undo committed local changes
If you add some files to staging, but you want to remove them from the
current commit while retaining those changes, move them outside
of the staging tree. You can also discard all changes with
`git reset --hard` or think about `git stash` [as described earlier.](#quickly-save-local-changes)
Lets start the example by editing a file with your favorite editor to change the
content and add it to staging:
```shell
vim <file>
git add <file>
```
The file is now added to staging as confirmed by `git status` command:
```shell
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
new file: <file>
```
Now you have 4 options to undo your changes:
- Unstage the file to current commit (HEAD):
```shell
git reset HEAD <file>
```
- Unstage everything - retain changes:
```shell
git reset
```
- Discard all local changes, but save them for [later](#quickly-save-local-changes):
```shell
git stash
```
- Discard everything permanently:
```shell
git reset --hard
```
## Committed local changes
After you commit, your changes are recorded by the version control system. After you commit, your changes are recorded by the version control system.
Because you haven't pushed to your remote repository yet, your changes are Because you haven't pushed to your remote repository yet, your changes are
...@@ -289,6 +231,9 @@ these options to remove all or part of it from our repository: ...@@ -289,6 +231,9 @@ these options to remove all or part of it from our repository:
### With history modification ### With history modification
You can rewrite history in Git, but you should avoid it, because it can cause problems
when multiple developers are contributing to the same codebase.
There is one command for history modification and that is `git rebase`. Command There is one command for history modification and that is `git rebase`. Command
provides interactive mode (`-i` flag) which enables you to: provides interactive mode (`-i` flag) which enables you to:
...@@ -335,7 +280,7 @@ In case you want to modify something introduced in commit `B`. ...@@ -335,7 +280,7 @@ In case you want to modify something introduced in commit `B`.
You can find some more examples in the section explaining You can find some more examples in the section explaining
[how to modify history](#how-modifying-history-is-done). [how to modify history](#how-modifying-history-is-done).
### Redoing the Undo ### Redoing the undo
Sometimes you realize that the changes you undid were useful and you want them Sometimes you realize that the changes you undid were useful and you want them
back. Well because of first paragraph you are in luck. Command `git reflog` back. Well because of first paragraph you are in luck. Command `git reflog`
...@@ -501,14 +446,6 @@ feature set as `git filter-branch` does, but focus on specific use cases. ...@@ -501,14 +446,6 @@ feature set as `git filter-branch` does, but focus on specific use cases.
Refer [Reduce repository size](../../../user/project/repository/reducing_the_repo_size_using_git.md) page to know more about purging files from repository history & GitLab storage. Refer [Reduce repository size](../../../user/project/repository/reducing_the_repo_size_using_git.md) page to know more about purging files from repository history & GitLab storage.
## Conclusion
Various options exist for undoing your work with any version control system, but
because of the de-centralized nature of Git, these options are multiplied (or limited)
depending on the stage of your process. Git also enables rewriting history, but that
should be avoided as it might cause problems when multiple developers are
contributing to the same codebase.
<!-- ## Troubleshooting <!-- ## Troubleshooting
Include any troubleshooting steps that you can foresee. If you know beforehand what issues Include any troubleshooting steps that you can foresee. If you know beforehand what issues
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment