KEMBAR78
Git Slides | PDF
0% found this document useful (0 votes)
63 views34 pages

Git Slides

The document provides an overview of version control and Git, including key concepts like snapshots, commits, repositories, branches, merging, and GitHub. It explains the basic Git workflow and commands for cloning repositories, tracking files, committing changes, viewing history, branching and merging, and pushing to remote repositories on GitHub.

Uploaded by

Muhammad Haris
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
63 views34 pages

Git Slides

The document provides an overview of version control and Git, including key concepts like snapshots, commits, repositories, branches, merging, and GitHub. It explains the basic Git workflow and commands for cloning repositories, tracking files, committing changes, viewing history, branching and merging, and pushing to remote repositories on GitHub.

Uploaded by

Muhammad Haris
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 34

GIT AND GITHUB

EXPLANATION
COMPLETE GUIDE
What is Version Control?
● A system that keep record of your change.
● Allows for collaborative development.
● Allows you to know who made what changes and when.
● Allows you to revert any changes and go back to previous state.

12/30/2020 2
What is GIT?
● A distributed version control system.
● A few use cases:
○ Keep a history of previous versions.
○ Develop simultaneously on different branches.
■ Easily try out new features, integrate them into
production or throw them out.
○ Collaborate with other developers.
■ Push” and “pull” code from hosted repositories
such as Github
12/30/2020 3
KEY CONCEPTS:Snapshots

A snapshot is a representation of the current state of your tracked files in


the form of a manifest, which can be compared with other manifests to
see where the differences are.

4
KEY CONCEPTS:Commit

● The act of creating a snapshot.


● Can be a noun or verb.
○ “I commit a code”
○ “Here the message what you commit”
● Essentially a project made up of bunch of commits.
● Commits contain three pieces of information.
○ Which File you change
○ What changes are
○ And a hash code name.

5
KEY CONCEPTS:Repositories

● Shortened as a repo
● A collection of all files and the history of those files.
○ Consists of all your commits.
○ Place where all your hardwork is stored.
● Can live on local Machine or live server.
● The act of copying a repository from a remote server is called
Cloning.
● Cloning from a remote server allows team to work together.
● The process of downloading commits from that doesnot exist in your
machine is called pulling changes.
● The process of adding your local changes to remote machine called
pushing changes.
6
KEY CONCEPTS:Branches

● The main branch is known as a master branch .


● All the sub branches will extracted from master branch.
● A typical project look like this .
Head : Reference to the current branch.
● The main branch in your project .
● Doesn’t have to me called master
but almost it is.

7
KEY CONCEPT: Branches
● When you make a new changes you create a new branch and then push
on master branch.

8
KEY CONCEPT: Merging
When you are done with your new feature . You have to merge.

9
Working Of Commit
STEP 1:
Cloning the existing git Repository from the server to your local repository.
git clone (url)
STEP 2:
Import the existing project or directory in your local git repository and push
into the remote git repository.
git init //Create an empty git repository or re initialize an existing one.
git add *.*//Add file contents to the index.
git commit -m ‘initial version//REcord changes to the local repository..
git push origin master //Push the code into the remote repository.
10
THREE MAIN STAGES
Three main stages of git.
● Working Directory.
● Staging Area.
● Git Directory(Repository).

11
Three Stages

1. You modify files in your working tree.


2. You selectively stage just those changes you want to be part of your next commit,
which adds only those changes to the staging area.
3. You do a commit, which takes the files as they are in the staging area and stores
that snapshot permanently to your Git directory.

12
FILE STATUS LIFECYCLE
Each file in your working directory can
Can be in one state.
Tracked or untracked.
File Status in LifeCycle
● Untracked
● Unmodified
● Modified
● Staged

13
CHECKING THE STATUS OF YOUR FILE

Command : git status


Untracked Files: Files in your working directory that are not present in
last snapshot or in staging.
Tracked Files: Files that are present in last snapshot.
The following command is used to make the file status as trackable.
Command : git add FileName

14
CHECKING THE STATE OF YOUR FILE.

Staging modified Files : File that is modified and in tracking but not
staged .
Unstaging Modified Files: The file out of staging area .
Command : git reset HEAD filename.

15
VIEWING YOUR STAGED AND UNSTAGED
CHANGES
● To view the difference between staged and unstaged changes.
○ Command : git diff
● To View the differences between staged and last commit file.
○ Command : git diff -cached

COMMITTING YOUR CHANGES


The simplest way to commit is to type.
Command :git commit
Along with comments : git commit -m “Comments”
Skip Staging area :git commit -a -m “Comments”.
16
Remove Files
To remove the file.
Command :git rm filename
To remove the file from staged area .
Command :git rm --cached filename

Moving Files
The Metadata stored in git doesnot tell you wetherthe file is renamed.
To rename a file in git .
Command :git mv file_from file_to

17
VIEW COMMIT HISTORY

To View commit history


Command :git log
To View the difference in each commit.
Command :git log p
To Limit the output for last two entries
Command :git log p -2€

18
CHANGE LAST COMMIT
Change the last commit if we forget any file instead of doing new commit
Command: git commit -amend
Example :
● git commit -m “comments”
● git add file
● git commit -amend

19
UNSTAGING AND MODIFYING
To make the Staged file to unstaged file.
Command: git reset HEAD filename.
To make the Modified file to Unmodified file.
Command: git checkout filename.

20
WORKING WITH REMOTES
To push our code to the remote server.
Command: git push origin branchname
To pull the code from the remote server
Command : git pull
To get the newly created branches in our local repository
Command :git push

21
BRANCHING
To create a branch in local repository
Command :git checkout -b branchname
To delete a branch in local repository
Command :git branch -d branchname
Merge:
Command : git merge branch name
git checkout devel //Switch to devel branch in local repository
git pull//pull the latest code of devel from remote repository
Git merge hotfix//Merge the hotfix branch into devel branch
git push origin devel//merge devel branch is pushed to remote repository
22
.gitignore FILE

● Specifies files that you don’t want Git to track under version control
● Commonly used for compiled files, binaries, large asset files (e.g. images)
● Can use wildcards (e.g. *.pyc, *.png, Images/*, etc.)
● Be careful – if you add a file to .gitignore after it’s already been tracked,
potential issues
● A list of recommended .gitignore files: https://github.com/github/gitignore.

23
GITHUB
GitHub is a collaboration platform built on top of a distributed version control
system called Git. One does not have to worry about losing data on his hard
drive or managing a project across multiple computers - one can sync from
anywhere. You can track issues, build & test the things and finally deploy.
Why Use of GitHub for Projects?
Version Control (Allows experiments and mistakes without messing up in final
product)
Keep your Code in One Place
Great Collaboration Platform
Git, GitHub, GitHub.com, GitHub Desktop,

24
CREATE A REPOSITORY
A repository is usually used to organize a single project. Repositories can
contain folders and files, images, videos, spreadsheets, and data sets – anything
your project needs. We recommend including a README, or a file with
information about your project. GitHub makes it easy to add one at the same
time you create your new repository. It also offers other common options such as a
license file.

25
TO CREATE A NEW REPOSITORY

1. In the upper right corner, next to your avatar or identicon, click and then
select New repository.
2. Name your repository hello-world.
3. Write a short description.
4. Select Initialize this repository with a README.

26
STEP 2: CREATE A BRANCH

Branching is the way to work on different versions of a repository at one time.

This diagram shows:

● The main branch


● A new branch called feature (because we’re doing ‘feature work’ on this branch)
● The journey that feature takes before it’s merged into main

27
CREATE A NEW BRANCH

1. Go to your new repository


hello-world.
2. Click the drop down at the top of the
file list that says branch: main.
3. Type a branch name, readme-edits,
into the new branch text box.
4. Select the blue Create branch box or
hit “Enter” on your keyboard.

28
STEP 3:MAKE AND COMMIT CHANGES
1. Click the README.md file.
2. Click the pencil icon in the upper right corner of the file view to edit.
3. In the editor, write a bit about yourself.
4. Write a commit message that describes your changes.
5. Click Commit changes button.

29
STEP 4: OPEN A PULL REQUEST
STEPS SCREENSHOT

Click the Pull Request tab, then from


the Pull Request page, click the green
New pull request button.

In the Example Comparisons box,


select the branch you made,
readme-edits, to compare with main
(the original).

30
OPEN A PULL REQUEST
STEPS SCREENSHOTS

Look over your changes in the diffs on


the Compare page, make sure they’re
what you want to submit.

31
OPEN A PULL REQUEST
STEPS SCREENSHOTS

When you’re satisfied that these


are the changes you want to
submit, click the big green Create
Pull Request button.

32
OPEN A PULL REQUEST

STEPS SCREENSHOTS

Give your pull request a title and


write a brief description of your
changes.

33
STEP 5 :MERGE YOUR PULL REQUESTS
In this final step, it’s time to bring your changes together – merging your
readme-edits branch into the main branch.
● Click the green Merge pull request button to merge the changes into main.
● Click Confirm merge.
● Go ahead and delete the branch, since its changes have been incorporated,
with the Delete branch button in the purple box.

34

You might also like