Project 2: Creating Shell Commands Using Rust

Getting Started

If using Windows Subsystem for Linux (WSL), start with:

sudo apt-get update
sudo apt install build-essential

Then install Rust:

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

Install Visual Studio Code.

Click on the Extensions icon: Extensions Icon

Install:

  • rust-analyzer
  • Error Lens
  • Search crates.io
  • Even Better TOML
  • (On WSL) Remote Development

You can open a Unix shell within Visual Studio Code with CTRL-`.

Creating a Cargo Project

From a command line, type:

cargo new part1
cd part1/src/
mkdir bin
mv main.rs bin/cmd.rs

Then open VSCode and open the shells folder. Open bin/cmd.rs and paste in the code below:

fn main() {
    for arg in std::env::args() {
        println!("{arg}");
    }
}

To execute this program in the shell:

cargo run --bin cmd a b c

Assignment

Implement the following shell commands as Rust programs. You might find the fs module useful in writing many of these programs:

  • dir: Prints out all of the names of the files and directories in the current directory. It will not employ any command-line arguments.
    • Source file: src/bin/dir.rs in the part1 project.
  • destroy: Delete every file in the list of command-line arguments.
    • Source file: src/bin/destroy.rs in the part1 project.
  • newname: This program expects two command-line arguments. It will give a “usage” message if it does not receive them. It will change the name of the file given by the first argument to be the name given by the second argument.
    • Source file: src/bin/newname.rs in the part1 project.
  • duplicate: This program also expects two command-line arguments. It will give a “usage” message if it does not receive them. It will make a copy of the file given by the first argument with the name given by the second argument.
    • Source file: src/bin/duplicate.rs in the part1 project.
  • start: Prints out the first ten lines of each file listed in the command-line arguments. If the first argument begins with a dash, use the number immediately following the dash instead of ten.
    • Source file: src/bin/start.rs in the part1 project.
  • counter: Prints out the number of words, lines, and characters for each file listed in its command-line arguments. If the first argument begins with a dash, the letters “w”, “l”, and “c” immediately following the dash indicate which of words, lines, and characters get displayed.
    • Source file: src/bin/counter.rs in the part1 project.

Submissions

  • Share the part1 project as a private GitHub repository.
  • Submit your GitHub URL via Teams.

Assessment

  • Level 1: Any three programs correctly completed.
  • Level 2: Any five programs correctly completed.
  • Level 3: All six programs correctly completed.