PHS 7045: Advanced Programming
2024-08-20
Before we start with the class:
Workflow:
All submissions (labs, assignments, midterm, and final) through GitHub.
Submissions must be using quarto, Rmarkdown, or similar (like this presentation!).
Weekly readings.
Two weekly sessions: Lecture + Lab.
One big project to be completed: Midterm and Final.
We will learn about version control and GitHub.
Set up git and GitHub (make sure it works).
Throughout the course, we will be using the following tools:
[I]s the management of changes to documents […] Changes are usually identified by a number or letter code, termed the “revision number”, “revision level”, or simply “revision”. For example, an initial set of files is “revision 1”. When the first change is made, the resulting set is “revision 2”, and so on. Each revision is associated with a timestamp and the person making the change. Revisions can be compared, restored, and with some types of files, merged. – Wiki
Have you ever:
In these cases, and no doubt others, a version control system should make your life easier.
– Stackoverflow (by si618)
During this class (and perhaps, the entire program,) we will be using
There are several ways to include Git in your work pipeline. A few are:
Through the command line
Through one of the available Git GUIs:
More alternatives here.
Git has a ton of features, but the daily workflow only features a handful of commands: git pull
, git add
, git commit
, and git push
:
git pull
Make changes
(optional) Add untracked/new files: git add [target file]
(optional) Stage modified files: git add [target file]
(optional) Revert changes: git checkout [target file]
git add
Commit:
If nothing pending: git commit -m "Your comments go here."
If modifications are not staged: git commit -a -m "Your comments go here."
git push
.Set up your git install with git config
, start by telling who you are
$ git config --global user.name "Juan Perez"
$ git config --global user.email "jperez@treschanchitos.edu"
Try it yourself (5 minutes) (more on how to configure git here)
We will start by working on our very first project. To do so, you are required to start using Git and GitHub so you can share your code with your team. For now, you can keep things local and skip Github. For this exercise, you need to
PHS7045-first-project
)git init
command.README.md
file and write a brief description of your project.git add
command, and check the status.Make the first commit using the git commit
command adding a message, e.g.
And use git log
to see the history.
Note 1: We are assuming that you already installed git in your system.
Note 2: Need a text editor? Check out this website link.
The following code is fully executable (copy-pastable)
# (a) Creating the folder for the project (and getting in there)
mkdir ~/PHS7045-first-project
cd ~/PHS7045-first-project
# (b) Initializing git, creating a file, and adding the file
git init
# (c) Creating the Readme file
echo An empty line > README.md
# (d) Adding the file to the tree
git add README.md
git status
# (e) Committing and check out the history
git commit -m "My first commit ever!"
git log
Ups! It seems that I added the wrong file to the tree, you can remove files from the tree using git rm --cached
, for example, imagine that you added the file class-notes.docx
(which you are not supposed to track), then you can remove it using
This will remove the file from the tree but not from your computer. You can go further and ask git to avoid adding Docx files using the .gitignore file
Now that you have something to share, your teammates are asking you to share the code with them. Since you are smart, you know you can do this using something like Gitlab or Github. So you now need to:
Create an online repository (empty) for your project using Github.
Add the remote using git remote add
, in particular
Then, use the commands git status
and git remote -v
to see what’s going on.
git push
like this:You should also check the status of the project using git status
to see what Git tells you about it. Origin is the tag associated with the remote repo setup, while ‘master’ is the tag associated with the current branch of your repo.
Recommended: Complete GitHub’s Training team “Uploading your project to GitHub”
For part (b), there are a couple of solutions, first, you could try using your ssh-key (if you set it up)
# (b)
git remote add origin git@github.com:gvegayon/PHS7045-first-project.git
git remote -v
git status
Otherwise, you can use the simple URL (this will prompt user+password) every time you want to push (and pull, if private).
For the first git push
, you need to specify the source (master) and target (origin) and set the upstream (the -u
option):
The --set-upstream
, which was invoked with -u
, will set the tracking reference for pull
and push
.
Example extracted directly from Pro-Git (link).
# ignore all .a files *.a # but do track lib.a, even though you're ignoring .a files above !lib.a # only ignore the TODO file in the current directory, not subdir/TODO /TODO # ignore all files in any directory named build build/ # ignore doc/notes.txt, but not doc/server/arch.txt doc/*.txt # ignore all .pdf files in the doc/ directory and any of its subdirectories doc/**/*.pdf
Git’s everyday commands, type man giteveryday
in your terminal/command line. and the very nice cheatsheet.
My personal choice for nightstand book: The Pro-git book (free online) (link)
Github’s website of resources (link)
The “Happy Git with R” book (link)
Roger Peng’s Mastering Software Development Book Section 3.9 Version control and Github (link)
Git exercises by Wojciech Frącz and Jacek Dajda (link)
Checkout GitHub’s Training YouTube Channel (link)