---
title: README.md
author: @raseen3
tags: ["abstract", "preface", "introduction"]
---
A review and cheat-sheet to study up on git
This Repository documents how to use each git
-command in plain english and the different use cases and best practices.
tbd
To generate an SSH key, first open your shell in the Home Directory.
Then ENTER:
ssh-keygen -f ~/.ssh/keyforgithub -t ecdsa
and COPY the result of:
cat ~/.ssh/keyforgithub.pub
you will have to have had git installed for this to work
Then go to your code hosting platform of choice (i.e. GitHub, GitLab, etc.) and navigate to your account settings to where you can add a new SSH Key and PASTE what you just copied.
To add your git profile, add a file called config to your /.ssh
directory:
touch ~/.ssh/config
and inside the file add the url your code is hosted on and on a new indented line the path to the ssh key Example:
Host github.com
IdentityFile ~/.ssh/keyforgithub
To see if you key works ENTER the command:
ssh -T [email protected]
and if the output is something along the lines of
Hi _yourUsername_! You've successfully authenticated, but GitHub does not provide shell access
then you have successfully added you ssh key
tbd
Create and/or navigate to inside the directory where you want your project to be stored inside then ENTER:
git init
To be able to push to GitHub create a repository in GitHub and copy the repository link then ENTER:
git remote add origin [email protected]:username/repository.git //or whatever what you copied was
and this will link your local repository to the one you are hosting online
Alternatively you can just do:
git clone [email protected]:username/repository.git //or whatever what you copied was
saves changes to local machine
Staged all files pending addition, deletion, and modification
stages file or directory to be committed
saves changes to local branch
Commits all the changes that have been staged
Saves/sends changes to the Remote branch hosted on GitHub
use this command the first time you push a change on a branch to set the origin of your changes
Pushes local changes to the remote hosted branch along with all the tags
deleted specified tag
updates changes to what is saved in the Remote branch hosted on GitHub if the local branch is not up-to-date
tells you what branch you're on and the status of all files that have either been added, deleted, or modified between adds and commits and whether they are being staged
logs all the commits
shows the difference between what you currently have and what is saved in the branch
Show changes between working directory and staging area.
Shows any changes between the staging area and the repository.
can set default commit message, git aliases, and specifer git user in the .git
and .gitconfig
file
can use .gitignore
to ignore certain files
Example .gitignore
:
/logs/*
!logs/.gitkeep
/tmp
*.swp
Verify the .gitignore file exists in your project and ignore certain type of files, such as all files in logs directory (excluding the .gitkeep file), whole tmp directory and all files *.swp. File ignoring will work for the directory (and children directories) where .gitignore file is placed.
Revert your repository to a previous known working state.
Create a new commit, reverting changes from the most recent commit. It generates an inversion of changes.
Remove file from working directory and staging area
Put current changes in your working direcotry into stash for later use
Apply stored stash content into working directory, and clear stash
Delete a specific stash from all your previous stashes
creates a tag named tag-name with a message tied to current commit (can specify commit)
switches you to the specified branch (can also switch you to a specified tag if that is set up)
creates a copy of the current branch and switches to the new branch
merges specified branch into current working branch; assuming you are in the branch that you want to merge into (send all the changes to)