Week 2 - Intro to Command Line and Text User Interfaces

Date: 2025-01-29

Overview

Our Desktops

Reminder of desktop metaphors:

Macintosh desktop program Magic Cap

We’ll review our homework from the past week.

Text User Interfaces

Note for Windows users: I’m sorry to say this, but the standard text interface is Linux! Macintosh computers have access to this under the hood because they are built on top of BSD, which uses the same commands as Linux. PC users, your Windows Powershell is fundamentally different, and so you should use Windows Subsystem for Linux.

Text User Interfaces

Last week we looked at a history of interfaces and operating systems.

Review: What is a User Interface?

Yet with its creaky, decades-old constraints and inexplicable quirks, the command line is still the most versatile corner of the computer. It lets you pull back the curtain, see what’s really going on, and creatively interact with the machine at a level of sophistication and depth that GUIs cannot afford. It’s available on almost any laptop, for anyone who wants to learn it. It can be used interactively, or it can be automated. And, it doesn’t change as fast as other parts of the system. There is creative value in its stability. –source: Command Line Interface Guidelines

In the early years of computing, we had circuits, switches, lights, and dials. Later came punch cards for calculations and storing data and programs. Still later came terminals, which were monitors connected to a computer. We input commands to the computer through a Teletype typewriter. Output would be printed out or displayed on the terminal monitor.

Computers are complex. IC chips that computers were built from, especially in the earlier years, were expensive. Because of this, computers had a minimal amount of memory. Text was much easier to store and work with, so the priority was placed on text. This became the primary way to interact with a computer.

Video: keyboards and command line interfaces on youtube - PBS Video, 11min

example command line interface
example command line interface

The command line interface is a text-only interface. Where the user types in commands is known as the prompt. A user types in commands; then the output is displayed immediately. And a user may then type in more commands, with more output, in a continuous cycle.

Some advantages: - A “powerful” environment. Everything can be done on one screen, in one location. Commands can be combined together. - Commands are “conversational”. They can evolve over time, iteratively. - They can be automated.

Disadvantages: - “Discoverability” problem. Which commands are available? How do you use them? What options exist? - Expertise needed to get started and to advance. Not beginner-friendly.

Macintosh computers were the first mass-market computers to popularize taking a graphics-first approach to computer interfaces. The Mac Human User Interface guidelines were printed in 1987. They emphasized “see and point” instead of remember and type.

Hitchhiker’s Guide to the Galaxy Game
Hitchhiker’s Guide to the Galaxy Game

You can see in this screen a text-based game. These were similar to “Choose your own adventure” style books you may have read as a kid, or other branching narratives, but they had much more functionality. Not only did you advance in a story, but you had inventory, could solve puzzles, join battles and more.

This program uses a parser. The parser is the interface that runs through commands you type in and then executes code depending on your commands.

These types of games attempted to use a more natural language, but they could still have problems with their commands being unclear.

Over time, programmers attempted to use space and to make these programs more visual.

Text User Interface example
text user interface example

simpler text user interface example
A simpler text user interface example. You can see how this approaches a traditional graphic user interface in design.

These kinds of programs that run in the command line are called Text User Interfaces.

file manager
a file manager program, an alternative way to view the desktop

Some of these programs started using color. They can be quite complex.

email - microsoft exchange
This is an example of Microsoft Exchange, the email system our school uses, navigated in DOS with a Text User Interface.

You’ll notice this program almost appears to be a GUI. It even has menus.

Google in w3m
Here is a web browser running in the command line, searching on Google.

Keyboards and Command Line Interfaces from PBS

Keyboards and Command Line Interfaces, on PBS, 11 minutes

Workshop

Basic commands today

To move around:

cd [foldername]

To move around (“change directory”) in folders on our computer.

ls

To list files in a folder.

pwd

To remind you what folder you are in. (aka “print working directory”)

cat [filename]

This prints out the text of a file onto the screen.

man [program-name]

This starts up the computer manual for a command line program. You can scroll up and down and press Q when you are finished reading to exit.

echo "text"

Prints out text.

When you get stuck, Control-C usually is the CANCEL command. Though a few use Control-D.

Workshop: Creating simple text user interfaces.

BASH

#!/bin/bash
# Ask the user for their name

echo "Hello, who am I talking to?"
read varname
echo "It's nice to meet you $varname"

In-class: Pizza Order Calculator

Your goal: design command line software for determining the total number of pizzas to order for a group of people.

Your software should be useable by a variety of people, from beginners to command line interfaces to advanced users.

Your program should have help, be intuitive, and ideally, powerful.

At minimum, your program should ask for the total number of people, then print out the ideal number of pizzas to order.

Other optional things to consider adding: Do you want to tailor your program for kids vs adults, how hungry you are, various sizes of pizza, or what toppings people like?

Things to consider: - adding ascii art - adding a menu - adding help - adding “power features”

Please note that there is not one definitive best way to calculate. Figure out a formula that seems right to you. You will see a variety of potential formulas online, including the “3/8” rule.

Command Line Interface Resources

Homework: Code a Text User Interface

Due in 2 weeks:

Work with a partner to design a Text User Interface for a program of your choice. You could make music playing software, a countdown timer, a program that reads aloud to the user, a to-do list maker, a meditation app, a sleep machine, or something else.

Create a menu by printing out options for the user.
Use the select command to run a function based on the user selection.

In class we learned you can combine command line software together. In this assignment you should consider what building blocks from BASH you will use to make your software. We can consider gluing these program bits together similar to sticking together lego blocks.

Recommended program parts to use in your software:

# this is a comment. Use them!

echo "some text" # prints text out

echo -e "some text
on two lines"

read -$ "Enter your name " yourname
#Prompts with "Enter your name" and saves in $yourname
#Don't forget variables are used starting with $

say "something" # speaks text out loud

afplay file.mp3 # plays an audio file

sleep 10 # sleeps (waits) 10 seconds

This should be all you need to make an interesting basic CLI program. You are welcome to use other BASH commands and programs as well.

Your final program will be due in 2 weeks. In addition to a function piece of software, consider how a prominent title, emojis and/or ascii art could help or hinder your software. How can color help make your interface more useable and/or fun? How can you make the program more discoverable with help?

You have two weeks to finish your CLI program. For homework, continue to work with your partner on your CLI program, getting the main concept developed along with creating your working program loop. You will likely have a loop that checks for user input, then displays a result based on what the user selects from a menu. Next week we will be doing user testing and build in a ‘help’ command to our programs.

Homework: Reading

Due Next week:

Read the excerpt from Design/Interface in The Interface Experience, up to page 58 in the book (which is 23 pages of the pdf).

Write: In The Interface Experience what concepts from earlier media theorists, technicians and designers stick out to you that can inform our user interface design work?

Homework: User Interface Wall of Shame

Due Next Week: