The assignments listed here should take you approximately 25 total minutes.
To start this assignment, click the button in the upper right-hand corner that says Fork. This is now your copy of the document. Click the Edit button when you're ready to start adding your answers. To save your work, click the green button in the bottom right-hand corner. You can always come back and re-edit your gist.
Need help? You can go back to the files/directories portion of the lesson here.
Scroll down to the bottom of this page and look at the image of the directories and files. Use commands in your terminal to create the directories and files structured exactly how they appear in the image.
When you're done, type history to see your commands. Copy and paste the commands that were used to create the directory and files:
35 mkdir session_3_practice
36 pwd
37 cd session_3_practice
38 touch budget.csv
39 touch mentors.txt
40 ls
41 mkdir notes
42 ls
43 cd notes
44 touch git_notes.txt
45 touch command_line_notes.txt
46 ls
47 cd ..
48 mkdir practice
49 cd practice
50 touch git_practice.txt
51 mkdir projects
52 cd projects
53 touch game.js
54 ls
55 cd ..
56 ls
57 cd ..
58 ls
59 history
joshuasherwood~/session_3_practice$
Since this is just a practice directory, feel free to remove the parent directory session_3_practice when you're done with this exercise.
You can reference the files/directories portion of the lesson here.
Follow the steps below to practice the git workflow. Be ready to copy-paste your terminal output as confirmation of your practice.
- Create a directory called
git_homework. Inside of there, create a file calledquotes.txt. - Initialize the directory
- Check the git status
- Add your
quotes.txtfile to the staging area - Check the git status
- Create an initial commit
- Check the status
- Add your favorite quote to the
quotes.txtfile - Check the status
- Check the diff
- Add the changes to the staging area
- Commit the new changes
- Check the status
- Show the log in oneline format
Copy and paste all of the terminal text from this process below (not just the history):
Terminal Text
joshuasherwood~$ mkdir git_homework
joshuasherwood~$ cd git_homework
joshuasherwood~/git_homework$ touch quotes.txt
joshuasherwood~/git_homework$ git init
Initialized empty Git repository in /Users/joshuasherwood/git_homework/.git/
joshuasherwood~/git_homework$ git status
On branch master
No commits yet
Untracked files:
(use "git add <file>..." to include in what will be committed)
quotes.txt
nothing added to commit but untracked files present (use "git add" to track)
joshuasherwood~/git_homework$ git add quotes.txt
joshuasherwood~/git_homework$ git status
On branch master
No commits yet
Changes to be committed:
(use "git rm --cached <file>..." to unstage)
new file: quotes.txt
joshuasherwood~/git_homework$ git commit -m 'initial commit'
[master (root-commit) 12b8c94] initial commit
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 quotes.txt
joshuasherwood~/git_homework[master]$ git status
On branch master
nothing to commit, working tree clean
joshuasherwood~/git_homework[master]$ echo "you always gain by giving love - Reese Witherspoon" >> quotes.txt
joshuasherwood~/git_homework[master !]$ cat quotes.txt
you always gain by giving love - Reese Witherspoon
joshuasherwood~/git_homework[master !]$ git status
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: quotes.txt
no changes added to commit (use "git add" and/or "git commit -a")
joshuasherwood~/git_homework[master !]$ git diff quotes.txt
diff --git a/quotes.txt b/quotes.txt
index e69de29..99d165d 100644
--- a/quotes.txt
+++ b/quotes.txt
@@ -0,0 +1 @@
+you always gain by giving love - Reese Witherspoon
joshuasherwood~/git_homework[master !]$ git add quotes.txt
joshuasherwood~/git_homework[master !]$ git commit -m 'second commit'
[master b92f76e] second commit
1 file changed, 1 insertion(+)
joshuasherwood~/git_homework[master]$ git status
On branch master
nothing to commit, working tree clean
joshuasherwood~/git_homework[master]$ git log
commit b92f76e00bb4cfb20955a4c39bdc3999fe72ed9d (HEAD -> master)
Author: Joshua Sherwood <[email protected]>
Date: Wed May 8 22:33:59 2019 -0600
second commit
commit 12b8c948fca78e5225b42435fe51d51e0d3bf2f9
Author: Joshua Sherwood <[email protected]>
Date: Wed May 8 22:18:51 2019 -0600
initial commit
joshuasherwood~/git_homework[master]$
Command History:
61 mkdir git_homework
62 cd git_homework
63 touch quotes.txt
64 git init
65 git status
66 git add quotes.txt
67 git status
68 git commit -m 'initial commit'
69 git status
70 echo "you always gain by giving love - Reese Witherspoon" >> quotes.txt
71 cat quotes.txt
72 git status
73 git diff quotes.txt
74 git add quotes.txt
75 git commit -m 'second commit'
76 git status
77 git log
78 history
joshuasherwood~/git_homework[master]$
IMPORTANT: Do not remove this git_homework directory. You will be using this directory during Thursday's session.
If you have any questions, comments, or confusions that you would an instructor to address, list them below:
-
If time permits and you want extra git practice and alternative explanations (it's often beneficial to have something explained in many different ways), check out Codecademy's Git Course, particularly the first free item on the syllabus, "Basic Git Workflow". In Mod 0, we will not cover anything beyond Codecademy's intro section; however, you are welcome to check out the other git lessons listed on the syllabus if you want a head start.
-
This course is how I personally learned command line. If time permits, I highly recommend reading and practicing.
-
Also recommended by Jeff Casimir: Michael Hartl's Learn Enough Command Line.
-
Add tab completion to make your life easier: Type Less. Do More.

Awesome job, @joshsherwood1! Everything looks correct.