The following outlines how we can use Git/GitHub to streamline the firmware development process. We first have step-by-step instructions on how to use GitHub issues to your advantage, and then we have Git commands, which are to be used in either GitBash or Terminal.
ChatGPT says: "GitHub issues are a feature of the GitHub platform that allows users to track tasks, enhancements, bugs, or any other kind of item related to a repository. They serve as a centralized communication and coordination tool for managing project tasks and discussions among team members or contributors."
Here are the steps you and your team can take to use issues effectively:
- Create an issue which describes the task that needs to be done
- Create a new branch attached to the issue
- Complete the task in the new branch
- Open a pull request and add a reviewer (usually the person who made the issue, or your lead)
- Reviewer makes change requests (if they have any)
- Address the request in the same branch
- Request another review and repeat steps 5-7 as necessary
- Once approved by the reviewer, the pull request can be merged with the main branch. This is done on the GitHub website, simply navigate to the issue and follow the steps to merge the pull request. You may have to update the branch with main and resolve conflicts if recent changes have been made. The issue linked to the pull request will then close, and the branch will be automatically deleted. Good work!
git clone repo_url
cd repo_name
(cd stands for change directory - this takes you into the repo)
Note that for us, repo_url is https://github.com/UBCSailbot/com-module-firmware.git and repo_name is com-module-firmware. You always have to run these first two commands the first time you open GitBash or Terminal.
git fetch
(Updates your local repository with any changes made in the remote repository)
git pull
(Performs what git fetch
does, and then merges those changes with your current branch)
git add -A
(The -A adds all the changed files in the project)
OR
git add file_name
git commit -m message
(Replace "message" with a description of the changes made. Make sure to commit often to avoid unintentionally losing changes!)git push
(If you are pushing a new branch for the first time use the command listed under the Dealing with Branches section)
git branch
(Lists all local and remote branches)git branch branch_name
(Creates a new branch)git checkout branch_name
(Switches you to the specified branch)git checkout -B branch_name
(Creates a new branch AND switches you to it)git branch -d branch_name
(Deletes the specified branch)git push -u origin branch_name
(The new branch will first be on your local machine, and will show up on the GitHub repo once you run this command. In subsequent pushes you can simply usegit push
as listed under the Pushing to Repository section)
git status
(Lets you see which changes have been staged, which haven't, and which files aren't being tracked by Git)git log
(Lets you see commit history)