# Git Recipes

These are the commands for common tasks. Git can be a bit hard to memorize, since there's quite a few commands, and what those commands aren't necessarily named what you'd expect them to be named. This is intended be be a place where you can look up a task, and find the git commands needed to perform it.

## Set the git editor to something easier to use than vim

Append this to your .zshrc file:

```
export GIT_EDITOR=pico
```

## Initialize a git repository

```
git init
```

## Remove a git repository

```
rm -rf .git
```

## Stage all changed file for commit

This stages the commit at that point in time. If you add more to the file after using this command, it won't be part of the commit unless you use git add again.

```
git add . --all
```

## Unstage files

```
git reset (file)
```

## See the status of staged files

```
git status
```

## Commit all staged files

```
git commit -m "(Add your commit message here)"
```

### Important note!

Committed changes get a bit harder to remove/revert. Be sure you're committing what you want to commit.

## See history of commits

```
git log
```

## Reverse a change

Reversing a commit doesn't really undo it, it just creates another commit that changes the files you committed back to what they were before the commit. First, you have to find the ID of the commit you'd like to reverse using git log.

Copy that ID, and paste it into this command

```
git revert (Commit ID)
```

## Destroy all changes up to a certain point

It's possible to completely remove all records of changes back to a given commit. It's not a good idea to do this on a regular basis, but rarely, it becomes necessary.

```
git reset (Commit ID) --hard
```

If you try to push to a remote repository, the remote will just think you haven't received the latest commits, so you have to force the remote to rewrite it's own history

```
git push origin --force
```

## Create a branch

```
git checkout -b (branch name)
```

## Delete a branch

```
git branch -d (branch name)
```

## Merge a branch into main (master)

```
git checkout main
git merge (other branch name)
```

### NOTE:

You can merge a branch into any other branch. Just check out the branch you want to merge into, then merge just like above.

```
git checkout (branch name)
get merge (other branch name)
```

## Set remote origin

Having a repository on your computer is great, but what if other people want to contribute? Github is like a social network for git. It allows many people to work on the same repository and make commits. You have to link your local repository to Github in order to enable all this.

```
git remote add origin (Add Github URL here)
```

## List remotes

Did we add the remote correctly? Let's find out!

```
git remote -v
```

## Push to remote

```
git push (remote name) (optional branch name)
```

### NOTE:

It's generally a good idea to specify which branch you're pushing. You may have a lot of local branches that your collaborators don't care about. Also, it takes more time to push every branch you may have, so usually I use

```
git push origin main
```

in order to push only to the main branch.

## Pull from remote

```
git pull (remote name) (optional branch name)
```

## Delete remote branch

If you do push a branch to a remote, you can delete it like this:

```
git push origin :(branch name)
```

It's important to include the semicolon. If I had a branch named "my\_branch", I would delete it from the remote like this:

```
git push origin :my_branch
```
