data:image/s3,"s3://crabby-images/5a5b6/5a5b619b8dbd6e4e573d710afb772e5e8e9abfac" alt="image.png"
- Go to a open source project of your interest and press the fork button
data:image/s3,"s3://crabby-images/f555f/f555f79e1559958441faa3289c2e636d709ccb7f" alt="image.png"
data:image/s3,"s3://crabby-images/8c257/8c25755bb15dd99c88aaae8a4955c7fe15e7ea3a" alt="image.png"
- Press Code button and copy the url
data:image/s3,"s3://crabby-images/e3d9f/e3d9f0cc17292ddef1290bca0163a79745f60d8c" alt="image.png"
- Now go to your IDE. Here I will use VS Code
git clone "copied url"
data:image/s3,"s3://crabby-images/27169/27169fdcf217c37a6cc3231499268df9cde0aaf5" alt="image.png"
- We can see that everything is cloned into the local repository
data:image/s3,"s3://crabby-images/a065e/a065e70267273ceb41f292ba7c90451742a67746" alt="image.png"
How to update my local repository
- if other open source contributors make changes, then I will need to update my local repository
- Otherwise there will be a conflict when I ask for pull request
data:image/s3,"s3://crabby-images/448ad/448ad8baa112faa43f6c24f267eb456d48e308f9" alt="step-2-1-conflict.png"
- Go to the original project repository and copy the project url
data:image/s3,"s3://crabby-images/5358c/5358c4746687af15c6a1503f3ae8be62ce18a713" alt="image.png"
- Now go to your IDE terminal and type this
git remote add upstream "original project repository url"
# git remote -v shows remote repositories connected to your local repositories
git remote -v
- So it seems like original repository url is already there
- Now we can bring any recent changes made by other contributors
# bring latest updates from 'upstream'
git fetch upstream
# go to the branch you want to update
git checkout master
# merge the latest update and my changes
# git merge remote repository/my branch name
git merge upstream/master
# update my local repository
git push origin master
data:image/s3,"s3://crabby-images/11fbf/11fbf51e6912e9d38257128be3bbcaf24dfe60d5" alt="image.png"
Make a branch and Contribute
- instead of using master or main branch, it's better to make a branch to show what issue you are trying to solve
git checkout -b "branch name"
git branch "branch name"
git checkout "branch name"
data:image/s3,"s3://crabby-images/a122d/a122d6898d8362dee5bd42459291d57547ec4188" alt="image.png"
- Commit and push your changes
git add
git commit -m "Add visual studio code for code editor"
git push
data:image/s3,"s3://crabby-images/d592d/d592dbf7fb3b07ceaa54499a15d182d32822f31e" alt="image.png"
data:image/s3,"s3://crabby-images/58d56/58d5621630379aaf700b2d080aed49872bc2cce4" alt="image.png"
data:image/s3,"s3://crabby-images/ff9dc/ff9dce2a04f570add06ffb189541be8943511a52" alt="image.png"
data:image/s3,"s3://crabby-images/85b34/85b34aeed70eac0ce77e6971410bb2a8b4447019" alt="image.png"
- Press Create pull request button and it's all done!
data:image/s3,"s3://crabby-images/74c00/74c00e3ca8e1e2c3e75c7e4cd69debc3e3ec5d23" alt="image.png"
- All you have to do is wait to see if your pull request is approved