GIT & GITHUB
l . What is a Source Code Management
Source code management (SCM) is used to track modifications to a source code repository. SCM tracks a running history of changes to a code base and helps resolve conflicts when merging updates from multiple contributors.
SCM brought version control safeguards to prevent loss of work due to conflict overwriting. These safeguards work by tracking changes from each developer and identifying areas of conflict and preventing overwrites. SCM will then communicate these points of conflict back to the developers so that they can safely review and address them. SCM is also synonymous with Version control.
2. What is Git
GIT means a content tracker mostly used to store code. This code which is stored in Git keeps changing as more code is added. As a Version Control System, GIT helps in handling this by maintaining a history of what changes have happened. This code can either be in a remote repository which is stored in a server or a local repository which is stored in the computer of each developer.
WHY GIT
Real-life projects generally have multiple developers working in parallel. So a version control system like Git is needed to ensure there are no code conflicts between the developers.
3. What is GitHub
GitHub is a web-based hosting service for Git repositories. It offers all of Git’s DVCS SCM and has some additional features. This includes collaboration functionality like project management, support ticket management, and bug tracking. With GitHub, developers can share their repositories, access other developers’ repositories, and store remote copies of repositories to serve as backups.
4. What is the difference between Git and GitHub
Git is a single computer and GitHub is a network of multiple interconnected computers, all with the same end goal but a wildly different roles for how to get there.
Git is installed locally on a system, so developers can manage their source code history using their local machines as repositories, GitHub, meanwhile, lives in the cloud, so Internet access is required.
5. How to create a repository
First, what is a Repository? A repository is a folder/place where your project is kept.
How to create a Repository:
On your computer, create a folder for your project. Let’s call the project folder
demo-repo-git
Go into your project folder and add a local Git repository to the project using the following commands:
cd demo-repo-git
git init
The git init command adds a local Git repository to the project.
To add the ‘README’ file
demo-repo-git:(master) git add README.md
“add” is a git command that helps to track and stage files to be committed.
6. What is a README
A Readme file is often the first file that the users read. It is a text file that contains information for the user about the software, project, code, or game, or it might contain instructions, help, or details about the patches or updates.
How to write good READMEs
When writing a Readme file, the main focus is it should be brief but also contain all the information needed. In addition, it should have clarity, be up to date, brief and clear, detailed and self-explanatory.
7. How to commit
Now that your staging area is set up the way you want it, you can commit your changes. Remember that anything that is still unstaged — any files you have created or modified that you haven’t run git add since you edited them — won’t go into your commit. Commit here means a process in which the code is added to the local repository.
They will stay as modified files on your disk. In this case, let’s say that the last time you ran git status, you saw that everything was staged, so you’re ready to commit your changes.
Use the following command for staging the file:
git add filename
If you want to add all the files inside your project folder to the staging area, use the following command:
git add.
The simplest way to commit is to type
git commit -m "Initial Commit"
-m is a command to add a commit message, while “Initial Commit” is the commit message here. Enter a relevant commit message to indicate what code changes were done in that particular commit.
8. How to push code
GIT push pushes the code from the master branch in the local repository to the master branch in the remote repository.
To push your code to the remote repository, first, you have to create a connection between the local and the remote repository. To do that use the GITHUB as an example:
1. On GitHub create a new repository
2. Copy the clone SSH key and paste into the local machine.
Demo-repo-git:(master) git remote add origin (paste the clone SSH key)
After that, you can now push
demo-repo-git:(master) git push origin master
Or demo-repo-git:(master) git push -u
The command -u creates a tracking reference for every branch that you successfully push onto the remote repository.
Recommended by LinkedIn
9. How to pull updates
git pull is used to pull the latest changes from the remote repository into the local repository. Opposite of Push.
What is Pull Request?
Pull requests let you tell others about changes you've pushed to a branch in a repository on GitHub. Once a pull request is opened, you can discuss and review the potential changes with collaborators and add follow-up commits before your changes are merged into the base branch.
git pull origin master
10. How to create a branch
A branch in Git is simply a lightweight movable pointer to one of these commits. The default branch name in Git is master. As you start making commits, you’re given a master branch that points to the last commit you made. Every time you commit, the master branch pointer moves forward automatically. The “master” branch in Git is not a special branch. It is exactly like any other branch. The only reason nearly every repository has one is that the git init command creates it by default and most people don’t bother to change it.
To create a new branch:
git branch test
To switch to the test branch use the following command:
git checkout test
You can list out all the branches locally using the following command:
git branch
Do Some Commits in the New Branch
Modify demo.txt by adding the following command:
Initial Content Adding more Content Adding some Content from the test branch
Now stage and commit using the following commands:
git add demo.txt git commit -m "Test Branch Commit"
This commit was done in the Test Branch, and now Test Branch is ahead of Master Branch by 1 commit — as the test branch also includes the 2 commits from the master branch.
You can verify the commit history in Project Branch using:
git log
10. How to merge branches
Assuming the Project Branch is ahead of the Master by 1 commit. Let’s say that now we want all the code in the Test Branch to be brought back to the Master Branch. This is where git merge is very useful.
To merge the code from the test branch into the master branch, follow these steps:
First, go back to the master branch:
git checkout master
Then run the merge command:
git merge test
After running these 2 commands, the merge should be successful. In this example, there are no conflicts.
But in real projects, there will be conflicts when a merge is being done. Resolving the conflict is something that comes with experience, so as you work more with Git you will be able to get the hang of resolving conflicts.
Run the git log now and you will notice that the master also has 3 commits.
11. How to work as collaborators on a project
Each developer will work in their local repository but eventually, they will push the code into a remote repository. Once the code is in the remote repository, other developers can see and modify that code.
On GitHub apply the push request
git push -u origin
12. Which files should and which files should not appear in your repo
You should not commit these two types of files into your Git repository.
1. Files that don’t belong to the project
2. Files that are automatically generated.
The README, LICENSE, and gitignore are recommended to be in the repository.
Thank You
Thank you for going through this article. I hope you find it helpful and useful and insightful. Your feedback will be highly appreciated!
I will soon be publishing more articles on Tech Space. Stay tuned!
About the author
I love technology. I am a student at Females In Tech Organization . I will be sharing my tech journey here. Please follow and connect with me on my social media handles: