<style>
summary {
font-weight: bolder;
}
summary:hover {
text-decoration: underline;
}
</style>
# **CS200 GitHub Guide**
We use GitHub and git to give you access to project code, to allow you to save your work online so you can access it from anywhere, and to facilitate collaboration on partnered work. In CS200, we will be expecting you to access git through the terminal/command line and through GitHub. GitHub does have a companion app, but we do not recommend you use it and will not be able to support you in making it function.
# **What is GitHub?**
GitHub is a code-hosting platform that is used by many programmers to save their code and access it from any machine. Think of it like “the cloud” but for code projects! This guide is your go-to resource for help with GitHub/git setup as well as git commands you should know in order to interact with GitHub from your local machine.
# **Making an Account**
First, you’re going to need a GitHub account which will be an invaluable resource to you for the rest of your computer science career (both at Brown and beyond). To create an account:
1. Go to [www.github.com](http://www.github.com/)
2. Select “Sign up” in the upper right corner
3. Follow the steps on the website to get your account all set up :)
# **Installing Git**
Thankfully, installing git on your computer is super easy! First, we need check if you already have git installed on your computer. To do this, we'll need to use a terminal, which is how you'll primarily interact with git. If you haven't used a terminal much before, that's okay! You'll gradually learn more in this course and others, starting now!
To open a terminal and check if git is installed:
1. First, open the terminal on your computer:
1. **On Mac**: Go to **Applications** > **_Utilities_** > open **Terminal**
- (Alternatively, you can open _Spotlight Search_ (keyboard shortcut is “Command+Space’’), search for “terminal”, and open the first application listed)
2. **On Windows**: Open the Search bar, enter “command prompt”, and click the first application listed
2. Enter the command `git --version` and press Enter
If you already have git installed, your terminal should print the version you have (the version you have shouldn’t matter, as long as you have it installed). You can ignore the rest of this section and skip to [Configuring git](#Configuring-git-settings).
If get some error like "command not found", you need to install `git`. To do this, expand the instructions below:
<details><summary><b>Instructions for MacOS (click to expand)</b></summary>
1. **In your terminal, enter the command `xcode-select --install`** <br />This will download a set of recommended development tools from Apple, including git. If you want to install git another way, look [here](https://git-scm.com/download/mac).
2. **Follow the prompts to finish the installation.** The process may take several minutes.
3. **Verify you have Git installed** by running `git --version` in your terminal again. You may need to quit and reopen your terminal for this to work.
</details>
<details><summary><b>Instructions for Windows (click to expand)</b></summary>
1. **Go to [this page](https://git-scm.com/download/win)**. This should prompt an automatic download of git, but if not, click the link to manually download git.
2. **Open the .exe file** you downloaded and click next through each of the installation pages--**there is no need to adjust any settings, all the defaults are fine**.
3. **Verify you have Git installed** by running `git --version` in your command prompt again. You might need to quit and reopen your the command prompt window for this to work.
</details>
# Configuring git settings
Next, we need to to connect git on your computer to your GitHub account. To do this:
1. In your terminal, **enter the command `git config --global user.email "<email>"`**, where `<email>` is replaced with the email you used to make your GitHub account (don’t forget the quotes!).
2. **Enter the command `git config --global user.name "<name>"`** where `<name>` is replaced with your username (don’t forget the quotes!).
When you enter each command, you shouldn't see anything print in your terminal--this is expected. Git is configuring itself behind the scenes! (Often, terminal programs don't print anything when they run successfully--many only print a message when something goes wrong.)
:::info
**Documentation tip**: A common convention for software (which we will follow in CS200) is to write commands like this:
```
some_command_here <parameter>
```
The `<angle brackets>` indicate that `parameter` is a *placeholder* for you to fill in--the documentation will tell you what to put there. When you fill in the placeholder, **don't include the angle brackets**--they are just notation to tell you it's a placeholder when reading. So, if you were supposed to write "`cabbage`" for `parameter`, you'd type in:
```
some_command_here cabbage
```
Keep this in mind as you read this and other documentation!
:::
# Creating your Github access token
When you use `git` to connect to Github, you need to provide credentials to Github to prove you are the user you claim to be. To do this, you can create a Personal Access Token--this is similar to a password, but more commonly used when a program (eg. `git`) is logging in on your behalf (rather than asking you to type a password).
**Note:** If you had a GitHub account before, you may have used a password-based authentication. This is no longer supported, so you also need to follow the steps below!
To create your github Personal Access Token, do the following:
1. Open [your github profile settings](https://github.com/settings/profile) by clicking on your profile icon in the top-right. Then, click **Settings**, like this:
![](https://docs.cs200.io/uploads/ddf9fb89-f5d3-4ada-a3aa-358adab08af9.png =180x)
2. In the page that opens, scroll down to the very bottom left and click on **Developer Settings**, which looks like this:
![](https://docs.cs200.io/uploads/0355dce8-8b0c-4452-845d-3655486abd4d.png =500x)
3. In the Developer Settings page, look at the sidebar on the left and click on **Personal Access Tokens** > **Tokens (classic)**, like in the red box below:
![](https://docs.cs200.io/uploads/63a008d8-9b14-456a-b235-2018bdfeab6a.png)
4. After clicking on **Token (classic)**, you should see the following screen. Click on **Generate new token** > **Generate new token (classic)**. <u>Be sure to pick the **classic** token!</u>
![](https://docs.cs200.io/uploads/ee7f7840-0762-4774-a76e-6c2b5e7ce1c7.png)
5. Then, you should see a window that looks like the image below. Make sure to fill in all of the following options as shown in the image:
- **Name**: This is the name of your token--you can name it whatever you want (eg. "cs200").
- **Expiration**: Select "**No expiration**". You can ignore the warning from Github.
- **Select scopes**: Select the "**repo** option. This will check several other boxes under "repo".
![](https://docs.cs200.io/uploads/1f82130e-d3b1-4b3c-b49c-3dfe6e444972.png)
<!-- ![](https://docs.cs200.io/uploads/0e7751bc-9507-4535-831d-28d621de6f85.png =500x)
-->
7. Take a moment to **double-check that you have filled in all the settings** as on the figure, then click **Generate Token**.
After you generate your token, you should see a page like this:
![](https://docs.cs200.io/uploads/1eb934fa-ae14-4b1c-b1cb-d16de7e686b1.png)
<!--
![](https://docs.cs200.io/uploads/fa5e4746-2c4c-441f-9d6d-b8552bf5784f.png)
-->
9. Your token is a super-secret value like a password--you'll enter it when cloning repositories. **Copy this token** and save it somewhere safe so you can access it later.
<!-- After your token has been created copy and paste this token into your Password whenever you are trying to clone. You won't see the token pop up because the Password doesn't show up in your terminal, but just press enter after you paste your token and then you should be able to clone.
-->
10. One final step: we can configure `git` to remember your token the first time you clone a repo (you'll do this later), that way you hopefully won't need to enter it more than once. To do this, **enter the following in your terminal**:
```
git config --global credential.helper store
```
Once again, this command won't produce any output.
Great job! :tada: You should be all set for authenticating your Github account for this class. Now you're ready to clone repositories!
If you're reading this guide for the first time (eg. HW0), take a look at the terminology in the next section, then go back to HW0 to continue with your IDE setup. You'll use `git` again to before you start running code! :sunglasses:
<!--
Every time you try to clone / push to GitHub it will ask for your password, but what it’s actually looking for is your access token. This gets really annoying. We’d recommend configuring your computer to do this automatically.
:::warning
**Important:** you can save yourself a lot of future pain by configuring your `git` to save your access token so you don't need to enter it every time. To do this, enter the following in your terminal:
```
git config --global user.password "<access token>"`
```
where `<access token>` is replaced by the access token you just created (**without the `<>` brackets**)
The first time you clone an assignment after following these steps you may be prompted for your GitHub username and password (this will be your personal access token). Please enter these and you should be all set!
::: -->
# **Git terminology**
Before you start using git, here is some important GitHub terminology you should familiarize yourself with:
- **Repository** → a GitHub repository – or repo for short – is what a project on GitHub is called. Each time you accept an assignment for CS0200 by clicking on the assignment link, GitHub will create a repository for you for that project.
- **Commit** → The cool thing about GitHub is that it can keep track of all of the versions of your project as you edit them. Each project “version” is called a commit. It is basically a snapshot of your project at a moment in time, and it is up to you to create commits when you reach points in your project that you do not want to lose. (Your project will be saved on your local machine, but in order to save a snapshot on your GitHub, you must create a commit and push it to your GitHub). It is good practice to create commits regularly so if something gets messed up while you are coding, you will have old versions to look back at stored on your GitHub repository.
The next few sections describe some common tasks you'll do using `git`--the other course documentation will tell you when you need these, but remember that they're here in case you need them.
:::info
<h2 style="margin-top:0.2em; padding-top:0;"> More git resources</h2>
For more info about git, we recommend checking out the following links:
- **[Git - The Simple Guide](https://rogerdudler.github.io/git-guide/)**: a quick and dirty introduction
- **[Harvard CS61 intro to git](https://cs61.seas.harvard.edu/site/ref/git/)**: a nice pictoral reference
- **[Git handbook](https://guides.github.com/introduction/git-handbook/)**: an in-depth introduction
:::
# Common git tasks
This section outlines some common tasks for working with git. As you work on other assignments, we'll refer you to these sections as you need them:
- **[How to clone a git repository?](#Cloning-a-git-repository)**: you'll do this once for every project
- **[How to push your code to Github?](#How-do-I-push-my-code-to-Github)**: you can do this to save your work on Github, and to collaborate with others on the partner projects
- [How to create a Personal Authentication Token?](#Creating-your-Github-access-token): you've already done this, but look here if you need to create another token
## Cloning a git repository
Cloning a repository is how you download code to your computer. Depending on the assignment, there are two ways we might give you code to run, which changes how you will clone it:
- For **Homework/Project/Lab stencils**, we will give you a **Github Classroom link** (eg. `https://classroom.github.com/<something>`). To use these, see [**Accepting Github Classroom Assignments**](#Accepting-an-Assignment-on-GitHub-Classroom)
- For **HW0, lecture code, or other examples**, we will directly provide a direct **Github Repository URL** (`eg. https://github.com/<something>`). To use these, see **[Cloning from a Repository URL](#Cloning-a-repository-by-URL)**.
## **Accepting an Assignment on GitHub Classroom**
Github Classroom links allow us to set up a unique repository to hold your code for an assignment or project. To use it:
1. Accept the assignment on GitHub Classroom by following the link on the handout and clicking the **“Accept this assignment”** green button, which should look like this:
![](https://lh5.googleusercontent.com/e24ijbtm6ilPvpqJnpkoJGXgQI8TwViXnpfUrzTH8RhywgirOpXk3ldUTGK9DVHPYP8cTMzn9-xIEWzQk_IX13zajCslO92kgIpWIyl2INQ7qjNrMJqcfJZr3s1hVhJwFp6lR7rKn9ZGIuYtEDrKtNs)
2. Github will now create your repo–wait a few seconds and refresh the page. When it’s done, you should see a link to your shiny new Github repository (like the example below), **click this link to view it!**
![](https://lh5.googleusercontent.com/HIdc97on6mWkEUPnnEZOKuVHfwcoUtWs2SCD6cLoVt14OKIin8yieLtXG8m_abE4tUuF2qFIqV8gg1tiJPUezq4J6SaqEstrvz23qqtruWM8z4aHb6BvSK2YQGlZoyyWAer4-bQHvv7MYse8d2aeup4)
This link will open the main view of your repository on Github. Next, we need to download (or clone, in git terms) the repository to our system: to do this, see the next section.
## **Cloning a repository by URL**
Once we have a link to a repository, you can download it to your computer by “cloning” the repository into your CS200 folder with git. To do this:
1. If you have not done so already, open the repository link in your browser.
2. On the Github page, click the green **“Code”** button and **click the copy button** to copy the link, like this:
![](https://lh4.googleusercontent.com/_V1M4NA1nN5pkpukIUYq5GkHj5Wgs-u6riNRsIiyP1Ah8bFrmk11XjFgfejS4QkzEusi7ZE5T_v9YPBlmj0hsSmrqptm6l1T9TtM0zAIldIRgHbP9fwv5k1ZgDe1HMF_49XqYVv8IHShmbwU_W0Y2mU)
### **Getting to your CS200 folder**
To clone the repo, we’ll need to use the terminal to browse to your CS200 folder and run git to download the code. If you’re new with using a terminal, that’s okay! Follow the steps below for a step-by-step guide. Even if you’re more comfortable using a terminal, skim all of these instructions to make sure you understand the process–you might learn some useful shortcuts!
1. First, open the terminal on your computer:
1. **On Mac**: Go to **Applications** > **_Utilities_** > open **Terminal**
- (Alternatively, you can open _Spotlight Search_ (keyboard shortcut is “Command+Space’’), search for “terminal”, and open the first application listed)
2. **On Windows**: Open the Search bar, enter “command prompt”, and click the first application listed
:::info
<h4 style="margin-top:0;"> Quick intro to terminals</h4>
Just like when you browse folders in a window on your computer, in a terminal, there’s a concept of a current “working directory”, which is the folder where the terminal is “looking” at one time. The working directory is usually displayed in the terminal’s _prompt_, which is the line where you enter commands.
To see the current working directory, enter the command `pwd`, like this:
![](https://lh6.googleusercontent.com/oJsnBp0QIgjMUPYJ2a9-sxX1E2pfuB8C3lIw8X4ZRQRkQXFfiYHTE7rhFzmjZ1JN-aHCpF9LnNA6JVAWSEAyj4M_OwfQ5CEEpj-LfIkhNjVzlXOZqi-ZuZbJW7pAZ_CH3Ne16e36G_8lLwflef-1sSM =300x)
Here, the working directory is the user `deemer`’s Desktop folder.
Another way to write this is `~/Desktop`, where `~` is shorthand for a user’s home folder.
:::
2. Next, we need to navigate to our CS200 folder in the terminal. There a few ways to do this--use whichever you feel most comfortable:
<details><summary><b><u>Shortcut method (Mac)</u></b></summary>
1. Outside your terminal, open up your CS200 folder in Finder (the standard file/folder browser on Mac)
2. Drag the Finder window onto the Terminal icon on your dock (like the figure below). This should open a terminal already pointing to your CS200 folder! Pretty awesome, right?? 😎
(If this doesn’t work for you, just go with the classic method.)
![](https://lh5.googleusercontent.com/9KCz7A0ARot_kCxpu9LB8soSARcZWWnyUFfnkGiR6uH2dq5SlViBHgmJu2NnewpDrkQEgKNtLEdP4kfa_xHWe3vdG7h1kZ3VwHGyVj8gRc6L-xG4gOL17yiPozJ-pGekzFgCj7hJQtAONFFYrD8g7sM =400x)
</details>
<details><summary><b><u>Shortcut method (Windows)</u></b></summary>
1. Outside your terminal, open up your CS200 folder the way you’d normally search for a file
2. Inside the folder, **hold down Shift and Right Click** in the blank area in the folder view
3. In the menu that opens, click “**Open PowerShell window here**”. (PowerShell is another terminal program inside Windows, similar to command prompt.)
  If this method doesn’t work for you, just try the Classic method.
</details>
<details><summary><b><u>Classic Method</u></b></summary>
1. In your terminal, use the `cd` command to enter into your CS200 folder. The command for this will depend on where your CS200 folder is located on your computer–here’s what it should look like based on the folder locations we’ve recommended, but you can adjust it if you picked a different spot:
- **Mac (CS200 folder on Desktop)**: `cd ~/Desktop/CS200` or
`cd "/Users/your-name-on-mac-here/Desktop/CS200"`
- **Windows (CS200 folder on C: drive)**: `cd C:\CS200`
For more information on using terminal commands, take a look at our [Terminal Guide](https://docs.google.com/document/d/1kZ7AfOhUkZW1zqL7KWfEGuWvuyQZfPTK6x4jvCGFYlY/edit?usp=sharing), which describes `cd` and other commands in more detail.
At this stage, you should now have a terminal open to your CS200 directory! Now we can finally clone the repository.
</details>
### **Cloning the repository with git**
Next, you can download the repository to your computer–in git, this is called “cloning” the repository. To do this:
1. Enter the following command using the [link you copied from Github](#Cloning-a-repository-by-URL). \
 `git clone <pasted link>` (without the “`<>`” brackets)
2. If you are prompted to log in, enter the following:
- **Username**: Enter your **Github** username (*not* your Brown username)
- **Password**: Paste in your **[Github Personal Access Token](#Creating-your-Github-access-token)** (eg. `ghp_XXXX...`). If you don't have one, see [these instructions](#Creating-your-Github-access-token). (**Note: you won't see the password in the terminal as you paste/type it**--this is normal, just paste and press enter.)
After you log in successfully, you should see output something like this:
```
Cloning into '<name of repository>'...
remote: Enumerating objects: 39, done.
remote: Counting objects: 100% (39/39), done.
remote: Compressing objects: 100% (33/33), done.
remote: Total 39 (delta 8), reused 37 (delta 6), pack-reused 0
Receiving objects: 100% (39/39), 372.97 KiB | 6.32 MiB/s, done.
Resolving deltas: 100% (8/8), done.
```
2. If your output looks like this, your repository was cloned successfully, yay! If you see an error saying `Forbidden` or `Access denied`, make sure you are using the Github Access Token you created
Once you have cloned the repository, you should now see a folder in your CS200 with the same name as the repository you cloned. This is where the code lives!
To continue working with the code, you'll need to open the repository--see the stencil setup guides for the language you'll be using:
- For **Java** code, **[look here](https://docs.cs200.io/s/java-stencil-setup-guide#Opening-a-Stencil-in-IntelliJ)** for instructions on opening your code in IntelliJ
- For **Python** code, **[look here](https://docs.cs200.io/s/python-stencil-setup-guide#Opening-a-Stencil-in-VSCode)** for instructions on opening your code in VSCode and setting up your environment
<!--
Accepting assignments through GitHub Classroom can be a confusing process – do not fear, this section is here to help! Following these steps and accepting assignments should be a breeze (but if it’s not, please come to TA hours and we’ll be more than happy to help you troubleshoot).
:::info
**Note: Before the First Assignment**: Create a CS200 folder on your computer. This folder will hold all of your assignments for the rest of the semester. We recommend putting it on your Desktop (Mac) or the C Drive (Windows) for ease of access, but you can put it wherever makes sense for you!
:::
**Follow these steps for every(!) assignment you accept through GitHub Classroom this semester starting on HW1a.**
1. Accept the assignment on GitHub Classroom by following the link on the handout and clicking the “Accept this assignment” green button
2. After a few seconds, refresh the GitHub page, you should see a link labeled “Access your Assignment” – click this link
3. Click the green “Code” button, which will open a dropdown that says “Clone”, then copy the link that is shown.
![](https://lh6.googleusercontent.com/N8d8S6m5u5ius4tY0L8scgEH8wdSwJTpgfo7YoEVH4sWug8KPw5jodMksQoH4oZxakQZITdj01gXafUAh40s8y6wSfByIeXdPhxXeohX50qwYfLR1HIYbPNFHEV-oNGikBl88nVwT_IuSIBNnZHeGN8 =500x)
4. Open up the terminal (Mac) or command prompt (Windows) of your computer
5. Use the cd command to enter into the CS200 folder of your computer. (take a look at our [Terminal Guide](https://docs.google.com/document/d/1kZ7AfOhUkZW1zqL7KWfEGuWvuyQZfPTK6x4jvCGFYlY/edit?usp=sharing) for more info on what cd and other shell commands do) \
_If your CS200 folder is on your Desktop/C Drive, you can cd there as shown below:_ \
`cd ~/Desktop/CS200 or cd /Users/<yourName>/Desktop/CS200`(Mac)`
cd C:\CS200 `(Windows)
6. Now you’ll have to paste the link from before in order to clone the repository locally. You should type `git clone <pasted link>` (without the “`<>`” brackets). For instance, you should see something like this:
`Cloning into '<assignment#-username>'...`
`remote: Enumerating objects: 53, done.`
`remote: Counting objects: 100% (53/53), done.`
`remote: Compressing objects: 100% (49/49), done.`
`remote: Total 53 (delta 3), reused 52 (delta 3), pack-reused 0`
`Receiving objects: 100% (53/53), 851.09 KiB | 3.49 MiB/s, done.`
`Resolving deltas: 100% (3/3), done.`
If you see the following output above, then Yay! You now have cloned the assignment onto your machine! To run it in IntelliJ you can go to `File > Open >` and navigate to your assignment folder (click the folder with the name `<assignment>-<github login>`)!
However, you could run into authentication issues, such as the following output:
`fatal: Authentication failed for '{github_link}'`
If you are running into this issue, then look at the **How to Create a Personal Access Token** section below.
-->
### How do I push my code to Github?
If you want more information on what the actual commands do, then go to the **Need to Know Commands** section that goes through the commands needed to `git push`. However, here is a step-by-step guide with pictures that allows you to push your code to Github.
1. After you have made some changes, navigate to your terminal at the bottom of IntelliJ/VSCode. Additionally, make sure that you are in the same directory as your project/homework/lab.
![](https://docs.cs200.io/uploads/c2b2a587-d4da-4d61-a2b3-27f87908641a.png =500x )
2. Next, type in the following command: `git add .` (make sure that there is a space between the `add` and the period). There should be no output after.
![](https://docs.cs200.io/uploads/c3413865-662a-4968-ac0b-55236b6c6491.png =500x)
3. Next type in the following command: `git commit -m "message"` where the particular message is the message for your git commit. For example, since I edited my `AttributeNode` class in my Decision Tree project, I can type in the following commit message. Additionally, you can see the files that you have changed, the insertions that you made, and the deletions that you have made in the commit log.
![](https://docs.cs200.io/uploads/48dfe40f-4c27-4294-806a-819ea0b23069.png =500x)
4. Next type in your `git push` command. If you see the output below, then you have successfully pushed your code to Github.
![](https://docs.cs200.io/uploads/0214c213-a2ef-4db0-b2bb-bfb7deddd302.png =500x)
5. If you want to check that your code got pushed, then click on the blue link that is highlighted below:
![](https://docs.cs200.io/uploads/40450130-b940-446a-8c9f-48e5a79c210a.png =500x)
6. If you click on that link, that will take you to your Github repository and you will see your commit message on the files that you have changed.
![](https://docs.cs200.io/uploads/f6b4e993-eb05-4f9f-9f59-c794ae973fd0.png =500x)
## Appendix: Helpful git commands
| | |
| :--------------------------: | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |
| **Command** | **Explanation** |
| `git clone <repo URL>` | Once you accept an assignment and your repo is created, click the green “Code” button and copy the link that is listed. That link is your repo URL. Then, in your terminal, type this command with the repo URL to make a folder with the code in your repo on your computer. The folder will be made in whichever directory you are currently in, so be sure to cd into your desired directory before running this command! |
| `git add <file>``git add -A` | This command is the first of 3 commands that you need to run when you are trying to get the code you wrote on your computer back up to GitHub. You must add the files that you want to update on GitHub. You can do this by running git add with one file specified at a time, or you can use `git add -A` to update all files (typically what is used when you want to save a snapshot of your current code). |
| `git commit -m “<message>”` | Once you have added all of the desired files using git add, you are ready to commit these changes and save your snapshot to GitHub! This command is the 2nd of 3 commands you must run to get your code edits back up to GitHub. It creates the commit, or “snapshot” that we will soon send to GitHub. Instead of `<message>`, you should write something informative about what you’ve changed! |
| `git push` | Now you’re ready to push the changes to GitHub! Running this command will send your commit to the online repository where your code is stored. This is the final of the 3 commands you will run to get your code back to GitHub! After running this, go on your GitHub repo and ensure that your updates were made! |
| `git pull` | This command lets you pull any changes on this repository that are present on GitHub but not on your local machine. No need to worry about this for solo projects, but if you’re working on partner projects, pull before you begin working / after you commit and before you push in order to get all your partner’s changes! |
If you have any git problems, feel free to post on Ed!
***
_Please let us know if you find any mistakes, inconsistencies, or confusing language in this or any other CSCI0200 document by filling out the_ [_anonymous feedback form_](https://forms.gle/8HY7tDdgM98fk2e19)_._