The tools required for this book include the .NET SDK, VS Code, and the C# extension
(a VS Code extension). In addition, we will also use the command line interface
(CLI, the Command Prompt in Windows or shell in macOS/Linux, or just “the terminal”)
for certain operations from time to time.
A software development kit (SDK) is a collection of software development tools in one installable package.
They facilitate the creation of applications by having a compiler, debugger and sometimes a software framework.
SDKs are normally specific to a hardware platform and operating system combination. [1][2]
Runtime:
As part of the .NET SDK, the .NET runtime is a virtual machine that converts the compiled intermediate code into
machine code to be executed on the CPU. In addition, the .NET runtime provides an environment, that performs
services such as exception handling and garbage collection.
Having some knowledge of using the command line interface (CLI, often referred to as command prompt in Windows,
“shell” in Linux/macOS, or command line/terminal in general) is necessary when learning how to code.
Major operating systems all have CLIs for users to interact with the
operating system by issuing text commands in the terminal rather than using the graphical user interface
(GUI). Different operating systems are shipped with different default terminal applications
(or “terminal emulators” as they emulate the locally-attached dumb terminals).
When we open a terminal application, a default shell program is running as a command line interpreter program
that takes commands from users for execution. The terminal applications can run
different shells and they work similarly. For Windows, the default shell is PowerShell; for macOS it is
the Z shell (Zsh); and for Linux OS distributions, it is usually the Bourne Again Shell (Bash).
When you open the CLI application, you use the keyboard (without a mouse) to issue text commands. In the terminal,
you see a command prompt (user_name@computer_name:~$ for macOS/Linux or C:\Users\user_name>
for Windows) followed by a cursor (maybe blinking), which is where you type to issue your commands.
For Windows users, you may issue wsl to switch from the default PowerShell to Windows Subsystem for Linux (wsl)
to use Bash as your shell. Your command prompt will change to user_name@computer_name:/mnt/c/Users/user_name$.
For the purpose of this book, you may use PowerShell and use the Bash commands with a slightly different interface.
Unix-like OSs (such as Unix, macOS, and Linux) system are file-based, meaning the design principle dictates that
everything in the system is a file, and the files are organized as a tree-like file system structure. In the
command line, a file path is then used to specify the location of a file in a the computer’s file system structure.
The file system structure begins with the root (/), with a number of default first level directories representing the
functionalities. For example, oen of the first the default location after logging in is the user’s home directory, which is specified
as /home/USER_NAME.
To start navigating around the file system structure, some of the essential commands include:
ls (list storage) to show the files and directories in the current directory
pwd (present working directory) to see the full path of the current directory
mkdirfolder (make directory) to create a new directory called folder
cd*path* (change directory) to change in the path directory in the directory tree structure (path “..” means the upper level directory).
^+C (hold the Control key and then hit the C key) to terminate a process.
touch*filename* (Mac) to create an empty file.
new-item*filename* (PowerShell) to create an empty file.
exit to exit out of the terminal app.
Some special pathname characters are commonly used for specifying paths:
/ is the root of the system’s file directory tree structure
~ is the user’s home directory
.. is the pathname of the directory one-level up of the current directory
. means the current directory; but when placed at the beginning of a file, it makes the file a hidden file.
1.3.2.1. Exercise: Creating Directories and Files
As an exercise, please:
#. Terminal application: Open your terminal app (Windows PowerShell or macOS Terminal).
#. Create directories:
Create a directory called workspace in your home directory (mkdirworkspace), then change directory into the workspace directory (cdworkspace)
Create a directory called tests in the workspace directory ((mkdirtests)), then change directory into the tests directory (cdtests).
Create a file: Create an empty file called test.txt (new-itemtest.txt for Windows and touchtest.txt for macOS).
Make sure the files is created: Use the list storage command (ls then Enter) to list the files to make sure the file test.txt is created.
Change directory to your user home directory: Change your location back to the user home directory (cd../..).
Exit out of terminal app: exit then Enter to exit.
The whole process should look similar to this in Windows:
PSC:\Users\tcn85>mkdirworkspace### create the workspace directory in user home directory
PSC:\Users\tcn85>cdworkspace### change directory into workspace
PSC:\Users\tcn85\workspace>mkdirtests### create the tests directory
PSC:\Users\tcn85\workspace>cdtests### change into the test directory
PSC:\Users\tcn85\workspace\tests>new-itemtest.txt### create an empty file; use "touch test.txt" if you use macOS.
PSC:\Users\tcn85\workspace\tests>ls### list storage to see the file
test.txt
PSC:\Users\tcn85\workspace\tests>cd../..### change to the upper directory twice
PSC:\Users\tcn85>exit### exit --> Enter to leave the terminal
If you use macOS, the process should look similar enough:
Creating a workspace directory, tests subdirectory, and a test file in macOS.
Note that:
- To rename a file or a directory, use the mv (“move”) command. For example:
mvist_1551introcscs will rename a folder called ist_1551 to introcscs.
- To remove/delete a file, use rm*file_name*.
- To remove an empty directory, use rmdir*directory_name*.
- To remove a directory and all its content, use rm-rf*directory_name*.
Integrated development environment (IDE) applications play a critical role in software development workflow and
usually contains tools such as source-code editor, build automation tools, and a debugger.
IDEs commonly used by professionals developers are: Visual Studio Code, Visual Studio, IntelliJ IDEA, Notepad++, and Vim.
Visual Studio Code (VS Code) is an editor with plenty of features. It has turned from a text
editor into an integrated development editor (IDE) with a large number of
extensions available to enhance and enrich its tools and features. A great advantage of learning
VS Code is that it is extremely versatile. Once you learn how to use it, you can use it for
almost every other programming languages and technology as long as they involve editing and coding.
Visual Studio Code remains the preferred IDE across all developers. [3]
Terminal: In the Panel section (), you have access to the TERMINAL and other console tabs. Note that:
The TERMINAL is exactly the same as your terminal application.
When you open a project by issuing code. in the project directory, the terminal will be default
to the project directory.
You may use Cmd+J (Ctl+J) to toggle the Panel to use the terminal.
Command Palette: In addition to the UI elements, an important key combination to learn is
Ctl+Shift+P on Windows and Linux, or Shift+Command+P on Mac. Command
palette gives access to all the functionalities within VS Code. For example,
if you type .NET at the command palette, you get to access the .NET commands
and features as follows.
While VS Code and .NET templates have made coding C# easy, a REPL (Read–Evaluate–Print-Loop, or
language shell/interpreter) provides immediate execution and result return, which can be very useful
as you get to see immediate feedback of your code. This means direct execution of C# code
without creating projects and files.
Installation: CSharpRepl can be installed by issuing dotnettoolinstall-gcsharprepl.
Usage: CSharpRepl is invoked by using the csharprepl command at terminal/command line.
CSharpRepl is good for:
Rapid experimentation and exploration of C# syntax and features.
invoke it in the VS Code terminal. That way, code editing and quick syntax testing are in one place.
There are plenty of development tools that are worthy of our time to learn, except that we would
not be able to learn all of them in one semester. A short list of those tools would include: