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:
7 mkdir session_3_practice
8 touch budget.csv
9 touch mentors.txt
10 mkdir notes
11 cd notes
12 touch git_notes.txt
13 touch command_line_notes.txt
14 cd ..
15 mkdir practice
16 cd practice
17 touch git_practice.txt
18 mkdir projects
19 cd projects
20 touch game.js
21 ls
22 history
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.txt
file to the staging area - Check the git status
- Create an initial commit
- Check the status
- Add your favorite quote to the
quotes.txt
file - 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):
ericmeldrum~/practice/projects$ cd ~ ericmeldrum~$ mkdir git_homework ericmeldrum~$ cd git_homework ericmeldrum~/git_homework$ quotes.txt -bash: quotes.txt: command not found ericmeldrum~/git_homework$ touch quotes.txt ericmeldrum~/git_homework$ git init Initialized empty Git repository in /Users/ericmeldrum/git_homework/.git/ ericmeldrum~/git_homework$ git status On branch master
No commits yet
Untracked files: (use "git add ..." to include in what will be committed)
quotes.txt
nothing added to commit but untracked files present (use "git add" to track) ericmeldrum~/git_homework$ git add Nothing specified, nothing added. Maybe you wanted to say 'git add .'? ericmeldrum~/git_homework$ git add quotes.txt ericmeldrum~/git_homework$ git status On branch master
No commits yet
Changes to be committed: (use "git rm --cached ..." to unstage)
new file: quotes.txt
ericmeldrum~/git_homework$ git commit quotes.txt Aborting commit due to empty commit message. ericmeldrum~/git_homework$ git commit -m 'Initial commit' [master (root-commit) b1b876e] Initial commit 1 file changed, 0 insertions(+), 0 deletions(-) create mode 100644 quotes.txt ericmeldrum~/git_homework[master]$ git status On branch master nothing to commit, working tree clean ericmeldrum~/git_homework[master]$ echo "BORRRTTTLLLESSS!!!" >> quotes.txt -bash: !": event not found ericmeldrum~/git_homework[master]$ git diff quotes.txt ericmeldrum~/git_homework[master]$ echo "BORRRTTTLLLESSS" >> quotes.txt ericmeldrum~/git_homework[master !]$ git diff quotes.txt diff --git a/quotes.txt b/quotes.txt index e69de29..654c302 100644 --- a/quotes.txt +++ b/quotes.txt @@ -0,0 +1 @@ +BORRRTTTLLLESSS ericmeldrum~/git_homework[master !]$ git add Nothing specified, nothing added. Maybe you wanted to say 'git add .'? ericmeldrum~/git_homework[master !]$ git add quotes.txt ericmeldrum~/git_homework[master !]$ git commit -m 'Add quote' [master c32fdea] Add quote 1 file changed, 1 insertion(+) ericmeldrum~/git_homework[master]$ git status On branch master nothing to commit, working tree clean ericmeldrum~/git_homework[master]$ git log oneline fatal: ambiguous argument 'oneline': unknown revision or path not in the working tree. Use '--' to separate paths from revisions, like this: 'git [...] -- [...]' ericmeldrum~/git_homework[master]$ git log --pretty=oneline c32fdeab18b075f76ff275bd43c25b60afb9b241 (HEAD -> master) Add quote b1b876e33780d472f3aa2b2779957b9ae1cfbf32 Initial commit ericmeldrum~/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.
Great job, @ericwm76! Looks your formatting in your markdown got a little funky when pasting in your terminal output, but solid work!