Skip to content

How to use Git and Github in your day to day Tutorial for Beginners

Notifications You must be signed in to change notification settings

henriqpohl/Tutorial-HowToUseGit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 

Repository files navigation

How to use Git and Github in your day-to-day Tutorial for Beginners.

Summary

Introduction

Hi there, my name is Henrique! 👋

This tutorial teaches you how you can use the Git and GitHub in your day-to-day.

So, if you're here, I guess that you know what Git and GitHub are, but if you don't know, I will leave below a short resume regarding them.

⬇️

Git

Git is a distributed, open-source version control system. It enables developers and data scientists to track code, merge changes and revert to older versions. It allows you to sync changes with a remote server as well.

GitHub

GitHub is a cloud development platform. It is commonly used for saving files, tracking changes and collaborating on development projects. GitHub has become the most popular social platform for software development communities. Individuals can contribute to open-source projects and bug reports, discuss new projects and discover new tools.

Why should I use Git?

When you use a centralized version control system and decide to use Git, it will change the way that your development team works. Basically, unlike centralized version control systems, Git works like "feature branch workflow", so you can make many Git branches for your future features and it's easy to merge in your main branch as well.

Why should I use GitHub?

You can use GitHub as a portfolio to show if you are working or studying at the moment. For students, the platform has become a great opportunity to gain work experience and eventually, why not a job opportunity? Below is an example of what the GitHub profile looks like.

Getting started 🚀

Installing Git and create a free GitHub account

To get started, the first step to do is, install git and create a free GitHub account.

Installing Git: The latest version of Git is available for macOS, Windows and Linux, to download it, you can use the link below: ⬇️

If you want to install by terminal:

for macOS:

  • Homebrew: Install homebrew if you don't already have it, then:
$ brew install git
  • MacPorts: Install MacPorts if you don't already have it, then:
$ sudo port install git

for Windows:
You can find the latest version of Git for Windows here.

for Linux:

Debian/Ubuntu
For the latest stable version for your release of Debian/Ubuntu

# apt-get install git

For Ubuntu, this PPA provides the latest stable upstream Git version

# add-apt-repository ppa:git-core/ppa
# apt update; apt install git

For other Linux distributions you can follow here.

GitHub account: After the Git installed, you can create a GitHub account here.

Git Interfaces (GUI Clients)

If you've decided not to use GitHub you also can use some Git interfaces, which makes your life easier when you need to see how your repository (project) looks, what was changed in each commit, when it was done, by who and etc.

You can check some Git GUI here.

They are available for Mac, Windows, Linux, iOS and Android.

Setting your username and email in Git

I strongly recommend that if you've never used Git before, try it. Moreover, it will make your commit list appear with your GitHub username (profile) in your repository, for example, if you don't do this when you make a new commit and send to GitHub repository it will appear like this:

And after, you can see like this:

Setting your Git username and email for every repository on your computer

Open the Terminal and run the following command: git config --global user.name and git config --global user.name.

ℹ️ If you've decided to use GitHub, in this part, you should use the same username and email from your GitHub profile.

  • Setting a Git username:
$ git config --global user.name "<your-username>"
  • Setting a Git email:
$ git config --global user.email "<your-email>"

To confirm that you have set the Git username correctly run the command $ git config --global user.name and $ git config --global user.name.

$ git config --global user.name
> <your-username>
$ git config --global user.email
> <your-email>

Setting your Git username and email for a single repository

Open the Terminal and run the following command git config user.name and git config user.name.

  • Setting a Git username:
$ git config user.name "<your-username>"
  • Setting a Git email:
$ git config user.email "<your-email>"

To confirm that you have set the Git username correctly run the command $ git config user.name and $ git config user.name.

$ git config user.name
> <your-username>
$ git config user.email
> <your-email>

Creating a local repository and adding a new file, let's do it!

Open the Git Bash already installed in your computer together with Git or you can use your default Terminal or VSCode Terminal.

cd ~/Desktop
mkdir Tutorial-HowToUseGit
cd Tutorial-HowToUseGit/

~/Tutorial-HowToUseGit %

Adding a new file: You can use any text editor that you prefer, in this example, to create a new file we will use the touch <filename> command:

~/Tutorial-HowToUseGit % touch README.md
~/Tutorial-HowToUseGit % ls
README.md

Now, we have the project folder with file (README.MD) inside, ready to go ahead.

💡 TIP: If you are using macOS, I strongly recommend the Warp Terminal + Fish + Starship. You can download it below:

Warp + Fish + Starship are amazing combinations pretty much friendly, take a look in the screenshot below:

Git Basic Commands

  • git init: create a Git repository in a local directory.
  • git clone <remote-repo-address>: copy the entire repository from a remote server to remote directory. You can also use it to copy local repositories.
  • git add <file.txt>: add a single file or multiple files and folders to the staging area.
  • git commit –m "Message": create a snapshot of changes and save it in the repository.
  • git config: used to set user-specific configurations like email, username, and file format.
  • git status: shows the list of changed files or files that have yet to be staged and committed.
  • git push <remote-name> <branch-name>: send local commits to remote branch of repository.
  • git checkout -b <branch-name>: creates a new branch and switches to a new branch.
  • git remote –v: view all remote repositories.
  • git remote add <remote-name> <host-or-remoteURL>: add remote server to local repository.
  • git branch –d <branch-name>: delete the branch.
  • git pull: fetch commits from a remote repository to a local repository and update it to match that content.
  • git merge <branch-name>: after resolving merge conflicts the command blends selected branches into the current branch.
  • git log: show a detailed list of commits for the current branch.

No worries about that for now, we will use all this command together ahead. 😁

Initializing a local git repository and starting using Git.

To initialize a git repository: In the root of the folder, run git init command:

As mentioned before, you can use Git bash, your default Terminal or VSCode Terminal.

Git was initialized in your project folder. 🥳

ℹ️ A hidden folder .git, was created in your root folder ☠️ never delete it ☠️, there is where all the Git magic happens.

After initializing the Git repository, you can run git status command to see which files git knows exist.

As you can see, Git returned basically "Oh, we have a new file called README.md that you created, but it hasn't been untracked yet."

Adding a new file to the staging environment (list)

To add a new file to the staging list you can use: git add <filename>.

Now, you can use git status to check again.

You can see now the notice: "Changes to be committed" and that Git flagged your file to a "New file", which means that your file is in the staging environment waiting to be committed.

To be easier, look at the image below, you will be able to see how the previous steps works. ⬇️


Create a commit

Finally it's time to create your first commit! 😂

Run the following command: git commit -m "Your message about the commit".

Now, you can see, your Commit is done ✅ and your Branch Master is available, but we need to do one more thing: We need to rename Branch Master to Branch Main (that is the currently recommended best practice).

To do that, we will use git branch to check what is the current branch name and after git branch -M "main" to rename it, take a look in the screenshot below:

Create a new repository on GitHub

Now, we will push the local repository to GitHub. You don't need to follow it if you just want to track your code locally. If you work on a team or want to use your code to collaboratively modify it, you shouldn't skip it.

To create a new repository on GitHub, log in and go to GitHub home page. You should find the “New repository” option under the “+” sign next to your profile picture, on the top right corner of the navbar:


If you have already logged in, you can click here. Both ways will redirect you to the page like below and this is very important because it's where you are going to set your repository name and a short description about it:


In this section they show possibilities to start creating a new repository or only make a remote link to an existing Git repository and this is what we will do now.

To do so, we are going to use the git remote add origin and git push -u origin main



Now, you can go back to your GitHub repository page to check your push request.

Create a new branch

When you have a project and you need to make a new feature, but you don't want to make this in the main project while you are developing the feature, for that you can use a branch concept.

Branches allow you to switch between the "states" of a project. For example, if you want to add a new page to your website you can create a new branch just for that page without affecting the main part of the project. Once you have done it, you can merge your changes from your branch into the primary branch. When you create a new branch, Git keeps tracking of which commit your branch "branched" off of, so it knows the history behind all the files.

To create a new branch you can run: git checkout -b <my branch name>.

After creating the new branch, you can use the git branch command to confirm that your branch was created.

Push a branch to GitHub Repository

After you develop some feature and make a commit we'll push the commit in your branch with "a new feature" to your GitHub repository, after approved by the repository's owner, the changes can then be merged into the primary branch, to do so you can use the git push origin <new-branch-name> command, GitHub will automatically create the branch for you on the remote repository:

For example take a look in the screenshot below, before, I put some text in my blank README.md file, just to simulate some changes... then:

You might be wondering what the word "origin" means in the command above. What happens is that when you clone a remote repository to your local machine, git creates an alias for you. In nearly all cases this alias is called "origin." It's essentially shorthand for the remote repository's URL. So, to push your changes to the remote repository, you could've used either the command:

git push [email protected]:git/git.git your-branch-name

or

git push origin your-branch-name

ℹ️ If this is your first time using GitHub locally, it might prompt you to log in with your GitHub username and password.

If you go back in your GitHub repository page, click in branches:

Now, you'll see your branch list with you last branch listed there.

Merge a new branch to a main branch

After you develop the new feature in your new branch, we need to merge to a main branch, to do that, you need to go back to our main branch, then run git checkout <main branch-name> and after to merge we need to use git merge <my-new-branch-name>

After merge, if you refresh the GitHub page, you'll see basically a note saying "a new branch has just been pushed into the repository". You can also click the "branches" link to see your branch listed there.

Now click the green button "Compare & pull request" and you're going to make a pull request.

Create a Pull Request (PR)

A pull request works as an alert, after you make a PR, the repository owners will know that you want to make some changes in their project. The owners will make a review in your PR and they will make sure if it looks great before approving your changes on the primary branch.

For example after your push a new branch in your own code or make a new branch in a forked repository with a collaborator position the owners must see like the screenshot below:


The PR page shows up before you've submitted it, so you need to send some details to make it easier for the owners to make a review.


And this is how it looks like once you've submitted the PR request:

Now, you can see a big green button that says "Merge pull request". Basically click on it and then click "Confirm merge" it means that you've merged and confirmed your changes into the primary branch.

Sometimes you'll be a co-owner or the sole owner of a repository, and in that case you don't need to create a PR to merge your changes. However, it is still a good idea to make one so you can keep a more complete history of your updates. Furthermore, make sure you always create a new branch when making changes because if you have any problem it will be easier to analyze like a "debug".

Merge a Pull Request (PR)

After clicking the green "Merge pull request" button, all your changes in your branch will be merged in the primary branch.

Once you finish to merge the pull request, which means merge some new branch to the main branch, you no longer need the older version of the branch, so you can delete it. Having many branches can become a big mess, so click in "Delete branch" to do it.

Now you can check your commits were merged by clicking on the "Commits" in you main page of your repository and you can see the screenshot below:

You can also see the hash code of the commit on the right side. A hash code is a unique identifier for each specific commit. It's useful for referring to specific commits and then undoing changes.

To revert you can use: git revert <hash code number> command.

Cloning a entire repository (Clone)

When we need to copy any GitHub repository, we can use git clone, but how can we do that? Let's check it below.

After you click on in the green button called "Code" you will be able to see and copy the link to clone this repository.

And after in your project folder that you want to clone you can run the command:

git clone https://github.com/henriqpohl/Tutorial-HowToUseGit.git

After that, you already have a copy from the desired repository in your computer.

Forking a entire repository (Fork)

Forking in GitHub is the process of creating a copy of a repository to the user's GitHub Account from another account. It is usually done for community contribution or teamwork.

To make a Fork is very easy, go to the repository page that you want to make a Fork and click in the "Fork" button and after click in "Create a new fork" like the screenshot below:

Once clicked, you will be able to see the Create a new fork page like the screenshot below:

After that, just click on the green "Create fork" button and it will appear in your repositories list.

Get changes on GitHub back to your computer (Pull request)

This part is very important, now you will get all the changes from your GitHub repository and put it back in your computer because your local code is different from your GitHub repository.

So, you can use: git pull origin main or only git pull.

The git pull command shows you all the files that have changed.

If you want to see all changes you can use the git log command to see all new commits.

In this stage you may need to switch branches back to the primary branch. You can do that using the git checkout main command.

Congratulations! 🥳
You've successfully made a PR and merged your code to the primary branch.

Conclusion

https://training.github.com/
Github’s official git cheat sheets! Handy for remembering the everyday commands you’ll use.

https://git-school.github.io/visualizing-git
Another tool for exploring git visually. This one is more of an open-ended sandbox than learngitbranching.js.org

Thanks so much!

I hope you learned a lot after reading this, if you have any question you can reach me using my GitHub profile here or in my website here. 😎

Or, if there's something you want me to improve here, why not make a PR? 😜

❤️

About

How to use Git and Github in your day to day Tutorial for Beginners

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published