You are not Logged In! |
Difference between revisions of "Public:GitHub"
m (→FW (Firmware): clarifying which repos get cloned) |
|||
Line 5: | Line 5: | ||
| Text = This page is about the set-up and workflow we use on Github. Other pages are used for how git is used with certain software such as [[KiCad]] or [[MCUXpresso]]. Additionally, it does not include info about github management, teams, and projects as used by Illini Solar Car, which is at [[GitHub Projects|GitHub Projects]] | | Text = This page is about the set-up and workflow we use on Github. Other pages are used for how git is used with certain software such as [[KiCad]] or [[MCUXpresso]]. Additionally, it does not include info about github management, teams, and projects as used by Illini Solar Car, which is at [[GitHub Projects|GitHub Projects]] | ||
}} | }} | ||
+ | |||
+ | GitHub is a website for hosting and working with [[Wikipedia:Git|Git]] repositories. Git is a distributed version control system for text based files (primarily software) created by the Linux Kernel development team. Unlike most version control systems, it is distributed which means that every single person has the full fledged repository on their machine and thus there is no single point of failure. For collaboration there need to be one copy of the repository that is the origin that is accessible to everyone. For us, that is on GitHub. | ||
+ | |||
+ | GitHub adds many features on top of just git, including issue tracking and [[GitHub Projects|projects]], [[Wikipedia:Continuous integration|Continuous Integration]] including [[GitHub Actions]], Releases, and more. Below you'll find info for general use of git and links to pages for specific instructions for each of our repos. | ||
+ | |||
+ | == ISC GitHub Repos == | ||
+ | {{Subpages}} | ||
Illini Solar Car has several git repositories within our organization [https://github.com/illinisolarcar|organization on GitHub]. You must talk with an [[Electrical Group Structure|Electrical Lead]] or Strategy & Telemetry Lead so they can give you access to our private repositories. In general, many people use git via the command line. We use it almost exclusively, and you should learn it in order to git (haha) on the same page as everyone else. On most Linux distros this is included in command line. On Mac and Windows you can [https://git-scm.com/downloads| download git]. When "Adjusting your PATH environment," I recommend selecting "Use Git from Git Bash" and not using git in the Windows Command Prompt. When "Configuring the line ending conversions" please use the settings recommended for your operating system unless you know what you are doing. | Illini Solar Car has several git repositories within our organization [https://github.com/illinisolarcar|organization on GitHub]. You must talk with an [[Electrical Group Structure|Electrical Lead]] or Strategy & Telemetry Lead so they can give you access to our private repositories. In general, many people use git via the command line. We use it almost exclusively, and you should learn it in order to git (haha) on the same page as everyone else. On most Linux distros this is included in command line. On Mac and Windows you can [https://git-scm.com/downloads| download git]. When "Adjusting your PATH environment," I recommend selecting "Use Git from Git Bash" and not using git in the Windows Command Prompt. When "Configuring the line ending conversions" please use the settings recommended for your operating system unless you know what you are doing. | ||
If you're new to Github they're many resources on the internet to learn more about it. Watching some youtube videos on the basics and trying it out by creating your own repository is a great way to get started. | If you're new to Github they're many resources on the internet to learn more about it. Watching some youtube videos on the basics and trying it out by creating your own repository is a great way to get started. | ||
+ | |||
+ | == Installing Git == | ||
= General Guidelines= | = General Guidelines= | ||
Line 60: | Line 69: | ||
* [https://www.lynda.com/Git-tutorials/Git-Essential-Training/100222-2.html Lynda.com tutorial] | * [https://www.lynda.com/Git-tutorials/Git-Essential-Training/100222-2.html Lynda.com tutorial] | ||
* [https://hkn.illinois.edu/assets/presentations/git.pdf Git Presentation by Dave Boutcher of Ocient] | * [https://hkn.illinois.edu/assets/presentations/git.pdf Git Presentation by Dave Boutcher of Ocient] | ||
+ | {{Platforms Navbox|collapsed=}} |
Revision as of 22:17, 19 November 2020
This Page is a Work In Progress | |
Moving to subpages, getting rid of tabs, adding info for the other Repos. This page will turn into generally using github - Jonathan |
Note | |
This page is about the set-up and workflow we use on Github. Other pages are used for how git is used with certain software such as KiCad or MCUXpresso. Additionally, it does not include info about github management, teams, and projects as used by Illini Solar Car, which is at GitHub Projects |
GitHub is a website for hosting and working with Git repositories. Git is a distributed version control system for text based files (primarily software) created by the Linux Kernel development team. Unlike most version control systems, it is distributed which means that every single person has the full fledged repository on their machine and thus there is no single point of failure. For collaboration there need to be one copy of the repository that is the origin that is accessible to everyone. For us, that is on GitHub.
GitHub adds many features on top of just git, including issue tracking and projects, Continuous Integration including GitHub Actions, Releases, and more. Below you'll find info for general use of git and links to pages for specific instructions for each of our repos.
ISC GitHub Repos
Illini Solar Car has several git repositories within our organization on GitHub. You must talk with an Electrical Lead or Strategy & Telemetry Lead so they can give you access to our private repositories. In general, many people use git via the command line. We use it almost exclusively, and you should learn it in order to git (haha) on the same page as everyone else. On most Linux distros this is included in command line. On Mac and Windows you can download git. When "Adjusting your PATH environment," I recommend selecting "Use Git from Git Bash" and not using git in the Windows Command Prompt. When "Configuring the line ending conversions" please use the settings recommended for your operating system unless you know what you are doing.
If you're new to Github they're many resources on the internet to learn more about it. Watching some youtube videos on the basics and trying it out by creating your own repository is a great way to get started.
Installing Git
General Guidelines
- Make your commit messages useful
- Pull often!
- Commit often (but not too often)
- If you aren't sure what you are doing ask for help!
- If you think you broke something talk to someone right away!
- It essentially always fixable but we want to do so quickly so others don't run into problems
Info on how to use git by group:
FW (Firmware)
See repositories to clone: GitHub/b-fw
and GitHub/ARGO-FW
and info on submoduled repositories: GitHub/mbed
and GitHub/CAN
See GitHub/Telemetry
Tutorials
Git is a super useful tool that is becoming ubiquitous with CS / ECE and more engineering fields. It is used for all sorts of things (not just code) . Version control is incredibly powerful, but because of that it can be hard to learn. Below are some recommended tutorials. Of course, as git was made for code, there is tons of info on the internet. Being good with git will be very helpful within jobs and academics.
- ISC Git Cheatsheet
- ISC Git Presentation on Drive
- Another Git Cheatsheet
- Git manual
- Another good Git reference
- Github video guides
- Interactive intro to git
- Git branching tutorial
- Git merge conflict resolution
- Lynda.com tutorial
- Git Presentation by Dave Boutcher of Ocient
| |||||||||||||||