Day 5: Git and GitHub
Reminders for Tony
- Put on mic
- Open Zoom chat
- Record! Anyone else?
Prep
- CLI (command line interface) Cheat Sheet
- Configuring Git
- Git and GitHub for Poets
- Why does GitHub recommend HTTPS over SSH?
Prerequisites
- Git installed
- VS Code installed
- Github Account created
Goal for today
By the end of the day, you should have a local project repository “pushed” and synced to the remote copy located on GitHub.
- Create a new repository on Github. It should have a similar name to your local project.
- It needs to be public for GH Pages to work
- DO NOT initialize with a README.md
- Click “Create repository”. Save the next page; it has important info.
- After creating your repo, you should see a list of instructions for different situations. We will start with the first one: “…or create a new repository on the command line”.
But FIRST! We need to learn some command line…
Lecture 1: Command line basics
Most of the command line tools we will be using in this course (like Git, Node and NPM) will depend greatly on which folder you are in. We will cover the three system commands that help up us navigate the file system.
Warning: There are two flavours of “command line”: Windows and Unix. We will be using the latter: Git Bash (installed along with Git) on Windows and Terminal on Mac (Mac is unix-based so almost any terminal app will do; Tony uses iTerm).
pwd
- displays your ‘present working directory’. This will usually default to your home folder when you first open your terminal.
ls
- Lists the contents of your current directory.
- The
-l
flag lists extra information and-a
lists hidden files.-la
will list extra information and also all hidden files. Examples:$ ls -l
$ ls -a
$ ls -la
cd
: changes your directory based on the path you provide after the command (separated by a space). Examples:$ cd Documents/cprg210
$ cd /h/sait/cprg210
$ cd ..
(moves up one directory)
Quality of life cli tips
- tab: auto-completes file names and directories
- up arrow: browse through command history
Live-code objectives
- What is the starting directory when you open a terminal on your system?
- What files and directories are in this initial directory?
- What file did you last open? Try to find it using only the terminal.
- What’s at the top of your directory structure? How do you get there?
- Using the terminal, find the directory you’ve chosen to store your cprg 210 projects.
Activity 1: Navigating the file system
You will be working in teams. Make sure you have installed Git on your system. We will be using Git Bash for this exercise.
Try navigating to various directories on your system to get accustomed to the command line.
Lecture: Your first git repository (maybe)
Let’s go back to that page of instructions we received after creating our GitHub repo. Remember, we’ll be starting with the top option: “…or create a new repository on the command line”.
Top Git commands
$ git status
: Show the current status of your repository (repo)$ git add
: Add file contents to be committed$ git commit
: Record changes to the repository$ git push
: Update remote refs along with associated objects$ git pull
: Fetch from and integrate with another repository or a local branch
Live-code objectives
- How will you organize your projects?
- If you’ve just installed Git, set your name and email using the
git config
command described in the Prep. - Create a git repository for the project you’ve been working on in the HTML/CSS portion of this course.
- Navigate to your project directory on the command line.
git status
to make sure you are not already in a repo.git init
to initialize a new repo. This is usually done only once (if that) per project.git status
to see what files are modified/deleted/untracked.git add .
to add all your files for an initial commitgit status
to double-check before you commit.git commit -m "concise description of your changes"
to commit your changes.git status
again to confirm that your “working directory is clean”.- Make some changes to your code and start again at Step 4. You should be committing your changes multiple times a day.
When you are ready, enter the last two lines of the GitHub instructions to attach and sync your local and remote repos.
$ git remote add origin https://github.com/acidtone/hello-world.git
$ git push -u origin master
There are two ways to connect your system to GitHub: HTTPS and SSH. It’s widely recommended that beginners use the HTTPS option. You will be asked for your login credentials the first time but your terminal should remember this for future connections.
Activity: Project work
You will be working in teams. Work on your projects as you normally would, but try committing your changes as you go. Get used to the status/add/commit lifecycle of a professional developer.
When you like what you see, push your changes to GH.
Mid-day Huddle
- who needs help?
- any pivots?
- any show-and-tell?
[lunch]
GitHub Tour
Git is an open source tool that helps developers manage their code. GitHub is a company that has built a community around the Git technology.
Activity 3: Publish your website to GH Pages
You will be working in teams. Go to pages.github.com to get a summary of what GH Pages is and how to use it. Work together to publish each of your projects to a GH Pages website.
Summary
- any trophies?
- prep for tomorrow?
- applause