Skip to content
/ ugit Public
forked from Bhupesh-V/ugit

๐Ÿšจ๏ธ ugit helps you undo your last git command. Your damage control git buddy. Powered by FZF

License

Notifications You must be signed in to change notification settings

unixorn/ugit

ย 
ย 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

67 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

ugit

ugit logo

Undo your last oopsie ๐Ÿ™ˆ๏ธ in git

build ugit DeepSource License: MIT platform support linux and macos Twitter: bhupeshimself ugit demo: restore file gif

More Video Demos โœจ๏ธ

Undo git add

ugit.git.add.demo.mp4

Undo git branch -D

ugit.git.branch.delete.demo.mp4

Undo git merge

ugit.git.merge.demo.mp4

Why ugit

  • You did an accidental git command you didn't want to.
  • You don't want to waste your time searching on how to undo ...
  • Because ugit is cool

What's in the box

ugit/git-undo supports undoing following operations, some are a WIP. If you know of any other operations that can be undone and is not in the list, make sure to send a quick PR ๐Ÿ’›๏ธ

  • Undo git commit
  • Undo git add
  • Undo git push
  • Undo git branch -D (branch delete)
  • Undo git pull
  • Undo git reset
  • Undo git tag -d (tag delete)
  • Undo git stash apply
  • Undo git stash pop/drop/clear
  • Undo accidental file delete (Restore a deleted file after a commit)
  • Undo (Restore) a file to a previous version
  • Undo git merge
  • Undo git tag (rename a tag)
  • Undo git rebase
  • Undo git cherry-pick
  • Undo git worktree remove (recover deleted work-tree)

Help me finish above tasks by contributing?

Have any other ideas/suggestions? Hop in to ugit discussions ๐Ÿ’ฌ๏ธ

Installation

Prerequisites

ugit dependencies:

  • Bash>=3
  • GNU utils like awk, grep, tput etc
  • fzf (Install latest version. Minimum required 0.21.0)

Manual Installation

  1. Install the script using curl

    Linux

    curl -fsSL https://github.com/Bhupesh-V/ugit/releases/latest/download/ugit -o ugit && chmod +x ugit && mv ugit $HOME/.local/bin/

    Mac

    curl -fsSL https://github.com/Bhupesh-V/ugit/releases/latest/download/ugit -o ugit && chmod +x ugit && mv ugit /usr/local/bin

    Or Arch Linux users can install ugit via AUR.

  2. Verify installation

    ugit --version

    Optionally run ugit --help to see help and management commands

    Undo your last oopsie in Git ๐Ÿ™ˆ
    Usage: ugit [-h] [-v] [-u]
    
    ugit helps you undo your last git command without much effort
    Just run 'ugit' and search for what you want to undo
    
    Available options:
    
    -h, --help      Print this help and exit
    -v, --version   Print current ugit version
    -u, --update    Update ugit
    
    Contact ๐Ÿ“ฌ: varshneybhupesh@gmail.com for assistance
    Read the guide: https://bhupesh.gitbook.io/notes/git/how-to-undo-anything-in-git
    

ZSH Frameworks

Zgenom

If you're using Zgenom:

  1. Add zgenom load Bhupesh-V/ugit to your .zshrc along with your other zgenom load commands.
  2. zgenom reset && zgenom save

Antigen

If you're using Antigen:

  1. Add antigen bundle Bhupesh-V/ugit to your .zshrc where you've listed your other plugins.
  2. Close and reopen your Terminal/iTerm window to refresh context and use the plugin. Alternatively, you can run antigen bundle Bhupesh-V/ugit in a running shell to have antigen load the new plugin.

Oh-My-ZSH

If you're using oh-my-zsh:

  1. Clone the repository into a new ugit directory in oh-my-zsh's plugin folder:

    git clone https://github.com/Bhupesh-V/ugit.git $ZSH_CUSTOM/plugins/ugit

  2. Edit your ~/.zshrc and add ugit โ€“ same as clone directory โ€“ to the list of plugins to enable:

    plugins=( ... ugit )

  3. Then, restart your terminal application to refresh context and use the plugin. Alternatively, you can source your current shell configuration:

    source ~/.zshrc

ugit in ...

News

Community

Please read โš ๏ธ

Git comes with a garbage collector (in case you didn't know) therefore undoing some commands will become impossible if the entries are deleted from the reflog. One way to prevent this is to increase default time limits before the reflog entries expire.

Add these configuration in your global .gitconfig file:

[gc]
    # default 90 days
    reflogExpire = 200

Used to set how long records in a branches reflog should be preserved.

[gc]
    # default 30 days
    reflogExpireUnreachable = 90

Used to set how long inaccessible reflog records should be preserved.

Not satisfied? ๐Ÿ˜’๏ธ

You can read my in-process guide on How to undo anything in Git

Author

๐Ÿ‘ค Bhupesh Varshney

Credit & Thanks

To all the SO threads that I will probably never visit again ;)

โ˜บ๏ธ Show your support

Support me by giving a โญ๏ธ if this project helped you! or just Twitter URL

Support via PayPal

๐Ÿ“ License

Copyright ยฉ 2021 Bhupesh Varshney.
This project is MIT licensed.

๐Ÿ‘‹ Contributing

Please read the CONTRIBUTING file for the process of submitting pull requests to us.

Contributors โœจ

Thanks goes to these wonderful people (emoji key):


Sharan Aithal

๐Ÿ’ป ๐Ÿ“–

Tabulate

๐Ÿ’ป ๐Ÿ“ฆ

Joe Block

๐Ÿ’ป ๐Ÿ“– ๐Ÿ”Œ

This project follows the all-contributors specification. Contributions of any kind welcome!

About

๐Ÿšจ๏ธ ugit helps you undo your last git command. Your damage control git buddy. Powered by FZF

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 100.0%