title | intro | versions | type | topics | redirect_from | |||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Hello World |
Follow this Hello World exercise to learn {% data variables.product.github %}'s pull request workflow. |
|
quick_start |
|
|
This tutorial teaches you {% data variables.product.github %} essentials like repositories, branches, commits, and pull requests. You'll create your own Hello World repository and learn {% data variables.product.github %}'s pull request workflow, a popular way to create and review code.
In this quickstart guide, you will:
- Create and use a repository.
- Start and manage a new branch.
- Make changes to a file and push them to {% data variables.product.github %} as commits.
- Open and merge a pull request.
-
You must have a {% data variables.product.github %} account. {% ifversion fpt or ghec %}For more information, see AUTOTITLE.{% endif %}
-
You don't need to know how to code, use the command line, or install Git (the version control software that {% data variables.product.github %} is built on).
The first thing we'll do is create a repository. You can think of a repository as a folder that contains related items, such as files, images, videos, or even other folders. A repository usually groups together items that belong to the same "project" or thing you're working on.
Often, repositories include a README file, a file with information about your project. README files are written in Markdown, which is an easy-to-read, easy-to-write language for formatting plain text. We'll learn more about Markdown in the next tutorial, AUTOTITLE.
{% data variables.product.github %} lets you add a README file at the same time you create your new repository. {% data variables.product.github %} also offers other common options such as a license file, but you do not have to select any of them now.
Your hello-world
repository can be a place where you store ideas, resources, or even share and discuss things with others.
{% data reusables.repositories.create_new %}
- In the "Repository name" box, type
hello-world
. {% data reusables.repositories.add-description %} For example, type "This repository is for practicing the {% data variables.product.prodname_dotcom %} Flow." {% data reusables.repositories.select-public-or-private %} {% data reusables.repositories.add-readme %} {% data reusables.repositories.click-create %}
Branching lets you have different versions of a repository at one time.
By default, your repository has one branch named main
that is considered to be the definitive branch. You can create additional branches off of main
in your repository.
Branching is helpful when you want to add new features to a project without changing the main source of code. The work done on different branches will not show up on the main branch until you merge it, which we will cover later in this guide. You can use branches to experiment and make edits before committing them to main
.
When you create a branch off the main
branch, you're making a copy, or snapshot, of main
as it was at that point in time. If someone else made changes to the main
branch while you were working on your branch, you could pull in those updates.
This diagram shows:
- The
main
branch - A new branch called
feature
- The journey that
feature
takes through stages for "Commit changes," "Submit pull request," and "Discuss proposed changes" before it's merged intomain
- Click the Code tab of your
hello-world
repository. - Above the file list, click the dropdown menu that says main.
{% ifversion global-nav-update %}
{% else %}
{% endif %}
Now you have two branches, main
and readme-edits
. Right now, they look exactly the same. Next you'll add changes to the new readme-edits
branch.
When you created a new branch in the previous step, {% data variables.product.github %} brought you to the code page for your new readme-edits
branch, which is a copy of main
.
You can make and save changes to the files in your repository. On {% data variables.product.github %}, saved changes are called commits. Each commit has an associated commit message, which is a description explaining why a particular change was made. Commit messages capture the history of your changes so that other contributors can understand what you’ve done and why.
- Under the
readme-edits
branch you created, click theREADME.md
file. - To edit the file, click {% octicon "pencil" aria-label="Edit file" %}.
- In the editor, write a bit about yourself. {% ifversion code-view-ui %}1. Click Commit changes.{% endif %}
- In the "Commit changes" box, write a commit message that describes your changes.
- Click Commit changes.
These changes will be made only to the README file on your readme-edits
branch, so now this branch contains content that's different from main
.
Now that you have changes in a branch off of main
, you can open a pull request.
Pull requests are the heart of collaboration on {% data variables.product.github %}. When you open a pull request, you're proposing your changes and requesting that someone review and pull in your contribution and merge them into their branch. Pull requests show diffs, or differences, of the content from both branches. The changes, additions, and subtractions are shown in different colors.
As soon as you make a commit, you can open a pull request and start a discussion, even before the code is finished.
In this step, you'll open a pull request in your own repository and then merge it yourself. It's a great way to practice the {% data variables.product.github %} flow before working on larger projects.
-
Click the Pull requests tab of your
hello-world
repository. -
Click New pull request.
-
In the Example Comparisons box, select the branch you made,
readme-edits
, to compare withmain
(the original). -
Look over your changes in the diffs on the Compare page, make sure they're what you want to submit.
-
Click Create pull request.
-
Give your pull request a title and write a brief description of your changes. You can include emojis and drag and drop images and gifs.
-
Click Create pull request.
When you start collaborating with others, this is the time you'd ask for their review. This allows your collaborators to comment on, or propose changes to, your pull request before you merge the changes into the main
branch.
We won't cover reviewing pull requests in this tutorial, but if you're interested in learning more, see AUTOTITLE. Alternatively, try the {% data variables.product.prodname_learning %} "Reviewing pull requests" course.
In this final step, you will merge your readme-edits
branch into the main
branch. After you merge your pull request, the changes on your readme-edits
branch will be incorporated into main
.
Sometimes, a pull request may introduce changes to code that conflict with the existing code on main
. If there are any conflicts, {% data variables.product.github %} will alert you about the conflicting code and prevent merging until the conflicts are resolved. You can make a commit that resolves the conflicts or use comments in the pull request to discuss the conflicts with your team members.
In this walk-through, you should not have any conflicts, so you are ready to merge your branch into the main branch.
- At the bottom of the pull request, click Merge pull request to merge the changes into
main
. - Click Confirm merge. You will receive a message that the request was successfully merged and the request was closed.
- Click Delete branch. Now that your pull request is merged and your changes are on
main
, you can safely delete thereadme-edits
branch. If you want to make more changes to your project, you can always create a new branch and repeat this process. - Click back to the Code tab of your
hello-world
repository to see your published changes onmain
.
By completing this tutorial, you've learned to create a project and make a pull request on {% data variables.product.github %}.
As part of that, we've learned how to:
- Create a repository.
- Start and manage a new branch.
- Change a file and commit those changes to {% data variables.product.github %}.
- Open and merge a pull request.
- Take a look at your {% data variables.product.github %} profile and you'll see your work reflected on your contribution graph.
- If you want to practice the skills you've learned in this tutorial again, try the {% data variables.product.prodname_learning %} "Introduction to {% data variables.product.prodname_dotcom %}" course.
- In the next tutorial, AUTOTITLE, you'll learn how to personalize your profile and you'll also learn some basic Markdown syntax for writing on {% data variables.product.github %}.