/git-cheatsheet

A brief cheatsheet for beginners

OtherNOASSERTION

Git: A Brief Introductory Cheatsheet for Beginners

Git banner. Created by Facundo Martínez (c) 2023, licensed under CC BY-NC-SA 4.0

Versión en español

Click acá

1. What is Git?

Git is a distributed version control system used to track changes made to a set of files by individuals or groups. It is a FOSS (free and open-source) tool that is widely utilized by companies due to its efficiency and speed.

Git allows the creation of parallel development branches, enabling you and your team members to work simultaneously on different project features and merge them later. By keeping track of the changes made to the project, you can easily revert to a previous version in case any issues arise.

2. Installing Git

Windows:

Git for Windows installer

Debian/Ubuntu:

$ sudo apt-get update
$ sudo apt-get install git-all

Fedora:

$ sudo dnf install git-all

Mac:

git-osx-installer

Using Homebrew

$ brew install git

After installing git, you need to configure it by setting your global username and email:

$ git config --global user.name "Your username"
$ git config --global user.email "youremail@domain.com"

If you want to configure a different username and email for a specific repository, you can run the same commands inside the folder of the repository without adding the --global option.

3. Basic concepts

git-operations

In Git you have three main states: the working directory, the staging area, and the Git directory (or local repository). You can also have a remote repository connected to your Git directory.

The working directory is, in essence, a copy of your project version. Git stores a compressed copy of all your versions inside a hidden folder, and they are decompressed when you need to access them.

The staging area stores information about the changes that are about to be committed to the repository.

The Git directory (or local repository) stores all the important metadata for your project: commits, remote repositories, logs, etcetera.

4. Setting up a local repository

Create new repository

When you begin a new project, you can create a new folder to store your Git repository, which is created with git init

$ mkdir projectfolder
$ cd projectfolder
$ git init

See repository status

This command will show you which files have been recently modified inside the project folder.

$ git status

Adding files to staging area

After creating and/or modifying the files from your working directory, you can add them all at once to the staging area using this command:

$ git add .

If you want to add a single file:

$ git add yourfilename

Committing files from the staging area to the local repository

To commit all the changes to the local repository, you can use this command:

$ git commit -m "Your comment"

The comment should indicate what changes have been made to the repository. It's a good practice to write detailed messages that accurately represent the changes that have been made. If you type git commit without adding anything else, a text editor window will pop-up allowing you to write a message. The changes will commit to the local repository after you close the window.

5. Verifying changes in the local repository

Checking what commits have been made

$ git log

Checking what has been recently modified before a commit

After you modify a file, you will see it classified as "modified" after running git status. To see the changes that have been made since the last commit:

$ git diff

6. Branches

See current branch

$ git branch

This command will print the branch you're currently working on.

Create new branch

Verify that you do not have pending commits:

$ git status

Create new branch:

$ git checkout -b yournewbranchname

It's common practice to create new branches when you want to add a new feature to the project. You can name them as feature/your-feature where "your-feature" corresponds to the name of the feature you want to add.

Move to another branch

To move from a branch to another:

$ git checkout branchname

or

$ git switch branchname

Where "branchname" is the branch you want to move to.

NOTE: you can also use git-checkout to restore changed files to their latest version.

Merge branches

Let's say you have a branch that is several commits ahead from another. To merge that branch with your current branch:

$ git merge branchname

Where "branchname" corresponds to the branch you want to merge.

Resolve merge conflicts

7. Remote repositories

You can communicate with external repositories using Git.

Pushing an existing repository to a remote location

If you want to push to a remote repository, like one from Github:

$ git remote add origin git@github.com:username/repositoryname.git
$ git branch -M main
$ git push -u origin main

Where "username" corresponds to the owner and "repositoryname" is the name of the remote repository.

TIP: you can replace "origin" with any other word you want, it's just an identifier.

Clone remote repository to local

$ git clone repository-url

Where repository-url is the URL of the remote repository you want to clone inside your current directory.

See configured remote repositories

$ git remote -v

Retrieve changes from remote to local repository

To download changes from a single remote location:

$ git fetch origin

To download changes from all remote locations:

$ git fetch --all

Fetch changes from remote and integrate them

IMPORTANT NOTE: It is not recommended to use this command to download and integrate all changes from remote at once, unless you know there will be no conflicts. It's best to use git-fetch first.

$ git pull origin

To integrate changes from all remote locations:

$ git pull --all

8. Best practices

Some free external resources for learning and applying Git best practices:

Final notes

This article was created by Facundo Martínez © 2023. It is licensed under CC BY-NC-SA 4.0

I love creating free content for everyone. If my articles and repos were useful to you, please consider supporting me on Github Sponsors, Ko-Fi or PayPal. It would be of great help and I would really appreciate it!

Github-sponsors Ko-Fi PayPal

If you want to provide feedback on this guide (including possible additions and/or corrections), click here