-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathTK_03.Rmd
109 lines (75 loc) · 5.11 KB
/
TK_03.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
---
title: Git Repository
week: 3
type: Task
subtitle: Start using Github to manage course materials
reading:
- Chapters [4-5 in R4DS](http://r4ds.had.co.nz){target='blank'}
- Chapters [4-10 in Happy Git and Github for the useR - Installation](https://happygitwithr.com/install-intro.html){target='blank'}
- Chapters [13-15 in Happy Git and Github for the useR - Installation](http://happygitwithr.com){target='blank'}
tasks:
- Watch [the Git GUI](https://www.youtube.com/watch?v=E2d91v1Twcc){target='blank'}
- Install [git on your computer](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git)
- Configure Git
- Make sure git works in R-Studio (do you see the Git tab in the upper right?)
- Optionally sign up for the [GitHub Education pack](https://education.github.com/pack)
- Click on [this link to create a repository for your case studies](https://classroom.github.com/a/BRmhFFxj)
- Set up [it credentials following this](https://happygitwithr.com/hello-git.html)
- Create a new project in Rstudio and connect it to the new repository in GitHub. Helpful instructions are [here](http://happygitwithr.com/rstudio-git-github.html#clone-the-new-github-repository-to-your-computer-via-rstudio)
- Make some change. For example, you could edit the README.md file in your repository to include a brief description of the repository (e.g. "Coursework for Spatial Data Science").
- Stage and Commit your changes to Git (using the git tab in the upper right of RStudio)
- Push the repository up to GitHub
- Confirm that the changes are visible on your github webpage
- Copy the contents of your scripts from previous weeks into the appropriate files (but don't edit the file names!)
---
```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE)
library(knitr)
library(kableExtra)
source("functions.R")
```
# Reading
```{r reading,results='asis',echo=F}
md_bullet(rmarkdown::metadata$reading)
```
# Tasks
```{r tasks,results='asis',echo=F}
md_bullet(rmarkdown::metadata$tasks)
```
# Background
Version control systems (VCS) allow developers to maintain a record of how their code has changed over time. When used properly, a VCS can help a developer track down the exact point in time when a bug was introduced or fixed, easily undo changes, and collaborate with other developers.
There are many types of version control systems. Some of the more popular ones include CVS, subversion, mercurial, and git. In recent years, git has quickly become the most popular of the group.
## Git
Git stores files in a type of database called a `repository` or `repo`. Most data science teams that work with git keep a central repository on a server somewhere that everyone on the team can access. This repository stores the files and the history of every change made to each file, including who made the changes and when those changes were made.
Git works with groups of changes called `commits`. A single commit might have many changes associated with it. Those changes might include updates to, existing files, the addition of new files, or the removal of files.
## Example
Imagine a developer named Sally who has started a new job for US Robotics. She's told that her first assignment is to fix a bug in the positronic brain code that is causing all of the robots to walk around in circles. She takes the following steps:
1. First, Sally will clone the central repository which creates a copy of the repository on her computer.
```
git clone https://github.com/us-robotics/brain.git
```
2. Next, Sally finds the bug in the PositronicBrain.R file that is causing the odd behavior. She quickly fixes the bug and saves her changes.
3. Sally's next step is to add the PositronicBrain.R file to the list of changed files to commit.
```
git add PositronicBrain.R
```
4. When Sally is done adding files, she will commit those changes, adding a brief message to describe her changes.
```
git commit -m "Fixed the bug that made robots attack ice cream shops."
```
5. Now that her changes are finished before she can share them, she must pull any changes her teammates have made from the central repository into her local copy.
```
git pull
```
6. After making sure that there isn't a conflict between her teammates' changes and her own, she is ready to push her changes up to the central repository.
```
git push
```
Most of your interactions with a git repository will follow the same six steps that Sally followed. **Note the sequence of the pull and push commands.**
This is critical when working with git: **Always pull before you push.**
As we are getting introduced to git and GitHub, you will be the only one that is working with your repository. This will make the `git pull` less used in our day-to-day workflow. We will only need to get the workflow for adding files from our local repository to the GitHub central repository.
## Course Folder Structure
For the rest of the course, you should keep your files organzed in a git-managed repository. After syncing your local computer with your class repository, you will have a folder structure similar to the image below.
```{r, out.width="400px", echo=F}
knitr::include_graphics("img/folderstructure.png")
```