Introducing the Shell
What is a shell?
A shell is a computer program that presents a command line interface which allows you to control your computer using commands entered with a keyboard instead of controlling graphical user interfaces (GUIs) with a mouse/keyboard/touchscreen combination.
There are different types of shell such as Windows Powershell, Windows Command Shell, Bash and zsh for Mac computers.
For this workshop we will be using Git Bash, which is a command-line shell that enables Git commands and provides some unix based shell utilities but not all of them. The commands that we will be exploring can be also used in a zsh (Mac Terminal) or PowerShell (Windows Shell) with very little or no modifications.
It is important to consider that Git Bash may not be compatible with other command line programs, and it is recommended to use Windows Linux Subsystem, a Linux Distribution if you plan on working with a Linux enviroment in a Windows machine.
Why should I learn Shell?
There are many reasons that may benefit you from learning about about the shell:
- Automate repetitive tasks. If you often need to repeat tasks with a large number of files, with the shell, you can automate those. 
- Make your work less error-prone. The shell makes your work less error-prone. When humans do the same thing a hundred different times (or even ten times), they’re likely to make a mistake. Your computer can do the same thing a thousand times with no mistakes. 
- Make your work reproductible. By using the command-line, the your computer keeps a record of every step that you’ve carried out, which you can use to re-do your work when you need to. It also gives you a way to communicate unambiguously what you’ve done, so that others can inspect or apply your process to new data. 
- Save on computing capacity. Sometimes, when we work with data some tasks may require large amounts of computing power and can’t realistically be run on your own machine. These tasks are best performed using remote computers or cloud computing, which can only be accessed through a shell. 
- Get advantage of the command line tools. Many bioinformatics tools can only be used through a command line interface. Many more have features and parameter options which are not available in the GUI. BLAST is an example. Many of the advanced functions are only accessible to users who know how to use a shell. 
The Git Bash Window
As you open your Git Bash Window, you may see something like the following:
ComputerUserName-####ABC MINGW64 ~
$The dollar sign is a prompt, which shows us that the shell is waiting for input; your shell may use a different character as a prompt and may add information before the prompt. When typing commands, either from these lessons or from other sources, do not type the prompt, only the commands that follow it.
This symbol may be different if you are using a Linux or Mac computer.
Exercise
Use the -l option for the ls command to display more information for each item in the directory.
What is one piece of additional information this long format gives you that you don’t see with the bare ls command?
Command:
$ ls -lOutput: Note: This is an example
total 8
drwxr-x--- user user 4096 Jul 30  2015 sra_metadata
drwxr-xr-x user user 4096 Nov 15  2017 untrimmed_fastqThe additional information given includes the name of the owner of the file, when the file was last modified, and whether the current user has permission to read and write to the file.
No one can possibly learn all of these arguments, that’s what the help page is for. You can (and should) refer to the help page or other help files as needed.
Let’s go into the untrimmed_fastq directory and see what is in there.
Command:
$ cd untrimmed_fastq
$ ls -FOutput:
SRR097977.fastq  SRR098026.fastqThis directory contains two files with .fastq extensions. FASTQ is a format for storing information about sequencing reads and their quality. We will be learning more about FASTQ files in a later lesson.
Shortcut: Tab Completion
Typing out file or directory names can waste a lot of time and it’s easy to make typing mistakes.Instead we can use tab complete as a shortcut. When you start typing out the name of a directory or file, then hit the Tab key, the shell will try to fill in the rest of the directory or file name.
Return to your home directory and navigate to your desktop.
Command:
$ cd 
$ cd Desktop
$ cd unix_lessonUse the tab shorcut to return to shell_data directory.
$ cd she<tab>The shell will fill in the rest of the directory name for shell_data.
Now, change directories to untrimmed_fastq
$ cd un<tab><tab>Using tab complete can be very helpful. However, it will only autocomplete a file or directory name if you’ve typed enough characters to provide a unique identifier for the file or directory you are trying to access.
For example, if we now try to list the files which names start with SR by using tab complete:
$ ls SR<tab>The shell auto-completes your command to SRR09, because all file names in the directory begin with this prefix. When you hit Tab again, the shell will list the possible choices.
Command:
$ ls SRR09<tab><tab>Output:
SRR097977.fastq  SRR098026.fastqTab completion can also fill in the names of programs, which can be useful if you remember the beginning of a program name.
Command:
$ pw<tab><tab>Output:
pwck      pwconv    pwd       pwdx      pwunconvDisplays the name of every program that starts with pw.
Summary
We now know how to move around our file system using the command line. This gives us an advantage over interacting with the file system through a GUI as it allows us to work on a remote server, carry out the same set of operations on a large number of files quickly, and opens up many opportunities for using bioinformatic software that is only available in command line versions.
In the next few episodes, we’ll be expanding on these skills and seeing how using the command line shell enables us to make our workflow more efficient and reproducible.
Lesson Keypoints
- The shell gives you the ability to work more efficiently by using keyboard commands rather than a GUI.
- Useful commands for navigating your file system include: ls,pwd, andcd.
- Most commands take options (flags) which begin with a -.
- Tab completion can reduce errors from mistyping and make work more efficient in the shell.