Git Basics
Telerik Academy Alpha
Table of contents
What is Version Control
Version Control System
-
Version control is a system that records changes to a file or set of files over time so that you can recall specific versions later
-
Allows you to revert files back to a previous state
-
Revert the entire project back to a previous state
-
Compare changes over time
-
See who last modified something that might be causing a problem
Local Version Control
-
Local VCSs that had a simple database that kept all the changes to files under revision control
Centralized Version Control
-
Single server that contains all the versioned files, and a number of clients that check out files from that central place
-
CVS
-
TFS
-
Subversion
-
Distributed Version Control
-
Clients don’t just check out the latest snapshot of the files: they fully mirror the repository
Git
Mercurial
Bazaar
What is Git
Git
-
The most widely used modern version control system in the world
-
originally developed in 2005 by Linus Torvalds (creator of Linux)
-
-
Every developer has a working copy of the code
-
repository that can contain the full history of all changes
-
-
Performance, security and flexibility in mind
1. PROS
Git
-
It could be difficult to learn for newcomers, especially coming from SVN
-
Many commands with many options
-
Some commands are non-intuitive and need a level of understanding the internals of git
2. CONS
Git branches
-
Feature branches
- Git branches are cheap and easy to merge
- Provide an isolated environment for every change
- Branches ensures that the master branch always contains production-quality code
Distributed development
-
Each developer gets their own local repository
- complete with a full history of commits
- Distributed development creates a more reliable environment
- In case of an error in central repository everybody can continue going about their business in their own local repositories
Pull request
-
A pull request is a way to ask another developer to merge one of your branches into their repository
- Makes it easier for to keep track of changes
- Lets developers initiate discussions around their work before integrating it with the rest of the codebase
Git Install
Git Install
- Install Git for your platform
-
Follow the instructions and setup Git
-
Use the default options for now
-
Use the default options for now
-
Git will be added in your PATH
- Git Bash will be installed for you
Check for Git installed
-
Open the command prompt or Git Bash
- type "git --version"
- This will ensure you have Git installed on your system
- Now you are ready to begin using Git
Basic Git Commands
Configure Git
-
git config --global user.name "[name]"
-
Sets the user name for all commits
-
Sets the user name for all commits
-
git config --global user.email "[email address]"
- Sets the email for all commits
Create/Clone repository
-
git init [project name]
-
Creates new repository with specified name
-
Creates new repository with specified name
-
git clone [repository url]
- Downloads the specified repository
Make/Check local changes
-
git status
-
Lists all the changes which will be commited
-
Lists all the changes which will be commited
- git add [file]
-
git add .
- Prepare the content staged for the next commit
- Prepare the content staged for the next commit
-
git commit -m "Some message "
- Stores the current contents in a new commit
Synchronize changes
-
git fetch [bookmark]
-
Download objects and refs from another repository
-
Download objects and refs from another repository
-
git merge [bookmark]/[branch]
- Join two or more development histories together
Synchronize changes
-
git push [alias] [branch]
-
Update remote refs along with associated objects
-
Update remote refs along with associated objects
-
git pull
-
Fetch from and integrate with another repository
-
GUI for Git
GUI for Git
- You are free to choose any of these
Questions?
[Git] Git Basics
By telerikacademy
[Git] Git Basics
- 1,523