Automated Version Control
Figure 1
data:image/s3,"s3://crabby-images/62770/627706becfa4e4a166788e33e0b14afabdb02c22" alt="One same files called Press release.doc with modifications in different files using the words FINAL, VERSION, REVISED, APPROVED. Source: Proper Discord."
Tracking changes for the
Press release.doc
file. Never
use the word “final” in a filename.Figure 2
data:image/s3,"s3://crabby-images/a985c/a985cda41f946cf5def960c6e96e63b863cf25d0" alt="Tracking changes for the git-test file."
Tracking changes for the
git-test
file.Figure 3
data:image/s3,"s3://crabby-images/6fcbe/6fcbe49fc79f5a0110b81b5d4888221085ba1162" alt="The most recent version of the git-test file is called “third version”."
The most recent version of the
git-test
file is called “third version”.Figure 4
data:image/s3,"s3://crabby-images/92996/92996e88cf68300464fbde788d0834d583924361" alt="We can view the “first version” of the file git-test. We can also restore it with the Restore this version button."
We can view the “first version” of the file
git-test
. We can also restore it with the
Restore this version
button.Figure 5
data:image/s3,"s3://crabby-images/2e892/2e8926c5586eebda91a0eda6e30d1de97d21d007" alt="The Turing Way project illustration by Scriberia. Used under a CC-BY 4.0 licence. DOI: https://zenodo.org/doi/10.5281/zenodo.3332807."
The Turing Way project illustration by
Scriberia. Used under a CC-BY 4.0 licence. DOI: https://zenodo.org/doi/10.5281/zenodo.3332807.
Figure 6
Figure 7
data:image/s3,"s3://crabby-images/f56ae/f56aef4eb80f2d1e86ea8dc60281250403088c80" alt="Examples of non-plain and plain text files."
Examples of non-plain and plain text
files.
Figure 8
data:image/s3,"s3://crabby-images/bb21c/bb21cd4134d475a472d04f4ccd7caffc65d23569" alt="We can increase the reproducibility of our Open science projects with version control sytems like Git. Text and final results can be connected and executable by Data and code. From: “Ciencia reproducible: qué, por qué, cómo” https://www.revistaecosistemas.net/index.php/ecosistemas/article/view/1178"
We can increase the reproducibility of our Open
science projects with version control sytems like
Git
. Text
and final results can be connected and executable by Data and code.
From: “Ciencia reproducible: qué, por qué, cómo” https://www.revistaecosistemas.net/index.php/ecosistemas/article/view/1178
Figure 9
data:image/s3,"s3://crabby-images/0cb43/0cb43777cd5a804455662adaa49d25be29e58525" alt="Concept map for automatic version control."
Concept map for automatic version control.
Setting Up Git
Figure 1
data:image/s3,"s3://crabby-images/b98aa/b98aaae96c84c3b119b9482d5e97b14d5cef504a" alt="Changes Are Saved Sequentially"
Each record of changes is called a
commit
. From: https://speakerdeck.com/alicebartlett/git-for-humans
Figure 2
data:image/s3,"s3://crabby-images/506ec/506eca14617ad7b3bdd4e2eb45e2120400e6ae7f" alt="Visual appearance of the Console."
Visual appearance of the Console.
Figure 3
data:image/s3,"s3://crabby-images/dbee2/dbee249abf860ed95fd08270de6919bd7d8c33ef" alt="Visual display with the recommended scopes selected. Optional scopes are “gist” and “delete_repo” to create a gist and delete repositories."
Visual display with the recommended scopes
selected. Optional scopes are “gist” and “delete_repo” to create a gist
and delete repositories.
Figure 4
data:image/s3,"s3://crabby-images/5f983/5f9830bb3fe40f64b6d434a65b979920d3640af4" alt="Version history within a single branch."
Version history within a single branch.
Creating a Repository
Figure 1
data:image/s3,"s3://crabby-images/27143/2714373183e2ebf4bd82fd2037204c366c98f33d" alt="Word cloud for Git from https://thoughtbot.com/blog/recommending-blog-posts"
Word cloud for Git from https://thoughtbot.com/blog/recommending-blog-posts
Figure 2
data:image/s3,"s3://crabby-images/b3a58/b3a58adf084d1b65b1dafb11f305a8c719742858" alt="Workflow will show actions, git verb commands, and spaces."
Workflow will show actions,
git verb
commands, and spaces.Figure 3
data:image/s3,"s3://crabby-images/01c47/01c471986e48411b3070d0872eb6a20f40ef44a0" alt="Initialize a Local Repository in your Workspace with the git init command verb"
Initialize a Local Repository in your Workspace
with the
git init
command verbFigure 4
data:image/s3,"s3://crabby-images/c14e0/c14e003786a5193a5d095a009ea073ebae6cb779" alt="wolfman and dracula using computers for data analysis"
Image by Bing, 2023, CC BY 4.0,
created with Bing Image Creator
powered by DALL·E 3
Figure 5
data:image/s3,"s3://crabby-images/b0e08/b0e080320d9dfd1a2240089e1e0c940b16218186" alt="The Git tab in the Environments pane shows the status of your repository."
The Git tab in the Environments pane shows the
status
of your repository.Figure 6
data:image/s3,"s3://crabby-images/fc93a/fc93a7821518b3f5d58c4ba0a08d61573efbc098" alt="Set up Git once per computer. Initialize Git once per project."
Set up
Git
once per computer.
Initialize Git
once per project.Figure 7
data:image/s3,"s3://crabby-images/bf71f/bf71f25eb09dcf0bfea692c014d8c7ae19aa26bd" alt="Show hidden files in an Local repository."
Show hidden files in an Local repository.
Figure 8
data:image/s3,"s3://crabby-images/9b8cb/9b8cb0c9b546f7b3564b9b557f6f07033d747c46" alt="The .git folder is a hidden folder in a Local repository."
The
.git
folder is a hidden folder
in a Local repository.Figure 9
data:image/s3,"s3://crabby-images/2ca87/2ca879decffef2c27a4c4aea0547ee387e9d786d" alt="Visual appearance of the Terminal."
Visual appearance of the Terminal.
Figure 10
data:image/s3,"s3://crabby-images/01c47/01c471986e48411b3070d0872eb6a20f40ef44a0" alt="Initialize a Local Repository in your Workspace with the git init command verb"
Initialize a Local Repository in your Workspace
with the
git init
command verbFigure 11
data:image/s3,"s3://crabby-images/4f35a/4f35a828875b1e2b70cc07f82e4e55698c8d4f5d" alt="Use the git init command to initialize a Local Repository in your Workspace. Use git status to check the status of the repository."
Use the
git init
command to
initialize a Local Repository in your Workspace. Use
git status
to check the status of the repository.Tracking Changes
Figure 1
Figure 2
data:image/s3,"s3://crabby-images/5bf16/5bf16b7dbd4c7f6914e4be497ecb038f1349a6ba" alt="Use git status to display the state of the working directory and the staging area. git add your changes before you git commit them to the Local repository. Use the git log to get the history of changes in it. Use git diff to compare these changes."
Use
git status
to display the state
of the working directory and the staging area. git add
your
changes before you git commit
them to the Local repository.
Use the git log
to get the history of changes in it. Use
git diff
to compare these changes.Figure 3
Ignoring Things
Remotes in GitHub
Figure 1
Figure 2
data:image/s3,"s3://crabby-images/ab603/ab603c6c635191a47232251351b0b95c14f7673a" alt="Freshly-Made GitHub Repository"
Figure 3
data:image/s3,"s3://crabby-images/bb017/bb01797f17f3da6ec300c448dee6e02dd84d8044" alt="Creating a Repository on GitHub (Step 1)"
Figure 4
data:image/s3,"s3://crabby-images/1b901/1b901baaf537e37e8204da1ad39d73bb2d684231" alt="Creating a Repository on GitHub (Step 2)"
Figure 5
data:image/s3,"s3://crabby-images/0cb84/0cb840bb8c196be52029d9a6096e293b1343c821" alt="Creating a Repository on GitHub (Step 3)"
Figure 6
Figure 7
data:image/s3,"s3://crabby-images/ab603/ab603c6c635191a47232251351b0b95c14f7673a" alt="Freshly-Made GitHub Repository"
Figure 8
data:image/s3,"s3://crabby-images/1ba9a/1ba9ae753ea6a19d3a733fa50b0c5331f9cebe97" alt="Where to Find Repository URL on GitHub"
Figure 9
data:image/s3,"s3://crabby-images/43ddb/43ddbf7fa24bfa4029514c973c305c5c552fa266" alt="GitHub Repository After First Push"
Figure 10
data:image/s3,"s3://crabby-images/bb81b/bb81b147c8068178a9d2a20b5ec93b7388e164c1" alt=""
Figure 11
data:image/s3,"s3://crabby-images/f6cdd/f6cdd22ec684019335e217e66895a15bad81ef05" alt="Use git pull to download content from a remote repository to the workspace and update the local repository to match that content. Use git push to upload local repository content to a remote repository."
Use
git pull
to download content
from a remote repository to the workspace and update the local
repository to match that content. Use git push
to upload
local repository content to a remote repository.Collaborating
Figure 1
data:image/s3,"s3://crabby-images/65a38/65a38e7957c525ec322b0c88ba6b4de88f81bbf2" alt=""
Figure 2
data:image/s3,"s3://crabby-images/10289/102893c5f969669e5307e4807f2ca2626f29fcf7" alt=""
Figure 3
data:image/s3,"s3://crabby-images/d5224/d522499ebf1b661032d47e4523f48849502f2ea4" alt=""
Figure 4
data:image/s3,"s3://crabby-images/f89a5/f89a522f3bde3bff1bf4c43b54fc2134242fffb6" alt="screenshot of repository page with Settings then Collaborators selected, showing how to add Collaborators in a GitHub repository"
Figure 5
data:image/s3,"s3://crabby-images/1f980/1f9804ffc6cfcdec93063a6f71672747902323da" alt="After Creating Clone of Repository"
In the Outbreak response scenario, now Wolfman
has a local copy of the remote repository. They are already set up to
collaborate for one project!
Figure 6
data:image/s3,"s3://crabby-images/a8a20/a8a20b7f87d83d5775b2f24abd0afa604a33b56f" alt="Click on “commit”. Select one commit."
Click on “commit”. Select one commit.
Figure 7
data:image/s3,"s3://crabby-images/bf40f/bf40f3af75221ae83917251df5bc854d202f347d" alt="Replace age with sex commit. The removed content within lines is in red. The added content within lines is in green."
Replace age with sex commit. The removed content
within lines is in red. The added content within lines is in
green.
Figure 8
data:image/s3,"s3://crabby-images/fae5b/fae5b664aa823bb0d9fa5627291f9ef185b74793" alt="Use git fetch to download the remote content but not update your local repo’s working state, leaving your current work intact. Use git pull to download the remote content for the active local branch and immediately merge it. this can potentially cause conflicts."
Use
git fetch
to download the
remote content but not update your local repo’s working state, leaving
your current work intact. Use git pull
to download the
remote content for the active local branch and immediately merge it.
this can potentially cause conflicts.Figure 9
data:image/s3,"s3://crabby-images/91caa/91caa7949ecf5a1f49da415a2332e8a158a121b8" alt=""
Figure 10
data:image/s3,"s3://crabby-images/3b3b3/3b3b354f0ea6ffd14138302c013373ca1423c35f" alt=""
Figure 11
data:image/s3,"s3://crabby-images/6b93c/6b93c1881aa6a2ed9e1643d665f056d106944759" alt=""
Figure 12
data:image/s3,"s3://crabby-images/88c33/88c338446622524d6fd78ff9d73b25a31eeaa648" alt=""
Figure 13
data:image/s3,"s3://crabby-images/12a2d/12a2d52220e4bc445eec7036f582a38bede9e77e" alt="Use git clone to obtain a development copy of a remote repository. Like git init, cloning is generally a one-time operation. Use git pull to update the local repository to match the content in the remote repository."
Use
git clone
to obtain a
development copy of a remote repository. Like git init
,
cloning is generally a one-time operation. Use git pull
to
update the local repository to match the content in the remote
repository.Conflicts
Figure 1
Figure 2
Figure 3
Figure 4
Figure 5
data:image/s3,"s3://crabby-images/740d6/740d6981bba1a66f8e6f601ba84423717174e090" alt="One feature branch and one main branch in Git."
One feature branch and one main branch in
Git.
Figure 6
data:image/s3,"s3://crabby-images/24da3/24da319be2093d4b2fa849baf4a60670184647b5" alt="Two feature branches and one main branch in Git."
Two feature branches and one main branch in
Git.
Figure 7
data:image/s3,"s3://crabby-images/f7c3b/f7c3bf5560995b19ed25f4030e7c8940182d222f" alt=""
Figure 8
data:image/s3,"s3://crabby-images/d56a2/d56a22925a883573ee50e5af9a1b16e1fad64d1d" alt="Two related modified lines must be part of the same commit."
Two related modified lines must be part of the
same commit.
Figure 9
data:image/s3,"s3://crabby-images/64f4d/64f4d1038c37e89b80d36feeea9d5ee2f942f755" alt="Two unrelated edits must be part of two isolated commits."
Two unrelated edits must be part of two isolated
commits.
Wrap-up
Figure 1
data:image/s3,"s3://crabby-images/23425/234251e645d0fd35c3a4ad0b51f5fa9184474563" alt="Complete workflow with actions, git verb commands, and spaces."
Complete workflow with actions,
git verb
commands, and spaces.Supplemental: Using RStudio for Git
Figure 1
data:image/s3,"s3://crabby-images/d8ad3/d8ad35350541da162b7445aedd138f30d0d88ae8" alt="RStudio screenshot showing the file menu dropdown with "New Project..." selected"
Figure 2
data:image/s3,"s3://crabby-images/47c18/47c187a64fce1ca7be4df84f251fa911d7a5116c" alt="RStudio screenshot showing New Project dialog window with "Create project from existing directory" selected"
Figure 3
data:image/s3,"s3://crabby-images/aaac8/aaac87e5d4bec97b81ba00feb853adb017f6002d" alt=""
Figure 4
data:image/s3,"s3://crabby-images/34627/346272538f7498c325013ed5092507cf56f3e849" alt=""
Figure 5
data:image/s3,"s3://crabby-images/85201/8520101dd3bacadaea1f240b45d0f0fadb50cc93" alt=""
Figure 6
data:image/s3,"s3://crabby-images/4c828/4c8281d45089b6d065769f669780ae382beffe01" alt="RStudio window after new project is created with large arrow pointing to vertical Git menu bar."
Figure 7
data:image/s3,"s3://crabby-images/811f5/811f53b967749110c1fbd93938e032839e7d1c30" alt=""
Figure 8
data:image/s3,"s3://crabby-images/1b5fb/1b5fbb1b4ce80091804f5b75eee5344a4742e536" alt="RStudio screenshot showing the Git menu dropdown with "Commit..." selected"
Figure 9
data:image/s3,"s3://crabby-images/6126a/6126a3e86db015b2b12e7a7590dce6309676a627" alt=""
Figure 10
data:image/s3,"s3://crabby-images/262ec/262ec6e286b90ea8f09f603c998f237442f23c7e" alt=""
Figure 11
data:image/s3,"s3://crabby-images/7a0a4/7a0a49626dc274d80d44fed2fa093fb9ad6914dd" alt="RStudio screenshot showing the git menu dropdown with "History" selected"
Figure 12
data:image/s3,"s3://crabby-images/a6345/a6345df9138cb3e0ef708db01870a4df849b0b6a" alt=""
Figure 13
data:image/s3,"s3://crabby-images/a6551/a65511bcacfebc7d4c3a4b97816b5ccd1ccea5b0" alt="RStudio screenshot showing .gitignore open in the editor pane with the files .Rproj.user, .Rhistory, .RData, and *.Rproj added to the end"
Figure 14
data:image/s3,"s3://crabby-images/d7911/d79115c54f360b85f28fae4305f07fb4bb3ba7ab" alt=""
Figure 15
data:image/s3,"s3://crabby-images/bb0de/bb0deda9f023502369ad2cdec030d2a9cde78866" alt=""
Figure 16
data:image/s3,"s3://crabby-images/54ebf/54ebf375ecd1adc0b2542b167dfc343ce027353f" alt=""
Figure 17
data:image/s3,"s3://crabby-images/115d7/115d7194a09513dcf697255ea34bfa6bb9c49b6c" alt=""
Exploring History
Figure 1
Figure 2
Figure 3
data:image/s3,"s3://crabby-images/2faf6/2faf6fa7a546565811f7be6e27108acfe8af34e5" alt="Use git diff to compare changes since last commit or between commits. Use git checkout to undo changes by restoring the staging area (committed changes) or the local repository (last commit)"
Use
git diff
to compare changes
since last commit or between commits. Use git checkout
to
undo changes by restoring the staging area (committed changes) or the
local repository (last commit)