We have updated the content of our program. To access the current Software Engineering curriculum visit curriculum.turing.edu.
Introduction to the Terminal
Learning Goals
- Understand what the terminal is and use of it is essential
- Fluently navigate a directory structure with bash commands
- Fluently create and remove directories and files with bash commands
Vocabulary
Terminal
A program that allows a user to interact with The Command LineShell
A low level interface for your computer. Instead of pointing and clicking on things, you type words and run commandsThe Command Line
The same thing as a shell - often used interchangeablybash
A particular type of shell found on Unix systemsDirectory
Same thing as a Foldercommand
- A set of instructions for the computer to execute - provided via the command lineargument
- A piece of information needed to run a certain command ie.touch sample.txt
where sample.txt is the argument
A note on interchangeable terms above
Most people use the terms terminal
, shell
, command line
, and bash
interchangeably.
That’s okay! The problem comes when they’re used incorrectly.
Here’s a few examples of correct usage:
- “Can you increase the font size of your terminal?”
- “We need to open up the command line here.”
- “Let’s use the shell for this task.”
- “I don’t like using bash - I think fish is better”
Additionally, there’s a Mac application just called Terminal
. That’s a specific program that accesses the command line.
Why Programmers Use The Terminal
You’re not as fast as you think
You probably grew up around computers, but if you’re like most of the non-developer population, you may have never touched the terminal. Why would you need to? Everything you need to do can be done on the desktop or through the Finder, and only super nerds use the terminal anyway. Right?
Well, no…
You might be thinking to yourself “Hey, wait a minute! I’m pretty fast when it comes to using my mouse to get around. Why do you think I need to use the terminal?”
Efficiency and Competency Show
It turns out you actually aren’t fast enough. As a developer, everything you do should be based on speed and efficiency. When any part of your work flow is lacking, you are wasting time. Over the course of a day, every extra second compounds into time you aren’t spending doing productive work. Not being a fluent user of your command line is a pain point that may not be terribly noticeable as you first start writing code and you’re still gaining momentum, but over time as you work more quickly you (and your pairing partners) will absolutely feel it.
Additionally, in an interview or workplace environment not being able to effectively use your terminal is a red flag. That is why it’s important to start flexing your command line muscles right away to build understanding and comfort with this tool.
Terminal-Only Tools
Additionally, some of the tools you will use as a developer can only be used through the terminal and not by clicking in a program.
Getting Started
The terminal seems scary at first - no graphics, all text, little to no feedback, and you might be worried about deleting everything in your computer.
Don’t worry! You are not going to break your computer. It’s easy to fear the unknown and let it keep you from learning how to efficiently use the terminal. But if you push past the first day or two of feeling uncomfortable, you’ll become great at using the terminal in no time.
When you’re first starting to learn anything coding related, you have to build up your muscle memory. It’s totally normal to start slow and improve with focused practice and repetition. You’re not going to learn unless you actually get your hands dirty and dive right in!
Let’s actually start working on some basic interactions with our files using the terminal. We’re going to assume that you’re using a Mac for this lesson.
Open your terminal using cmd + spacebar
, then type terminal
, and press enter
. The mysterious black window appears…
Side Note - Keyboard Shortcuts for Efficiency
cmd + spacebar
will open your spotlight searchcmd + tab
will take you to your most recent open application
Observe the File Structure: pwd
, ls
When you open up your terminal, you aren’t greeted with much. It just says your name and that’s about it. Typically when you open up your terminal you are brought to your root directory. Directory
is just another word for folder. Your root directory usually contains:
|- Applications
|- Documents
|- Desktop
|- Music
|- Pictures
(and other directories depending on your computer)
Must-Know Commands
We will dive into the details shortly, but here’s a quick preview of the commands you should be fluent with by the end of this lesson:
pwd
ls
cd
mkdir
touch
rm
rmdir
man
On the graphic organizer provided, complete each column for the command as we discuss it in class. If you aren’t sure how to complete a given box, please let your partner or instructor know!
pwd
(print working directory)
Let’s first get a handle of where we are in our computer’s file structure. To see where you are located in the file structure, enter pwd
in the terminal. This stands for your present working directory. If you are in the root directory, it will most like say /Users/[your name]
. If you ever forget or are confused about where you are, then use pwd
to find out!
The return from this command will be the name of the directory you are currently in.
This is equivalent to referencing the top bar in the finder:
ls
(list)
In the terminal, we don’t have Finder to graphically tell us what is contained within a directory or nested directories, but we do have commands to help us.
We can use the command ls
to list the content in our current directory. You can see directories and files in the current directory, but you cannot see directories and files that are inside other directories.
The return from this command will be a list of all contents inside your current working directory.
ls
doesn’t explicitly tell us what is a directory and what is a file, as compared to the finder which provides an icon the the left of each item inside a directory. We can, however, determine this by observing if a specific item in a directory has a file extension or now. For example, .png
, .js
, etc.
Try It
- Open your terminal and enter the command
pwd
. What do you see? Can you find this same location using Finder? - Enter the command
ls
. What directories and files do you see? - Enter
ls -la
. How does this list change? Do you see the same files and directories when you use Finder?
For a more detailed list of content, we can use ls -la
- note the space between the characters. The addition of -la
gives more information about when that file or directory was last modified, permissions, and also lists hidden files/directories.
Move Through the File Structure: cd
cd
(change directory)
If we are in our root directory and we want to see what files are within the Desktop directory, we currently don’t have a way to do that. For instance, if we are in the root directory, and we enter ls
in the terminal, it will just list the files and directories in the root directory, but we cannot see what is inside Desktop by only using ls
.
To see what is in other directories, we can move around and navigate through our file structure. We want to change into the Desktop directory to see what is inside it.
To change our current directory, we use the command cd [directory name]
. This is the equivalent to double-clicking a file in Finder, or clicking the little arrow to the left of the folder icon.
There is no return value for this command.
We can move through directories in two directions: up or down - to a previous directory or to a nested directory. If you want to go back to the gender_gap
directory, then use a space two periods after the cd
command: cd ..
to go back up one level. With the previous example where you are currently in the notes directory, you would type cd ..
to get to the Desktop
directory. This is the equivalent to clicking the back button or clicking that arrow to the left of the folder icon again, to collapse the contents of that folder.
There is no return value for this command.
Make Folders & Create/Remove Files: mkdir
, touch
, rm
mkdir
(make directory)
Creating a folder/directory is something that you will be doing often. A way to create a new folder is using the mkdir [dir name]
command. What this will do is create a new folder for us with whatever name you want to give it.
Note: A common way to document how to use a command is the command name, mkdir
, and then something within square brackets, [dir name]
. The first part, mkdir
, is the text that the terminal recognizes as a command. The second part, [dir name]
, is the part where you will specify the new directory’s name. The square brackets mean that this is a place for you to fill in your own information, but you do not include the square brackets.
There is no return value for this command.
How do we check that the directory was made? Use ls
to check that it is listed.
Keep in mind that even though you’ve created this folder, it doesn’t mean you are inside of that folder you’ve just created. To actually go into our new folder, you need to change into that new directory.
touch
(create file)
Similar to directories, we also need to be able to create new files. The command we are going to use to do this is the touch [file name]
command. There doesn’t seem to be a Finder “equivalent” for this command!
There is no return value for this command.
rmdir
(remove directory)
We also need a way to remove a directory. We can use the command rmdir [directory name]
when navigated to its parent directory.
There is no return value for this command.
rm
(remove file)
So we can make directories and new files, but we want to be able to remove them. That is where the rm
command comes in. If we’re not happy with our new-file.html
file, then we can delete it.
There is no return value for this command.
As you can see there was no warning such as, “Are you sure you want to delete this file?…” Be careful with this command because you can’t undo it.
Try It
- Open a new terminal window. Create a directory called
terminal-practice
. Navigate into that directory, then follow the steps below. - Create three different directories (with different names). Double check that all of the directories are listed in your current directory. Delete all the directories.
- Create five new files with different file names. Double check that all the files are listed in your current directory. Delete all the files you just created.
- Now, create three new directories, each with 2 files inside of them. Then delete both files in a directory, then the directory. Repeat until your
terminal-practice
is empty!
Tab Autocomplete
Tab completion is your friend when you don’t want to type an entire directory name or you don’t quite remember how something is spelled. To utilize this tool, start typing the first part of a file or directory, then hit tab
. The terminal will auto-complete the rest of the desired file or directory name for you.
Nested Directories
What if you want to change to a directory that is inside another directory? You can imagine that using cd
multiple times would get tiring and slow. If we have something multiple levels deep we can keep adding directories to our cd
command. Say we have:
|- Desktop
|- turing
|-- class-work
|--- terminal-practice
If we’re in Desktop
and we want to get to terminal-practice
quickly, then we can do this with one command: cd turing/class-work/terminal-practice
Likewise, we can also go back up multiple directories using one command. If you are in the terminal-practice
directory and you want to go back to the turing
directory, then you can use the double dots as before with the slash separator: cd ../..
Try It
- In your terminal, change to your root directory. Your root directory is noted as a
~
symbol. So the change directory command would becd
. From there,cd
into your Documents directory. - Now, list the contents of the Documents directory.
- In your Documents directory, make a new directory of your choosing. Change into that directory, and make another new directory. Repeat this three times. When you are done, delete the directories you just made, one directory at a time.
Commands From Your Present Working Directory
Using cd
, you can move around directories and add files in the directories where we need them. However, moving around to other directories can get tedious and time consuming.
From our present working directory, you can add files or directories anywhere in our file system by adding our “directory path” in our terminal commands.
Create Files
Going back to mkdir
and touch
, you can chain on directories if you want to add files inside other directories. Say you have these directories:
|- turing (your present working directory)
|-- mod1
If your present working directory is turing
, then you can create a new file inside mod1
using one command: touch mod1/new-file.txt
. This command includes the directory and then the new file you want to create. You don’t have to cd
into mod1
. With this command, you end up with:
|- turing
|-- mod1
|--- new-file.txt
Create Directories
The same can be done with making new directories. With our current running example, let’s add a directory inside the mod1
directory. Again, if your present working directory is turing
, then you can do this with one command:
mkdir mod1/new-directory
We end up with:
|- turing
|-- mod1
|--- new-directory
|--- new-file.txt
Try It
- Change to your root directory if you are not there already. How did you do this? With these next tasks, do not change into other directories. Keep your root directory as your present working directory.
- Make three nested directories
- In each nested directory, create a file
- Remove all of the directories and files that you just created - one directory at a time
Move and Copy Files/Directories: mv
, cp
Now that we can create and remove files, let’s add to our toolbox the ability to copy or move files. At a high level, mv
takes the source file and moves it to a new location. cp
keeps the source file and copies the file to a new location.
mv
(move)
If we want to move a file, then we use the mv
command with mv [source] [destination]
. It will take file that was provided as the first argument and move it to live in the directory that was provided as the second argument.
Let’s say we have the directory structure below:
|- turing
|-- notes
|-- projects
|--- project-1.html
Oops - project-1.html
should live inside the projects
directory. While inside the turing
directory, we can run:
mv project-1.html projects
and the project-1.html
file will be moved into the projects
directory.
Try It
Make a few nested directories with blank html
files in them, and move files around from directory to directory to practice using mv
.
cp
(copy)
The copy command, cp
, has two options you need to enter: cp [the thing you want to copy] [where you want to copy it to]
, or more simply cp [source] [destination]
.
If we have a file named sample.txt
in this turing
directory, and we want to copy it inside the notes directory, then we can use this series of terminal commands.
Current state:
|- turing
|-- sample.txt
|-- notes
Goal:
|- turing
|-- sample.txt
|-- notes
|--- sample.txt
If we are in the turing
directory, then this is how we move the file:
cp sample.txt notes/
Finding out how to use these commands on your own
man
(manual)
The internet can be an invaluable resource when you’re trying to find out more
about how to use specific terminal commands. However, there is also good
documentation built in, via the man
command.
man
opens up the manual for whatever command you have questions about. Once
you’ve found out what you need to, you can type q
to get back to the terminal.
If I wanted to find out how exactly I use the cp
command, I could read the
manual entry like so:
man cp
Try It
We already saw that ls
can take some options, when we used ls -la
. Go ahead
and use man
to find out what other options we could use with ls
.
Wrap Up
From this point forward, you should not be using the Finder. Challenge yourself to use the terminal for navigation. It will be painful at first, but you can’t get fast without starting slow!
Working efficiently in the terminal is an essential skill for developers, and we’re going to support you in building it now. We expect that you use the terminal only while working alone, pairing, and in evaluations.
Take some time to review this cheatsheet of commands.
You don’t need all of the commands, or even most of them - but try out a few that seem interesting to you.
The documentation for each command in the terminal is available if you type man [command]
. For instance, man cd
. Once you’re done viewing the manual page, enter q
to exit.
If You Are Feeling Like You Need More Practice
Use this short course to practice: Learn the Command Line from Code Academy
If You Are Feeling Pretty Comfortable
Continue on and complete the advance topics, listed below:
Copy Paste for File Contents: pbcopy
, pbpaste
It’s likely that copy-and-pasting is a big part of your life. You might think that doing something like this is in the terminal could be frustrating. In actuality it’s not that difficult.
In this case pbcopy < [file]
& pbpaste > [file]
copies the context of one file and pastes the contents into another file.
For example, let’s say we have a file hello.txt
with the content Hello World!
written inside of it, and we want to copy that text into a file named aloha.txt
.
- Copy the contents from
hello.txt
:pbcopy < hello.txt
- Paste it into the
aloha.txt
file:pbpaste > aloha.txt
Now the aloha.txt
file has the contents Hello World!
.