How to Collaborate Using Git:
Clone this remote repository to your local folder. <directory>
is optional, indicating the local folder that you want to clone to.
git clone https://github.com/derek1909/GG3G3.git <directory>
When you want to work on the project (e.g. task 1.1), create a new branch so that your changes won't affect the main branch before rebase
.
git checkout -b <my-branch>
Or
git switch -C <my-branch>
First, check the difference between what git has stored and what's on your disk. These are the changes you have made.
git diff
Then, save your changes to your local git and in your new branch.
git add <changed_files>
git commit -m "what you have done"
This will add a new branch <my-branch>
in the remote repository and push your local commits.
git push origin <my-branch>
When you develop a feature in a separate branch, other people might update the main branch with their changes (commits). This means your feature branch might be based on an outdated version of the main branch. Rebase helps you solve this problem. It moves or "rebases" your entire feature branch to begin on the tip of the main branch, effectively incorporating all the new commits from the main branch.
First, you need to fetch the latest changes of the main branch. In your local repository, you can switch to the main branch and use the pull
command to fetch the latest changes.
git checkout main
git pull origin main
Then, you can switch back to your working branch and use the rebase
command to base your changes on top of the latest changes of the main branch.
git checkout <my-branch>
git rebase main
If conflicts occur during the rebase
, Git will pause the rebase
and allow you to resolve the conflicts. You can open the conflicting files in an editor, manually resolve the conflicts, then add the resolved files to the staging area.
git add filename
git rebase --continue
If you want to abandon the rebase
, you can use the git rebase --abort
command.
Once the rebase
is complete, you can push your changes to the remote repository. Since rebase
changes the commit history, you need to use the -f
or --force
option to force the push.
git push origin <my-branch> -f
After this, you can create a pull request on GitHub to request that your branch be merged into the main branch (I will do the merge as soon as possible). Remember, using rebase
can make the commit history cleaner, but it also makes the history of the changes more linear, which might not always be desirable depending on the project's needs.
(To be continued...)