Git is a free and open source distributed version control system. - Git Website
GitHub, and competitors BitBucket and GitLab, all use Git as the underlying version control system.
Official References:
Beginner References:
Command-Line References:
First see if Git is already installed (it may come pre-installed):
# Mac Terminal:
git --version #> git version 2.20.1
which git #> /usr/local/bin/git
# Windows Command Prompt, Anaconda Prompt, or Git Bash:
git --version #> git version 2.20.1.windows.1
where git #> C:\Program Files\Git\cmd\git.exe
If these commands produce a version-looking output and a filepath-looking output, respectively, then Git is already installed and you can skip down to the "Git Commands Overview" section. Otherwise, follow the OS-specific sections below to install Git.
Mac users can install Git from https://git-scm.com/downloads, or via homebrew (recommended) with brew install git
.
After installing, restart your terminal application, where you should now be able to execute Git commands (like git --version
).
Windows users can install Git from https://git-scm.com/downloads. This installation should also install a program called Git Bash, which Windows users will use as their default command-line computing application.
The Git Bash application is where you can execute Git commands (like git --version
). Depending on how you installed it, your Command Prompt and Anaconda Prompt applications may also have access to the Git CLI, in which case you can run Git commands from within those applications as well.
References:
Configure the username and email message that will be associated with your work:
git config --global user.name "Mona Lisa"
git config --global user.email "email@example.com"
# verify settings:
git config --global user.name
git config --global user.email
FYI: If you'd like to keep your email private, you can use the noreply email from your GitHub email settings page (e.g.
YOUR_GITHUB_USERNAME@users.noreply.github.com
)
If you'd like to use the SSH protocol instead of HTTPS to connect to GitHub (so you don't have to keep typing your username and password), first generate a new public / private key pair, then follow the instructions to share your public key via the GitHub settings.
See: Connecting to GitHub via SSH, including: Generating SSH Keys and Adding SSH Keys to GitHub
This section provides an overview of the most important Git concepts and commands.
NOTE: after executing some commands like
git log
andgit diff
, you can press the "Enter" key to keep reading, and type "q" to quit when you are done.
NOTE: after executing commands like
git pull
, you may find yourself at times in an unfamiliar-looking "Vi" text editor window, which you can exit by pressing the "shift + ZZ" keys.
NOTE: instead of initializing repositories in this way, we'll usually create new repos via the GitHub interface, and then "clone" or download them to a specified local location (see "Remote Repositories" section below).
Navigate into a project directory, then initialize a new repository there:
mkdir ~/Desktop/my-example-repo
cd ~/Desktop/my-example-repo
git init . # initialize a new git repository, creating a hidden folder called .git in your project's root directory
Use your text editor to add, delete, and/or modify files, then save them.
After making and saving changes to files in a repository, you can detect the changes and review them:
git status
git diff
After reviewing the changes, if you are satisfied, stage and commit them:
git add .
git commit -m "my message"
Continue to iteratively repeat the process of reviewing and committing revisions as you incrementally develop your software.
List the most recent revisions:
git log
Show details about the most recent revision:
git show
One of the biggest benefits of version control is the ability to revert to previous versions. If you need to restore the state of your repository to some previous commit:
# where abc123def456 is the identifier, or "SHA", of the commit you would like to revert to:
git reset --hard abc123def456
When you create a new empty repository on GitHub, it will display a screen that contains the REMOTE_ADDRESS
. Otherwise, to find the REMOTE_ADDRESS
of any existing GitHub repository, visit its homepage and click the big green "Clone or download" button. The address should resemble https://github.com/USERNAME/REPONAME.git
(HTTPS), or git@github.com:USERNAME/REPONAME.git
(SSH).
NOTE: to enable SSH, see this guide on connecting to GitHub via SSH, which will prompt you to generate a public/private key pair and save the files locally in your "~/.ssh" directory. These files help establish your identity to GitHub.
If there is a remote repository you would like to download, clone it (where REMOTE_ADDRESS
refers to the repository's remote address):
git clone REMOTE_ADDRESS
After cloning, a default remote address named "origin" is automatically created. You can check a local repository's remote addresses at any time:
git remote -v
Add or remove a local repository's remote addresses, where REMOTE_NAME
refers to the name of the remote address, (e.g. "origin"), and REMOTE_ADDRESS
refers to the repository's remote address:
git remote add REMOTE_NAME REMOTE_ADDRESS
git remote rm REMOTE_NAME REMOTE_ADDRESS
If you would like to upload the contents of a local repository to a remote address but you don't already have a remote repo, follow these steps in order:
- Create a new repo on GitHub, then note its remote address.
- From the command-line, navigate to the root directory of your existing local repository (e.g
cd path/to/my-dir
). - Configure a "remote" address for your local repository:
git remote add origin REMOTE_ADDRESS
. NOTE: the overwhelming convention is to name your default GitHub remote address "origin". - Associate the local repo with the remote repo (one-time, first-time only):
git pull origin main --allow-unrelated-histories
. After doing so, you may be in a "Vi" text editor window, which you can exit by pressing the "shift + ZZ" keys. - Follow the "Syncing Local and Remote Repositories" section, below, to push your local changes up to GitHub.
Assuming you have already associated a local repository with a remote address named "origin":
git pull origin main # downloads recent contents from the remote repo, in case changes have been made to the remote repo since you last pushed.
git push origin main # uploads local repo contents to remote address
Sometimes after pulling, you may see merge conflicts, in which case you might need to perform a "rebase" before being able to push. The rebase process can be difficult, so feel free to ask the professor for help.
After pushing successfully, you should be able to visit your remote repository on GitHub and see your code there.
References:
Branches offer separate namespaces for different versions of your code. This allows a single developer to try different approaches without affecting some known working version of the code. It also facilitates developer collaboration by allowing each developer a space to work, and by enabling Pull Request operations and reviews on GitHub.
The default branch is called "main" (FYI: it used to be called "master"), but developers usually do their work on a branch corresponding with some development goal (e.g. "my-new-feature"):
# determine which branch you're on:
git branch
# create and switch to a new branch named "my-new-feature":
git checkout -b my-new-feature
# switch between existing branches:
git checkout main
git checkout my-new-feature
# after committing some changes, push the branch up to GitHub:
git push origin my-new-feature
FYI: when you switch branches, you're able to change between different versions of various files, so try making some changes and committing them and inspecting the files before and after you switch branches, to see the effects in action.