Basic Git
Basic Git
• Introduction to Git
• Git lifecycle
• Common Git command
• Git Workflow
• Working with Remote Repository
• Version controlling using Git
GitHub
• GitHub is a cloud-based platform where you can store, share, and work together
with others to write code.
• Storing your code in a "repository" on GitHub allows you to:
• Showcase or share your work.
• Track and manage changes to your code over time.
• Let others review your code, and make suggestions to improve it.
• Collaborate on a shared project, without worrying that your changes will impact the
work of your collaborators before you're ready to integrate them.
• Collaborative working, one of GitHub’s fundamental features, is made possible by
the open-source software, Git, upon which GitHub is built.
Version Control System
• A version control system, or VCS, tracks the history of changes as
people and teams collaborate on projects together.
• As developers make changes to the project, any earlier version of the
project can be recovered at any time.
• Developers can review project history to find out:
• Which changes were made?
• Who made the changes?
• When were the changes made?
• Why were changes needed?
• VCSs give each contributor a unified and consistent view of a project,
surfacing work that's already in progress.
• Seeing a transparent history of changes, who made them, and how
they contribute to the development of a project helps team members
stay aligned while working independently.
• In a distributed version control system, every developer has a full
copy of the project and project history.
• Unlike once popular centralized version control systems, DVCSs don't
need a constant connection to a central repository.
Introduction to Git
• Git is the most popular distributed version control system that intelligently tracks changes in files.
• Git is commonly used for both open source and commercial software development, with
significant benefits for individuals, teams and businesses.
• Git is particularly useful when you and a group of people are all making changes to the same files
at the same time.
• Git lets developers see the entire timeline of their changes, decisions, and progression of any
project in one place. From the moment they access the history of a project, the developer has all
the context they need to understand it and start contributing.\
• Developers work in every time zone. With a DVCS like Git, collaboration can happen any time
while maintaining source code integrity. Using branches, developers can safely propose changes
to production code.
• Businesses using Git can break down communication barriers between teams and keep them
focused on doing their best work. Plus, Git makes it possible to align experts across a business to
collaborate on major projects.
• Typically, to do Collaborative working in a Git-based workflow, you
would:
• Create a branch off from the main copy of files that you (and your collaborators) are working on.
• Make edits to the files independently and safely on your own personal branch.
• Let Git intelligently merge your specific changes back into the main copy of files, so that your
changes don't impact other people's updates.
• Let Git keep track of your and other people's changes, so you all stay working on the most up-to-
date version of the project.
How do Git and GitHub work together?
• When you upload files to GitHub, you'll store them in a "Git repository." This means that when you make
changes (or "commits") to your files in GitHub, Git will automatically start to track and manage your changes.
• There are plenty of Git-related actions that you can complete on GitHub directly in your browser, such as
creating a Git repository, creating branches, and uploading and editing files.
• However, most people work on their files locally (on their own computer), then continually sync these local
changes—and all the related Git data—with the central "remote" repository on GitHub. There are plenty of
tools that you can use to do this, such as GitHub Desktop.
• Once you start to collaborate with others and all need to work on the same repository at the same time,
you’ll continually:
• Pull all the latest changes made by your collaborators from the remote repository on GitHub.
• Push back your own changes to the same remote repository on GitHub.
• Git figures out how to intelligently merge this flow of changes, and GitHub helps you manage the flow
through features such as "pull requests."
Signing up for a new personal account
• Navigate to https://github.com/.
• Click Sign up.
• Follow the prompts to create your personal account.
• During sign up, you'll be asked to verify your email address. Without a
verified email address, you won't be able to complete some basic
GitHub tasks, such as creating a repository.
• Now that you've created your personal account, we'll start to explore
the basics of GitHub
Exercise : GitHub Essentials
• Lets perform basic GitHub essentials like repositories, branches,
commits, and pull requests.
• Step 1: Create and use a repository
• Step 2: Create and manage a branch
• Step 3: Make changes to a file and push them to GitHub as commits (commit
changes)
• Step 4: Open a pull request
• Step 5: Merge your pull request
About repositories
• A repository is the most basic element of GitHub.
• It's a place where you can store your code, your files, and each file's revision history.
• Repositories can have multiple collaborators and can be either public or private.
• Repository terminology:
• Branch : A parallel version of your code that is contained within the repository, but does not
affect the primary or main branch.
• Clone : To download a full copy of a repository's data from GitHub.com, including all versions of
every file and folder.
• Fork: A new repository that shares code and visibility settings with the original "upstream"
repository.
• Merge: To take the changes from one branch and apply them to another.
• Pull request: A request to merge changes from one branch into another.
• Remote:A repository stored on GitHub, not on your computer.
• Upstream: The branch on an original repository that has been forked or cloned. The corresponding
branch on the cloned or forked branch is called the "downstream."
Step 1: Create and use 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.
• GitHub lets you add a README file at the same time you create your new repository.
• GitHub also offers other common options such as a license file, but you do not have to select any
of them now.
Steps to create a repository
• In the upper-right corner of any page, select , then click New
repository.
• In the "Repository name" box, type “any name “.
• In the "Description" box, type a short description. For example, type
"This repository is for practicing the GitHub Flow."
• Select whether your repository will be Public or Private.
• Select Add a README file.
• Click Create repository.
Step 2: Create a branch
• 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:
1. The main branch
2. A new branch called feature
3. The journey that feature takes before it's merged
into main
Creating a branch
• Click the Code tab of your repository.
• Above the file list, click the dropdown menu that says main.
• Type a branch name, “new”, into the text box.
• Click Create branch: “new” from main.
• Now you have two branches, main and new.
• Right now, they look exactly the same.
• Next you'll add changes to the “new” branch.
Step 3: Make and commit changes
• When you created a new branch in the previous step, GitHub brought you to the
code page for your new branch, which is a copy of main.
• You can make and save changes to the files in your repository.
• On 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 new branch you created, click the README.md file.
• To edit the file, click .
• In the editor, write a bit about yourself.
• Click Commit changes.
• 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 new
branch, so now this branch contains content that's different from
main.
Step 4: Open a pull request
• 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 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 practise the GitHub flow before working on larger
projects.
• Click the Pull requests tab of your repository.
• Click New pull request.
• In the Example Comparisons box, select the branch you made, new, to
compare with main (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.
Step 5: Merge your pull request
• In this final step, you will merge your new branch into the main
branch.
• After you merge your pull request, the changes on your new 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, 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.
• 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 the new 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 repository to see your published
changes on main.