Git basics: What is GitHub?

โœ๏ธ

How does GitHub work and how is it related to Git?

4 Nov, 2021 ยท 6 min read

Now that we have a basic understanding of what Git is. Let's have a look at what GitHub is.

I love the following analogy as it makes so much sense (I stole this from the internet).

It's the difference between porn and pornhub.

What is GitHub?

GitHub is a website to host your Git repositories. But not just that, it's broader as it's also a place for millions of other developers to host their code.

Many people do their whole open source community on GitHub, making it one sole point of communication.

GitHub is remarkable in having automated actions, issues and managing team development.

Besides that, it gives us a super good visual overview of our code, branches, and pull-request.

A closer look at a GitHub repository

I've opened a repo on GitHub, and this is generally what you are welcomed with:

Screenshot 2021-10-24 at 08.01.45.png

I've divided this layout into four sections:

  1. Repo header
  2. Project files
  3. Sidebar
  4. Readme

Let's go through each of these items and see what they provide us in more detail.

1. GitHub repo header

Screenshot 2021-10-24 at 08.09.37.png

The header of a GitHub repo contains a lot of information and gives us a quick overview of what we can do with this repo.

The left top states the company/user and repo name. In this example, the company is dailydotdev, and we view the repo daily. It also states it's a public repo so that anyone can contribute to it.

On the right, you see some crucial icons with some numbers. These are very important to open source.

  • Watch: It's like following a repository. If you do this activity for this repo will show up on your GitHub homepage.
  • Star: Stars are one of the most significant things in GitHub for open source projects. The way GitHub works is that repos with the most stars will show up higher in the search. So if you like a project, make sure to star them!
  • Fork: Forking a project means you clone the project to your profile as a clone of the project. The general idea is that you will work on an issue and merge a solution back. But you could fork, make changes and use your version now.

The last part of the header contains a menu to navigate the repo options.

  • Code: The actual code files of this project. And generally, the homepage we enter.

  • Issues: Issues are like the name suggest issues that are logged for this repository. For public repos anyone can log a problem, and it's a well-known way of logging issues for open source.

Issues screen on GitHub

  • Pull requests: In general, when it comes to using Git, there is a way of working, which we'll discuss in a later topic. This way uses Pull requests to check code before being pushed on the actual codebase. GitHub provides a super good visual screen for these pull requests.

GitHub pull request screen

  • Discussions: Discussions are a forum-like experience for a repository. It's a great way to have open discussions with people who use the repo and the maintainers. And it could include discussions for features that are not yet an issue.

GitHub discussions screen

  • Actions: Actions are probably the best new thing in GitHub. They provide a way to run specific actions if something happens in our repo. Let's give you an example and say a PR is merged. This could spark an action that automatically deploys this code to our website.

GitHub actions screen

  • Wiki: The wiki is a built-in wiki. It's a great way to add a more extended multi-page readme. And could tell people a lot more in detail about certain aspects of your project.

GitHub wiki example

  • Security: The security tab is most important to the maintainers of the project. It gives all the vulnerabilities a project might have. It can also scan your codebase for common mistakes as including secrets in your code. We can also set up dependabot from here.

GitHub security tab

  • Insights: The insights tab gives a good overview of the activity on a particular repo. It also shows the contributors and dependencies. It's an excellent way to see how well a repo is used.

GitHub insights tab explained

2. GitHub project files

The project files are the actual files of the project, and we can even navigate through folders and open files from this view.

GitHub project file section

  • Branch dropdown: This dropdown can be used to switch between all the branches in a repo. And show the code that belongs to that branch.

  • Branches: This is a list of all the branches and how they compare to the main branch. It quickly shows which branch is ahead or behind from the main/master branch and a PR open.

GitHub branches screen

  • Tags: The tags open a tag overview. Tags are specific releases that have received a tag. Generally, these are stable versions of a project that you can use.

GitHub tags screen

  • Go to file: This button can be used to quickly find a file in the project. I must admit I don't use this myself.

  • Add file: This button can be used to add a file directly into the project. It will also be added to the commit history. But I would always suggest using the normal git-flow.

  • Code dropdown: This dropdown can be used to download the codebase through a link or via SSH.

GitHub code download

3. GitHub repo sidebar

The sidebar provides a lot of quick information about a repo in a quick overview.

GitHub Sidebar element for a repo

In the sidebar, we see a lot of cool things:

  • About section describing the project
  • Link to the project homepage
  • Tags Associated with this repo
  • License and readme links
  • Releases for the project
  • Packages if the project publishes its own packages
  • Contributors who added code to this project
  • Users of this repo
  • Languages that are used in the codebase

4. GitHub readme

The readme is an essential part of open source projects. It's the welcome page to your project.

You should use this file to write something about the project, so other people understand what it's for and how to use it.

I'll write a more detailed article on what a good readme should look like.

The short version would be:

  • Describe your project
  • How to use it
  • In short, describe how it works (architecture)
  • How to run the project
  • Logging issues
  • License

This is not a golden standard and can be tailored to your project's needs. My best advice would be to look at what some other big projects are doing with their readme and work from there.

And that's it. I hope you have gotten a good overview of the layout of a GitHub repo and how we can use it. We'll dive into more details in creating our repo and pushing code to it.

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Spread the knowledge with fellow developers on Twitter
Tweet this tip
Powered by Webmentions - Learn more

Read next ๐Ÿ“–

Undo wrong Git changes

30 Jul, 2022 ยท 3 min read

Undo wrong Git changes

Git basics: Changing your last commit message

19 Jul, 2022 ยท 2 min read

Git basics: Changing your last commit message