UNIX for people : a modular guide to the UNIX operating system : visual editing, document preparation, & other resources 0139374590, 9780139374593


803 126 26MB

English Pages 568 Year 1985

Report DMCA / Copyright

DOWNLOAD PDF FILE

Recommend Papers

UNIX for people : a modular guide to the UNIX operating system : visual editing, document preparation, & other resources
 0139374590, 9780139374593

  • 0 2 0
  • Like this paper and download? You can publish your own PDF file online for free in a few minutes! Sign Up
File loading please wait...
Citation preview

CltNiat PATHOLOGY SERVICE (113A) VA MEDICAL CENTER 4150 CLEMENT STREET

SAN FRANCISCO, CA 94121

,

v,\Cl'|

CUBICAL PATHOLOGY SERVICE (213V VA MEDICAL CENTER 4150 CLEMENT STREET SAN FRANCISCO, CA 94121

RECEIVE"' JUL

1

8 1985

Digitized by the Internet Archive in

2017 with funding from

Kahle/Austin Foundation

https://archive.org/details/unixforpeoplemodOObirn

UNIX A Modular

Guide

for People

to the

UNIX

Operating System:

Visual Editing, Document Preparation,

&

Other Resources

% *

%

i!:

' i'

i

t

*

I

I

^

-

q

UNIX ‘for A Modular

Guide

to the

People

UNIX

Operating System:

Visual Editing, Document Preparation,

Peter Patrick B.

M.

&

Other Resources

Birns

Brown

John C. C. Muster

Prentice-Hall, Inc., *

UNIX

is

a

Englewood

trademark

Cliffs, N.J.

of Bell Laboratories

07632

Library of Congress Cataloging in Publication Data

Bims.

Peter.

UNIX

for people.

Includes index. I.

UNIX (Computer

Patrick

U N

I

B

II.

operating system)

Muster. John C.

III.

I.

Title.

Brown. IV. Title:

X, for people.

OA76.6.B5725 1984 ISBN 0-13-937459-0 ISBN 0-13-937442-6 (pbk.)

UNIX

is

a

84-10678

()01.64'2

trademark of

Bell Laboratories

Editorial / production supervision: Barbara

H. Palumbo

Cover design: Celine Brandes, Photo Plus Art Manufacturing buyer: Anthony Caruso Page layout: Peggy Finnerty, Jill Packard, Toni Sterling Photographers: John C.C. Muster, Patrick B. Brown, Peter M. Birns Typesetting: Patrick B. Brown, Peter M. Birns, John C.C. Muster Illustrations: Kevin Daly and Dana Cuff

©1985 by

Peter

M.

Birns, Patrick B.

No

All rights reserx'ed.

Brown, and John C.C. Muster

part of this publication

may be

reproduced,

stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without

prior written permission of the publishers.

Printed in the United States of

10

9

8

ISBN:

7

6

5

4

3

America

2 ..

1

0-13-'t37MST-D

-13-T37MMB-b IPBK.I Prhntice-Hali. Internahonal. Inc., London

Prentice-Hall oe Austraita Pfy. Limited, Sydney Editora Prentice-Hall do Brasil, Ltda., Rio de Janeiro Prentice-Hall Canada

Inc., Toronto

Prentice- Hall of India Private Limited,

New

Delhi

Prentice-Hall of Japan, Inc., Tokyo Prentice-Hall of Southeast Asia Pie. Ltd., Singapore

Whitehall Books Limited,

Wellington,

New Zealand

D1

Contents

Foreword Preface

Hi

Introductory Modules One

How

Two

Accessing the

Three

Your

Four

Editing Files Using the Visual Editor

Five

Nroff Formatting

Six

File

Seven

Conceptual Overview

105

Eight

Advanced Visual Editor Commands

120

Nine

Advanced Formatting Commands The -ms Macros

142

Ten

A

to

Use This Book

UNIX

1

System

6 21

First File

Management

Stroll

Through

Commands with Shell

Commands

37 61 81

a

Full Production

Number

169

V

Modules Eleven

Twelve

The Line Editor Ex Special Search

177

and Substitution 203

Characters

\J

Thirteen

Truly Advanced Visual Editing

222

Fourteen

Communicating with Others

241

Fifteen

The UNIX Directory Structure

249

Sixteen

Account Management

272

Seventeen

Backgrounding

Eighteen

Parts

Nineteen

Phototypesetting with Troff

Twenty

Macro Construction

Twenty-One

Utility

Twenty-Two

Commands,

Activities

and Wholes

301

&

Troff -ms

Programs

355

and Directories: Paths, Bins, & Yellow Brick Modes Files,

Form

Twenty-Four

Special Formatting Topics:

&

A

Title Page,

Index

Twenty-Seven

404

A

Busboy’s Nightmare The TBL Pre-Processor

Setting Tables:

421

Equalizing Equations:

The EQN Pre-Processor Twenty-Eight

Troubleshooting

Twenty-Nine

Where

VI

392

Bibliographies and Footnotes:

The REFER Program Twenty-Six

366 382

Letters

Table of Contents,

\1

312 327

Twenty-Three

Twenty-Five

289

a Process

to

Now?

445

468 481

Command Summary

Section

Shell

488

Visual Editor

497

Format

.

507

Location of Material within the Book Index

518

Quick Access Chart

527

VII

aHr ‘•S*

€ t

}

i

4

«

t

V

•}

!?

n

Foreword

Why

Does Anyone Need a Book to Help Them Learn to Use UNIX? The UNIX computing environment enhances human pro-

No

ductivity. ity.

ing

other single reason can explain

its

growing popular-

Yet some would — be users have considerable how to use it, and others never learn to

Why

effectively.

is

this

so?

apocrypha nicely captures UNIX have

is

so

The

this

following

tap

power

its

of Bell Laboratories

paradox:

complicated

to teach the

bit

difficulty learn-

engineers

the

secretaries

how

to

use

it!

We

have observed similar activities in our own environments, so even if the quote is not a literal truth (and is a disservice to both secretaries and engineers), it is a useful illustration of the importance of the method by which one learns how to use UNIX, and learns how to use it effectively. The key here is that secretaries, and other people who need to use computers to get their work done, have the luxury of learning experientially — often in a supportive environment full of other users who have learned what they

know

in similar

fashion.

But there are problems with learning to use UNIX experientially. First, in the absence of a book like this, one must have access to the right kind of supportive environment, something difficult to find

outside

certain

institutions.

And

second,

the

experiential

It be self— limiting. is hard to develop, unilaterally, the requisite conceptual models which unlock the real power of the UNIX environment.

learning

Both

tends,

eventually,

experiential

One reason

to

learning and conceptual models are necessary.

analytically

inclined

would-be

engineers) have difficulty getting started ribly inefficient way of discovering the

is

users

(our maligned

that ‘‘analysis'’

skills

is

a ter-

necessary to be an L\

And

much

The problem with too much experiential learning is that, eventually, UNIX users come to the point where they enter a mere line of text and “mountains

effective

user.

move’*!

If

it

it’s

not

fun.

wasn’t the right collection of mountains, or they

didn’t go to the right place, experience rarely provides the explana-

here that an (analytical) model can help a user probe the process UNIX uses to execute his or her command, to reveal the source of the error. Lest the reader be intimidated by this, simple tion.

It’s

diagrams or a repertoire of well chosen examples can provide much of what is needed.

So most would — be UNIX users, especially ones who are learning how to use computers for the first time, need a good book — one that provides sufficient guidance for the experiential learning, and one which also helps consolidate the experience via the timely introduction of conceptual models.

Why UNIX.

This Book? It

This book addresses both barriers to learning provides guidance sufficient to allow computer — naive

users to learn

how

to use

so on their own, and

it

UNIX

experientially,

provides

how UNIX works, models

some of

necessary

for

even

if

they must do

the requisite models of

consolidation

of

the

The user “experiences” laid out fun and efficient. The experiences convey a

experientially acquired material.

by the authors are wealth of material, without seeming burdensome. Similarly, the models of editor— states, of the UNIX command interpreter, and of the hierarchical file system are clear, carefully pictorial, and essen-

They give the reader the confidence to engage moving with reasonable expectations for success.

tial!

in

mountain-

What Can Readers Expect To Be Able To Do Once They Complete It? Users who complete this book will be well on their way computing productivity. As the early focus is on word — processing and document preparation, readers begin getting real work done as soon as possible; and the exposition is sufficiently tool — oriented (again, tools are what one uses to get work done) so that readers will be able to learn to work in other arenas, such as program development and maintenance. The tool — building techniques illustrated are very general and are among the most powerful activities that UNIX facilitates. to

enhancing

their

Ultimately, the real power of

UNIX

methods it enables for getting work done with a computer. These methods are hard to articulate, computer scientists are struggling with them as we X

lies in

the

from examples. One of the strengths of this book is that its authors had to learn these methods, unconsciously, to complete their book. The book was a group effort resulting from the focus of different backgrounds on a single topic — how to teach people how to use UNIX. It has been field tested by students and staff, gone through numerous revisions and might never have been completed had it not been done using UNIX. Thus, the UNIX methodology is implicit in what the authors have done, and their real success is that they have communicated this experience to their readers. write,

but

they

can

be

learned

Mark

S.

Charles Michael

Tuttle

Woodson J.

Clancy

Computer Science Division

— EECS

University of California, Berkeley

March, 1984

XI

Preface

This book

UNIX. It was written over the span of two years, using a UNIX system. We began with the modest intention of providing our friends with some introductory, English language materials on how to text process with UNIX. It is a comment about the ability of the system to foster evolving group projects that our five page introduction grew into this book. One of Another modified and us wrote a few pages explaining how to. expanded the ideas. More was written, revised, combined, thrown out, synthesized, and rewritten— with the entire process taking place in one set of files in one UNIX account. is

a creature of

.

Our

desire

minimum

is

that

the

reader

of frustration learn

quickly,

how

to

.

efficiently,

and with

do what took us

a

collectively

over 10 years to discover concerning how to use UNIX. An understanding of the information presented here would allow you to create a product matching the detail and complexity of this book.

UNIX

is

a seductive beast.

We

several times, only to discover

mand, or had

a different

thought we had the text finished

some

way of looking

additional ideas, a at

new com-

the whole thing that just

be included. Because revisions are so easily accomplished with UNIX, we made the changes. to

What was

an introductory book on text processing and the visual editor (perhaps 200 pages at most) has grown into a more complete introduction to the entire UNIX Operating System. The expansion of our task was due largely to the feedback we received from students using drafts of the text in workshops and classes. Each group of students identified aspects of the system they wanted to know more about.

XU

originally intended as

We

computer

are not

educators.

We

scientists.

We

like

to

consider ourselves

selected and ordered the topics, wrote explanations,

and created conceptual maps with the goal of providing educationally sound, accessible material. Our objective was to remain truthful about how the system works and to present this information in an educationally effective way.

Three people— our respective partners — have made enormous con-

We

profoundly Without their support we could not have completed tributions

to

this

project.

are

in

this

their

debt.

book.

thousands who used this book in its various unpublished stages and gave us a chance to explore firsthand which parts of our efforts were effective and which needed additional work. Finally,

we

offer a sincere thanks to the cast of

Peter Patrick B.

M. Birns

Brown

John C. C. Muster University of California

Berkeley

'

V

# caog

Module One

How

to

wr

Use This Book

Introduction The UNIX operating system provides an effective and efficient way to compose papers, write computer programs, enter data, and maintain records. UNIX is a powerful system: there is virtually no what can be accomplished using and programs. Because it can do so much limit to

Due

its it

variety of is

commands

rather complicated.

complexity people have often found learning to use UNIX a frustrating and at times overwhelming experience. As a direct result of interacting with people as they learned UNIX and text processing we developed this modular, self-paced, ""low-jargon''' to

its

handbook.

Prerequisites None. It is assumed that the reader has no knowledge of computers, UNIX, or text processing.

Objectives The

objective of this

Module

is

to introduce

conventions and the modular format used effectively learn UNIX and text processing.

you

in this

to the essential

book so you can

1

The (a)

(b)

objectives of this

book

are the following:

Completion of Modules One through Ten will allow you to use the visual editor to prepare most research papers or reports and to enter and edit computer programs; Mastery of the individual Modules Eleven to Twenty-Nine will allow you to complete more advanced specific tasks, such as use special characters for searches and substitutions, send electronic messages to other UNIX users, create and easily

move among

several levels of directories, generate typeset

documents, access the UNIX preformatters which exist to help with bibliographies, equations, and tables, and write your own formatting commands (macros); and (c)

Completion prepare you

Modules One through Twenty-Nine will format a document or written project similar in

of to

complexity to

this

book.

Procedure (1)

Establishing an Account:

Make arrangements through your

super-

department, or system administrator for a UNIX account. Depending upon your location, you will need to obtain two or three pieces of information about your account:

visor,

(a)

you are located in a large organization in which there is a “network” of UNIX machines, you will be assigned to one of them and given a system name. You will need to know the name of the machine you are assigned. This information consists of a system name^ letter, or number,

(b)

Your account

(c)

Your account password.

If

login name',

and

Be certain you obtain the appropriate information about your account. Without this information you will not be able to gain access to UNIX.

(2)

2

How

People Learn:

has been our experience teaching courses and workshops in text processing that people: It

(a)

Learn

(b)

Learn best when they can about it;

Using

this

at different

Book

speeds; try

out each process as they read

(c)

Grasp ideas better

in

(d)

Remember more

effectively

self-contained units; if

they practice

commands and

procedures; (e)

Master complicated material most a “step by step” way; and

(f)

Better retain information

easily

when given

when

led

through

in

opportunities to review

recently learned material in self-diagnostic “quizzes.”

(3)

Using These Modules: Although we are firm believers in the educational value of getting lost and finding your way back home, UNIX can be a very unfriendly universe for someone who is off the path and unfamiliar with the rules. We suggest you allow us to hold your hand and lead you step by step through the basic procedures of the first ten Modules. Hundreds of people learning UNIX guided our design and revisions of the modular sequence and content of this book. You will find learning UNIX least frustrating if you study each section in order. Don’t skim over paragraphs, and be sure to try each procedure at least once. Avoid the pressure to hurry— relax and master each part. (a)

Each Module

(b)

Following the Introduction is a list of Prerequisites. you satisfy each prerequisite before proceeding.

(c)

The do

(d)

starts with a brief Introduction to set the stage.

you know what you completing each Module.

Objectives section lets

after

The Procedure

section

is

a

step by step

list

will

Make

sure

be able to

of actions you

should take and explanations you should read. (e)

Exercises,

reviews and self-check questions are an integral

part of the procedures.

Taking the time

them

ability to

will

improve your

you may surprise yourself with (f)

(g)

to

perform or answer

remember the material (and what you know how to do).

You

will

The

following conventions are used throughout this book.

be asked to type in text as you proceed through the book. Don’t begin learning text processing with a paper or other written material that is important to you! Practice with something you can afford to lose.

All

UNIX commands

are in boldface type.

When you

Using

this

are to

Book

3

supply information to a command sequence (such as your own password) the requested word\ will be put inside a box |

(h)

\

Be patient with yourself. There it

can be frustrating, but

it

is

a lot to learn

can be mastered.

about UNIX —

You

are better

few extra moments reviewing each section than rushing through the process. off taking a

(i)

(This

“types” in the crowd.) This book was written to be used with Bell Lab’s UNIX Version 7 with Berkeley enhancements (BSD UNIX). This material should be of use for instruction about any UNIX system that supports is

for the technical

the visual editor “vi.” currently available

— in

Due

many versions of UNIX to the many local variations in be some slight differences the

to

addition

implementation — there may between the procedures you should use and those presented in this book. These variations will be most pronounced when getting started or accessing the

UNIX system.

If so,

ask for

help getting “logged in.” (j)

We

have made every effort to insure that all suggestions are appropriate and command sequences correct. We have been through several drafts of these materials— and thousands of students have worked with many of the Modules — to eliminate errors and problems. Please be aware, however, that the sophistication and complexity of the UNIX Operating

System— coupled



with the various versions in use make the task of completely “bomb proofing” your experience essentially impossible. Before attempting to use a new procedure with your version of the Great American Novel or Nobel Prize-winning report you should first experiment with a prac-

Only then can you feel comfortable that the command or procedure will do what you want it to do. tice

(4)

file.

might be helpful (but is not necessary) to identify an experienced UNIX user (most college campuses have paid computer conIt

sultants, while in a business or office setting there will be familiar with the local UNIX system). Inform this

someone

individual of

your intention which logging

Two

4

to learn

UNIX with the help of

steps outlined in the are appropriate for your location.

Using

this

in

Book

first

book, and ask few pages of Module this

(5)

Modules One through Ten comprise the foundational core of the book and should be studied in the order presented. Each builds upon skills mastered in prior Modules. Modules Eleven to Twenty-Nine can be taken in any order, as long as all prerequisites are satisfied.

(6)

Proceed to Module

Two and

enjoy the learning process.

R,kett,

hungry

dtcides to

mr jmmortcdii/, ujrite his

autohiogruphy on the ^^processor.

Using

this

Book

5

Module Two Accessing the

UNIX System

Introduction In this

work

Module you

will

learn

how

to access

(logon) and finish

on your UNIX account. Four commands the kind of resources available on UNIX.

(logout)

to illustrate

will

be used

Prerequisites

You need through

to

have

a

UNIX account. An account can be established

contacting

administrator.

your

supervisor,

Depending upon your

department,

or

system

you will receive one, two, or three pieces of information about your account. If you are in a large organization in which there are several UNIX systems you will be assigned to one of them and given (a) a system name. At all locations you will be given (b) a login, a short name that the computer and you will use to identify your work. Most locations will also provide you with (c) a secret code password, which is used to protect access to your account. Before beginning this Module enter this information

in pencil in

(a)

My

system

(b)

My

login

(c)

My

password

Accessing the System

is:

_

is:

is:

location

the spaces provided here:

Although your login name will be available to anyone interested, your password should remain secret so that only you can access your account. Your password is like your instant cash bank card “secret” code number which is known only to you and the bank.

Objectives

# coos

After completing this

Module you should be

able to: tnr

(1)

Identify yourself to

UNIX and inform

it

you are beginning

work (logon); (2)

Inform UNIX you are quitting work (logout); and

(3)

Make

use of the UNIX of

commands

who

(a)

Present a

(b)

Give today’s date and time;

(c)

Provide a

(d)

Change

list

list

is

which:

currently logged in;

of correctly spelled words; and

the password to your account.

Procedure Module Two contains four sections. First you will learn how to logon and logout of your UNIX account. In the second section the Conceptual

Four basic

Map of the logging on and out process is discussed. commands will be used in the third section to illustrate The

the kind of resources available in UNIX.

final section consists

of a review of the material presented in this Module.

Logging onto UNIX: Gaining Access

to the

System

Many

people have found that logging onto UNIX for the first time can be a very frustrating experience. If you have not already done so, it might be useful to identify an experienced UNIX user in your

and ask which parts of the logging in procedures outthis Module are appropriate for your location.

institution

lined in

Accessing the System

1

may

Additionally, you

number of each (1)

activity

START, Turning (a)

this

find

helpful to put a check next to the

it

once you’ve completed

the Terminal

it.

ON:

Turn on the power to the terminal. On many terminals switch is located on the back, lower right. The terminal

may answer

with a beep.

Wait a few seconds.

(b)

Find the brightness dial— usually located either just above the top right of the keyboard or on the back, lower right near the power switch. Adjust the brightness of the screen to a comfortable level.

(c)

you are were given If

in a location

with several UNIX systems (and you

system name) you might have a small box with a switch or button attached to your terminal. a

your terminal has such a switch or button, push without a button, skip this Step and proceed. If

is

If you

make an

it

— if

it

any point in the logging in procedure you should turn the power to your terminal off and then back on and begin again.

(2)

error at

Locate Map A at the end of this Module. Two copies are included in this text. We suggest you remove one copy to place next to your terminal for easy reference as you proceed through this material.

We

will refer

to

Map A

throughout the next few

pages.

The

in— as pictured Mode. Once you are

objective of logging

box labeled Shell mands to perform such and print material.

in

to get to the

you can enter comtext, look up spellings,

there,

activities as edit

In the process of getting to the Shell

Map A — is

you may be stopped and

asked for from one to four different pieces of information, depending on how your system is organized. You may be asked only for your login (account name), or you may be asked for login, password, system name and even for the name of the type of terminal you are using.

Map A

is

a sketch of the trip

arrival in the Shell.

8

Accessing the System

from turning the terminal on

Consider yourself to be

at

to

the beginning of

Map A down

at

the

the place labeled Start.

path toward the Shell.

Now

imagine yourself traveling Map A we have indicated

On

between turning the terminal on and the Shell. If your system needs information corresponding to one of the stations, you are stopped at that station and asked for the appropriate information. Once you type in the needed information you are allowed to go on.- If information at a station is not needed, you are not stopped but passed on to the next station.

the four stations that

(3)

lie

System Name: If the word Request: appears on the The printing of screen, you have been stopped at Station 1. that you indicates Request: Station

1,

have the machine’s attention and it needs to be told your or letter, name, system number.

Type the number, or

name

UNIX

(lower case)

you

of the

were entered by

you

system

assigned [Item

letter,

(a)

in the Prerequisites section

above].

Press

the

RETURN

key.

your system name does not appear on the screen as you type it, you should push the button or turn the power to the terminal off and back on. Once Request: reappears, re-type your system name. You must enter the letter (s) of your assigned system within 15 If

seconds of the appearance of the word Request: or else the computer will not attend to your response.

Feeling

Depressed?

If

the

machine

upper case characters check that the not

locked

depressed

on.

Make

(perhaps

certain

administer

presenting

ALPHALOCK

that .5

is

mg

this

key

all

key is

of lithium)

is

not

by

ALPHALOCK

key to release it. Next re-start the logging in sequence by pressing the button or turning the power to your terminal off and back on. pressing the

Accessing the System

9

(4)

Station

Login Name: The

2,

printing of login: indicates that

you have been stopped at Station 2, and the machine is ready to receive your login name.

Type [Item

(5)

(b)

your in

login

name

Prerequisites.]

certain

to

use

letters

or

numbers,

spaces.

Press the

all

lower

case

with

RETURN

Be no

key.

Station 3, Secret Password: If the word Password: appears on the screen, you have been stopped at Station 4. You will not be allowed to go any further without entering the password that is associated with your account.

Enter

your

password (again, leave no spaces), and press

RETURN.

As you

type your password

it

on the screen, so that no one else can see what it is. It is, however, being registered by the computer. (A few seconds will will

not appear

now

pass.)

Error in Logging On:

your login or password was entered incorrectly the terminal says login incorrect and repeats the word login:. You must then re-enter both the login and password. Be very careful to enter both exactly as provided you. Remember to use all lower case letters or numbers with no spaces, and to press

RETURN

If either

after entering each.

(Note that if you make a mistake entering the password., you will be told login incorrect and you must properly enter both the login and password.) both the login and password were correctly typed and match with the computer s list of accounts, you are permitted to continue If

down

the path.

the screen

10

may

Depending on how your or

may

Accessing the System

not begin

filling

local

system

is

managed,

with dated news items.

1

(6)

Station 4, Terminal Type: If your terminal displays the words TERM = Terminal Type?\ you have been stopped at Station 4.

UNIX must be informed what type of terminal you are using. This will allow UNIX and your terminal to communicate without any misunderstandings. (Pardon my dialect, but I’m from the Bronx.) In the

most straightforward case UNIX will be informed automatically about what type of terminal you are using, and you will pass by this Station.

you are stopped at Station 4, your screen will probably display line that looks something like one of the following: If

TERM =

a

(tvi925)

or:

TERM = The

(z29):

parentheses are an abbreviation for the most comterminal at your location (e.g., tvi925 for Televideo 925 or

letters in

mon

You

need to determine whether you are using the type of terminal mentioned in the above line (inspect the terminal for a nameplate and/or ask someone near you).

z29 for Zenith 29.

If

the terminal

RETURN If

is

will

of the displayed type you need only press the

key.

the terminal

is

a different type,

determine the appropriate

abbreviation and carefully enter it then press knows what type of terminal you are using.

(7)

RETURN. UNIX now

you entered a terminal type that UNIX recognized, a Shell Prompt % appears on the screen (this should take a few seconds). Note: Alternate versions of UNIX use different characters ( %, $, or #) Whenever we display a Shell prompt in this

The Shell Mode:

book we

will

If

use the

%

Prompt, you have made

sign. it

When

the terminal displays the Shell

to the Shell.

Accessing the System

1

(8)

Logging Out: The appearance of the prompt means you have completed the login procedure and the computer is waiting for your next instructions.

You now know how

to log

munication with UNIX)

is

onto UNIX.

much

Logging out (ending com-

simpler.

Logout of UNIX by typing the command logout

and press RETURN. This command tells UNIX you are finished working on your account and want to terminate this session.

you were successful, one of several things probably occurred. Either the screen went blank or the screen displayed a written mes-

If

sage like ‘‘logout complete.”

you are not logged out and the terminal displays the words Command not found you probably mistyped the word logout. Retype the command logout and press the RETURN key. If

Conceptual

Map

As an aid to your understanding of how the UNIX system operates, we will be introducing a series of “Conceptual Maps.” Each Map present those segments and paths of the system with which you are working. You have been using Map A to logon to the system. will visually

(1)

Map later

Symbols: To utilize the rest of Map A and the other Maps in Modules, you need to know what the various symbols mean:

(a)

The boxes and

“locations” in UNIX and contain both a descriptive label for the part of the UNIX system being accessed and the function performed by that part of the system.

(b)

The arrows

circles are

reflect

commands used

to

used

when you

move from one

place to

another. (c)

12

The symbol

®

is

Accessing the System

to indicate

are to press the

RETURN

key (right-middle of most keyboards).

tion will be used throughout this

RETURN

Now

book

The

®

nota-

to indicate Press the

key.

you have logged out, log back in following your path on the Conceptual Map. Notice how the information you type (system, login, password) moves you from one location (Station) that

to the next.

logged on, logout. Repeat the logging in and logging out procedure until you feel comfortable with both processes.

Once

fully

Logout of your UNIX account and continue reading Module.

Do

not forget

to

logout

whenever you

UNIX session — if you neglect

this

are finished with a

your account will continue to accrue the hourly connection charge. In addition, some unscrupulous, dastardly, or generally ornery critter may discover your oversight and proceed to first use your account to perform his/her own UNIX tasks, then delete all your files and send nasty notes to your friends, thereby causing you untold grief and probably leaving you freight train

first

In

summary: be

little if

to logout,

choice but to leave town on the

you are even remotely honorable.

certain

you logout

after

each UNIX ses-

sion.

Four Shell Commands The appearance of the Shell Prompt % indicates “Shell Mode,” the main command center of (Find the box marked Shell on Map A.) Being that

you can issue

programmed

to

you are in the the UNIX system.

that

in

the Shell

means

a specific set of

commands which

The commands.

following procedure steps intro-

respond

duce four of these

to.

the machine

is

Each of these four resources can be accessed only from the Shell

Mode Mode

is

%

#

This is because the Shell programmed to perform a specific function in response to

(with the

or $ or

prompt).

Accessing the System

13

your entering each of these commands. The appropriate command is typed in and then the RETURN key is pressed. Until you press the the machine does not process what you have typed. Rather, it

®

®

you to indicate that you are finished typing instructions (which you do by pressing the RETURN key). Within quietly waiting for

sits

the Shell

Mode,

®

pressing the

key

is

interpreted to

mean “pro-

cess this line.”

(1)

Follow the Conceptual Map and log onto your account. If necessary, review the steps indicated in the prior section. Once you are logged in, and the Shell prompt is displayed, proceed to the next step. Note:

if

note “Command Try it again.

(2)

Who

one of the next commands you receive the not found” you probably mistyped the command.

after entering

on the System?

is

You

can request of UNIX a (what logins) are currently logged onto the system.

To

access this

command from

A

® as

of

who

the Shell type:

who Remember:

list

®

used above means press

the

RETURN

key.

of current users allows you to see if any of your friends are on the system and what terminal locations they are using. This list

prove useful once you learn how to communicate with them via UNIX. Notice that your login is included among the will later

several that are presented.

Two-Way Commands: Find the Shell on Map A. Locate command just used. Note that it is attached to an arrow

the

who

that has

heads on both ends (a two-way arrow). A two-way arrow with a command next to it indicates that by typing in the command you cause the computer to execute that command and then automatireturn you to the original mode. For instance, the command who is given from the Shell and will access the who system file. After performing its function (listing the logins of everyone logged onto the system) it will return you to the Shell Mode (your originating mode). cally

14

Accessing the System

(3)

What Time

Should you awake one day, forget to strap on your $7900 Rolex day-date wristwatch, log onto your UNIX account, and desire to know the current time and date, UNIX can Is It?

provide this information.

To determine

today’s date and time type:

date

(4)

How Do You

Spell

As

example

®

UNIX maintains an on-line spelling dictionary with a word volume somewhere between Webster’s elementary school version and the New Oxford Dictionary.

how ary

an

When

the

.

?

of

the

following.

prompt

Shell

appears type:

®

look egg

A

list

of

eggplant,

egghead,

egg,

most cases

In

word you might

the

know how

contained (the

be

will

etc.

displayed.

to

.

to access this dictiontry

%

.

to

the

in

like

spell

is

display

UNIX dictionary does

not contain definitions to

words, only the spellings).

You

enter the

first

few

of a word and UNIX displays

letters

all

the

words contained in its dictionary which begin with these first few Another example probably best explains how this works. letters.

The command

®

look psych

whole

ogy’.

produce Try this

that

amuses you.

will

The words porarily

a

command

will

halt

at a

rapid rate.

presentation

and psycholfew letters of a word

like psychologist,

again, using the

parade by

the

words

flock of

first

If

of words

you would press

temthe CTRL-S key like to

Accessing the System

15

down

marked CTRL and press the s key one time). Scrolling resumes when you press the SPACEBAR. (hold

(5)

the

key

Password: We have noted the importance of a password your keeping

My

Change

secret.

One

solution

is

to

never write it down. The only problem with not having it written

down anywhere

is

that

can be forgotten, especially

it

account

is

a

if

the password assigned to your

nonsense collection of random

letters.

one was not provided you, create one) to a “word” that does hold meaning to you. Your new password must be between five (5) and eight (8) characters in length, and should contain at least one letter and one number. Be careful to select a password that is not obvious: computer theft occurs with disturbing frequency. An obvious password provides no protection from any account snoopers who may inhabit your system. For instance, your birth date or the name of a spouse may not be good choices. A better choice would be some combination of several meaningful words {ml8ml8 if you like rabbits, or lOsnel if tennis is your hobby).

You

can easily change your password

To change your password

(or, if

type (from the Shell):

passwd After typing the passwd (a)

To supply your

(b)

To

type a

(c)

To

repeat your

command UNIX

® will

ask you:

old password;

new password; and

new password.

Be sure to remember the new password, as it will be your UNIX password from now until the next time you change it.

16

Accessing the System

A Note on Making It

is

easy to

make

Corrections

corrections within a single line because the Shell

does not process the line until you press the RETURN key. If you make an error in a line you may back up one or more characters by using the CONTROL-H key. Hold down the CTRL key and press the h key one time for every space you want to back up. If your terminal has a BACKSPACE key it may be used to accomplish the same thing. The characters can then be retyped.

Once you

press

RETURN

the line

is

“processed.’’

®

dote (typed incorrectly), then backspace

and

retype the correct Shell If

you experience

a

not

UNIX will then press found” and display another Shell prompt. Type the “word”

you mistype

“Command

command and

(1)

If

command

difficulty

reply

date.

using the

CTRL-H

or

BACKSPACE keys

does not backspace or the terminal beeps whenever you press these keys) you probably made an error when informing UNIX of the type of terminal you are using. Please see the section of Module Twenty-Eight: Trouble Shooting entitled Specifying Your Terminal Type. (perhaps

the

cursor

The Finale Without referring to prior sections of form the following actions:

this

Module

(a)

Logout of your account and turn the terminal

(b)

Log back onto your account.

(c)

Ask UNIX

Map

per-

off.

words

starting with the

Logout of your account and turn the power

to the terminal

to look

following letters: (d)

or the

up the spelling of

all

electr

off.

Accessing the System

17

When you

can perform the above actions without referring to sec-

tions of this

Module you have mastered

UNIX account. You files,

are

now

the ability to access your

ready to learn

which just conveniently happens

to

how

to create

your

be the content of Module

Three.

A PDP

18

11-70;

UNIX was

Accessing the System

own

originally designed to

run on

this

machine.

A

second copy of this

map

is

located at the end of the book.

Accessing the System

19

kJ-«

Module Three

Your

First File CDO

wr

3



Introduction In this

Module you

“file.”

A file

be using two important components of the UNIX system — the Shell and the Visual Text Editor vi—io create a is

will

the term used for a collection of characters that

stored together, such as the words in a letter or a paper, a

program, or a listing of data. together so you and UNIX can puter

work on

The

file

is

comkept

it.

generating process

often confusing at ing.

This information

is

Take

heart:

first

You

is

meet-

are not

Shell

know all about the and vi when you finish

this

Module.

expected to

Rather,

it

is

intended that you will gain experience you can build on in later Modules to understand the UNIX system.

Prerequisites His

You need

know how

first file.

your account (logon) and terminate work on the account (logout). If you are not sure how to accomplish these procedures, review Module Two. to

to access

21

Objectives Upon completion

Module you should be

of this

(1)

Create a

(2)

Append

(3)

Escape from Text Append Mode;

(4)

Quit working on a file, save the changes return to the Shell;

(5)

Display a

(6)

Have

file

for visual editing;

text to the

list

of

file;

all files

copy of your

a

able to:

in

file

made

in

the

file,

and

your account; and

sent to the printer.

Procedure The Procedure

Module

section of this

is

two

in

parts.

The

first

you through the process of creating and appending text to a file. The second section introduces the Shell commands to list the filenames in your account and to print a file. A brief self-quiz and a comprehensive command summary are placed at the end of this Module. A second Conceptual Map is included to help you chart your course through the paths of UNIX. section leads

Creating a

Appending

File,

Returning

Locate

(1)

Map B

again been included.

at

Text,

to the Shell

the end of this

Module— two

You should remove one and

your terminal to review as you complete your

Logon

(2)

learned in

to

it

22

is

First File

place

it

next to

activities.

logged on you are in the Shell prompt). Find this Mode on Map B; fully

(which usually has a % your home base in the UNIX

Your

copies have

your UNIX account following the procedure you

Module Two. Once

Mode

and

game of Hide and

Seek.

(3)

Starting Your First File: There are two steps to beginning your first file:

From

(a)

the Shell enter the following two words (which

must be

separated by a space): vi first space

I

Press the

(b)

RETURN

key.

Once you have entered the command sequence the

RETURN

key the screen

bottom of the screen saying “first"

New file.

Tildes

(~)

will clear

and a note

either “first'' will

vi first

No

will

and pressed

appear

the

at

such file or directory or

parade in a column

down

the

left,

Line numbers may also appear along the left border of the screen. This translates as: “OK, you’ve called for the file with the name./zrsr. It did not exist but is now being created and, at this moment, con-

and the cursor

tains

will

appear

at

left

of the screen.

no text.” you have

Let’s take a look at what

sequence (a)

the top

vi

vi first

means

is

that

in

two

just done.

The command

parts:

you wish

to

employ the UNIX y\sual

text editor,

and (b)

first is

the nanie of the

to be

worked on.

word you choose, within some limibe discussed later. (We are suggesting you title

The filename can be any tations that will

file

single

this hit first because, curiously,

it

is

your

® command

first file.)

on Map

The filename is in a box to indicate that you can substitute the name of whatever file In this instance, you have named this file you want for [filename} first. Recall also that ® included at the end of a command means Locate the vi

[filename}

B.

.

press the

RETURN

key after you enter the

command

sequence.

From Map B note that the command sequence vi moves you from the Shell to the vi Command Mode.

(4)

filename

®

Appending Text: “How can I add text to this file?” you ask. Although there are several ways to add text, we’d like to initially introduce one of the most useful commands. Your

First File

23

You

are in the Visual Editor

you want

tor that

not press the

Command Mode. To

to enter text, press this

RETURN

inform the edikey a single time (and do

key):

a

What happened? Nothing. How come this a didn’t appear on the screen? Because in the Command Mode, pressing the a key tells you want

add or append text to the file. After pressing the a key the visual editor will add anything you type to the file and at the same time display it on the screen. You are now in what is called Append Mode, because everything you type will be entered as text. vi

that

to

Type the following sentence:

(5)

/ anticipate a long

(6)

and harmonious

relationship with

UNIX.

Typing Suggestions:

PLEASE more

read this

we’d

typing, as

BEFORE

you begin any

like to

offer a couple of very important hints.

Short lines are most easily

worked with when using UNIX. You should press the RETURN key after each main idea or 5-8 words, and always after the end of each sentence. (Just like these lines.)

make

will

It

Your

editing

a

easier.

text should look like this section:

short lines, with

on

much

new

all

sentences starting

line.

After your text

is

formatted

(Module Five), the short lines will be joined together

form

uniform length. (Like the remainder of this text.)

to

lines of

Now

type the 16 short lines of text contained in Procedure Step 6 above. This is for practice, so don’t worry about mistakes.

24

Your

First File

Leave the typing errors alone— in a later Module you’ll learn how Just blast in the text. Don't bother with to easily correct them. corrections— ]\xsi type a line, press press

®

.

.

.

of text began

You

gin.

at

the

all

lines

left

mar-

of formatting will

that

specific

commands which

meet

in

Module

Five.

time you

will

insert

commands

to

indent

paragraphs, double space, and center

Whenever you

lines.

CSh^t

in

another

line,

text

you

should

not

attempt to format the material yourself— let UNIX do it for

lines are

most

easily

worked with when using UNIX.

You should after

press the

RETURN

keyj

each main idea

or 5-8 words, and

always after the end of each sentence. (Just like these tines.) It

enter

then type

did not indent para-

graphs or try to center lines or double space while typing in the text. UNIX possesses a set

you At

,

.

Note how

Finished?

®

will

Your

make

editing

much

easier.

text should look like this

section;

you.

(8)

Leaving the Append Mode: At this point you should now have 15 to 20 lines of text displayed on the screen before you. How do you now tell UNIX that you are finished adding text and want to do something else? Try typing these words: stop, finish,

getmeoutojhere, and pleaseletgoofmeiwantoutofthisthing

None of these words will move you out of the Append Mode (which you entered when you pressed the a key). You are finished, but everything you type continues to be What entered into the file.

you must do

is

tell

stop, finish, getmeoutofhere,

pleaseletgoofmeiwantoutofthisthing

the visual

move you out Append Mode and back to

editor editor to

of

Command Mode.

Your

First File

25

(9)

that

Look at Map B. What is the command written on the arrow moves you from Append Mode back to vi Command Mode?

THE WAY OUT OF APPEND MODE IS THROUGH PRESSING THE ESCAPE\y^ KEY your best vi friend — find it on the keyboard (usually near the top on the left), introduce yourself, and then gently, lovingly press it. Anything happen? Nothing appeared to happen, but you are now out of Append Mode and back in the Command

The

key

|ESC|

is

Mode. To be sounds,

certain, press the

[Em

key

a

second time.

If a

beep

simply telling you that you are already in Command Mode. Let us stress this point. In your trials and tribulations experienced while learning to use the visual editor you may find yourself a bit lost. While in the midst of entering text into a file VI

is

you may not be sure whether you are Mode. The ESCAPE key

When Mode

in

Mode

the

is

in

Command

or

Append

your path out of this confusion.

doubt about whether you are in vi Command or Append press the |ESC| key. Within the Append Mode the [esc key means. Move me into Command Mode.” Within the Command

ESC key means, ^Please beep.” When using the visual editor pressing the |esc| key will always leave you in Command Mode. You can decide from that point what it is you want to do. Trace the action you just now completed on Map B. Notice that the ESCAPE [ESC! key moved you out of Append Mode and back to Command Mode. Please review the information presented above. Knowing when to use the |£SC| key is the single most critical factor leading to successful editing with the visual editor.

(

10 )

__ Did

To it

insure you are in the Command Mode, press the lEsc] key. beep at you? The beep translates as, ”But Captain, you are

already in

From

Command Mode.” the

Command Mode

type this word:

duty 26

Your First File

What happened? The times, in fact.

(If

it

terminal should have beeped at you; several did not beep and the word duty appeared on

the screen, press ESC] and repeat this step.) !

Type the following:

(12)

aduty This time the word duty should appear on the screen. It appears because the first letter of the “word” aduty- was a and this a is the

append command. Therefore the a was interpreted to mean, “Move me from Command Mode into the Append Mode.” Thus, when you typed the next four letters they were entered into your file as text.

duty

Press the jESCj key.

(13)

You have

You

are returned to the

Command Mode.

had another real-life encounter with the a (append) and jESCj (escape) commands. just

Summary:

the a

command

text; the jESCj stops the

to

permits you to start entering

append process and returns you

Command Mode.

you have entered is now sitting on the screen staring at you and waiting for you to do something with it. Suppose you want to finish working on the file for nowleaving any typing mistakes you made in composing it uncorrected until later. You need a command which will tell the visual editor “Tm finished — save this text in a file for another time and bring me back to the Shell.” Looking at the Conceptual Map, what command moves you from v/ Command Mode back to the Shell?

(14) Returning to the Shell:

Go

The

text

ahead now and type (Upper Case):

ZZ If

the letters

Mode.

ZZ

appear on the screen you are

You must

first

move

to

in

still

Command Mode

Append this com-

the

for

mand to be properly interpreted. Press jESCj to move to the Command Mode and then type the ZZ command (hold the SHIFT key down and press the Z key two times). Your

First File

27

What happened? something

At the bottom of the screen appears the note

like:

'‘first*'

Below

20

lines,

the Shell prompt

568

characters.

%

which indicates you are back in the Shell Mode and that the system is awaiting your next Shell command (remember the Shell commands who, date, look, and passwd practiced in Module Two?). this

is

Examine

Ma p

y ou are in the Shell and enter the vi [filename\ you are moved into the ComB,

If

command ® mand Mode. The ZZ command moves you out of Command Mode and back to the Shell, and can only be executed when you are in the Command Mode (and not Append So a

(15)

or Shell

Mode).

you’ve written 15-20 lines of text and saved this material as named first (where it will wait patiently for your return.)

far

file

A

Second File: It would now be useful to through which you created your first file.

From

the Shell type the following:

second

VI \

As

practice the procedures

space

we put second in a box to indicate that you need not new file by the name second, but can use whatever name

before,

call this

you want. Trace the action you just completed on

row leading ind icates

into the

vi

Command Mode

Map is

a

Note that the arone-way arrow. This B.

from the time you enter the command vi \filename\ until you return to the Shell Mode, you are in ‘‘different world” where a different “language” is spoken. The t

hat,

commands

that the Shell can interpret cannot be understood by the visual editor, nor can the Shell properly interpret commands

meant

for the visual editor.

The commands

that are properly in-

terpreted by the Shell will be either misinterpreted or entirely not understood by the visual editor. Each Mode has its owm com-

mands.

28

Your

First File

(a)

In

what UNIX

Mode must you

be to use the vi second com-

mand?

(16)

(b)

After you enter the vi second you located?

(c)

What

Answers:

be the

will

(a) Shell

To append

(b)

name

of this

new

Command Mode

(add) text to the

must you enter? Press

command,

this

file

in

you are creating?

second

(c)

called second

file

what mode are

command

what

key (lower case): a

Again look at the Conceptual Map. (17) to what mode?

Answer: You

Now

are in the

Append Mode,

you are

that

in the

Pressing the a key

so text can

now

Append Mode,

be added to the

Write anything you want, but remember short and start all new sentences on new lines.

keep your

to

you should

6 to 8 lines,

are finished appending text, want this text saved in a to return to the Shell.

move

Refer to

Map

B;

is

from Append Mode to the Shell? reach the Shell you need to move in two steps:

From Append Mode

(b)

From

the

to

Command Mode;

Command Mode

lines

you and want

tell

file,

there a

directly

(a)

file.

type 6 to 8 short lines

of text.

Once you have entered these

moves you

vi

command

No.

to

In order to

and then

to the Shell.

You have been adding text, so at the moment you are in the Append Mode. Map B shows the command to move out of Append Mode and into Command Mode. It is the ESCAPE key.

Press:

Esc

You

are

now

in

the

Command Mode.

Your

First File

29

^

How

(18)

Map B

do you move from

indicates that

ZZ

Command Mode

the appropriate

is

to the Shell?

Again,

command. Type:

ZZ You should now be back

ZZ

appeared on the screen, you forgot to press the |ESC| key before the ZZ was the Shell.

at

(If

the

entered.)

Listing

Two more commands and (1)

and

Printing Files

Listing Files: Suppose you want to

your UNIX account. list)

Type the

Shell

know

The command

of the names of your

Is

the

names of

the

will call forth a list

files in {Is



files.

command:

®

Is

Did the filenames

Module Three.

you’re finished with

and second appear? The names of other files will also appear if you have created any others, or if your account is used by other people. The list command will work only from the Shell.

(2)

first

Line Printing Files: You might now like to produce a printed copy of one of your files. Look at Map B. Wh at comma nd is on the arrow from the Shell to the printer? The [filenam^ in the com-

mand any

Ipr [filename\

file

To

®

means

that

you can substitute the name of

you want printed. print out the

file first

you should

type:

first I

The

line printer {Ipr

Mne

space

printer)

command

is

only understood

by the Shell. For the terminally curious, the term line printer is derived from the fact that most early high speed printers printed one line of output at a time.

30

Your First File

You

can also send the

second to be printed with the

file

Ipr

second

command:

®

your printer is located away from your terminal.) Several moments after you have entered the Ipr [filenanw\ command sequence a message may appear on the screen informing you where your printed output (here, a copy of your file./7>5r) may be found. (This next point

is

relevant only

if

®

(If

(3)

down the name of box number displayed on the

appropriate) Write

number, and the need each to identify the

You

(4)

are

now

Module Three.

room you may

the building, screen, as

location of your printout.

finished with the on-line activities contained in

Logout of UNIX (from the Shell type the word

logout) and continue reading the last section.

You 've

Made

It

(Puff-Puff)

Module you are now text proCertainly there is much more to learn (otherwise we cessing. wouldn’t have written the next 400+ pages). Still, the fundamentals are contained in this section, and you’ll build on them in later With the knowledge gained

in this

Modules.

A summary text of this

A Quick

list

of the

Self-Quiz: Consider yourself finished with this Module

In

(b)

What must you

(e)

these questions:

what mode must you be

(a)

(d)

practiced follows the

Module.

when you can answer

(c)

commands you have

to start a

type to start a

new

new file

file?

to

be

named bonzol

command to add (append) text to a file? What is the command to leave Append Mode and Command Mode? What is the command to quit an editing session, What

is

the

Your

return to

save the

First File

31

additions and changes you

made

in that session,

and return

to

the Shell? (f)

What

is

the

command

to display a

list

of the filenames in your

account? (g)

What

is

the

command

to

have a copy of

a file printed

on the

line printer?

Answers: (g) Ipr

Note:

(a) Shell

(b) vi

bonzo

(c) a

(d)

[E^

(e)

ZZ

(f) Is

filename

If

you correctly answered question

(d)

you are awarded the

Houdini lESCAPEI Artist Award. Please turn to the last page of Module for your extravagant certificate, suitable for framing.

32

Your First File

this

Command Summary Visual Text Editing

Command a

ESC

zz

Commands

Function



Moves you

into

2idd text to a

file.

Append Mode, where you can

Append Mode and Command Mode. Escapes from

Quits working on the

returns to vi

writes changes

file,

made

in

an editing session, and returns you to the Shell.

Shell

vi

filename

Starts

a

flename Is

^

Ipr

filename

existing

file

named

for visual editing.

list

of

names

file

in

your account

(Is

list.

Has a copy of filename (Ipr

who

or retrieves an

file

Displays a



Commands



line

Presents a

printed on the line i^vinter

inter).

list

of

who

is

currently logged onto

your UNIX system. date

look

abc

Displays today’s date and time.

Looks

in

dictionary

for

correctly

spelled

words

beginning with abc.

passwd

Changes account.

passwo/d assigned to your UNIX (Remember your new password!) the

Your

First File

33

book.

the

of end

the

at

located

is

map

this

of

copy

B second

Map

A

35

oudini

i\

,



is given

^0

tkw

day

of

— in the year. for distinguish e'd

and

miraculous escapes executed from the Append tAode

Module Four

M

Editing Files Using the Visual Editor

O D U L E 4

Introduction

We

seldom express ourselves precisely in work. As a result good writing involves adding to our

first

attempts.

An

first

drafts of written

revising,

editing,

and

advantage of text processing with

and ease with which changes and additions can be made. words and paraLetters,

UNIX

is

graphs

precision

the

can

be

easily

or expanded, moved around. A copy of

replaced,

the

paper

(with

all

revi-

sions) can then be printed,

having to retype the entire manuscript.

without

Although there are dozens of UNIX commands availediting

text,

able

for

an

introductory

essential

this time.

set

and very

commands

will

More

only

of

versatile

be used

at

specialized

procedures will be included in later Modules.

One approach

to the editing process

37

Prerequisites To employ this Module you should be commands introduced in Module Three:

Command

able to use the following

Function

vi [filename

or

Starts

retrieves

moves you from Allows you

a

to

file

for

the Shell to

start

(Moves you from ESC

a

vi

visual

to

and

Command Mode.

appending text

Command

editing

to

the

file.

Append Mode.)

you no longer want to add text to a file. (Moves you from Append to Command > Mode.) Signals that

ZZ

Saves changes quits

made during an

work on the

file,

editing

session,

and returns you

to

the

Shell.

Objectives After completing this

Module you should be

able to:

(1)

Access an existing

(2)

Position the cursor on desired lines and words within a

(3)

Delete

(4)

Replace

(5)

Undo the effect of the last text change command entered; and Add more text wherever you want in the body of a file.

(6)

letters,

file

for editing;

words or

letters or

file;

lines;

change words;

Procedure This Module contains five sections. Files and filenames are considered in section one. Section two introduces several cursor moving

commands, while

The Visual Editor

text

changing

commands

are discussed

in

tion four.

The

you

section asks

fifth

appear

in sec-

your text editing several points throughout the

Self-check quizzes appear at

skills.

commands

Additional text appending

section three.

to practice

Module.

Log onto your UNIX account following the procedure you learned After the Shell prompt is displayed, proceed to in Module Two. the

section.

first

Files

From

(1)

the Shell

and Filenames

Mode, type

the

command

®

Is

which causes the Shell your account. (The

to display the

®

sary to

let

the Shell

The screen

will

including the

The

Shell

means

know you

press the

files

prompt

the

command.)

your account, {first and second). then displayed, indicating that the system is

names of the files you began in Module Three is

files

are finished typing a

display the

awaiting your next Shell

(2)

you have in RETURN key and is neces-

names of

in

command.

Recalling an Existing File for Editing: In Module Three you used The the command vi filename to begin creating a new file. filename you assign to the file (for instance, first or second) becomes the identification label used to let UNIX know which file you want to work with. Once the filename is assigned, you must

use the same filename to recall the

file

for further editing.

which you began in Module Three. To call the file up for visual editing you must type the following command sequence (two words):

We

suggest you edit the

file first

vi

first I

The beginning all

of the

tioned

at

file,

lines of the

space

appear on the screen (perhaps length). The cursor will be posi-

file will

depending on

the start of the

®

its

first line.

The Visual Editor

39

Yes, the

command

mand used

to reenter a file

is

exactly the

same

as the

com-

to start the file in the first place:

vi

filename

®

where you supply the filename.

Once you will

type vi filename and press the

®

key one of two things

happen:

(a)

the filename you type after the vi is the name of an already existing file, the Shell recalls that file for you to edit; or

(b)

the filename you type is not the name of an existing process of starting a new file with that name begins.

If

If

What happens

you want

if

incorrectly type the

to

name? The

work on an

existing

file,

file,

the

but

Shell will search for a

file with the filename exactly as you typed it. Because the name of the file is typed incorrectly, the Shell won’t be able to find a file with that name. Therefore, it will start a new file with the misspelled Jylename as its name. To stop the process of setting up a

and return (3 )



Locate

to the Shell, type the (upper case)

Map C

at

new ZZ command.

file

the end of this Module, and find the box

marked; Shell

Lo cate

the arrow leading downward from the Shell with the label vi filename\ (where filename is the name of the file you want to edit: in this instance it is the file named first). According to Map C, if you are in the Shell Mode and enter the

®

command

filename you are

The command mand Mode.

moved

into

vi

what Mode?

filename moves you from the Shell to vi ComIt is only from vi Command Mode that you can begin editing a file. Make sure you find that transition on Map C.

When

editing a

ular words,

vl

file

remove

a particular point.

you often need

to correct the spelling

of partic-

specific lines of text, or insert additional text at

With the screen full of lines of type, how can you tell vi which specific word or line you want to change or where you want to add more text?

40

The Visual Editor

The

cursor, or

moving

light rectangle, is central to

com-

municating with the visual editor and must be moved the word or line you want to alter.

Cursor Moving The Arrow Keys: The (1)

basic

Commands moving the cursor through These are separate keys on some

method

for

by using the arrow keys. and the h, and terminals

a

file is

Rmm R

to

k,

j,

and

1

keys on others.

Once you have called up a file for editing with the y\ filename command, the cursor should be at the first line of the file. If this line does not contain text, press the down arrow key until the cursor is on a line of text.

R

and Locate the key with the arrow pointing to the right press it. If you did not see the cursor move when you pressed it, press the arrow key again while carefully watching the cursor on the screen.

The cursor should move

the cursor does not

one character. few seconds. UNIX

to the right

move immediately

wait a

If is

time sharing system, which means that it shares its brain among you and the other users. UNIX may not be able to follow your every command as soon as you issue it. (If the cursor still does a

not move, depress the key marked ESC and then try again.) I

Try each of the four arrow

(2)

to

move

keys.

I

What happens when you

the cursor too far to the left?

Beyond the

try

text to the

right?

move the cursor up, down, right and left through the text. NOTE: If the four arrow keys don’t move the cursor, you may have made a mistake during the logging in process when you told UNIX what type of terminal you were using. If the You should be

cursor

is

not

Twenty-Eight:

able to

behaving

properly,

see

Trouble Shooting entitled

the

section

Specifying

of

Module

Your Terminal

Type.

(3)

the middle of the second line of text and, using the arrow keys, move the cursor to the beginning of that Select a

word

in

word.

The Visual Editor

41

W)

(5)



Press the right arrow |—»| key four should move four spaces to the right.

more

times.

The cursor

Augmenting the Arrow Keys: You can include the number keys (1 - 9) as part of arrow commands. The result is to move the cursor several lines or characters at once.

— — Now

For instance, try pressing the 4 key and then pressing the down arrow\^ key. Did the cursor move down four lines?

key.

press the

number

3 key followed by the

Again, the cursor should

move down

down arrow

[J]

3 lines.

Warning: Many terminals have an extra row of keys located directly above the number keys. These keys may be labeled FI, F2, F3, etc. These are called Function Keys and do not have the same action as the convenUonal number keys. Instead, they will cause much

grief

if

unintentionally struck.

Avoid them

for

now.

Try the 2 key followed by the up arrow, then 4 |—»| 3 Q] and Rather than repeatedly pressing keys tension releasing) to include

you want

to

Note

when you

that

move

it

is

usually easier (but not as

numbers preceding arrow keys when

the cursor several spaces or lines at once.

press the arrow keys the editor does what you request (moves the cursor) and then waits for your next command. You can issue cursor-moving command after cursormoving command without leaving the Command Mode. Find the

arrow key commands headed?

in

Map

C.

Are they

single

or

double-

These double-headed arrows represent the actions of two-way commands. These commands do not move you into another Mode, and do not require that you use the RETURN or

[e^

take effect immediately originating Mode.

You have probably

keys.

They

upon being typed, and you remain

in the

noticed that there are limits to where you can rnove the cursor on the screen. If you try to move the cursor past the left margin or to the right beyond the last character of your text. It does not move but instead you hear a beep. You cannot go

42

The Visual Editor

beyond the text which you have added. (Remember that blank spaces, whether between words or accidentally placed at the end of a line, are characters.)

(7)

Select another

word near the bottom of the

keys followed by arrow keys to place the cursor the word.

(8)

text. at

Use number

the beginning of

The Search Command: An easier way to move the cursor to a specific word in the text is with the search command. When you type (from Command Mode) ! specific the cursor will move to the word specific in the text. word somewhere near the top of the your screen of Move the cursor to the word you selected by typing

Select a

(9) text.

/ [wor3\

where word

is

As you enter

(10) text).

the word that you want the cursor to find. the slash and the target word the terminal displays

what you type

moved

in the

After you

specified

lower

left

Append Mode (and

to

®

word

press

in the text.

this display

®

the If

corner of the screen.

it

key,

is

the

You

are not

not entered into your

moves

cursor

does not, press |ESC| and

to

the

try again.

ESCAPE? The slash-search command is a vi Command Mode process and |ESC| makes sure you are in the Command— and not Append — Mode.)

(Why

press

another word and use the slash-search command to move the cursor to that word. The slash-search command is a powerful way to locate a word in your text. It is a two-way command— you are always returned to Command Mode. Select

(11) Finding Clones: If the word

you

select in this exercise

is

found

more than once in your file, the search command can go to only one of them at a time. Pressing the n key (for next) will send the cursor to the next identical word in your file. Repeat this process and the next instance of the and you will locate the next .

word.

When

.

.

.

.

the editor has reached the end of a

back to the beginning of the

file

.

file

it

will

loop

and continue the search.

The Visual Editor

43

No

(12)

doubt you used the word

the

more than once

in

your

file.

Type

®

/the

and move to the next the by pressing the n key. The n is a two-way command.

Two-Way (1)

Text Changing

command

Commands

Deleting Lines: Lines of text are easily deleted. To delete an entire line of text, position the cursor on any character on that line

and

type:

dd Blank lines

(as well as text lines)

can be removed with the dd com-

mand. Note:

You do

not press the

®

key.

As soon

machine does what is requested removed. The dd command is a two-way command.

struck, the line

(2)

is

second d is and ZAP!! The

as the

.

.

.

Undoing an Editor Command: It is possible to undo the effect of the most recent text changing command using another command, the undo

command.

Type the undo, or ‘T goofed” command: u

The

removed

should reappear on your screen. The undo command allows you to go back only one text changing command. You can only issue the undo command from the Command Mode just

line

of the visual editor.

Press u again.

(3)

What happened? Because u undoes

the preced-

command,

ing

pressing the u key a second time will have the interesting effect of undoing the previous undo. This will return

your

file

to the condition

command. 44

The Visual Editor

it

was

in

before you issued the

first

undo

Type

(4)

3(1(1

which

will

cursor

is

delete three lines starting with the line

located.

command.

Bring the lines back with the undo

(5)

Time

to Fill in the

What

(b)

Where must

(c)

What

is

is

(a)

the

the

Blanks! Consider the following questions:

command

(a)

Answers:

1(6)

on which the

to delete

one

line of text?

the cursor be positioned to delete a line of text?

command

dd

(b)

Deleting a Single Word:

to delete eight lines of text?

anywhere on the

It is

line

possible to

(c)

remove

5dd

single

words from

the text.

Move

the cursor to the

first letter

of any word and type:

dw The dw command stands

Nice disappearing

for delete word.

act,

isn’t it?

Now i(7)

bring the

Place the cursor in the middle of a

mand. Does

(8)

word back with the u command.

it

delete the whole

word and

try the

dw com-

word?

Position the cursor on the

first

letter

of another word and

press these keys:

3dw As with most

vi

used preceding the

Command Mode commands, numbers dw command

can be

to increase the effect of the

com-

mand.

The Visual Editor

45

(9)

Deleting Specific Characters: Select a letter someplace in the text and move the cursor to that letter. Delete it with the command (lower case): X

The X command It

(10)

is

deletes only the single character under the cursor.

the delete one character at a time

place an x over a character,

command.

and instead of leaving

(Now you can a

smudge, the

character disappears.)

What do you expect 6x

will

The space between words on

do? Try

a line

is

it.

a character just as are letters

or numbers.

Thus, the x can be used to delete unwanted spaces between words.

(11)

Another Quick Review: (a)

What

(b)

What command

(c)

What command

(12) (d)

is

the

command deletes

to delete

an entire

line of

your

file?

one word?

deletes the one character under the cursor?

Without referring to the commands, return to your current file and remove one more line, one more word and one specific letter.

Answers:

(a)

dd

(b)

dw

(c)

x

Replacing a Single Character: The

commands

dd, dw,

and x allow you to selectively delete lines, words and characters. At times what is needed is the substitution of one character for another. The r command replaces the one character located under the cursor with the very next character that you type. For instance, imagine the cursor is located at the w in the word two. If the r command were typed, followed by the letter o, then the w in the word two will be replaced by an o. The word two becomes too. This

46

may seem

vi

confusing, but the action we’re describing

The Visual Editor

is

not.

the

Move the command

cursor to a particular letter and replace

by typing

it

r

followed by the replacement character. with several other characters in your file.

That

Now

(13)

command

dogcatcher^s back.-ther&''s

Breaking

Up

a

a character

is

to

long what

is

really

making

it

Id

Like to

replace

Long Line: One of the handy uses of the replace break one long line into two lines. If a line is too

command dle,

Practice the r

two

needed

is

for a

RETURN

to be placed in the

mid-

lines, right?

Select a long line in your text.

Move

between two words near the middle of the

the cursor to the space line.

Type the

replace r

The Visual Editor

47

command and

then

press

®

the

You

key.

'‘space” character between the two words with a

move

the second part of the line should

works because the

®

is

to a

replacing

are

new

®

As

.

the

a result,

This action

line.

just another character to the visual editor.

One- Way Text Changing Commands (14) Substituting for a Single Character:

The

command

r

replace a single character with one other character.

allows you to

Often an author

programmer needs to substitute several characters for a single character. The s command will substitute for the one character under the cursor whatever you type until you press the lESCI key. or

Select a

word

in

your

you might like to word and type (lower

that

file

cursor over a letter in that

Type one or more characters, then press |ESC| mand, the s command must be followed by

.

Position the

alter.

case):

comwhen you are

Unlike the |ESC|

r

finished entering text.

The

difference between the r and s

command removes replace the

single

is

important.

single

new

Each

The r will The r com-

character in your text.

one character with a

mand makes to the

a

commands

character.

the single substitution and returns you automatically

Command Mode

You

two-way command).

(r is a

are not

Append; you do not use the |ESC| key. In contrast, the s command allows you to substitute as many characters as you wish for the one removed character. The s command moves you from Command Mode to Append Mode and leaves you there until you use the lESCj to return to Command Mode (s is a one-way command). left

in

(15) Substituting for a

Word:

exchange a specific word in your text for other words. Position the cursor on the first letter of a word. Type the command: It

is

also possible to

cw

The cw stands at

48

for change

the end of the

The Visual Editor

word

word being

.

A

dollar sign ($) will

replaced.

You then

now

appear

can type the

replacement text. Although the command removed only one word, you can replace that one word with several words, entire sentences, or pages.

Typing the cw

command removes

the one

word and moves you into the Append Mode; therefore everything you type will be entered as text until you press the ESC key (16)

Weird Characters on the Screen: A common mistake is to try to move the cursor, thinking you are in Command Mode, when you are actually in the Append Mode. A series of weird characters or "[A"[B"[D"[D) will appear on the screen (not unlike a Monty Python movie). If this happens, you are in the Append Mode, and those "K or "[A type characters are the control characters associated with the arrow keys. The visual editor is following your instructions and happily adding control characters to your file. Should this happen you need to press |ESC1 and use the x

command i(17)

to delete the control characters.

and cw commands allow you to subtext for a single character and for specific words, respecYou can also substitute for entire lines in your file.

Substituting for Lines: The stitute tively.

s

on any character in a line that is a likely candisubstitution and enter the command (lower case):

Place the cursor

date for

cc

Whatever you now type will be entered into the file in place of the one line that went poof! You are not limited to entering only one line, but can append any number of lines at this point. (18)

Append Mode/Command Mode: It is important that the function of the various commands be understood. Look again at Map C. Whenever you leave the Shell and enter the visual editor you are All this means is that the always placed in Command Mode. machine is programmed to understand and act on a limited number of specific commands. These result in moving the cursor, deleting or changing text, or moving into Append Mode. an append command is given (such as a to 2Lppend text or cw to change a word) the machine is programmed to move you out of

When

and into Append Mode. Once in Append Mode, every character you type will be put in the file as text and

Command Mode virtually

The Visual Editor

49

displayed on the screen.

ESCAPE

You remain

Append Mode

in

until

you

This means you must tell the editor you are finished adding text and want to return to the Com-

press the

when mand Mode,

|ESC| key.

regardless

of which

particular

command you may

Append Mode. The ESCAPE key Command Mode!

have used back to

When

to enter the

is

the

way

doubt about what mode you are in, press the ESC key. If you are in Append Mode (adding text) you will be moved to the Command Mode. If you are already in Command Mode, pressing the |ESC| key will do no harm. It will inform you that you are already in Command Mode by harmlessly “beeping.” in

I

Appending Text (1)

to

a File

Module Three you used the a command to append text when you initially started a file. The a can be used any time you want to In

add text

to the right of the cursor.

Pick a place in the text where you could add more text and move the cursor to the last letter of the word just before where you

make the addition. Then press the a key. You are moved to Append Mode and whatever you type will be entered as text. Add several words and then press ESC to return to Command want

to

Mode.

The

command

allows you to start adding text to the right of the cursor. But what if you need to add text to the left of the cursor (as the first character on a line, for example)?

(2)

a

Inserting Text: Select a place to add some text (such as the beginning of a line). Move the cursor to that place and use the 1

command to insert (i — insert) text. The moves you from Command Mode to Append Mode. Every character you type after typing the command will be entered as text in your file starting with i

i

the space to the

50

left

The Visual Editor

of the cursor.

(3)

Add

several words or lines

The way

of text.

to

indicate

you want to stop adding and return to vi Com-

that text

mand Mode ingly, with the

Figure

1

not

is, I

i

surpris-

a

I

Figure

ESC key

1

I

indicates

where the various Text Appending Commands

adding text relative to the position of the cursor: a appends text to the right of the cursor, and i inserts to the left.

start

(4)

and i keys. Position the cursor on your file, press either key, add a word

Practice using both the the a

the

first letter

of a word in

of text, and note where the

Opening

a Line Below:

already existing lines.

on

that line

It

new word is

is

placed.

add text between two

also possible to

Select a line,

move

the cursor to

some

place

and type (lower case): 0

The

(5)

0 stands for open a

new

line

below the cursor

line.

A

space

opens up for a new line between the line where the cursor is located and the next line in your file. [When you enter the o command on dumb terminals the line below a ppear s to be removed. Panic not — it will reappear when you press ESC and the screen is

The next line is not deleted, just temporarily make room for the new one (or ones).]

‘‘redrawn.”

over”

to

‘‘covered

can continue typing as long as you wish; you are not limited to t hat one line. As with all Append Commands, you must use |ESC| to let the machine know when you are finished adding text and want to return to Command Mode.

Add some new

Opening

text.

You

a Line Above: In addition,

above the line

in

which the cursor

any character on {\\q mand (Upper Case):

first line

is

of text

you can open up located. in

your

Move

file

a

new

line

the cursor to

and type the com-

O The

O

stands for Open a line above the cursor

line.

A new

above the cursor should open up and whatever you type

The Visual Editor

will

line

be

51

added at that point. Again, if the first line “disappears” it has not been removed. The O (Upper Case O) command is the easiest way to add text to the top of a file. As you have now discovered, it can be used to open a line for text above the first line.

As with

command, you can continue

the o (lower case o)

typing as

long as you wish; you are not limited to that one line. Because these two open a new line commands move you from Command to Append Mode, you must use the |esc| key to signal when you are ready to stop adding text and return to Command Mode. (6)

Summary

of

append

on

Append Commands: You now know how to the

text

cursor.

four sides of This ability is all

summarized

in

Figure

the

as

your

cursor

point,

i

inserts

2:

with

i

a

left;

appends to the right; O Opens the line above; and o opens the line below.

To make sure you

You

key.

Figure 2

are in

v/

as

it

can save the

Shell by typing the

a

I

starting

the

to

q

file

Command Mode now

is

press the [esc

written and return to the

command:

ZZ (8)

Time

to Fill in the

from Shell

to

Command

and

vi

Command Mode

finally

lowing questions on (a)

What

is

Blanks: Look

the

Map C and

at

to

Append Mode, then back

back to the Shell.

Map

follow the path

Locate answers to the

to

fol-

C.

command

to

move from

the Shell to

vi

Com-

mand Mode? (b)

What to

52

are four

the

commands

Mode where

to

text

(c)

what mode must you be arrows?

(d)

After entering an o or

In

The Visual Editor

O

move from can

to

be

vi

Command Mode

added?

employ the cursor moving

command, what Mode

are

you in?

What

(e)

command

the

is

appending text and want

(f)

What command

(g)

your

What What

(h)

the

is

command

Command Mode?

starting

new

a

file?

UNIX of com-

to leave the Shell, terminate the

Mode, where

a

new

set

understood?

is

What command do you use

(i)

begin

to

session, and return to Reality

mands

vi

saves the

command

the

is

to return to

are finished

new (and improved) version of memory of UNIX and returns you to the Shell?

the

file in

know you

to let the editor

to

add text

text

after

to the line

below the

cursor line?

How

(j)

Answers: editor

(d)

would

(a)

you

filename

vi

(b) a,

Append Mode

(h) logout

(i)

and enter the a

0

add

(e)

i,

o,

[ESC

(lower case)

(j)

O

(c) (f)

Command Mode

ZZ

(g) vi

place cursor

on the

word?

of the visual

filename last letter

of the word

command

Another Practice

(1)

particular

a

File

Mode. If you logged out, log back Once the Shell prompt appears you into your UNIX account. should start a new file which we will call experience. From the Shell

You should

still

be

in

the Shell

type:

In this

new

file

we’d

ing text processing

is

like

vi

experience

you

to describe

going.

® how

the process of learn-

Summarize what you have learned so

whether or not you are enjoying the process, and what suggestions you’d make about improving these Instructional Modules. Keep the lines short, don’t correct mistakes as you are entering the text, and just type away. Attempt to enter as much text as quickly

far,

as

you can.

The Visual Editor

53

Enter at

(2)

least

practiced in later

(3)

30 short

lines.

Forty lines

Modules more useful

make

will

the activities

to you,

Now

go back and make corrections to this text using the commands that were introduced earlier (the slash-search I word command, arrow keys change word cw command, etc.). A summary of the commands you have used is included as the final pages of this Module. Be sure to try each of them several times as you write your new experience file.

E

Examine what you have

(4) line;

open up

a line

above

that line

(5)

Find several places

(6)

Change one word

(7)

Delete one line and add

(8)

Remove

to

Move

the cursor to the

Return

add more text and do

so.

into another word.

the

to the Shell

Make a paper Shell command

new

text in

and save the

its

place.

(a)

file

using the

copy of the

(line printed)

of “Filling

mands append cursor’s

ZZ command. experience using

Blanks”:

— — "

What com-

cursor.

that

®

experience

Consider the rectangle in the diagram at right to be the

file

make

sequence: Ipr

Round Four

first

and enter an introduction.

the period at the end of a sentence and sentence longer with the s command.

(9)

(11)

written.

text to the

left, right,

above,

and below? (b)

You have now words and

54

practiced the

lines.

The Visual Editor

commands

You have

also

that delete characters,

used the

commands

that

substitute or change characters, words and lines.

mand

that substitutes text for

in the

appropriate box in the following chart.

five

one character

s

is

and

Fill in

The comis

printed

the other

commands.

Character

Substitute

Word

Line

s

Delete

Answers:

(a)

O I

i

a

0

(12)

Your

experience

Character

Word

Line

Substitute

s

cw

cc

Delete

X

dw

dd

file

Modules; add as much (13) Please

Module

read

be useful as you

will

to

it

the following

as

complete the next

you can.

command summary

before beginning

Five.

The Visual Editor

55

Command Summary Shell

Commands

Command vi

Function

filename

Starts

or

retrieves

a

named

file

filename for

\\sual editing.

Displays a

Is

Ipr

Has

filename

a

1/s/

of

file

names

your account.

in

copy of the specified filename printed on

the Vine printer.

who

Presents a

list

who

of

is

currently logged into

your UNIX system. date

look

Provides today’s date and time.

Looks

abc

in

and displays words beginning

dictionary

correctly

spelled

a

of

list

with

the

letters abc.

passwd

Changes the passwo/d assigned account.

Cursor Moving

#

(h,j,k,I keys)

Commands

Moves

cursor one line left.

arrows

Moves

#

/ word

Moves cursor forward through

Moves mand.)

56

Commands

or one space right and

n

The Visual Editor

cursor

to

your UNIX

(Don’t forget your new password!)

Vi Text Editing

BmmB-

to

number

next word.

up/down

of lines or characters. text to word.

(Used with /word com-

Text Changing

Commands

Two-Way Commands (Automatic Return

to

Command Mode)

Command dd

#Jdd

dw

# dw

Function

Deletes cursor line of text. Deletes

number #

of lines of text.

Deletes one word from text.

Deletes

number # of words from

text.

Deletes the one character under the cursor.

#

X

r[3

u

Deletes

number # of

characters

from

text.

Replaces the one character under the cursor with the next character typed c.

Undo: Reverses

change action.

last text

Append Mode Commands One- Way Commands (Leave

a

You

in

Append Mode)

Appends (adds)

text to a

file

to the right of cur-

sor.

i

0

Inserts (adds) text to a

file

to the left of cursor.

(lower case o) Opens a line below cursor line for

appending

text.

The Visual Editor

57

o cw

(Upper Case O) Opens a for appending text.

Change word: exchanges new in text that

cc

Change text that

S

line

it

text for

one word

exchanges new text for one removes.

line in

new

line in

line: it

it

line

removes.

Substitution: exchanges text that

above cursor

removes (same

text for

as cc

one

command).

Mode Changing Commands Command ESC

Function

Escapes from text Append v/

zz

Mode and

Command Mode.

Quits work on a ing

that

editing

file,

writes changes

session

into

the

The Visual Editor

made

dur-

memory

UNIX, and returns to the Shell Mode.

58

returns to

of

book.

the

of end

the

at O)

iosaJ O)

"^(g) ino3oi

oo

•O

o

~a

ZZ

B

located

1

® djnpdoojj IIlSOT

C/D

o

u

luwUaflJ' lA

L

AV3

0;

33



key

>

ed version of your


!

entered:

to re-encrypt

it

newname

instructs the Shell to overwrite the old encryptfile

with the

new encrypted

new nonencrypted version you may want to remove it.)

still

The Pack and Compact Commands: At many is

is

filename

and then wish

filename

forget that the

account

line

command:

crypt

The




symbol? will

have numbers

edit a particular file?

command

What

stop the Shell from overwriting an

Command Mode command

when you

(c)

will

when you use

file

displayed

you

command

Shell

existing

log into

remove the include

(until

editing

numbers

numbers? for any files that

you logoff)?

How

could you have numbers appear in every you logon to your account?

What command produces

a listing of

all

files

file

every time

your

in

Home

directory, including the dot files? (g)

How

could you have the word format interpreted by the Shell to mean nroff -ms [whatever file you enter] as an argument to format, and have the output sent to the page command?

Answers! (d)

setenv

the .login

(a) set

noclobber

EXINIT

file,

(f) Is

set

-a

number' (g)

.login file.

288

(b) set

Account Management

enter

number

(e)

(c) set

add setenv

nonumber

EXINIT

format 'nroff -ms \l*

set \

number'

to

page' into the

&

M O D U

Module Seventeen

L E

Backgrounding a Process

17

Introduction At various places in this book we have mentioned the concept of running a job in the background. Backgrounding a process refers to having a current Shell process (nroff, Ipr, etc.) run in such a way that the terminal

is

free to accept other Shell

commands. You

are

then able to work on one task while UNIX quietly completes a different Shell command sequence. This Module presents an introduction to the

commands

that affect

background processes.

Prerequisites Before starting this Module you should have completed the exercises through Module Ten. In particular, make sure you are familiar with the & backgrounding character introduced in Module Six.

Objectives After completing this (1)

Execute

a Shell

Module you should be

command sequence

work on some other UNIX

able to:

while you simultaneously

task;

289

(2)

Monitor jobs or processes that are running and

(3)

Terminate jobs or processes that are running ground.

in the

background;

in

the back-

Procedure The procedure steps for this Module are presented in three sections. The first section deals with running jobs in the background. The second section discusses how processes currently running in the background can be stopped and re-started (a feature available

on BSD

4.0,

4.1,

and

introduces the batch

UNIX versions

4.2

command— a

only).

The

final section

cheaper way to run a job

in the

background.

Running a Shell Command Sequence (1)

Log onto your UNIX account.

Select

one of your

for the exercises in this Procedure Section. lines

(2)

would be

Background

in the

A

file

larger text files

with 300 to 400

ideal.

The Ampersand: The &

character was introduced in

This creature allows you to background a Shell

To further explore how mand sequence: nroff

-ms

this

command

command works

[filename] |

Ipr

Module

Six.

line.

enter the

com-

&

Appending an ampersand to any Shell command line places the process into the background (where it is quietly but efficiently executed), and returns control of the terminal to you. (Kind of reminds us of the old tv series Outer Limits.)

You

can then attend to other

UNIX

activities,

without

having to wait sequence. Most

first

complete your requested command versions of UNIX will inform you when the process is complete by writing a brief message on your screen. At some locations you may need to periodically check whether the process has been comfor

to

pleted.

290

Backgrounding a Process

(3)

Waiting for Godot: The simplest way the background job is completed is

check on whether or not to use the wait command. to

Enter the Shell command:

®

wait

the job sent into the background has not been completed, this command will cause UNIX to pause until the backgrounded job is complete. Using the wait command returns UNIX to the state it If

would have been

in

if

you had not sent the job

into the back-

ground.

you get bored waiting for the process to finish or want to continue with another UNIX task press the DELETE key. This will If

delete the wait process, allowing the job to slip quietly back into the background.

(4)

Performing a Process Status Check: While UNIX is attending to a Shell Command sequence such as the one you entered in Step

Two, type the following

Shell

command:

®

ps

You should

receive a message which appears similar to the follow-

ing:

TT

12581

ia

STAT R

12438

id

R

PID

The ps command stands time to report

all

the formatter

TIME

COMMAND

:02

ps

:46

nroff -ms experience

and can be used processes submitted from your account. for i^rocess status

at

any

speedy (or if you sent a short file) the process status may not show that you are backgrounding an nroff process (as the process may have already finished). If this happens, submit a longer file to be formatted using the & to put the process in the background, then retype the ps command. If

is

particularly

Backgrounding a Process

291

your backgrounded process. PID means Vrocess Identification’, this is the “job number assigned by UNIX to the command listed under the heading Com-

Note the PID number assigned

to

mand. The other headings are not of interest

(5)

Killing

at this time.

Backgrounded Process: You can terminate

a

grounded process with the

kill

command. For example,

a

back-

to kill the

process identified as 12438 in the above sample process status check, you would enter the sequence kill 12438. Shell

Enter the following Shell

command sequence

where

[pYd]

is

abandon Note:

(6)

if

number found

the process

when you entered (kill)

the job

is

command

the ps

the

®

PID

kill

already completed,

background job

UNIX will with that number.

in the prior step.

associated

process

Shell

for your

it

cannot be

killed.

Quiz Number One: (a)

background the process the file named samneric and

What command would cause UNIX of locating misspelled words in put these words in a

(b)

named

What command can be used tiated in question (a)

(c)

file

How Shell

above

is

to

spellsam?

to see

if

the spell process

ini-

completed?

UNIX you’ve changed your mind about the process initiated in question (a) above and don’t wish to

could you

tell

have the process completed? Answers:

(a) spell

samneric

>

&

spellsam

(b) ps

(c) kill

PID

Stopping and Re-Starting Jobs (Available Only on

(1)

Versions)

Stopping a Foreground Process: Some UNIX systems will allow you to temporarily stop whatever process you are working on. In effect the process is placed in a state of suspended animation, while you are

292

Some

moved back

into the Shell

Backgrounding a Process

Mode

(microprocessor cryogenics).

one of your first

and

several lines of the

the

at

same time

practice files for visual editing. file

are displayed,

press the

Z

key once):

®

CTRL-Z

You should should now

Once the type (hold down CTRL

receive a note indicating Stopped and a Shell prompt appear. If those two events do not take place, your

system probably does not have these features, and you should proceed to the next section: Running Jobs through Batch.

you have stopped the job and are presented with a Shell prompt you can perform any Shell activity you desire— your stopped process will silently await your return. Perform some modest Shell command action (perhaps look up the spelling of all words beginning with the letters uni). Leave your file in suspended animation for another moment— you’ll soon learn how to re-call it. If

(3)

Checking the Background report

tems the

all

that

ps

The ps command will processes running on your UNIX account. Most UNIX syssupport the CTRL-Z command also offer an alternative to

command

for

for Processes:

checking

on

stopped

or

backgrounded

processes.

From

the Shell enter:

jobs

A

®

of backgrounded or stopped processes will be displayed for your edification. The jobs command is the quickest way to discover these processes (much quicker but less thorough than the ps list

command). (4)

Pulling a Stopped or Backgrounded Process into the Foreground: Any Shell command sequence which has been backgrounded or stopped can be brought back into the foreground.

The process you stopped

command)

is

still

in

command). following command: the jobs

few moments ago (with the CTRL-Z suspended animation (you just checked with It can be brought into the ioreg^round mXh the a

fg

® Backgrounding a Process

293

Voila!

editing process reappears,

Your backgrounded

continue work. with the

Write the

and you may

onto the disk and return to the Shell

file

ZZ command.

Warning: The following sequence of events (a)

Begin editing a

(b)

Make some changes

is

dangerous:

file;

to

it;

Stop work on the file with the CTRL-Z command, and perform some Shell task (such as look up the spelling of a word);

(c)

was placed in limbo, again enter the vi filename command and thus call up a new buffer copy of the file [as it was before you began this editing Forgetting that the buffer copy of the

(d)

file

session in step (a)]; then Start editing this

(e)

second version of the

file.

At this point, in addition to the disk copy, you would have two temporary copies of your file, one in the background and one in the foreground. Both copies are now different from the original disk copy and different from each other. If you write one file onto the disk, and then write the other, the second will overwrite the first, resulting in the loss of the editing performed on the first copy. Be certain to go back to files that are stopped rather than

up new versions of the file.

call

The backgrounding of you need

to look

editing processes

up the spelling of

some other file to write out a Just remember to bring file. rather than starting over with a

(5)

Killing a

word

especially useful

or

if

when

you want go

into

portion for inclusion in the present the

file

back into the foreground

new

edit

command.

Backgrounded Process with chkps: As you now know,

one of the uses of

number

a

is

a process status

assigned to your

check

command

is

to discover the process

so that you can

kill

that pro-

On most UNIX systems that support the CTRL-Z, fg, and jobs commands these two actions can be accomplished in one easy step. cess.

From

the Shell enter the

command

chkps

294

Backgrounding a Process

-iv

line:

®

This

command

individually

will

list

processes currently in the

all

background. You will be asked whether you would like to terminate any of the processes. If you want the job killed, enter yes (or y) and press the key. If you want the process to continue, simply press This Shell command sequence is a useful addition to your .logout file, as it will detect any unwanted processes which might continue to use computer time after you logoff. For

®

®

reason,

this

.

the chkps

command

is

noted

in

Module

Sixteen:

Account Management.

(6)

Review: (a)

you are editing a file named rhett and need to know how to spell the word butlet\ how could you find the word using the spell command, without ending your editing session?

(b)

Once you had

If

editing the

What

(c)

(d)

the correct spelling,

how would you

return to

file rhettl

command

Shell

could you use to see suspended animation?

stopped and

in

What

command

Shell

identifies

all

if

the

file

rhett

is

backgrounded Jobs and

permits you to decide whether each should be continued?

Answers: (d)

chkps

(a) First type

CTRL-Z, then look

but

(b) fg

(c)

jobs or ps

-iv

Running Jobs Through Batch While UNIX

designed primarily as an interactive operating system it is possible to run Jobs through the UNIX batch facility. Each batch Job is held by the system until UNIX has the resources necesis

one time. This contrasts with interacJobs, which are worked on in a piecemeal fashion. Although

sary to complete the Job at tive

batch

processing

is

usually slower then interactive processing,

it

does offer the advantage of allowing you to specify certain limits to the Job that cannot be done with interactive Jobs (e.g., run at night when costs go down or exit Job if it takes longer then a specified

Backgrounding a Process

295

amount of cpu

batch

In addition,

time).

is

often considerably

cheaper (and easier on the system) then running jobs interactively or in the background. Batch jobs can be run with a wide variety of options. We will present only the basic process. Additional information is available from the on-line UNIX Programmers* Manual.

Running Running

a Batch Job: a batch job

The a

is

batch facility

is

accessed from the Shell.

command same command lines

two step process:

(1) the Shell

you want followed (these are the you would submit from the Shell if you were running the job line(s) that

are entered into a

interactively)

commands is then commands are executed. Shell

file;

the

(2)

file

containing the

sent to the batch processor, where the

For instance, assume you have a text file named report2 that you want to format. The steps necessary to batch this nroff job would be:

(a)

First create a “script” file containing the Shell

be submitted to batch (in this instance, the would be nroff -ms report! Ipr); and to

command command

line line

\

(b)

Then submit ate Shell

the script

command

This general process

(1)

is

file

line (e.g.,

Just place the

the Shell into a

Use the

script

scriptfile).

file

in

this

command (s) you would

example

is

easily

normally use from

file.

visual editor to create a

contain only the following Shell nroff

batch

by entering the appropri-

described in the following steps.

Creating a Script File: The created.

to batch

-ms filename

new

file

Command

called script

which

will

line:

>

filename is the name of a file in your account that you would like formatted. The filename nfile is the name you would like given to the formatted version of this file. In this

command sequence

(Programmers can replace this line with the Shell command quence necessary to compile a program.)

296

Backgrounding a Process

se-

(2)

Submitting the Job: The following Shell command sequence will ask UNIX to process your batch job (i.e., have the command (s) you entered into your script file obeyed): batch

The

file

named

script

is

®

script

sent to be batch processed.

In response,

batch will do two things:

you the jobname being assigned scrip 17429, and

(a)

Tell

(b)

Create two

files in

file

(3)

will

use

it

is

the

line(s)

file

more

to-be-worked-on.

batch involves at least two

command(s) which

consists only of the Shell

the Shell to perform one or

mand

you

next Procedure Step.

one

file(s)

such as

batch. out.

as scripl 7429) as

The process of having jobs run through files:

this job,

your account: batch. err and

Note the assigned jobname (such in the

to

specific processes,

The

and the to-be-worked-on

file

instruct

and the other

containing Shell com-

file(s) are

not the same

file.

A

General Nroff Script File: It can be awkward having to go into the script file and change the name of the to-be-formatted file every time you want to batch (or botch) a formatting job. Much more useful is a script file that permits you to specify the to-beformatted file as you give the batch command.

To

create such a general script

line in

your

nroff

script file

-ms

$1

file

you should replace the present

with the following

>

line:

$2

>

With the nroff -ms

$1

the following Shell

command sequence

$2 line in your script

file,

to batch

you could use

process the

file

oldfile:

batch

The file oldfile named newfile.

will

script oldfile newfile

®

be formatted and the output placed

Backgrounding a Process

in

a file

297

and $2 are symbols interpreted by the Shell to mean: replace these characters with the first and second arguments that

The

$1

follow the

name

Consider sequence

another

of the script

named

in a file

with

example:

the

the Shell

script,

command line. above Shell command command sequence

batch Shell

in the

file

®

script experience n.exper

batch

named

and place this material into a file named n.exper. (Note: Arguments are discussed in Module Sixteen: Account Management.)

will

(4)

have batch format the

file

experience

you forget the batch job name otherwise check on the status of

Checking the Batch Que:

In case

assigned to your job or wish to your batch job you may enter the following Shell

command:

®

batq

inform you of the status of your batch job (along with any others being processed) whenever you enter the batq Shell

UNIX

will

command. (5)

Removing and then

a Batch Job: Occasionally you

realize that the job

processing.

Jobs

sent,

was not

but

not

(removed from the batch que).

may send

a job to batch

ready for the requested processed, can be cancelled really

you need is the jobname scripl7429) and the following

All

assigned to the batch job (such as

command. To remove command:

the job scripl7429, you would enter the following Shell

batrm In general, to

remove

-j

scripl7429

a batch job

®

you use the following

command

sequence

batrm where jobname

298

is

the

name

Backgrounding a Process

-j

[jobname

®

that batch assigned to

your job.

(6)

Additional

Commands: Two

additional Shell

commands should be

noted: (a)

batman, which summons forth an overweight and poorly conditioned middle-aged man who dresses funny and drives a very unusual car which closely resembles a 1963 Cadillac, and

(b)

robin, which will do

all

that

batman

will

do, but with

much

less self-confidence.

(7)

A

Final Review:

(a)

What

Shell

script file

and sent (b)

What

command sequence would you

named

script

to

have

files

place within the

formatted by nroff -ms

to the line printer?

command

would you use

have the

file

formatted and printed using the batch script script created in question (a)?

file

Shell

line

to

experience

named

Answers:

(a) nroff

-ms

$1

Ipr I

(b)

batch

script experience

Backgrounding a Process

299

Command Summary

Background

(Most Versions With Berkeley Enhancements)

Command &

Function

command sequence in the You are given a Shell prompt.

ground. wait ps

Pause

ps -g

until

Perform '.that

back-

Shell

Place

backgrounded job

is

complete

a process status check.

List processes

belong to you (your terminal).

Perform

process

a

status

check.

List

all

processes that belong to your account.

king] kill -9

g

batch

batq

batrm

Kill

jobs

number #.

process

Nuke named

process

Execute a Shell

number #.

script as a batch job.

Check the batch que.

Remove

(BSD CTRL-Z

named

4. 0,

a job

4. 1, 4.

Stop a process. List

all

from the batch que.

2 Only)

Immediately place into

Shell.

jobs currently stopped or running in the

background. fg

Bring a backgrounded or stopped job into the

foreground.

chkps

-iv

Perform

a

for a process

BSD

prompt command (not available on

process status check. kill

4.2).

MEDICAL CENTER 4150 CLCMENI

Vfc

300

Will

Backgrounding a Process

, .j

;

• coos

Module Eighteen Parts

and Wholes Mr

Introduction

When

we

writing a long or complicated paper,

usually focus

on the

development of only one part at a time. For instance, we may complete the problem statement or summary, and leave the remainder of the text alone. It is a waste of computer resources to have the entire paper formatted and printed whenever we want to examine only the part under construction. Conveniently, UNIX allows edited)

us to both separate parts as well

Additionally,

is

it

several separate

as join

files files

into

make commands

together to

possible to have Shell

files as if

(and

smaller

they were a single

more

easily

larger

files.

function on

file.

Prerequisites This Module

will

be most useful

if

you:

(1)

Have completed Modules One through Ten;

(2)

numbers displayed next to each a file (see the section on setenv EXINIT A ccount Management)

Have

line

when you edit Module Sixteen:

line in

(3)

Have the Shell command Module Sixteen); and

(4)

Have reviewed the process of working with directories cussed in Module Fifteen: The UNIX Directory Structure.

set noclobber in

your

.login file (see

as dis-

301

Objectives Upon completion Create

(1)

files

Add

be able

to:

editing;

from another

text

will

which contain blocks of text drawn from the

you are currently

file

(2)

new

Module you

of this

file

to the

file

you are currently

edit-

ing; (3)

Create a

(4)

Use

file

containing the contents of several

several special Shell characters to perform various Shell

functions

(e.g.

format and print text or compile and execute

programs on several (5)

Use several new or

files;

files

files

with one

command

line);

and

nrojf options to format selected parts of a

file

that are sections of a larger paper.

Procedure The procedural steps in this Module are presented in four sections. The first section reviews a method of breaking a file into separate parts while working in an editor Command Mode. The second section reviews several methods of joining files together from within an editor Command Mode. A new Shell procedure that accomplishes a similar task in a different way is also introduced. The

how you

can use filename expansion characters to perform Shell functions on several files simultaneously. The final section presents nroff Shell command options which can be used in the production of a paper or text. third section illustrates

Separating a File into Component Parts

(1)

Writing Out Text: To write out a block of text from your current file to a new file you need two pieces of information: (1) the line numbers of the first and last lines of the text you want to write out, and (2) a new filename for this material.

As an example suppose you and wish

302

Parts

to

save the

and Wholes

first

are visually editing the

seven

lines

of text

file

letter,

mom

(perhaps as an

introduction to your next bi-annual letter) as a separate titled

mom. start). From

vi

Command Mode

:7,

you would

(to

be

type:

®

w mom. start

7

file

The

lines specified by the line address (7,7) would be copied and written into a new file. The text would then exist in two places— in

you are currently you did not want this text the

file

to delete

(2)

editing, in

your

and

new

in a

mom

letter.

file,

mom. start. If you would need

file

it.

Various forms of the write

command

are

Command

summarized below:

Function

:J,6

w

newfile

Creates newfile copying text lines

:I,6

w

»

Appends copy of

:1,6

w! oldfile

oldfile

lines

Overwrites (replaces) lines

1

1

to 6 to

oldfile

1

to 6

end of

oldfile

with contents of

to 6

Note: These are visual editor commands. To use these from the ex line editor you would drop the colon (:).

commands

Joining Files Together from within an Editor

Two methods exist for editor Command Mode. (1)

(2)

joining

files

»

Writing out Text: The :1,6 w mand reviewed above can be used append it to another.

together while working in an

form of the write comtake part of one file and

oldfile

to

Reading in Text: To read another file into the one you are editing, you need two pieces of information: (1) the name of the file containing the material you wish to copy into your current file, and (2) the location (line number) in your current file after which you want this

new

material to appear.

Parts

and Wholes

303

Suppose you are visual editing a file named letter. mom and wish to send her a copy of the poem you created for your English CompoThis

sition course.

Command Mode

poem

is

contained in the poem

(while editing the

letter.

mom

file.

From

v/

you would type

file)

the following: :8 read

A

copy of the

following line

file

8.

®

poem

poem would be read into letter, mom immediately Once you read in this material it becomes a part

and may be treated like the rest of the text. copy was made of the originating file, and it is left unchanged. of your current

file

Joining Files Together (3)

From

A

the Shell

Copying Two Files to Create a Third: In an earlier Module you met the Shell cat command as one way of viewing files (the fly-by, catch-me-if-you-can approach). Additionally, cat allows you to merge the contents of two or more files. Cat (which stands for concatenate, a word which few people recognize and even fewer can pronounce) is an excellent tool for the task of combining files.

To have

the

poem, letter

file

file

poem combined with

enter the Shell cat

The sequence

poem

to use this

cat

sequence:

mom >

poem, letter

command I

file letter.

command

letter,

[filel

the

[file2\

in general

>

mom

into a

new

is:

[file3\

®

and file2 are the files to be combined, the > is the “larger than” right arrowhead (the redirect symbol), and fileS is

where

filel

name

the

selected for a

new

file

to receive the contents of files

1

Note: The contents of each file is not affected. The original filel and file2 will still exist, while a new filed has been created to hold a copy of both filel and file2.

and

(4)

2.

Beware!!!

Do

not use the

name

of an existing

file

to receive files

concatenated with a single arrow head (as demonstrated in the two examples in Step 3). At best you will be prohibited from executing the command, and at worst the existing file will be lost. If

304

Parts

and Wholes

your

does not contain the Shell following will occur: The cat command’s the

.login

file

following the

one

to cat

file

file

>

of

contents

its

(if

command

action

first it

has any).

into another using a single arrow

the loss of one of the

In this

files.

mand sequence would be

noclobber the is

empty

to

Thus, trying

head

will result in

manner, the following cat com-

disastrous:

cat paperl paper2

>

®

paperl

would first empty the file paperl then copy the empty paperl, leaving you without the first part of

In this instance cat

paper2 into

your paper.

The

cat sequence can be used to concatenate any

number of

files.

Thus, the sequence

>

cat filel file2 filed file4 filed

an enormous

will create

of file

1

®

megafile

{megafile) with copies of the contents

file

to filed.

Combining Two

Files:

It

is

also possible to cat

one

file

onto the end of another, without affecting the second.

command

The

Shell

line

poem

cat

will

directly

append

a

copy of the poem

The double arrowhead tents of the

first

file

» to

is

»

letter,

file at

the end of the

interpreted to

whatever

is

®

mom

in

file letter.

mom.

mean, “add the con-

the second, without

first

deleting the second.”

Due

to the ease with

good idea

which you can combine

down

files,

it

is

often a

and more easily managed files. These smaller files can be edited and revised separately. Whenever you want them re-assembled you can put to break a large file

them back together with the

cat

into smaller

command.

Before proceeding to the following review, log onto your account

and (a)

try the following:

Select

two

files

and cat them together into

Parts

a

new

third

and Wholes

file.

305

(b)

Visually edit the

you

file

command.

tions a divorce, using the :w (c)

From

the Shell add one

»

cat filel

(8)

file

to

command

another with the

line

file2.

Review Number One: Consider the following questions: (a)

What

command would you

v/

your current

file in

a

new

enter to place lines

named

file

1

to 33 of

debby.suel

(b)

What vi command will replace the contents of an existing named schubert with lines 29-200 of your current file?

(c)

What

(d)

What

will

append

onto the end of the

file

vi

magoo (e)

command

vi

current

command

will

read

in

tortie

holding the contents of

(a) :1,33

w

read magoo

debby.sue

(e) cat

File

The following

file

sarah peter

Name

lines are

r/c/c?

the content of the

file

named

file

named

file?

files

(b) :29,200

file

36 through 74 of your

named

command sequence would

Shell

(d) :40

lines

40 of your current

at line

What

Answers:

(1)

and give the two por-

just married

create a

named

w! schubert

new

sarah and

(c)

:36,74

peter^l

y/»rick

> tortie

Expansion Characters

an example

listing

of the filenames in one

of our directories:

modi mod2 mod3 mod4

This group of file

name

mods mod6 mod? mods

Parts

modindex

nmodl nmod2

names

smodl smod2 tmod4 tmod4

tmod4 vi-summary

be used to demonstrate the role of expansion characters in performing various Shell funcfile

tions.

306

mod9

and Wholes

will

9

All these files contain text relating to the Modules.

For instance, modi contains Module One, mod2 contains Module Two, modind contains an index to the Modules, smodl contains a list of words misspelled in Module One, vi-summary is the table of vi commands, and tmod4 contains a section of Module Four written out for testing a complex formatting command sequence. (Not to worry— you won’t be quizzed on this material!)

Bracketed Filenames: Sequential numbers or letters placed within brackets have a special meaning to the Shell. For instance, the Shell will understand the notation mod[l-9] to mean ‘‘act on all files from modi through mod9y You can also bracket individual (non-sequential) filenames. For example, mod[13569] will be interpreted to mean “act on modi, modS, mod5, mod6, and mod9y

Note

that the characters enclosed in brackets are not separated by a

space or

comma, nor

rootname

is

there a space between the brackets and the

(here, mod).

Suppose we wanted to list the files in this directory an entire Module. The Shell command

the

will list

names of

the

®

mod\l-9\

Is

files

that contained

containing entire Modules:

modi mod2 modS mod4 mod5 mod6 mod? modS mod Create four short (for

instance, call

files

them

should be very short. the

using the

same

root in their filenames

rootljoot2, rootS, and root4).

After

all

Each

are created, use the brackets to

file list

files:

Is

where

root

is

ruod#-#l

®

the root you used for your filenames, and

#-#

are

the alphabetical or numerical sequential labels.

Using

file

big deal

it

name expansion itself.

It

is

a

characters with the

good way

to test

what

Parts

Is

command

files will

is

no

be accessed

and Wholes

307

these characters to perform a more dramatic Shell action, however. This is demonstrated in the following step.

when you use

(5)

Format and Line Print

Files:

You

can use a filename expansion

For examformat and print Modules One through

character to sequentially format and print several

should we chose to

ple,

Four we would enter

this Shell

nroff

-ms mod[l-4]

sequence: Ipr

|

®

modi through mod4 would then be formatted and printed

Files

Page numbering

together.

(6)

Command

files.

will

be continuous.

Matching Any Set of Characters Is

would

yield this

list

of

file

(*):

mod*

The command

®

names:

modi modi modS mod4 modS mod6 mod? mod8 mod9 modindex matches any one or more characters. Thus the Shell command Is w* would list all filenames (regardless of length) beginning with the letter m. The Shell command Is *m would list all filenames (regardless of length) ending with the letter m.

The

(7)

*

Matching a Single Character: The command ? modi

will

generate this

list

of

file

®

names:

smodl nmodl

The

?

matches any

single character.

As another example,

the Shell

command Is

308

would

list all

letters

mod.

Parts

modi

®

filenames of four characters length beginning with the

and Wholes

Your

commands introduced you will name the component

effectiveness with the

can be increased

if

in this

Module

of a large

files

project filename 1 filename! filename! filename4 filename! where filename is the same root name (the above examples have used the

word mod). This root name obviously should have specific meaning to you. It could, for example, be the topic of your paper or series of programs.

(8)

Review Number Two: Consider the following questions:

What

(a)

Shell

command sequence

will

format the

files

named

format the

files

named

manic 1, manic!, manic!, and manic4‘l

What

(b)

Shell

command sequence

will

apaper, bpaper, dpaper, and tpaper? (c)

What files will be formatted with mand sequence: nroff city[l-!]

(d)

What

filenames could be listed with the

(e)

What

filenames could be listed with the following

Is

any

all

Is

com-

command?

tree*

command:

Ihead*

Answers: (d)

the following Shell

(a)

nroff manic\l-4]

(b)

nroff \abdt]paper

filenames beginning with the word

character

followed

by

the

word

tree

(e)

head

and

all

(c)

city I

city2 city3

filenames beginning with

finishing

with

any

other

character (s).

Summary

Character

Table of Filename Expansion Characters

Function

*

matches any string of characters

9

matches any single character

[]

matches any characters enclosed

[-]

matches any sequential range of characters

Parts

in

brackets

and Wholes

309

Nrojf Options Several options are available to structure

how

nrojf prepares the

copy of your paper. Options can be used to specify that only part of your paper is to be formatted. For instance, only page 9 would be printed using the following nroff command: final

nrofF -o9

The option (minus

filename

Ipr \

sign, lower case o, 9)

must immediately follow

the nroff command separated by a space.

If

you want

a file to

be given page numbers starting with page ten,

you (-nlO). This is very convenient if the file is actually the second section of a paper and the first nine page section has already been formatted.

another option

is

Each option formats and

inserted into the nroff Shell

is

available to

Command

line

which

The presence of an option is indicated to UNIX by the inclusion of a single minus sign (-) followed immediately by the name of the option. You can use more than prints

your paper.

one option (for instance both the option to limit output to specified pages and the option to halt after every so many pages). However, all options must appear between nroff and the filename, and there must be a space before each minus (-) sign in the command line.

The general

Shell

command

line for indicating a nroff

-option

A

filename

nr

option

is:

®

Table of Selected Nroff Options follows as the last page of this Module. Additional options exist and can be learned through accessing the on-line UNIX Programmer's Manual with the man nroff

command.

310

Parts

and Wholes

Selected Nroff Options

Option -

0#

Function (minus lowercase o) Limits output

#

pages indicated by the pages 3 through 5

.You

5

For example,

provided.

only would be indicated as -o3-

could ask for

the notation

to only those

-o-6

.

all

You

pages up to page 6 with

could ask for

after page 4 with the notation -o4-

case 0

,

4,

all

pages

{minus, lower

minus).

-n#

Numbers

-s#

Halts output every

#

For example, the option -nl4 would cause the first page of your paper to sport page number 14, with the second page as 15. the

first

on

a

#

pages.

.

The option

-si

is

you are producing your finished typewriter-like printer and wish to

useful in nroff

paper

page of text

if

hand feed individual sheets of high quality paper. Output resumes when you press SPACEBAR. Usually -s without an argument is set to be one page.

Parts

and Wholes

311

Module Nineteen Phototypesetting with Troff

Introduction

&

Troff -ms

*

The UNIX troff text processing system interprets formatting commands in files to produce typeset quality output, such as the text of this book. The content of this Module is intended as an introduction to typesetting. For a more detailed examination of the topic consult the Nroffl Troff User's Manual and A Troff Tutorial, available from

Bell Laboratories or

your favorite computer science book-

store.

Prerequisites

You

will

(1)

Have mastered

be able to use

this

Module once you:

the use of formatting instructions (Modules

Five and Nine);

312

(2)

Are acquainted with advanced Shell commands (Module and

(3)

Have

access to a phototypesetter on your

UNIX system.

Six);

3

Objectives Upon completion (1)

Use

troff or

of this Module you should be able troff

basic type size

and

to:

-ms formatting instructions to specify the style desired

when

document;

typesetting a

(2)

Determine type size and style for section headings and words or characters within a document;

(3)

Utilize special troff characters.

specific coo

Mr

Procedure The procedure first

tion

Module contains four

parts.

The

section provides an overview of the troff text formatter.

Sec-

two

describes

section of this

introduces

how

line length.

specific

troff

The

requests.

third

section

keeps track of such variables as point size and The final section considers how to use troff with the troff

-ms macros.

The troff

the

is

troff Text Formatter

a text formatter just as

commands embedded

is

nroff.

The

troff

system interprets

format text for a phototypesetter in the same way that nroff is used to format text for a line printer or terminal. When preparing a document for phototypesetting you employ the same basic formatting instructions that you have already used with nroff to specify paragraphs, spaces, indents, and centered text. In addition to the nroff formatting options you have already used to produce typewriter-like print, the phototypesetter has the ability to vary the size of type {point size), and style of type (fonts: Bold, Roman, and Italic) used in the printing of the formatted text. If

you include

in

a

file

to

troff instructions in a file, that file

nroff to be formatted for a line printer.

In

can

still

be sent to

most cases the

line

accommodate your type changing requests, so nroff simply ignores them. The troff system parallels the nroff system — printer cannot

both are text formatters,

troff

is

not a preprocessor to nroff (as are

and neqn). You do not send a other— you select one or the other. tbl

file

first

to

one and then the

Phototypesetting

3

1

Determining Type Characteristics This

how to determine commands without the

point size and

section will illustrate

first

font of output using troff

use of the -ms

macro package.

(1)

Point Size: The size of the typeface used in printing a document is measured in points. Most of the text in this book is set in 1 1 point type. A point is 1/72 of an inch: thus, six point type is 1/12 inch high, while thirty-six point type is V2 inch high.

Point Sizes Available on

The

point sizes usually available on trojf are:

6 point type: Six point type

7 point type:

is

of

little

Seven point type

8 point type: Eight points

is

is

use, except in advertisements for eye doctors.

not

much

people.

When

for

12345!#$%&

11

point type:

in the

When

.12345!#$%&

12345!#$%&

often used as book type, but

is

hard to read for

course of

in the

human

course of

events,

human

it

becomes necessary

events,

When

in the

human

events course

it

16 point type: The necessary course 12345!#$%&

point

type:

necessary course.

course. 1

4

Human

human events

human events

are

a

12345!#$%&

A

humane, necessary 12345!#$%&

20 point type:

3

became

12345!#$%&

14 point type: The course was a necessary event. 12345!#$%&

18

becomes

it

12345!#$%&

12 point type:

necessary

is

12345#$%&

12345!#$%&

10 point type:

necessary

of an improvement

a dull basketball quarter.

9 point type: Nine point type

many

troff

Phototypesetting

5

22

point

name 24

is

type:

Necessity,

thy

course.

point

human

type:

Are

coarse necessary?

events

12345!#$%& 28 point type: Hopefully not.

12345!#$%&

36 point type: We hope. 12345!#$%& (2)

Unspecified Point Size: The default point size setting for most troff systems is: 9 point type, which

is

the point size of this line; or

10 point type, which was specified for this

line.

Unless you specify a different value, the formatted text

will

be

in

the default point size.

(3)

Specifying Point Size:

To

specify a different point size for

some

portion of text, you must include a troff instruction as the line in

your file immediately preceding the line or lines of text you want formatted in a new point size. For example, if the following lines are included in a file, the .ps 14 will be read as a point size request and the lines which follow will be set in 14 point type.

Phototypesetting

3

1

.ps7^ This is the beginning of text set

at

14 point type.

All text will be printed in 14 point type until a

new

instruction for

some

different point size

is

included.

.ps77

This

the

is

The formatted

of type in the eleven point

first line

size.

typeset output will be:

the beginning of text set at 14 point type. All text will be printed in 14 point type until a

This

is

new

instruction for some different point size is included. This is the first line of type in the eleven point size.

To change

point size you place the

line preceding the text

you want

command

set in

|

.ps

number] as the

number\ point size type.

The change begins with the next line of the file. Whole lines are set in specified type sizes when you use the .ps number\ command.

When

using

Once you you

troff,

commands

point size

specify the point size,

instruct

otherwise.

all

commands.

text will be set in that size until

you

(If

are one-way

find

that

your

point

specifications are mysteriously cancelled at the start of each

paragraph you are probably using the -ms macros. read the -ms macros section of this Module.)

Changing Point Size Within

a Line:

You do

size

new

Be certain

to

not have to limit

yourself to specifying the text point size for entire lines of your

Should you need to make a change within a specific line (or even within a word) you place a \s number] in front of the character in the line where the change is to occur. file.

|

For example, consider: this

When

formatted, this appears this

3

1

6

dis\sl6play of te\sllxt

Phototypesetting

display

as:

of

text.

7

In the previous paragraph

we

played around with the point size in

the words: “within a line or even a word.” The following text line— with embedded commands— was used to format that line: .

.

within a line (or

.

e\s\^ve\s\\n

w/\s11As14/7/\s11/7\s11 a w\^\4o\s\(ird\^\\) you place

(5)

....

Spacing: In music, the notes which are played are essential — but so is the silence between the notes. In setting the type for a printed page, the white space between lines of type is as important as the size of the type used. This book is set with a vertical spacing of 13 point, because the text is 11 point. The vertical spacing of troff output can be changed. For instance, by includVertical

ing the instruction: .vs 9 in the text the amount of space between lines is reduced. The net effect is to put the type close together and make it difficult to read. Usually the vertical spacing is set to be two points larger than the size of the type selected for the text.

To change

the vertical spacing include the .vs

command:

number

Font Selection for Text The phototypesetter usually offers 3 or 4 separate text fonts, such as Times Roman (the standard or default typeface). Times Boldwhich includes Greek letters, mathematical symbols and other gems. As is the case with point size changes, font changes can occur either between lines or within a line (or word). face,

(6)

Times

Italics:

Italic,

plus

a

The rroj^command

special

to

character

change

font

fo/7t to Italics is:

.ft I

When

the

.ft

I

command

is

placed alone on a line in the text,

all

which follow are set in I/^7//c5. The .ft command is a one-way command. It remains in force until a new font specification is lines

entered. Phototypesetting

3

1

8

For instance: It is

when

easy to change fonts

typesetting.

.ft I

This text

be set in Italics. text will be in Italics

will

In fact

all

until a

new

.ft

font

is

selected.

R

After another font specification is

entered,

the text

When

the

file is

be set

font

(7)

set in the

is

new

font.

formatted the resulting output

easy to change fonts

It is

is

command

selected.

typesetting.

In fact all text will be

in Italics.

is

when

is:

This text will

in Italics until

After another font specification

entered, the text

is

set in the

new

a new

command

font.

Boldface: Likewise, to set type in Boldface employ the nroff one-

way command

B

.ft

(8)

Roman: To change

the type used to

following example demonstrates

B Here

the

command

is:

R

.ft

The

Roman,

all

three fonts:

.ft

.ft

feel bold,

I

here .ft

I

Italic,

R

here Roman.

The following formatted sentence Here

3

1

I

feel bold, here Italic,

Phototypesetting

reflects these various

here

Roman.

moods:

9

(9)

Changing Fonts within a Line: To change fonts in the middle of a word or sentence, enter one of the following commands ahead of the characters you want set in a particular type: \fl for Italic,

\fB for Bold, and

\fR for Roman. Place the change font instruction immediately preceding whatever

character

is

to

be set

in the

For instance, the following

new

font.

line in a file

\fBdis\fIease\fR

produces the formatted: disease. To interpret the example, the \fB instructs the formatter to shift to Bold type. It then sets d i s in Bold type. The \fl changes the font to Italics, thus the letters are set in Italics. The last \fR merely resets the font to Roman for whatever follows.

ease

Another example: \fBantidis\fIestablish\fRmentar\fBian\fIism\fR appears

as:

SLntidisestablishmQniansinism

Note:

When

remain

using troff without the -ms macros a font change

in effect until

you specify

a

new

will

font.

does not interpret the nroff command .ul to mean underline the next line of text. Rather, it will Text may be underlined with troff, italicize the next line of text. but it is a somewhat complicated task. Additionally, boxes can be

(10) Underlining

and Boxes:

troff

drawn around words or blocks of text using troff commands. It is also a difficult task. If you have the -ms macros available to you it is much easier to use the boxing and underlining capabilities of If you would like to learn how to draw lines tliat macro package. boxes using Nroffl Troff User 5 Manual.

or

format

troff

commands

alone,

refer

Phototypesetting

to

the

3

1

Determining Page Characteristics (1)

One-Way

troff Requests:

trojf keeps

track

of the specific line

and several other one-way commands which determine the formatting of your text. Every time it starts length,

point

size,

font,

formatting a line of text, troff checks point size, font, line length, etc.

its

memory

for the specified

troff begins with a

“default”

Roman

font etc.)

value for each of the variables (10 point type, which it will use until you specify otherwise.

Troff Requests and Default Values Input

Command

Default

What

it

Governs

.ps

#

10 point

Point size

.ss

#

12/36em

Size of space

character

.ft

F

Roman

Type font used

.pi

#

11 inches

Page length

.po

#

0 inches

Page offset printed

.vs

#

12 point

Vertical spacing

6.5 inches

Line length

.11#

Note on Table of Troff Requests and Default Values: The # symbol is never used in the commands. You substitute an appropriate value or

in

Em’s

inches (3.5i), points (38p), centimeters (11c), picas (22P), (3m) for the #. The F is the appropriate Font: B,R, or I.

When you

are using troff without the -ms macros, the values

any of these variables

you

remain in force until you specify new values. They are ordinary one-way commands.

set for

320

Phototypesetting

will

1

When you 12,

.11

enter a font, point size or line length instruction, (.ps 7.5/, or .ft B) troff stores the information in its memory.

Then, when

checks for the latest instruction as it begins formatting the next line in your file, it finds the new specifications for font, point size or line length. It will then use the new instructions as it formats the line.

(2)

Special

troff

typesetters

is

One

Characters:

their ability to

is

of the

more

useful

of

aspects

print characters not available

on

a

A

sample of some interesting characters available with presented in the following Table of Special Font Characters.

typewriter. troff

troff

Special Font Characters

Input

Character

Input

Character

\(sc

§

\(+-

±

\(cu

U

\(ib

c

\(aa 1

\(ga \(*a

a

\(if

oo

\(*b \(*g

/3

\(is

I

y

\(pt

oc

\(*D \C*H

A

\(es

0

0

\(br 1

\(*s

I

\(rh

wr

\(*W

n

\(lh

“IW

\(ci

o

\(->

\«-

\(ct i

\(ua \(da \(dg

.

\(bu \(14 \(12

• '/4

V2

Note on Table of Special Font Characters: Each of the characters listed can be used by including the input code as a “word'’ in the text where you want the character placed. The point size of these creatures has been changed to 12 to better highlight their appearance.

Phototypesetting

32

For example, the following It is

line in a file:

as easy as \ (*a

produces the following formatted It is

A more the

(3)

complete

list

Nroff! Troff User

5

as easy as

line

f3

y

.

of text:

.

of the special font characters

is

contained

in

Manual.

Obtaining Output: Because the troff system is a text formatter just like the nrojf system, you send a file to the troff formatter (for phototypesetting)

instead of the

You

quality output).

will

file

there

is

a

queuing system

File

Length

command

similar to

filename

at

your location you might use;

-Q

troff

typewriter

(for

to the phototypesetter:

troff

If

nroff formatter

normally use a Shell

the following to send your

(4)

a

\ (*b \ (*g

[filename

Most phototypesetting machines have the files which can be printed. A max-

for Typesetting:

maximum page length imum length of 35 feet a

to

(about 35 pages) is not unusual. Before longer than several, pages, be sure to inquire

sending a file that is about the page length maximum in effect at your location. You may wish to discuss submitting longer jobs or breaking a long file into smaller parts with the typeset operator.

(Note: typeset operators

are in fact real, flesh-and-blood, genuine people.)

Using troff with the -ms Macros to

Determine Type Characteristics

The most important and

-ms is font are handled. specified remains troff

difference between typesetting with troff alone the way the variables such as point size and type

the case with -ms.

322

Phototypesetting

When you

set the point size using troff,

in effect until

you specify

a

new

one.

the size

This

is

not

(1)

'2)

Paragraph Resets: (3 troff

on

you set the point size with a .ps 16 command command) you would expect all of the text from that point If

be set in 16 point type. This is in fact how troff alone will respond. With troff -ms, however, only the text between the .ps instruction and the next paragraph macro will be in the requested to

(16 point) type size.

As soon

as

an -ms paragraph macro

encountered, the point size the -ms number register associis

be reset to the size stipulated in ated with point size. We have noted in several places how the -ms paragraph macros have a lot of unexpected effects written into them (this topic is considered in some detail in Modules Nine: Advanced Formatting and Twenty: Macro Construction). The font, will

type size, and a host of other page management variables are reset to the values in the appropriate number registers every time you

invoke one of the -ms paragraph macros.

For instance,

where the .psl6 point

included

command

size

is

in

the case

in

the

text will be set in 16 point type, until the next paragraph

file,

the

macro

is

encountered, where the point size is reset to the default 10 point (unless you have specified otherwise). «

Every time an -ms paragraph macro is encountered, the formatter checks the number register named PS to see what point size is specified. Unless you have stipulated otherwise, the .nr PS register it

is

set for 10 point type.

sets the type in

After the formatter checks the register,

10 point.

If

you want

a different default point

you must adjust the number register to another value (such as 12 point). This way every time a paragraph calls for resetting the point size the value you set will be read. size,

To set a document number register to

command

as

you must change the point size read “12 point.” To do so include the following in 12 point type

one of the

first lines in

.nr

With

command

number Whenever the paragraph macros this

the

PS

a

file:

12

register

is

now

set at Voint Size 12.

reset the point size they will reset

to the value of 12 point.

Changing

Default

Values:

The

troff

-ms

formatting

process

begins with deciding upon the basic page and type size characteristics of your paper. You then enter instructions for the appropriate

Phototypesetting

323

and place this material at the beginning of the For example, suppose you want lines to be 5 inches long (for file. 7 inch paper with one inch margins) and a 9 inch page length, set in 11 point type with vertical spacing of 13 point. You would enter

number

registers,

the following

commands .nr

.nr .nr

LL PS VS

the top of your

at

file:

5/

11

13

.pi 9/

Note

that the page length control

is

the nroff instruction .pi and

not an -ms number register. There is no -ms number register associated with page length. Page length is a one-way /zro# command which is not reset by -ms paragraph macros.

Summary

-ms Number Registers Default

Function

Register

324

of

LL

Line length of text

6 inches

PO

Page offset

0 inches

FL

Line length of footnotes

5.5 inches

PI

Paragraph indentation

5

spaces

Ql

Indentation of .QP paragraphs

5

spaces

HM

Header margin

1

inch

FM

Footer margin

1

inch

PD

Vertical offset of paragraphs

Iv in nroff 0.3v in troff

PS

Point size of printout

10

VS

Vertical spacing

12

Phototypesetting

(3 )

Boxes Around Text: The -ms macros provide an easy way to box one or more words of text in your file. To box a single word you use the command .BX word with the word placed next to the command. For example, the following text in your file:

being drawn around the word

.BX

school

(perhaps reflecting the school yard.)

box being drawn around the word

will result in a

\school\

(perhaps

reflecting the school yard).

To box two

more words— or even entire paragraphs— you use the .B1 and .B2 commands. Place the text block within the commands .B1 (to begin the box) and .B2 (to end the box). The -ms macros

will

or

respond with a box of

text.

.B1 These will

lines

of text

in

a file

be boxed.

Note that the box commands precede and follow the to- be -boxed text.

.B2

These

be boxed. Note that the box precede and follow the to-be-boxed text.

(4)

lines of text in a file will

Underlining Text: The -ms macro package

will

commands

allow you to under-

You must individually underline each word, however. The command .UL word\ will underline one word at a time. To underline several words, you need to use the .UL word\ command line

text.

|

|

for each word.

This means that

.UL each .UL word .UL must .UL be .UL individually .UL underlined. Phototypesetting

325

The above display each word must be

illustrates the fact that,

with the -ms macros,

individually underlined.

This completes the introduction to phototypesetting with troff and Additional information is available in the Nroffl Troff troff-ms. User's Manual dind A Troff Tutorial, produced by Bell Labs.

The developer

326

Phototypesetting

for typesetting.

Module Twenty



Macro Construction wr-coog

Introduction In

Module Five you used

nroff requests) to instruct

Module Nine described macro

nrojf formatting

commands

(also called

how to format your text file. -ms macro commands (also referred to

nrojf about

the

which allow you

format your work with greater ease than is possible with nroff requests alone. Module Nineteen introduced the requests used to specify how troff should format more eloquent output for production on the phototypesetter. This Module illustrates how the -ms macros have been constructed from nroff requests. This information will start you on the road to understanding how to build your own macros to meet your indivias

calls)

to

dual needs.

Prerequisites Before starting

this

Module you should be

able to:

(1)

Use nroff requests (Module Five) and the (Module Nine) to have your file formatted; and

(2)

Use

(Module Nineteen)

-ms

macros

perform fancy formatting feats (suggested only for section two of this Module). troff requests

to

327

Objectives After completing this (1)

Module you should be

able to:

Describe the differences between an nroff request and a macro call;

(2)

Access macros and macro packages

(3)

Build basic macros tailored to

(4)

fit

in several different

your

own

ways;

needs; and

Determine the compatibility of nroff requests, the -ms macros and your own home-made macros based on the internal workings of the -ms macro package.

Procedure This procedure section is divided into five parts. The first section presents several simple home-made macros and demonstrates how macros are built by bundling nroff requests. The second section describes how UNIX accesses macros. The workings of a fairly complex macro are illustrated in the third section. The fourth section

examines how nroff

when commands inside a simplified

how

it

fills

are followed.

text

The

lines

and determines exactly

final section

presents a look

segment of the -ms macro package

to illustrate

works.

An

Important Review

an instruction to the nroff formatter about how your file is to be formatted. Macros (like those that make up the -ms macro package) are collections or bundles of nroff requests that can be called into action (hence the term macro call) with a single command (such as .PP). The -ms macro package is a set of macros designed to work together when used to format a file. Recall that an nroff request (such as .ul)

is

The -ms macros were created to make your formatting tasks easier. There may be instances, however, where your needs are not met by these pre-packaged formatting commands. The ability to create

own macros which

then perform complex, repetitious, or boring formatting tasks (and thereby saving you time and energy) can be quite helpful.

your

328

will

Macro Construction

Home-Made Macros (1)

Log onto your UNIX account.

(2)

When

the Shell prompt appears type: vi

This

new

{context)

file

will

®

context

be

the

practice

file

used

in

this

Module’s exercises. (3)

(4)

Enter three paragraphs of text into your new file. Make each paragraph 3 or 4 sentences in length, and write about anything you wish. Begin each new paragraph with the appropriate -ms paragraph macro call (.IP, .LP, .PP, .QP, or .XP).

A

Centered Heading Using nroff Requests: How about placing a centered title above the material in paragraph two? This is accomplished with the following four lines of text.

Place these four lines after paragraph one and before the para-

graph formatting macro for paragraph two: .sp .ce .ul

Paragraph Two

The above four

lines of text will space

the words comprising the centered

down, center, and underline

title.

In this case the centered

be Paragraph Two. If you want some other the line Paragraph Two with whatever text you want. title

will

When

(5)

all

four lines are entered, use the

write the buffer version of the

Enter the Shell

(6)

command nroff

-ms

file

and return

title,

replace

ZZ commands

to

to the Shell.

line

context

\

page

®

formatted version of context displayed on the screen. Paragraph two should appear with a centered title above it.

to

have

a

Macro Construction

329

The four lines necessary to create modest amount of work on your

the centered

title

required only a

you had a file which required 26 centered titles? One option would be to retype (or yank and put) the four lines all 26 times— a somewhat tedious task. This is where a home-made macro can do some of the work part.

But what

if

for you.

(7)

Your

Home-Made Macro:

First

Move with the

and open a new line above At the top of your file, enter the following

to the first line in

O

command.

your

file

6 lines exactly as they appear here:

.de

Ct

.sp

.ne 4.1v .ce .ul

These

six lines are interpreted as follows:

.de Ct

Indicates to nroff that the following lines,

up

to the next

two dots (..), define (.de — define) the macro Ct. The Ct was chosen to remind us of Cen-

line containing only

tered

^

t itle.

down one

.sp

Spaces

.ne 4.1v

Requests nroff to make sure that at least four lines are available on this page: if not go on to the next page;

.ce

Centers the next

.ul

Underlines the next

Concludes

These

line

of text;

line

of text; finally

macro.

from .de Cmo taken together define the macro whenever you have need of a centered title in this file

six lines

Now

Ct.

this

line;

.

.

macro .Ct can be used.

the

The

you would any other -ms macro call. The Ct macro calls for the centering and underlining of the next line in the file. Thus you first enter the macro call, then on the next line enter the text for a centered title.

330

.Ct

is

entered into a

Macro Construction

file

just as

(8)

Return

your context

to

of nrojf requests

entered them

in

At the moment you have

file.

preceding the

Procedure Step

text

.ce,

text for the centered

title.

and

centered

.ul

first

by

(You

two paragraphs and delete

which are located just before the

In place of those nrojf requests enter the a line

titles.

4.)

Position the cursor between the

the nrojf requests .sp,

for

a series

new macro

call

.Ct

on

itself.

Repeat

procedure for each centered title you placed in the file. Your file should now contain the 6 lines defining the Ct macro followed by the three paragraphs originally written. Additionally there should be one or more .Ct macro calls preceding the text for centered titles. For instance, if the centered titles are Paragraph Two and Paragraph Three, your input file should appear

something

this

like the following:

Macro Definitions .LP

Some

text that will be paragraph one.

.Ct (9)

Paragraph Two

.PP

Some

text that will be another paragraph.

.Ct (10)

Paragraph Three

More

When

text.

finished, write this

file

and return

to the Shell (with the

ZZ command). To view

the formatting effects of your nroff

-ms

context

new macro

page

type:

®

As the formatted version of your file is displayed on the screen note how the Ct macro acted on your paper (automatically spaced down, centered, and underlined each centered title). (Note: Some terminals are unable to properly display underlining on the screen. Your printed text can be appropriately underlined, even though on the screen

it

may appear

incorrect.)

Macro Construction

331

(11)

How

Uses Macros to Format: The process of employing macro definition and a subsequent macro call is quite complex: nroff

(a)

The macro

(b)

When

be read by nroff\

with

comprise the macro into the

file at

The

the

Your

macro

the

same

the

make up

nroff

your

requests

file

it

which

location;

the

new macro.

text then reflects the effects of this

Nroff

in

macro and have been interpreted and followed; and

nroff requests (that

macro

In the case of the Ct (a)

first

call

replaces

inserted) are (d)

must

nroff encounters a call for this

internally

(c)

definition

a

this process translates as:

-

read the 6 lines defining the Ct macro (which the top of the file) and store this information

will first

are located at for later use; (b)

When prets

it

macro (c)

Then

macro

nroff encounters a .Ct to

mean

definition

in

call

your

file

it

inter-

“insert the nroff requests located inside the

named Ct

nroff spaces

at this

down one

point;”

vertical line (.sp),

makes

certain

that there are 4.1 vertical spaces available (.ne), centers (.ce)

(d)

and underlines

(.ul) the

The very next

line in

appears as a centered

next input line in your

your

(following the .Ct

file

first

anywhere (12)

that a

macro defined

in that file,

macro

call)

home-made macro. Obvi-

ously macros of this type can be of great assistance.

remember

and voila

title.

You have completed and used your to

file;

at

the start of a

but only within that one

Naming Home-Made Macros: We named

It is

file

important

can be used

file.

macro Ct employing one upper case and one lower case letter. This “mixed case” convention is followed in naming home-made macros to avoid confusion with -ms (all upper case) and nroff (all lower case) formatting commands.

Macro

the

your Ct macro You could re-type the 6 definition lines which in several files? make up the Ct macro at the top of each file (a tedious and somewhat tacky choice) or you could create a permanent macro file and

(13) Creating a

332

File:

Macro Construction

Suppose you needed

to use

place the 6 lines in

with whatever

any

effective in

From

file

This macro

can then be processed along you are formatting, so that your macros will be

file

it.

you

select.

the Shell type:

file

mac

will

be the

name

®

mac

vi

The

file

of your

new

Insert the six lines comprising the Ct

your mac

for macxos.

file

macro

definition into

file:

.de Ct

.sp

.ne 4.1v .ce .ul

When

finished, write this

new

and return

file

to the Shell with the

ZZ command. up your context

Call

macro

file

Before investigating

(14)

for visual editing

definition contained in the

finished, write the

the

file

mac

file, it

and return

how

file.

When

to the Shell.

macros located examine how -ms works.

in

macro package you place calls .PP) in the body of your paper.

to

to

In using the -ms

various -ms macros (such as

What causes

lines of the

to get nroff to use the

would be useful

The -ms Macros:

first six

and remove the Ct

nroff to read the -ms

macro

definitions [analogous to

Step 11(a) above]?

This reading occurs before the process of formatting your paper is begun, and is initiated with the Shell com-

mand after

line

the

(nroff

-ms filename

command

nroff and

Ipr). \

before

By placing the -ms option the

name

of the

to-be-

you cause nroff to read the -ms macro package definitions before it reads your file. The -ms macro package file contains the definitions of each of the -ms macros (for instance PP). This information permits nroff to interpret the -ms macro calls placed within the body of your file. formatted

file



Macro Construction

333

To

ask UNIX to read your

how -ms

similar to

mac

read by the formatter before the

is

command

Enter the Shell

nroff

The

mac

file

file is

read.

line:

mac

-ms

How

do you before formatting contextl In a way

bring our discussion back to the current situation:

context

\

®

page

now

be read after the -ms macro package and before the file context. In the above command line nroff reads the file containing the -ms macros, then it reads the macro definition contained in your mac file. While formatting the file context, nroff file

will

refers to the definition of

when each macro

is

Ct as well as other -ms macro definitions

called for in the trailing context

file.

Did your macro definition and call work? If not, check sure you entered the commands exactly as demonstrated. (15)

to

make

Quote Paragraphs: The -ms quote paragraph call .QP brings the left and right margins in, but leaves the text spacing unchanged. Writers usually prefer to have quoted paragraphs single spaced. The following macro will do just that.

Append .de

the following 11 lines to the end of your

mac

file:

Qs

.sp .Is

.in .11

1

-\-10m

-10m

• •

.de .Is

.in .11

Qe 2

Y assumes

double spacing

is

wanted

—10m -\-10m

• •

These 1 1 lines define two quote paragraph macros and demonstrate how one-way macros are defined. The Qs {Quote start) macro will:

334

(a)

Skip one space (.sp);

(b)

Set the line spacing to single space (.Is 7); and

(c)

move

both the

in ten

ems

(an

left

em

Macro Construction

and right margins (.11 —10m) spacing unit used by nroff and troff).

(.in is

a

-\-10m)

The Qe (Quote end) macro

needed

is

to reset the line spacing to

double spacing and to restore the original left and right margins. You may find use for these two modest macros in simplifying your formatting chores. (16)

Using the Quote Paragraph Macro: Call up your context file for visual editing. With the following two additions, the second paragraph

appear formatted as a quote paragraph:

will

(a)

Replace the -ms paragraph macro used to format the second paragraph with a .Qs (place a .Qs before the first line of text in the second paragraph); and

(b)

Place a .Qe after the

(17) last

of that paragraph

line

— before

the

next paragraph macro.

Now

employ the

Shell

command

-ms

nroflf

mac

line:

page

context

Your text file will be formatted and you can new quote paragraph macro.

®

see the effects of the

Accessing Macros Thus

you have been introduced

far

two methods of accessing

to

macros: (a)

You

can place the macro definitions within the

done

in the earliest exercises in this

the procedure of choice in that are only used in (b)

one

file

was

(as

Module). This method is the case of special purpose macros

text

file;

or

You

can place the macro definitions in a separate file and have that file read during the nroff process (for example, page). This second method is most siminroff mac context |

lar to

A

third

how

the -ms macros are accessed.

method of

accessing

your

own macros

now

will

be

presented. (1)

The Nroff Source Command:

If

you regularly employ

designed macro package, there is an nroff request that save you time and impress your friends.

a

self-

will

both

Macro Construction

335

up your context

Call

as the first line of the

file

for visual editing.

file

mac

.so

where

mac

definitions.

name This command is

the

process— to place the mac (to source in the

mac

Insert the following

of

the

file).

nroff—^wnng the formatting

instructs

file at It

the beginning of your context

in the

file

Now

have your text

mac

include

-ms

context

formatted.

file

in the Shell

by nroff because of the context

this line

command

use the

nroff

to

file

has the identical action as naming the

nroffShtW command line. After inserting write the context file and return to the Shell.

mac

macro

your

containing

file

command

\

®

page

Notice

how you do

not need to

Your mac file will be read source command, located on line 1 of your line.

file.

Rethink — Remember Time: (a)

What nroff command named Xy ?

(b)

What

command

indicates the beginning of a

indicates

the

of

conclusion

new macro macro

a

definition?

Where would

(c)

the definition for a macro be placed to have

available only for use

(d)

anywhere

a set of

rnacros.

What

Shell

named

is

in a file

a file

david.waasl

named mynamed lillian

home-made macros and

What formatting command— located file

file

command would have

file— will have nroff access the

(f)

the

home-made macros

Suppose

formatted using only these

(e)

in

macro

as

the

it

first

nroffl

line

of a

definitions located in the

named my-macrosl

Suppose the

named

.so

kenny-Joyce.

kenny-joyce

file

command is the first line of a What Shell command line will have

my-macros

formatted using only the my-macros and

Macro Construction

file

the

nroff^.

Answers: (d) nroff

(a) .de

X}’

my-macros

(b)

lillian

••

(c) at

beginning of

my-macros

(e) .so

file

david.waas

(f) nroflF

kenny-joyce

The Workings of a Complex Macro Arguments Within Macros: Frankly, it is very easy arguments with macros— but avoid it. They always win. (1)

The following macro in

your

file

for

cally label the

you

will

leave a specified

amount of blank space

to insert a figure or diagram.

space Figure

1

the

first

time the macro

antics are possible because

automati-

will

It

ure 2 the second time, and Figure 3 the third time

Such high powered

to get into

it

is

used, Fig-

is

used,

etc.

macros accept argu-

ments.

Append .nr .de

the following 8 line Figure macro to your

mac

file:

Fg 0 Fg

.ul

.ce

Fg \\n{Fg-Fl Figure \\n{Fg .nr

.sp \\$1

When

finished, use the

this file

and return

ZZ command

to the Shell.

to save the

changes made

to

gem

be

(The workings of

this

will

explained shortly).

(2)

To

leave space for two figures in your text, append these 12 lines

(The commands should be entered exactly as are presented here; the text can be changed to suit your to the

end of your context

file.

interests):

.sp

The following pgure illustrates the of practice time on learning.

effect

.Fg 3.5i Clearly,

the

when a person

commands

they are

actually practices

remembered more

easily than

Macro Construction

337

when

the person attempts to just read the book.

.sp 2

If the preceding figure didn V convince you, this

one certainly

will.

.Fg 2.5i

which concludes

Use the usual

our argument.

(or precludes ?)

ZZ command

to write the

file

and return

to the

Shell.

(3) file,

Because the .so mac command you can enter the command: nrofF

-ms

the

is

context

first line

context

in the

page

\

your figure macros. When you feel comfortable using these macros read on and discover why they work.

Examine the

results of

Behind the Lines in the Macro War: The remainder of this Module explores aspects of nroff and macro construction which are rather technical.

Freak not— it

is

not necessary to master every

how macros work until you begin seriously writing your own macros. For now you should read through it to obtain an overview of how the break, no break, backslash, and title line commands work. You can give this material a second detail in the explanations of

(and third) reading later on.

(4)

Interpreting the .Fg Macro: to the role of

number

You were

registers in the

introduced in Module Nine

formatting process.

The -ms

macros use number registers to control overall formatting tasks such as line length and page offset. Number registers are also used internally, by nroff, to keep track of many things including the As you read the following line-by-line current page number. description of the .Fg macro note how number registers were used.

The process of using macros begins with and then including the definitions either text

file

nroff

or in a separate

file

must read the macro

the

first

internal

338

line.

All definitions of

memory.

Also

Macro Construction

at

definitions before

any

file

line

i

i

the beginning of the

it

by

In either case

reads the text line, starting

macros are transferred

commands

i

creating their definitions

consisting of macros.

In the initial reading, nroff reads the

\

not

inside

the

to

file.

from nroff

macro

i

'

i

definition are

number Later,

performed

in this initial pass

through.

(For instance,

registers can be set to specific values in this first reading.)

when

macros

nroffxs formatting the text, nroff will find calls for the in the text file (for instance .Fg 3.5i). At that point nrojf

locates the definition of the

macro

in

its

memory and

executes

those requests.

Annotation of Requests .nr

Fg 0

A number

appear

Fg Macro

named Fg and is set to This number register request

register

the value zero.

must

in the

is

outside

the

(which begins with the next that the

number

register

before the macro

is

macro

definition .de Fg), so

line:

Fg can be

set to zero

called during formatting.

read (and executed) by nroff only during Because nroff's first pass through the macro.

It

is

this

number

register

command

is

located out-

macro definition, it is not read when the macro is called (with the .Fg command) during the actual formatting of your When Fg is called, only the lines paper. between the .de Fg and the trailing .. are read. side

.de

Fg

of the

This begins the definition of the Fg macro.

.ul

Underline the next

.ce

Center the next

.nr

Fg \\n{FgFl

line of text.

line of text.

Fg translates as “set the number register Fg to whatever value follows the space character in this line.” If this line were .nr Fg 5, the number register would be set to However, what follows the Fg is not a 5. number but directions as to where the formatter can locate the needed number. (We are beginning a short game of Hide and Go Seek.)

The

.nr

The \\n( means

that the value the formatter

needs (to set the Fg number register) is not here either, but is stored in a number register, whose name follows these symbols.

Macro Construction

339

Fg + 1 identifies the number register, (namely itself, Fg) but the +1 stipulates ‘'read the present value in Fg, then add 1 to it.” Thus, whatever value is in Fg will be increased by one unit and then put back in Fg. Thus the numbers ascribed to each figure by the Fg macro will advance by one each time the macro

The

is

Figure \\n(Fg

called.

When

Fg macro call is located in your file, the word Figure and the number held in the Fg register are printed. The \\n(Fg prints the current value of the Fg register (7 the first time the macro is called, 2 the second time, etc.). Because the two prior requests in the macro definition (.ce and .ul) have been read, this line is centered and underlined (Italics in the

first

This line results in Figure

troff).

time the macro

called. Figure

is

1

the

first

2 the second,

etc.

.sp \\$1

This

last line

of the macro definition provides

the space for the figure in the formatted output.

If this line

always be

left

were .sp

Instead, \\$1 space

is

five inches

would

output for the figure.

the

in

5/,

called for.

When

nroff

reads a request followed by a \\$1 it interprets this to mean “insert the first argument to the

macro

call

of space the .Fg

here.”

You determined

when you

macro

call.

.Fg 3.5 for Figure

the

amount

attached the argument to

You

entered the

command

your file [in step (2)] and the resulting Figure 1 had 3.5 inches of 1

in

space in the output.

The

the argument for the .Fg

macro call. That argument is read into the macro because of the \\$1 request on this line. When you put the macro call for the figure macro in your text file [step (2)] you followed the first call with 3.5i and the second call with 2.5i. Each time nroff processes the macro call (whenever it appears in your file) it inserts the number you

Macro Construction

3.5

is

entered following the Fg in place of the \\$1. This gives you 3.5 inches of blank space for the first figure and 2.5 inches of space for the second.

Ends the

(5)

The Mystery

definition of the .Fg macro.

Double Backslashes: The characters that cause nroff to read in the first argument to your .Fg macro are $1. Note that references to both number registers (WnfF^) and arguments (\\$1) within an nroff request begin with two backslashes (\\ ). Why is one needed, let alone two?? of

the

To the nroff command interpreter, the \ The purpose of the nroff escape character

wh at the

I

fol lows as a

ESC key I

command and

nroff comes to a \ it characters as a command, it

the escape character.

is

to tell nroff to accept

not text.

(This

is

the

same

role

plays within the visual editor.)

When

which

is

removes

it

and interprets the following

unless the next character

is

also a \,

then leaves alone.

Commands

which have double backslashes are contained within macro definitions. If only one backslash were used, nroff would remove the backslash, interpret the command that followed and act upon it. As a result, nroff would interpret and try to act on the commands inside macros during its first pass through the macro — although in this first pass nroff is to only read the macro definitions

and store them

for use

when

called.

The second backslash is necessary to “conceal” the rest of request from nroff when the macro definition is first read.

the

For example, without the two backslashes in the line .sp \\$1, nroff would immediately act on the instructions. It would expect an argument to appear, though none would be provided. After all, this is nroff's first exposure to the macro, and is intended only to inform nroff of the existence of the macros and their definitions. You do not want nroff to act on the macro Instructions until after During the first reading it begins formatting the text of your file. of the macro

file

nroff

removes the

first \,

then finding another.

Macro Construction

341

moves on cute

(as

it

backslash the

quietly.

the

result

when

nroff returns to the

of a macro

call)

there will

This time through the backslash

left.

command

Later

is

Summary: The

macro

to exe-

be only one

is

removed, and

to

“conceal” the

exposed and followed.

role of the

second backslash

is

of the request from nroff when the macro definition is first read. This first backslash is “peeled off” at the time the macro is rest

initially

read so that the rest of the request can be interpreted and

acted on

when

the macro

is

actually

used.

This leaves a single

command when

backslash to identify this as a

the

macro

call

is

processed during the formatting of your paper.

(6)

A

Note of Caution: The macros introduced in this Module were carefully designed to work with the -ms macro package. Be aware that not all home-made macros will be compatible with the -ms macro package. The source of most problems is the way -ms uses internal number registers. The -ms paragraph macros reset various number register values in a multitude of strange ways. Unless you understand and anticipate their actions, your macros may not work as you expect. For example, the .RS macro trols

the

number

left

indent level.

call

resets a

number

All -ms paragraph

i

i

register that con-

macros check

this

determine the current indent level. This is why you can include one or more paragraphs between the .RS and the .RE and each paragraph will appear appropriately positioned on the page. Your home-made paragraph macros — unless given explicit instructions — do not access this register. Thus, they will be unaffected by a preceding .RS command. This means your homemade paragraph macro may not format text with the desired left register to

:

i

i

margin.

you want to use home-made macros in conjunction with the -ms macros (or whatever macro package you employ) it is advisable to test the compatibility of your home-made macros with the macro package you use. This notion of compatibility will become clearer once you complete the final sections of this Module. If

342

Macro Construction

\

i

i

A Look (1)

(2)

The Break Command: nroff starts a new line you might want

It is

at

Inside Nroff

sometimes necessary

some

point in your text.

produce output something

to

to

make

sure that

For example,

like:

For most people, nroff can be very frustrating. Although a very powerful formatter, it is difficult to learn for the

it

is

fol-

lowing reasons: (a)

There

is

a large variety of very specific

commands which

each other in strange ways, and (b) The effects of commands are not immediately observable.

affect

The above output was produced with

the following input lines:

For most people, ./

nroff

can be very frustrating. Although it is a very powerful formatter, it is

difficult to learn

for the following reasons: .br

(a) There

is

a large variety

of very specific commands which affect each other in strange ways, and .br (b)

The

effects

of commands are

not immediately observable.

The hxeak (.br) command requests that a new output line be started. The last line of text before the break appears is entered but not adjusted to meet the right margin. Even though there is in the output line for more words, the line will be still room printed as it is. The text will not be adjusted to stretch from the the right margin by adding additional spaces.

left to

Note

that a .sp

command

will

accomplish the same effect while

also skipping a vertical space.

Filling filling

is

and the Break Function: As mentioned

in

Module

Five,

the process of joining short input lines together to create

output lines of approximately equal length. form this function?

How

does nroff per-

Macro Construction

343

(a)

Starting with the

and places (b)

nroff collects this line

file,

memory.

in its internal

many

of the words from this input line as Usually all of the words will fit onto the first output line. from the first input line will fit on the first output line

Next nroff enters

we

(because (c)

it

text line in a

first

as

type short lines, right?!).

all

Nroff then reads the next input line. If it contains text, nroff uses the text to continue filling the first output line. Soon the At this first output line contains as many words as can fit. point there are frequently several words lected input line left over. in the current

(d)

(e)

line.

next input

line.

If this line

contains

memory, and

more

no room

is

last

to include

col-

them

It is full.

In this case, nroff stores these

in (f)

output

There

from the

text,

words

it

is

in

memory and

added

to the

reads the

words already

nroff starts filling the next output line.

however, nroff encounters a format command as the next input line it must decide what to do with the text left over from the last input line (or lines) which it has stored in its If,

memory. There are two (i)

(ii)

possibilities.

Nroff could enter the remaining text on the next output line and then perform the command function (i.e. if nroff encounters the .sp command, it could print the remaining text, then skip a line), or

Nroff could first perform the command function (enter a blank line), while holding the remaining text in its memory. Then after performing the command, nroff could collect the next text input line, add it to the text it had remaining when it encountered the .sp, and begin the process of filling the next output line.

The possibility noted as (i) above is what actually happens when nroff encounters a command that causes a break to occur. The remaining text is entered as an output line, then the .sp

is

executed.

the .bp, .sp,

.ce,

.in, .ti,

.nf,

and

cause a momentary break in the

The second choice

Macro Construction

(ii)

command itself, commands all normally

In addition to the .br

is

the

.fi

filling

process to occur.

“no break”

condition.

(3)

The Two Control Characters: In Module Five you were informed that the dot (.) character— when it is the first character on a linelets

nroffknov^ that a

The dot

control character.

The other

characters.

command is

follows.

actually

In this role the dot

a

one of two possible control

control character

is

the apostrophe C).

apostrophe is the no break control character. cause a break, while 'sp will not. (4)

is

As

The

a result, .sp will

A

Demonstration of Breaking and Filling: The nroff requests bp, sp, ce, in, ti, nf, and fi can all be preceded by the apostrophe as well as the dot. With the control character they do not cause a break. Consider the following twelve input lines. They will be formatted twice — first with the sp request using the usual dot (.) control character, and a second time with the no break character: '

O

What

IS

a break?

These examples should help this

that

illustrate

nrofffunction is

often confusing,

but also very important. .sp

Let 5

a few

of the break function, using the old familiar space command fsp j try

tests

with both the break to

and no break

control characters

see what happens.

This input produces the following output:

What

is

a break?

function that

is

These examples should help

illustrate this

nroff

often confusing, but also very important.

of the break function, using the old familiar space command fspj with both the break and no break control characters to see what happens. Let's try a

The same

few

tests

input, but with the .sp replaced by a 'sp, produces a

different output:

What

is

a break?

function that

a few

mand to

is

These examples should help

illustrate this

often confusing, but also very important.

nroff

Let's try

of the break function, using the old familiar space comf sp J with both the break and no break control characters

tests

see what happens.

Macro Construction

345

Note that the use of a the word important (the

.sp causes the space to occur directly after

word preceding the command) and, in addition, causes a break in the filling process. The 'sp, however, does not cause a break in the filling process. Nroff filled and justified the first output line and had the words function that is often confusing, but also very important in memory, when it encountered the 'sp nroff request. Because 'sp is a no break command the words in memory were not entered as a partial line but kept in memory as the space (blank line) was entered. After the blank line was in place nroff collected another input line, added the text to the words already held in memory, and constructed the next very important output line. Thus the words function that is .. last

.

begin the next line after the space. (5)

The nroff Three Part

Title Line Request:

the formatter include three part

title

lines in a

the following input line was included in a .tl

The

'

For example,

if

be:

Wogowon

The following

nroff request, placed

duce a three part

Word

Butler

anywhere

in

your

file will

pro-

title line:

r Word 2' Word 3'

be placed on the left. Word 2 placed against the right margin.

Word

file.

file:

upon formatting would

Winston

'

possible to have

is

Winston' Wogowon' Butler'

resulting output

.tl

It

1 will

The four apostrophes

separate the

in the center

title line

and Word 3

into three parts.

What

two apostrophes will be placed on the left. The string of characters between the second and third apostrophes will be placed in the center, and text entered between the third and forth apostrophes will be formatted on the right. ever

is

placed between the

A Look (1)

Top and Bottom the (.pi)

Macro

Inside Several -ms Like

Macros

Module Five you were introduced to page length command. At that time you were informed

that although

346

first

of Page: In

you can specify the page length, nroff \s unable

Construction

to

do

anything

the top and bottom of pages without the help of macModule Nine introduced the .nr and .nr number at

HM

ros.

registers

RF

.ds

and the

.ds

LH,

string definitions.

CH, .ds RH, .ds LF, .ds CF and These commands affect various registers .ds

and can be used with the -ms macros margins and title lines. This

is

to

produce header and footer

way headers and footers operate. an example of how you can instruct nroff to create top

section

Included

FM

introduces

the

and bottom margins (complete with title lines) using your own home-made macros. This example also illustrates how string definitions can be used with your own macros in much the same way as they are used with the -ms macros.

(

2)

Begin a new practice file which we will call pages. This file needs to contain at least 100 lines of text, with no formatting commands. If you do not have such a file you can copy one of your existing

files,

increase

its

remove

all

commands from it, and finally copy $ command. Once the file

formatting

length using the :1,$

100 lines long and void of formatting commands, you should enter the twelve lines comprising the he and fo macros is

at

least

exactly as they appear here at the top of the file. ter

used

in line six ('sp |7/) is

The following

[Note; the

charac|

the pipe character.]

nroff requests will (a) Define the page header

macro

he to include space and a three part title line, (b) Define the page footer macro fo to include a space and a three part title line, and (c) Set a “trap” to call the header macro into action at the top of each page and the footer at the bottom.

.wh 0 he .wh -li fo .de he

'sp .51

A\'\\*(\h'\\*(ch'\V(rh' sp

|li

.de fo

'sp .51

.tl'WMlf'WMcf'WMrf' bp

Macro Construction

347

These twelve

lines will

.wh 0 he

have the following meaning

This request

nroff to perform a

tells

when (when)

specific function

on

ticular position

to nroff.

a page

(sometimes called setting

The .wh request arguments. The

is

a par-

reached

a trap).

used with two

is

first

argument

(in

this case 0) indicates the position

a page

(The

where nroff is supposed 0 position

to act.

of the

top

the

is

The second argument must be a call for a macro page.)

specifies

what

do

to

at

on

(he)

that

that position

(when the 0 position on each page is reached). The fact that this second argument must be a macro call— and



not an nroff request is significant;it is the reason why you cannot instruct nroff about what to

do

at

the top and

bottom of pages without using macros.

.wh

-7/

fo

This call

.wh request the fo

(footer)

page position. The

instructs

macro

nroff to

the -7/

at

-7/ position

is

one

inch up from the bottom of the page.

Any (-)

position specified with a

number

is

a

relative

based on the page length.

minus

position

The

-7/

on a three inch page is two inches from the top, while on a ten inch page this position would be nine inches from the top. position

.de he

This

begins

the

definition

of

the

header macro that will be called at the top of every page. This automatic calling was specified with the .wh 0 he request.

348

Macro Construction

s

'sp .5/

The

first

action of the header

macro

be to space down one half of an inch. The no break control character is used so that text remaining in

will

nroff"

internal

printed

after

memory

be

will

the 'sp action

is

per-

formed, not before. Thus it avoids having a break before the top of each

new

The

page.

text

is

carried

into

the body of the next page. .tl

'\\*ilh'\\*(ch'\\*irh'

This

Because this title line is included in a header macro that is called at the top of every page it will produce the same header on all is

a title line.

pages.

To make

macro useful beyond

this

a

single paper the particular phrases to

be placed in each position have not been specified. Instead, characters such as \\*(lh in the left title position are included. The \\*( informs nroff that: (a)

A

two

string follows (b)

name

character

Somewhere

a

(.//?);

else

the

in

two character string (such as .ds

for

Ih

is

file

the

defined

Authors' Pets)\

and (c)

The two be

character

replaced

replace the

1

7/

This

A?

by

(Authors'

definition

'sp

name should the

string

Pets

will

//?).

request again uses the no

break control character to avoid causing a break before the top of each new page. The symbol can be used with any nroff lequQSi that includes a |

numeric value.

It

is

known

as

the

absolute position indicator and, in this

Macro Construction

349

case, informs nroff to space

down

to

the position one inch from the top of

page

the

one inch from

down

of spacing

(instead

the current position

on

the page).

This

..

the

indicates

end

of

the

he

definition. .de fo

This line begins the definition of the iooter macro which, in response to the .wh -li fo request, will be called whenever nroff reaches a position

one inch from the bottom of every page.

'sp

.5/

The

first

down

space

'\\*(lfA\*(cf'\\*(rf'

.tl

A

action of the fo a half of

title line will

macro

is

to

^

an inch.

be placed

at this posi-

on the page. The title line will consist of up to three parts: a left, To be center, and right footer. included in one of its three fields a string of characters must be specified as a string definition. Such string tion

definitions

macro bp

The is

are

placed following the

definitions in your

final action

after the title line

that the

file.

of the footer macro

cause a page

to

!

is

i

break to occur printed.

Notice

no break control character

is

i

i

used. I

This ends the definition of the fo

i

macro.

(3)

Using String Definitions With Your Own Macros: At this point you can use the .ds request to specify strings to be used in your header and footer title lines in much the same way as you do with the -ms macros.

350

Macro Construction

:

'

i

Enter something

like the following requests in

your pages file (place the following requests before any text but after your macro definitions):

(4)

.ds Ih

left

.ds ch

center header

.ds rh

right

header header

.ds If

left

.ds cf

center footer

.ds rf

right footer

footer

Testing the Page Control Macros: At test your new page control macros.

You can send your Shell command (do not

this

time you

may want

to

be formatted with the following include the -ms flag in your command to

file

line):

nroff

(5)

flenamel

\

The Strange Paragraph Reset Macro: macro package

page

If

(or read the material in

you regularly use the -ms Module Nine describing

these beasties) you have probably discovered that the paragraph

macros do a lot more than format paragraphs. In fact, all paragraph macro calls in the -ms system not only do what you expect (in the way of indentation and spacing) but also call a series of nroff requests that look something like the following .RT macro: .de

RT

.sp

.ne 1.1 .in

0

.ul

0

.ce 0 .ft

R

\\n(LL .ps \\n(PS .vs \\n(VS .II

The .RT macro all

-ms

is

known

paragraph macros.

as the It

ReseT macro and

turns off underlining

is

called

(.ul

Macro Construction

0)

by

and

351

centering (.ce 0), resets the font to Roman (.ft R), and resets the line length (.11 \\n(LL), point size (.ps \\n(PS), and the vertical spacing (.vs \\n(VS) to the values stored in the LL, PS, and VS

number

registers.

This

why

is

placed before a -ms paragraph

(#the

will turn

just set

a .ul request will

macro

call.

have no

effect

if

The -ms paragraph macro

request for underlining even though you have

to underline.

it

number

which controls the point size (.nr PS) request does not take immediate effect but must wait until after the next paragraph macro call. The change to the number register will not be read by nroff until it encounters the next paragraph macro. This is the reason why you must place a -ms paragraph macro call at the beginning of your file, after any number register requests that you use. That paragraph macro is necessary as it will establish the -ms defaults for these number registers. It is the initializing macro. Similarly, a

(6)

change

in the

register

Viewing the -ms Macros: For those of you who are interested, the -ms macro package is contained in a file with the following full path name: ! usr ! lib ! tmac ! tmac.s

To view

this file enter the

vi

If that

/

command:

command sequence

does not work enter the command:

whereis

Use the the

lair

®

usr / lib / tmac / tmac. s

tmac.s

®

pathname returned by the whereis command of the -ms macro package. full

to visit

Spend some time browsing through the -ms macros, and see if you can interpret how some of the commands actually perform their functions.

complex topic of macros. You may want to return to this Module after you have completed the remaining material in this book and give it a second reading. As you now know, the internal workings of macros decide how your formatted paper will appear. Your

The

352

quiz which follows concludes your introduction to the

Macro Construction

macro— and occasionally construct command does not exist— can make

ability to select the appropriate

your own when the necessary your formatting experiences both more effective and more

satisfy-

ing.

A

Final Quiz:

Describe the effect of the following nroff requcsi:

(a)

.tl

'jerry 'and 'meredith'

Consider

(b)

a

file

named

test,

which contains the following

six

lines:

Hi

.de .ce

\$1 • •

.Hi there

How

are

If this file

you?

was sent

to nroff to

be formatted, what would the

resulting output look like?

What

(c)

effect will the

command

'br

have

if

entered

in

a text

file?

Suppose you placed the following nroff xtquQsX at the top of a text file. What effect will it have on the resulting formatted

(d)

output?

.wh

Answers: and

in

(a)

A

bp

three pari

title line will

appear with the word

the middle, and mcredith against the right margin,

would not appear the

-1

macro

ing, as the effect.

in

(d)

on the

left,

The word “there”

the output, due to the presence of a \$1 instead of \\$1 in

definition; the line

break

(b)

./'em’

command

“How

are

you?” would be centered.

(c)

Noth-

with the no break control character will have no net

Nothing, as only macros can be used as arguments to the .wh

request.

Macro Construction

353

New Command

nroff Requests

Function

Begins macro

.de

Ends macro File will

XX

with two

macro name.

character

.so

Replace

^^finition.

named

definition.

file,

containing macro definitions,

be sourced into current

file.

Prints a three part Vt\e line.

.ti

\n(

XX

Reads

XX

Replace

XX

value stored in

in

with two character

number

register.

number

register

string

register.

name. \*(

XX

Reads

in

Replace

string

XX

stored

in

XX

with two character string register

name.

Reads

in first

argument

to

macro

Absolute position indicator.

No

354

Macro Construction

break control character.

call.

Module Twenty-One Utility

Programs

• CD02

nr

Introduction Through the

first

twenty Modules you have seen

how UNIX

can be

used to create and edit files, locate spelling errors, organize a directory system, communicate with other users, and line print or typeset all kinds of files. The remaining Modules will describe in some detail how UNIX can format form letters, tables of contents, tables, equations, and maintain a bibliography. The final Module briefly introduces several additional UNIX resources which can assist

with your editing, programming, or writing tasks.

What more can UNIX do? Quite you

will

meet programs which

a bit, actually.

will locate files,

In this

compare two

Module files to

they are the same, translate specific characters in a file into other characters, and sort lines alphabetically. And these are but a few of its various capabilities. see

if

Prerequisites To

utilize the

spell ‘‘utility”

information

in

this

Module you should be

and use the information presented

in

the

able to

first

eight

Modules Fifteen (The UNIX Directory Structure) and Twenty-Two (Commands, Files and Directories) are recommended.

Modules of

this

book.

Module Five

is

optional, while

355

Objectives of this Module you should be able

Upon completion (1)

Automatically remove

(2)

Sort a

(3)

Translate into a

new

file;

string or range of characters;

(5)

Compare two

all

redundant

common

Combine

a

occurrences of a string or range of characters

all

Remove

(6)

commands from

according to an alphabetic or numeric rule;

file

(4)

or

formatting

all

to:

files

lines

and find

from

a

file;

lines that are

unique

to either file

to both;

the above actions into useful ‘‘pipelines.”

Procedure This Module

will

introduce several

The format used

processing.

new programs

useful for text

to describe these utility

programs

will

from the approach used in other Modules, and will be similar to that used in the UNIX Programmer's Manual. The final section will present an example of how these programs can be joined differ

together to accomplish a complicated task.

deroff

NAME

(and function)

deroff



remove

nrofif, troff, tbl

SYNOPSIS (how command deroff

[

-w

]

is

and eqn commands

entered; brackets identify options)

filename

DESCRIPTION The

Shell

command deroff

will

output to the terminal a copy of filename, minus

instructions.

356

filename

Utility

Programs

all

formatting

To have the output Shell command:

not by lines but in single words, use the

listed

-w

deroff

filename

®

PROBLEMS remove

deroff does not always

subtle formatting constructs.

sort

NAME

(and function)

sort



sort a

file

SYNOPSIS (how command sort

[

-0 -d -f -r

]

entered; brackets identify options)

is

+posl

[

]

[

— pos2

]

filename

DESCRIPTION The

sort

program

will alphabetically

and/or numerically sort

lines

no +posl or -pos2 is specified) sort arranges the lines of a file in alphabetic and numeric order by comparing the first character of each line in a file. For example, the of a

file.

following

In

is

its

form

basic

(if

the contents of a

.nr

PO

file

named

test:

21

.LP This

is

file to

a be sorted

by the sort routine.

nf 11223 12133 13100 13101



Jt

Utility

Programs

357

The following

sequence would sort the above text and have the resulting output displayed on the terminal: sort Shell

sort

The

resulting sorted material

®

test

would look

like:

.LP .fi

^nf .

nr

PO

2i

11223 12133 13100 13101 Th is is a by the sort routine, file to

be sorted

Note the sorting order: symbols were listed first (periods), then numbers, followed by upper and then lower case letters.

Changes the

file

in

the sorting routine are possible.

named

test

and place the output into sort -0

The

output

The following will sort a file named output:

test

output to the file named as an argument to the option {output) instead of directing its output to the standard output. This command will accomplish the same -0 option tells sort to direct

its

result as:

sort

To

test\

>

output

sort only those lines beginning with a letter, digit, or blank

{dictionary order)

you would use the sort -d

Whatever

command

line:

flename

do not begin with a letter, digit, or blank will be placed at the bottom of the output. Thus the special characters, A/ro# requests, and macro calls would be removed from the sorting and placed as residue at the end. Utility

lines

Programs



If

both upper and lower case

letters

should be sorted together

{folded together), use:

sort -f

filename

®

The order of

sorting can be reversed (so that the line which would normally be sorted as the first line would instead be sorted last) by: sort -r

In addition,

the file(s)

character in each line.

filename

®

need not be sorted based upon the first Most lines of text or numeric data can be

considered as being composed of separate fields. A field is defined as a group of characters separated by white space (a word, a number, a series of letters, etc.). Thus the following line can be considered as consisting of six fields:

Name

Fido Nerfball Age 47

B.

The word Name

is

the

first field,

and Nerfball is the fourth and the number ^7 is the

field.

sixth.

B.

is

the second, Fido

The word Age

is

Suppose you had

is

the third,

the fifth field, a

hundred

line

with each line containing the same five fields of information (one line for each individual). You could sort the file according to

file

last

name

(4th field) with the

sort

The

-1-3

tells

command:

-1-3

filename

® and thus base the you wanted the sort to

sort to skip the first three fields

on the fourth and following fields. If be based only on the fourth field you would use the command:

sort

sort

This

command

-1-3

translates as,

ing the third field

filename

®

“base the sort on the

and preceding the

fifth field (the

field (s) follow-

fourth

field).

PROBLEMS sort

only sorts

lines.

It

cannot easily sort records consisting of

multiple lines based on a field

in

only one of the lines of the

record.

Utility

Programs

359

SEE ALSO comp

deroff, uniq,

NAME tr

(and function)



translate input characters

SYNOPSIS (how command tr

[

-c -d

-s

]

[

is

string 1

]

entered; brackets identify options) [

string!

]

filename

DESCRIPTION With the

command you

tr

into another.

characters.

can translate one string of characters The hyphen (-) can be used to specify a range of

For example the

A-Z

tr I

will translate all

command

space

a-z

filename

I

uppercase characters to lowercase.

SEE ALSO sed

uniq

NAME

(and function)

uniq

— remove

redundant

SYNOPSIS (how command uniq

[

-u -q

]

is

lines

from

a

file

entered; brackets identify options)

filename

DESCRIPTION Often when sorting or making an index you wind up with a file which there are duplicate lines. The uniq program will assist

360

Utility

Programs

in in

where there are several copies of identical lines. Note! duplicate lines must be adjacent when using uniq. If duplicate lines are not adjacent you should first sort the file and then use situations

uniq

to deal with duplicate lines.

To produce an output of

single copies of

which the second copy of any line is deleted) use the following Shell command. Output will consist of one copy of all unique lines and one copy of all duplicated lines: uniq

The

Shell

lines

(in

filename

command uniq -u

will

all

examine filename and

print

filename all

lines that

appear

in the file

only

one time (unique lines only). Output consists only of one copy of unique lines. Duplicate lines are ignored. Additionally, the

command: uniq -q

will

examine filename and

(duplicate lines only).

no matter how often no copy of all unique

find only those lines that are repeated

then print a single copy of each line, was repeated in the file. Output consists of

It it

®

filename

will

lines

and one copy of

all

duplicated lines.

SEE ALSO sort,

comm

comm NAME. (and

function)

comm — compare

two

SYNOPSIS (how command

comm

[

-

123

]

files

is

entered; brackets identify options)

file I file 2

Utility'

Programs

361

DESCRIPTION The comm program compares two

line

files,

by line and separates

the lines into three categories: (1)

Lines found

(2)

Lines found in file2 but not

(3)

Lines found in both

The

Shell

but not in file2

in filel

and

files.

command:

comm

file2

filel

perform the separation and then print

will

To suppress the printing of include the number 1 as a flag

comm This in

in filel,

will result in

both

files.

To

list

the

command

Those

lines

lines

found

in the

command

-1

in filel

and not

file2

sequence:

filel

filel

found only

common

in filel will

both

to

files,

not be printed.

use the -12

flag in

sequence:

comm

filel

three categories.

the printing of those lines found in file2 only or

only those lines

With the -23

all

flag the

-12

filel

comm command

(for instance the

names of

all

file2

will

produce a

students

who

list

of lines in

are in a doctoral

program) not in file2 (names of all students whose registrations were blocked). The resulting list are those names in filel not in file2 (students who are in the program but whose registrations were not blocked). Such a list would be created by:

comm

-23

SEE ALSO sort, deroff, uniq,

362

Utility

Programs

comp,

diff

filel

filel

An Example of the Wonders of Piping Not for Plumbers Only The

five utility

The

final step in this

programs introduced in this Module can be used together to transform a text file complete with formatting commands into a relatively short list of ‘‘unusual words.” process

compare

of words consisting of every word found in one of your files with a list of common English words. This second list of common English words exists on most UNIX systems in a file with the full path name lusrflibleign. The comm command introduced in this Module is used to compare the two files and identify all words found in one file but not in the is

to

a

list

Certain constraints must be met, however, before the two can be effectively compared with the comm command: (a)

other. files

Both each

files file

must be sorted should be on a

ascending sequence; (b) Every word in line by itself; (c) Every word in each file in

can occur only once; and (d) Because comm will treat a word beginning with a capital letter as different from the same word not capitalized, all characters must be translated into lower case.

(1)

The

actions necessary to

formed within

meet these constraints can

a single Shell

command

all

be per-

easier— and for many purposes more useful — to perform these actions in two steps, however. For these reasons, we will first illustrate the twostep method and then present the one-step method.

(2)

line.

It

is

Preparing the File of Common English Words: Before this file ilusrllibleign) can be compared to one of your files it must be sorted into ascending sequence. This is done with the following command sequence: sort

This

command

(containing

/

usd lib/ eign

> common

line will create a sorted

the

words) and place

one-hundred and

new common

®

copy of the /usdiib/eign

fifty

most

common

file

English

your current directory. (Later on this file can be expanded as you discover other frequently used words. Don’t forget to resort your common file after making additions, however.) this

file

into

Utility

Programs

363

(3)

Preparing Your Text File: Before your text file can be compared to your new common file several actions must occur. The file must be stripped of all formatting commands, and each word must appear on a line by itself. The words must be sorted into ascending sequence, all characters translated into lower case, and all redundant words must be removed.

The following command

line will

command

deroff

-w filename

line,

tr |

All formatting

but attempt to decipher

A-Z

sort

a-z

all

these actions and

(An explanation of each

do the actual comparison. the

perform

|

\

commands

in

uniq

|

comm

filename are

yourself

it

-23

first

-

step follows first):

common > unusual

removed by

droff,

then put the remaining words on individual lines (-w). The output from deroff will be passed on to tr, which will convert all upper-case letters to lower-case. (This step is required by the uniq program.) This material is passed to sort which will put these words into alphabetical order. The output of the sort program is passed to uniq, which will discard all redundant lines (words) and then hand its output to comm. The comm command then compares this output (or input, depending on your point of view) to

which

will

named common which contains a sorted list of the 150 most common English words. The output from comm (the words in filename that are not among the 150 most common English words) will be placed in a file called unusual. Whew!! the

file

The

file

named

unusual

will

of the words in filename of very common English words.

contain a

list

which were not in the UNIX list Such a list could be used to create a glossary or index (and was fact how the index to this book was generated).

(4)

The One-Step Method: The above two-step procedure can be consolidated into a single step by using the semi-colon

This special Shell character

is

to

be performed in sequence.

If

two

command

following Shell

command

sort otherfile

Utility

Programs

used to separate two

lines are separated

pleted before the second

364

in

>

one begins.

by a

;

the

(;)

character.

command

first will

lines

be com-

For example, consider the

line:

tempfile\comm -23

file tempfile

\

Here, sort

will first sort

put into a

file

name

then compare

will

the

tempfile.

file

named

Once

and place the out-

otherfile

this process

is

complete,

comm

file to tempfile.

This procedure has one potential drawback. You are left with a tempfile that you may never again use. You can avoid this problem through the use of two additional UNIX features. The first involves the use of the UNIX iemiporary directory. The full path name of this directory is

is

The

/tmp.

/tmp directory

periodically cleaned out by the

convenient place to deposit a

file

is

“powers

that

publicly accessible

Thus, it of only temporary use.

is

that be.”

The second feature is the $$ symbol. It can be used unique name to a temporary file. The command line sort filename

>

and is

a

to assign a

/ tmp/ %%

filename and place the output into a file with a numerical in the /tmp directory. (For those who are interested, this

will sort

name number (5)

With

is

the process ID of the parent Shell.)

as an

introduction, you are following Shell command

this

The features to work and accomplishes our finale.

We

display the

the sequence.

Do

not press

®

command

I

ready for the grand line puts all these UNIX

task

all in

one

step.

(Note:

two lines, owing to the length of This is, however, one continuous command line. until the entire command has been typed):

> comm

sort /usr/lib/eign sort

now

uniq

|

line as

/tmp/%%\ deroff -w filename -23 - /tmp/%% > newname

Utility

|

tr

A-Z

a-z

®

Programs

365

Module Twenty-Two

Commands,

Files,

and Directories:

or

Paths, Bins, and Yellow Brick

Modes

Introduction

We

have stated

in prior

UNIX

Modules

that

UNIX

stores information in

even your terminal. This is truly a remarkable feature, and one that allows you to and the standard input tie together (in conjunction with the pipe and output) Shell commands in an infinite number of combinations. This ability is what makes UNIX so flexible and powerful. files.

In practice

treats everything as a

file,

\

You have created and worked with your own files, but what about the commands that allow you to go about your UNIX tasks (vi, nroff, cp, page, and Ipr, to name but a few)? They also exist in files.

We

bins.

This trek

would

like to will

guide you into their lair—the UNIX storage

allow for a discussion of

how

one named page) can act upon another when you enter the command page filename). (like the

it

is

file

that a (as

file

occurs

Prerequisites To use

this

Module you should have completed

the material in

Modules One through Eight (Five optional). Fifteen: The UNIX Directory Structure (essential), and Sixteen: Account Management.

366

Objectives Upon completion (1)

Use

perform

Describe

how

a function);

be able

will

modes

permissions and

file

(able to (2)

of this Module you

to

make

to:

a

file

executable

and

directories, bins,

and search paths

affect

your

interactions with UNIX.

Procedure These procedure steps are presented in two sections. The first section explores modes, permissions, owners, and executable Shell scripts. Section two takes you on a tour of the UNIX command storage bins and discusses how the Shell “locates” a command.

coo

wr

Modes, Permissions, Owners, and Executable Shell Scripts

You need

to begin the exercises in this

directory.

To

insure that you are

Home

cd

Module of the

(1)

Fifteen: The

Home

Module from your Home type:

®

UNIX Directory Structure discusses the concept

directory.

Creating an Executable File: An executable file begins life the same as any other file. Begin a new file by entering the command: vi

(2)

22

facts

®

Place the following six lines in this,/^c/5

echo echo 'My current

directory

file:

is:'

pwd echo echo 'The files

in this directory are:'

Is

Commands d

Files

367

^

When

(3)

finished, write the

memory

into the

file

of the Beast and

return to the Shell.

From

(4)

the Shell type:

®

facts

What happened? You

receive a note stating:

facts: Permission denied.

facts This note lets you know that the Shell tried to execute the but found that it did not have “permission” to execute it. The file at this point is not executable.

the nature of this beast called an executable file? Well, the Shell program page is a good example of an executable file. The Shell can apply the contents of the page file to almost any file

So what

is

you have created, resulting

that

on the screen. The

ex

being displayed

also an executable

is

file.

executable, the Shell has been given permission to per-

If a file is

form the actions

As

line editor

in the specified file

UNIX

specified within the

file.

concerned the file facts is still only a nary, non-executable file. This will soon change ....

(5)

far as

is

Permissions:

File

From

the

List

the Shell enter the

sign, lower case

filenames

command

space

Shell

-1

(lower case

Home 1,

command

space,

Is

-1

will give

you

a long listing of the files

Among

other things, this long

like the following

files.

should be displayed on your screen:

total 9

drwx —rw —rw

—rw —rw 368

Commands &

minus

®

include the permissions attached to your

Something

s,

directory.

I

located in your current directory. listing will

your

1):

Is

The

in

plain, ordi-

Files

2

login

1

login

1

login

1

login

1

login

544 Nov 13 17:04 Study second 6100 Oct 12 11:32 1452 Sep 1 11:58 experience 1064 Sep 2 21:14 first 93

Dec 19 10:32

facts

Each

the long listing for one file or directory in your current Each long listing consists of several parts.

line

is

directory.

The

(a)

first

and

part

10 characters long {drwx

is

specifies the ‘‘permissions”

attached to each missions field.

The second

(b)

file.

We

The

(c)

the

part of the listing

number of links the moment.

(in this

The fourth

(d)

we have

case

also as i\\Q file

mode)

portion as the per-

number

a

is

just entered the

portion of the listing

and

file

the login of the

is

is

which of no

(7 or 2)

attached to the

third part of the long listing file

)

will refer to this

identifies the

concern for

(known

or (-rw

)

word

is

owner of

login).

the length of the

file

in

bytes.

The

(e)

date the

of the

The

(f)

last altered is

entry

is

the

file’s

2

#

Permission Fields

For the

in a

Listing

Nov 13

544

File’s

size in

Date of Last

Owner

bytes

Modification

the important feature

10 characters on the

Long

login

of

Links

moment

fifth part

name.

Information Fields

drwx

displayed as the

and

listing;

last

was

file

left

of each

line.

is

Study

1 7:04

Filename

the permissions

field:

the

Each of the 10 positions has

a particular significance.

The

first

tory, or

directory first

facts)

position indicates whether the listing

some other UNIX (i.e.,

a file), will

beast.

A

most often appear is

(—

file,

first

-

a direc-

for not a

in this position.

in

not a directory.

directory, as evidenced by the d in the

sions

for a

d for directory, or

character in the permissions field indicates that facts

is

the case of the

The

file

Study

The file is

a

position of the permis-

field.

The next nine

characters can be considered as three fields of three characters each. For now we need only concern ourselves with the

Commands d

Files

369

of these three fields following the directory character. three characters determine what you (the owner of the

first

directory) can

do with

These file

or

it.

of these three positions is filled with an r the owner has — read permission and can view the contents of the file. A (minus sign) indicates that the owner does not have read permisIf

the

first

sion.

the second of these three positions is a w the owner has yfrite permission and can make changes in the file. A minus sign in this position would indicate that the owner would not have write per-

If

mission.

The

third position indicates

whether the

file

can be executed.

An

X indicates that the owner has execute permission; a minus sign means that the file does not have execute permission. w, or x in a permission field indicates that the associated permission is granted; a — indicates that this permission is not granted. In

summary, the presence of

For now

named (a

-

a

r,

the permissions field associated with the file indicates that it is not a directory line -rw

let’s interpret

facts.

The

and that the owner (you) has both read and

in first position)

write, but not execute permission (rw- in positions 2-4).

Execute permission means that the file is a Shell script or a compiled program and that it has permission to perform its function. (An executable directory allows you to look for files in it.) Whenever you create a file it automatically has read and write — but not execute— permission. To add execute permission to a file you

must change (6)

its

Filemodes: You cutable. Type:

mode.

will

now change

chmod

the

mode

700 facts

of facts to

make

it

exe-

®

The command chmod stands for change mode. The number 700 gives the owner read, write, and execute permission for the file. The 700 can also be considered to have three fields (7 0 0). Again, we are only concerned here with the first field (the number 7), because this field determines what the owner can do with the file.

370

Commands &

Files

The number seven in the first field is actually a “composite” number (sum) constructed from the following “primitives:” (a)

1

grants execute permission

(b) 2 grants write permission (c)

4 grants read permission.

These primitives can be added together

to grant

any combination

of permissions.

The

basic permissions for the file’s

owner

are:

000 grants no permissions 100 grants execute permission only

200 grants write permission only 400 grants read permission only

The sum of 100 + 200

=

400 and execute permissions would -f-

all

700 would mean that read, write be granted.

300 grants execute and write permissions (100 + 200); and 500 grants read and execute permissions (100 + 400). The permission of 600 grants read and write permissions (200 + 400). These mode changing codes relate to permissions to the owner of the file. These three numbers (1,2, and 4) can be used to express the eight possible states involving combinations of these three binary conditions (yes or no for execute, write, and read permissions). As a point of interest, no other combination of three single-digit numbers yields this continuous and unique scale for binary combinations. Additionally,

To check on whether affected the filemode

the

facts enter the

Is

Note the presence of the in

So what does

-1

letter

the permissions section.

cutable.

command sequence chmod

this

x

command:

®

facts

in the position third

This x

700 facts

tells

you

that

./am

from the is

now

left

exe-

do for you?

Type: facts

® Commands &

Files

371

This lime you are treated to the display of the name of your current working directory, along with a listing of all files in your current directory. This information is the result of the two Shell commands placed within your facts file. No big deal (although it beats a poke in the eye with a sharp stick), but

any

file

owner must change (9)

With

You

commands

containing Shell its

made

can be

illustrates

it

how

executable: the

filemode to 700.

filemode of 700 a file becomes, in effect, a Shell command. can execute the contents of the file by simply typing its name. a

A

Second Executable File: As another example, you can create an executable file which will cause the Shell to first change directories to a specified sub directory and then start the process of visually editing a

(10)

file in

that directory.

sure you are in your Home directory. Once there you should create a file named go containing only the following 2 lines. (Substitute the name of one of your sub directories for directory

Make

and the name of

a

file

located in that directory for filename):

cd directory vi [filename

Return to the Shell and change the mode of the go Then from the Shell type:

file

to 700.

®

go

went according to plan you should be moved to the specified directory and filename should present itself for visual editing. If all

(12) (11) Creating a Bin: fully

more

You may

interesting)

wish

later to create additional

executable all

now. From within your

Home

facts into

Bin

sequence:

Commands &

Files

useful to create a files.

Let’s do this

®

your Bin directory.

mv 372

is

directory type:

mkdir

command

It

of your executable

directory (bin) to hold

Next relocate

files.

(and hope-

facts Bin

®

Use the following

Once

(13)

again enter the

command:

®

facts

The Shell replies “facts: Command not found” because it does not know where to look for the new facts command. In the next section of this Module you will learn how to include your own Bin in the search path followed by the Shell when looking for executable files.

Uses of Executable Files: The two example executable files presented here were designed to allow you to practice constructing files and changing their modes. In fact the tasks which these two files accomplished are more efficiently handled with the alias command. Executable files are normally used for more complex tasks not easily solved by an alias

(14) Yes,

(a)

command.

Another Quick Review:

What command

gives you a long listing of your filenames,

including the permissions attached to each (b)

What permissions missions

(c)

field (-r-x

file

(include the

What would had changed mission?

Answers:

(a) Is

the permissions field for a its

mode

(b) read

-l

chmod 700 filename

(d)

in

your

file

look like after you

to include read, write,

and execute per-

and execute but not write permissions

-rwx

Bins,

Log onto your UNIX account. you are located

to

mode number)?

UNIX Commands, Storage (1)

with the following per-

change a file’s permissions include read, write, and execute permission for the owner

of the

(c)

file

)?

What command would you use to

(d)

are granted to a

file?

Home

If

and Search Paths

already logged on,

directory.

cd

make

sure

Type:

® Commands

Files

373

(2)

In

Module

Fifteen you learned that

(dot dot)

..

is

the

UNIX name

your current directory. Ever wonder who or what exists above your Home directory? Here’s your chance to find out. Type:

for the directory located immediately above

cd

You

now

are

located one level above your

several deep breaths— the air

To determine

(3)

(now one

®

..

level

is

(4)

Root:

the contents of your current working directory

above your

Your

You

directory

Home

directory) type:

®

will

login will

need

among

be found

to use a

UNIX

‘'special

the

list.

character” for the next

move. Type: cd / space

The

(Take

of the other users of your UNIX system should be

logins

displayed.

directory.

pretty thin at these elevations.)

Is

The

Home

UNIX name

®

I

“root” directory (in addition to being the character used to separate directory and filenames when you use a full path name). Root is, curiously, located in the UNIX penthouse. All files and directories are located below root. /

is

What

(5)

the

files exist in

for the

the / {root) directory?

®

Is

The

Type:

of filenames probably does not look too exciting. the names listed should be the usr directory, however.

(6)

list

Change

directories to the usr directory.

cd

(7)

List the contents of the usr

usr

One

of

Type:

®

directory with the

Is

command.

Anything look familiar? If you are a UCBerkeley-type, your attention may be drawn to the directory named ucb. 374

Commands &

Files

To explore

the contents of the ucb directory.

List the filenames in this directory.

(9)

(10)

®

ucb

cd

Type:

Recognize any files? The names of Shell commands used to work with UNIX should now appear. (We told you this was pretty heady stuff.) If

the directory ucb did not appear, type: cd

The ucb

(or ucb/bin) directory

taining the files that are Shell

®

bin

is

one of the UNIX

commands. The

directories con-

directories

which

hold UNIX Shell commands are referred to (in UniJargon) as bins. The only difference between a bin and a garden variety directory is (11) that bins contain executable files. The term bin is derived from the fact that most of the executable files stored in these UNIX sys-

tem

directories are in a

To

find out

what

bitmy format.

a binary

file

®

page ex

You should

command:

looks like enter the

receive a note indicating:

(12)

ex: Permission

The commands

Denied

stored in the ucb directory are contained in

that are executable

but not readable.

commands you cannot

view the

files

Although you can use these

files that

contain

them

(this

is

part

of the UNIX security system).

For the next directory.

To

(13) Discovering

commands (known

you need to be located in your Home you are there enter the cd command.

activity

insure that

Your Search Path: You now know are

as bins).

actually

The

executable

files

stored

that

most UNIX

in

directories

bins that the Shell searches and the order in

Commands &

Files

375

which they are searched

named

variable

Sixteen)

used to

is

set

From

path.

is

The

determined by the setting of the Shell

command

set

used to control the search path in the the Shell variables ignoreeof and noclobber.

command:

the Shell enter the

set

Module

Shell

of the Sixteen).

®

command, used without arguments,

Recall that the set settings

Module same way it is

(introduced in

list

the

your account (see should look something like the follow-

variables

Your

will list

attendant

to

ing:

0

argv

cwd /pbjmpb/Book/Minis history

25

home

/pbjmpb

ignoreeof noclobber path (. /usr/ucb /bin /usr/bin) shell /bin/csh

0

status

term flOO user pbjmpb ignoreeof and noclobber variables should be familiar. For now note the information that follows the word '‘path,” as this is how your search path is currently set. When you enter almost any com-

The

exceptions are alias, set, and cd), the Shell will start its search for an executable file with that name in the first directory For example, suppose you type the listed in your search path.

mand (some

Shell

name of the executable file you created Module). The Shell will begin looking in the current If a file with that name (facts) is not found in the

command

earlier in this

directory

(.).

facts (the

current directory, the Shell will next check the /usr/ucb bin. If The last stop is still unsatisfied, the Shell goes to the /bin bin. /usr/bin. Each of these bin names is preceded by a / because they

more

below the root (/) directory. Finally, if the Shell cannot find the command in any of these locations (and it would not find facts with this search path) you will be greeted by the now familiar reply, ""Command not found.""

are

all

located one or

Commands &

Files

levels

377

command

can exist in several different forms, each in a file with the same name, but located in different These forms will be the command as it evolved over bins. different versions of UNIX. (The process of storing different files with identical names in separate directories was discussed in

On most UNIX

Module

systems

Fifteen.)

a

The most commonly used

bins for BSD

UNIX

are:

/usr/ucb, /bin, and /usr/bin. very important, because the Shell discontinues its search upon locating the first instance of an executable file with the right name. It does not matter, to the

The order

Shell,

if

in

which bins are searched

is

that filename also exists further

down

the path.

It

does,

however, matter to you. The search order can determine which executable file is found (and therefore used by you).

Your Path: Remember the file facts located in your Bin directory? An easy way to advise the Shell about executable files

(14) Setting

located in your Bin

is

to set

your search path to include a

trip

through Bin. Go ahead and advise the Shell of the existence of your Bin directory with the following Shell command sequence: set

=

path

" / Bin)

/usr/ucb /bin /usr/bin

(. I

space

I

j

I

your path the Shell may (15) be unable to find any Shell commands. Should this happen you "" Command not found"'' message upon typing in will receive the your Shell commands. Fear not— you need only logout and log back in again. Order will be automatically restored to your search Note:

If

you make

a mistake in specifying

path.

Now

type the

command facts

®

Did the Shell locate and execute the commands contained within If not, carefully reset your search path and this executable file? attempt this step a second time.

(16)

378

procedure step 14 has only a temporary effect — the Shell will forget about your Bin bin when you log out. You can permanently remind the Shell by inserting the above line in your .login file.

The sequence you entered

Commands &

Files

in

Double Warning: your

If

you

err in entering the following text into

you will continue to receive the ''Command not found'' message to your Shell commands. Logging out and back in again will not help. You will have successfully piloted your search path into a black hole, and you will need to perform the following three steps to escape from this situation: (a) Reset your path from the Shell (Enter from the Shell the set path command sequence noted in Step 14 above); (b) Re-edit your .login file to include the correct path; and (c) Again enter the source .login command. (a)

.login

file,

up your .login {dot login) appears on the screen find the Call

file

Once

for visual editing.

line

it

beginning with the words

set path.

(b)

append the following characters

Carefully

at

the end of your

search path (inside the right paren):

"iBin Without these characters added to your path

it

look simi-

will

lar to this:

set

path

=

(.

/usr/ucb /bin /usr/bin)

With these characters added to your path

it

will

look similar

to this:

set

(c)

Return Note:

path

=

to the Shell

If

and type the source

.login Shell

command.

the set path line does not appear in your .login

just insert the following line

set

path

=

somewhere

in

the .login

space

I

I

file

file:

^ ! Bin)

/usr/ucb /bin /usr/bin

(. 1

(17)

^ ! Bin)

/usr/ucb /bin /usr/bin

(.

1

and Modes: As you now know, the permissions attached to files and directories determine w'ho can do what with each file or directory. We have already discussed the

More on

File Permissions

role of the first four positions in a permission field: the first charac-

whether the file is a directory, and the next three characters indicate what the owner of a file can do with it. The second set of three characters determine the same permissions ter

indicates

Commands &

Files

379

and execute) for users in iht file owner’s group. Just who belongs to a group can be specified by the owner: see the UNIX Programmer’s Manual entry for newgrp. The final set of characters represent the permissions granted to everyone else (others). (read, write,

most cases these three permission groups (owner, group, others) will have the following meanings to you: In

owner’s permissions will determine what you can do with

The

(a)

the

files

you

create;

(b)

Group permissions will determine what people in your group can do with files. For instance, files containing Shell commands (such as the ex file— containing the line editor— that you attempted to view earlier in the Module), are executable but not readable to members of the file owners (root) group (everyone with an account on the UNIX system you are on); and

(c)

Others’ permissions will determine what other users can

with

the

files

you

create.

Normally

this

will

do

be nothing,

although you can specify otherwise. the topic of permissions interests you you might return to the

If

root directory and explore

some more. Try doing

a long listing in

several of the bins and interpreting the information supplied to

you.

In other words,

spend a few moments and “get lost,” but do

report back.

(18) Additional information about bins

and modes

UNIX Programmer’s Manual. To access

is

available in the

this material enter the Shell

commands: apropos

modes

®

or

apropos

(19)

A

bins

®

Final Quick Review: Consider these questions:

What

(a)

Shell

command

will

move you

directly to the root direc-

tory? (b)

What command would you use Shell?

380

Commands &

Files

to reset

your path from the

(c)

What

three steps woula you take to reset your path by modi-

fying your .login file? ( 1 ) (

2)

(

3)

Answers: (2)

(a)

cd /

append “set path

(b) set

=

(

path

=

new path )”

(

new path (3)

)

source

(c)

(1) vi

.login

login

Commands &

Files

381

Module Twenty-Three

Form

Letters

Introduction Multiple copies of a form letter can easily be generated on UNIX. This process requires only that you learn a few additional com-

mands.

Prerequisites Before starting (1)

Use the

(2)

Use both

this

Module you should be

visual editor;

nroff

able to:

and

and -ms macro commands

to

format

text.

Objectives Upon completion

of this

multiple copies of a form

Module you should be

able to produce

letter.

Procedure When

producing form letters you create two files: the first contains the basic form letter, complete with blanks to be filled in later; the second contains the list of whatever text (names, addresses) should be inserted in the blanks of the form letter.

382

(1)

Log onto your UNIX account and when the Shell prompt presented use the visual editor to start a new file called letter.

(2)

An Arc^Request in this

new

Reading Input:

for

is

Insert the following five lines

file:

.LP Dear .rd

.PP //ow’s

The

going

command

.rd

part of

it

your

letter

contain a

will

list

stands for read, and is

to

be

lets

The next

filled in later.

of names that

will

know

nroff

file

that this

you create

be inserted where the .rd

is

located. coo

Use the

(3)

ZZ command

to store this

file

and return

to the Shell. wr

Use the

(4)

(5)

visual editor to create another

Contents of the Input

new

file

called

list.

File:

Insert the following line in this

new

file:

Helen This line

the

is

name

to be

used to

fill

in the

blank in the form

letter.

Use the

(6)

(7)

The the

Shell

ZZ command

Command

to store this

Line

to

file

and return

to the Shell.

Read Input: From the

Shell enter

command: nroff

This

command

tells

-ms

UNIX

to

letter


7

/ /

(

Changing the Generic are,

of course, endless.

some

items, center

information.

.

.

Title Page:

You

entries

The

variations to this

theme

can change the vertical spacing of

and not center others, include other

.

The commands used in this section are described in the Command Summary Section at the end of the book. In addition. Module Five offers a more thorough description of each command. The keys

to successful title

page formatting are the

\& which

allow

you to format from the top of the formatted page, and the .bp 1 which begins the next page at page one. If those two commands are included in the file, whatever you do in between is up to you. (Try not to have the called for spaces add up to more than one page.)

Special Formatting Topics

395

Hermeneutical Homemaking

B.

Fido Nerfball

University of California, Berkeley

Fred Flintstone

Bedrock School of Mining

This research was

made

from the

396

Special Formatting Topics

Oil

possible through a grant

Foundation

Using the nroff Title Page title

to

page format

in a file that

add the following

(a)

An

initializing

to

-ms

you are using the nroff uses the -ms macros, you may need

in a

your

File: If

file:

macro such

as

.LP on

a line before the

\& com-

mand. (b)

A .ND graph

No Y^ate) command command to suppress the (for

.bp

1

(If

command.)

A A

printing of today’s date as the

you want the date on pages within the body add the command .DA to your file just before the

center footer.

of the text,

following the initializing para-

Title

Page Using

the

-ms Macros

of specific -ms macros can be used in place of nroff requests to construct a title page. The command sequences placed within a file to prepare a title page will first be shown. Notations series

describing each

command

A

sample title page, formatted according to these commands, has not been included. Rather, you are encouraged to create your own.

The Input

follow.

File:

.RP .TL Hermeneutical Homemaking

.AU B. Fido Nerfball

.AI University of California, Berkeley

.AU Fred Flintstone .AI Bedrock Mining College

.AB This article offers an ethnographic look at the daily existence of the

Wilma

Flintstone

Bedrock Retirement

and her

Facility, circa

associates at

2 Million B.C.

.AE As life,

any research purporting to examine prehistoric one must first consult J960*s era American cartoons

with

....

Special Formatting Topics

397

Interpreting the Input File: The following annotation of the -ms macro commands used in the above input file explains the function of each command. Following the annotation is a list of important constraints

on the use of the commands.

COMMAND

FUNCTION

.RP

Requests a separate cover sheet (optional).

.TL

Tells

UNIX

be the

title

that the next line(s) of text will

(must appear).

Place the Title

Information Here

.AU

The name(s) of

the author(s)

the next line(s). Type the as

you would

like

follow on

names

in exactly

them presented.

Author Information Here Place the

.AI

The author’s

institution

appears

on the

next line(s). Place the Institution

Information Here

.AB

An

abstract of the paper follows until the

.AE command appears

(optional).

Place the Abstract

Text Here

.AE

Marks end of .AB is used).

Begin the Text of Your Paper

Special Formatting Topics

abstract (must appear

if

the

Notes on the -ms Title Page: The above commands follow conventions that result in different outputs:

(a)

specific

With the .RP command included in the file, the title and author's institution will appear in two places: on the title page and also on page 1 of the paper. Without the .RP command a separate

cover page

will

not be prepared.

The

title

page

material will instead appear on page one with the text immediately following. (b)

The command .RP no used

in place

of the

.RP

will

suppress

the printing of the information on page one. (c)

The abstract will appear under a centered heading Abstract when the .AB request is included. To suppress this heading use the .AB no in place of the .AB request.

(d)

The commands related to author (.AU) and institution (.AI) may be repeated if there are several authors from different institutions (as

demonstrated

in

the above example).

Creating a Table of Contents

When

creating a major paper, there are two ways to collect and enter the list of entries which become the table of contents: (a)

You may produce

a draft of the paper, identify the pages that

each major section landed on, and then enter each of the entries into a separate section of your paper or, (b)

You may itself,

ask nroff to collect the entries from within the text noting the appropriate pages.

Each of these approaches

is

explained below.

Creating a Basic Table of Contents: The -ms system of macros includes a specific command to inform the formatter that an entry is the beginning of a Table of Contents. There is another command to identify intervening entries, and another for indicating the last

entry.

macros.

An

The

on the top of the next page uses -ms explanation of each macro call follows. input

file

Special Formatting Topics

399

.

The Input .XS

File:

1

Phenomenological Issues .XA 16 You,

Me, and Phenomenology

.XA 25 Tree-Frog Consciousness

.XA 32 5 Mocha Almond Fudge .XA 40 Suicide Brings on Changes

.XA 52

0

Finale-Husserl at Play

.XE .PX Interpreting the Input File:

An

annotation of the

command

lines

included above follows:

.XS

used to identify the first Table of Contents entry. The number which Is

1

follows (here, the

number of

the page

page

(here,

number

1

the

for

1)

first

indicates topic item

Phenomenological

Issues)

Phenomenological Issues

Next

.XA 16

is

You,

topic item will follow,

number

the page

and the 16

of that item.

Me, and Phenomenology

Next

.XA 25

is

topic item will follow,

number

the page

and the 25

of that item.

Tree-Frog Consciousness

.XA 32

5

Next is

topic item will follow,

the page

number 5

Special Formatting Topics

5

number of

tells

and the 32

that item.

The

nroff to indent this item

spaces to the right.

The indentation

vvill

remain

until

you inform nroff

to

return to 0 indentation (which follows).

Mocha Almond Fudge

.XA 40

Next is

topic item will follow,

number

the page

and the 40

of that item.

Suicide Brings on Changes

.XA 52

Next

0

is

topic item will follow,

the page

number

0

number of

tells

UNIX

margin to indented position).

that item.

The

to indent this item

0 spaces to the right left

and the 52

its

(i.e.,

return the

normal,

non-

Finale-Husserl at Play



XE

Marks the Contents.

.PX

Tells

last

This

entry of the Table of

command must

appear.

nroff to print this material as a

Table of Contents formatted. This

when

the paper

command

is

must

appear.

The Formatted Table sent

to

the

When the above input file is Shell command line nroff -ms

of Contents:

formatter with

the

filename, the following results:

Table of Contents

Phenomenological Issues

1

You, Me, and Phenomenology

16

Tree-Frog Consciousness

25

Mocha Almond Fudge

32

Suicide Brings on Changes

40

Finale-Husserl

at

52

Play

Special Formatting Topics

401

Collecting Entries from within the Text: The entries for the Table of Contents do not have to appear together as a set in the file (as was the case in the previous example). Instead, they may appear within the text of your paper on the pages they refer to. UNIX can be instructed to collect the entries and assign the appropriate page numbers for your table of contents. The Table of Contents generated in this

way

will

appear identical to the one created

in

the

prior example.

An example tion of a

.

.

.

of this alternate approach would be the following por-

file.

and he spoke as

Leader of the Pack.

the

.sp .ce

Mocha Almond Fudge .XS

Mocha Almond Fudge .XE .sp

This brings us into historical realism

The .XS and .XE

and

....

are entered into the text

file

wherever sections

you want included in the contents. In this case, Mocha Almond Fudge is a section title. Right after the section title The is entered, an entry for the Table of Contents is included. .XS and .XE surrounding the second Mocha Almond Fudge in the file will cause Mocha Almond Fudge to be an entry in the Table of are located that

You can not you do not know what Contents. ting.

The formatter

will

enter a page

number

page the entry

for the entry because

will fall

on during format-

enter the appropriate page

entry after the formatting

is

number

for the

completed.

Informing the Formatter: When generating a Table of Contents using the above approach you must include a .TC command at the end of your file, so UNIX knows to collect your topics and assemble a Table of Contents. The .PX command, which is included when you enter the Table as a unit, is not employed when the formatter collects the entries.

Special Formatting Topics

Creating an Index

The procedures employed

having the formatter create a Table of Contents can be used to create an Index. The process is the same; make all entries in the file using the .XS and .XE commands. in

The .TC will have the formatter collect all the entries and prepare them as a Table of Contents. Since this is to be an Index, you will need change the name of this list to Index.

Special Formatting Topics

403

Module Twenty-Five Bibliographies and Footnotes:

The REFER Program

Introduction I don't

bibliography .

.

.

writing the paper, but / can't stand typing the

mind .

.

.

underline

this,

put

in

periods,

commas

Then there are the

does the date go before the city?

footnotes. Yuk.

the above statement reflects your attitude toward bibliographies, then the UNIX refer bibliographic formatting package is for you. If

prompts you for the necessary information, then formats and alphabetizes your bibliography while you sit back and

Refer

first

smile.

In addition,

when formatting

place footnotes at the

a paper

bottoms of pages or

at

it

will appropriately

the end of the paper,

given just part of a citation.

Prerequisites Bibliographic entries and

UNIX system knowledge. (I)

404

You should

modification

call

for

basic editing

and

Specifically:

be able to edit text using the visual editor; and

(2)

Because

Module

this

phy, you

consists largely of creating a bibliogra-

need to have available either a more books and articles or their bibliographic will

author, date, journal,

series of 10 or citations

(title,

etc.).

Objectives Upon completion (1)

Use the

of this

refer

Module you should be

able to:

package to format a bibliography, including

annotations; (2)

Have your bibliography

(5)

annotations;

(3)

Correct citation entries

(4)

Alter the prompts that refer presents to meet your

in

printed both with and without the

the bibliography;

own

needs;

and

Use

refer

formatted footnotes

to create properly

in a written

Q D

work.

Procedure

L E

The procedures

will

consist of seven sections.

The

first

section

discusses the use of the refer prompts to enter citation information into a

file

covered

prompt

named

database.

Formatting and

citations. in

section three.

field

Section two describes getting

a

copy of a

and describes how

Section six discusses

the refer system.

The

to create

(1)

how

to

to edit the

bibliography

is

your own prompt is

explained

in

list.

section

to cite references in papers using

final section

Using Prompts

how

Section four considers the entire refer

Entering bibliographies without abstracts five.

M

contains a sample bibliography.

Create a Basic Bibliography

Log onto your UNIX account. When the Shell prompt appears enter the command (Note; the ® means press the RETURN key): addbib

database

® The REFER Program

405

25

If

the refer pre-processing package

is

available

on your system the

query Instructions ?

will

Answer by

be displayed on the screen.

®

yes

(2)

The addbib database command you process and

is

addbib

is

(a)

two

in

typing:

just entered initiates the refer

parts:

the Shell

command

that tells

UNIX

enter bibliographic information using the refer (b)

database

is

be placed.

we (3)

you want package, and

that

to

which the information will While you can name the file whatever you want

the

will refer to

name it

of the

file in

as database.

presented on the screen. Go ahead and read through them, but don’t worry if everything is not clear. The instructions will be covered in some detail in the next few pages.

Instructions will

now be

through the addbib process we suggest you not enter the information from an actual reference citation, but rather make up quick answers to each query. You will have a chance to

On

this first pass

enter a real citation in a

(4)

moment.

The prompt Author should appear on name, such

as your

the screen.

Type an author’s

own, or

Sigmund Freud After you have entered the author’s name, press

®

.

normal order (i.e., don’t enter surname first). When the file is formatted your bibliographic entries will be alphabetized by the first author’s surname. The output will then be printed surname first, resulting in: Freud, Sigmund Enter the

(5)

name

406

®

Pressing

the

author’s

name.

request for

in

Title is

key

indicates

The Author

you have finished entering the prompt then disappears and the

displayed on the screen.

The REFER Program

(6)

Enter a

title

such

as:

Psychoanalysis and the Couch

® and

Press

(7)

prompt gives way

Title

to Journal.

Continue through the prompts, answering those that you want, leaving others blank until you get to Abstract. After each entry press

(8)

the

® to

move

to the next

prompt.

When

the prompt Abstract appears, start entering comments about the mythical book you are citing. Since abstracts are invariably longer than one line, refer is designed so that the key now

®

works

in the

normal fashion, opening up

not shifting to the next prompt.

comments

You

a

new

line for text

and

can enter several lines of

in the Abstract field.

How

do you

since

®

is

refer

let

acting in

know you

are finished

normal way?

its

the abstract you enter the

When

making comments, you have completed

command: CTRL-D

(While holding

down

the

CTRL

key, press the d key one time.)

The prompt Continue? should appear on

(9)

the screen.

You have

two choices: (a)

If

you are finished entering

citations

and want

to return to the

Shell type no or quit\ (b)

If

you want

new (10)

continue adding citations, you can Author prompt by pressing the key. to

with a

start

®

You have now worked through

the fundamental process of enter-

ing bibliographic information using the refer system. There are several things to keep in mind while entering citations into refer. (a)

Mistakes: Don’t worry about mistakes, as they can

easily be

edited later; (b)

Irrelevant fields

Prompt

Fields: Simply pass over (with a

which do not pertain

ignored

when

to

your

citation,

®

and they

)

those

will

be

the formatting takes place;

The REFER Program

407

(c)

dealing with multiple authors, enter which will call the name of the first individual, then press the up the Title prompt. Instead of typing the title, enter This procedure will bring tninus sign ( ) and then press can up another Author prompt. The names of several authors

Multiple Authors:

When

®

®



in this fashion.

be entered (d)

.



Titles: Titles are often too long to

Lengthy

Because of

this users will often enter

most of

fit

on one

line.

a title and, see-

near the right edge of the screen, press They then find themselves facing the next prompt entry is instead of a new line to finish entering the title. If an enter a too long for one line (such as a long title of an article)

ing that the cursor

®

is

.

backslash (\) as the last character in the line before. pressing the new line, but key. The cursor will move to the start of a (because of the backslash) that line will be considered part of

®

the previous line. (e)

Terminating a Citation: If while you are entering a citation you must quit (or you have totally messed it up) just pass until through the remaining prompt fields by pressing the you reach the Abstract: prompt. The CTRL-D will bring up the prompt: Continue? At that point you can either bail out or when you start a new cycle with a new Author prompt. Later,

®

edit the

(II)

To

learn

file,

how

you can remove any aborted

to edit, format,

and

partial citations.

print the bibliography

you will Use the

entered into your database file. to enter the information for at least four published works. Use journal articles or books, but avoid articles written by one author and located in a book edited by someone else, as we’ll

need several refer prompts

-

citations

get to that later.

Editing the File

(1)

have entered your last abstract and have been presented with the Continue? prompt, enter the command:

When you

vi

This permits visual editing of your database file. You can only enter the visual editor when addbib presents the Continue? query.

408

The REFER Program

(2)

(3>

Once you have entered

the visual editor, examine the file. It should look similar to the database file located at the end of this Module. Note that the citation information begins with %T

%A

%J

and the abstract material

etc.,

%A

The

%T

and

field.

at

the end of each citation.

characters which begin each line are the refer

codes placed in the

other data

is

by

file

Your

each Author, Title, or complete entry should look something

refer

first

to identify

like:

%A %T

Sigmund Freud Psychoanalysis and the Couch

%J The Vienna

%D %V %X

Circle

1897 2

Brief account of criteria for selection

of couch for office: not too hard, nor sleep inducing.

When

the addbib program prompts you with Author, it places the in the file, followed on the same line by whatever you type,

%A

®

you press The interactive process of incorporating the prompt with the data you enter is how each field {Title, Journal, until

Date)

is

.

created.

Because you entered vi when you were presented with the Continue? prompt, you can now visually edit database as you would any file. The visual editor may be used to correct spelling errors, modify each abstract, or delete aborted citations. Notice that there is a blank line between each full citation. The blank line is used by refer to keep all the information concerning

one

citation

Do

together.

not delete these blank

lines.

They are

essential.

When

%T)

be certain all the prompt abbreand the blank lines are still in their

first citation

(your mythical article by Freud) and

finished editing the

viations (such as

%A

or

file

proper places.

Remove make any

the

other corrections you wish.

ZZ. The

When you

are finished edit-

ZZ command

does not take you back to the Shell, but rather to the Continue? prompt in refer. At this point to continue adding reference citations, or enter no you can press ing, type

®

to return to the Shell.

The REFER Program

409

Returning to the File: When you type no in response to the Condatabase file tinue? prompt you are returned to the Shell, and the storage. What if you want is written onto the disk for permanent addbib database. to add more citations to the file? You simply type When you use addbib with an already existing file, the new citations are appended to the end of the file.

Formatting and Producing a Copy of the Bibliography addbib database you started the process of creating a file called database into which all bibliographic The database file is placed in_ your UNIX entries were made. account (just like any other file) and can be formatted and line

When you

entered the

command

printed.

(1)

A

Screen Display: To get the

file

database properly formatted and

displayed on the screen enter:

database

sortbib

(2)

Line Printed Copy: To send

page

roffbib

a formatted

|

copy of the bibliography

'

to the line printer enter:

database

sortbib

Without Annotations:

If

roffbib

Ipr 1

you want the bibliography printed out

without the annotations a -x option

is

included with the roffbib

command: sortbib

With Page

Offset: If

r,

roffbib -x

Ipr |

you want the bibliography printed with

(a

larger

left

command: sortbib

410

a

one

margin), a -rOli option (minus, upper case O, one, eye) is included with the roffbib

inch page offset

lower case

database

The REFER Program

database

roffbib

-rOli

Ipr 1

i

,

i

1

Explanation of Commands: The

command

lines just presented can

be interpreted as follows: (a)

The

sortbib, sorts the entries in the

file

database by author

(and by date); (b)

The

next sent to roffbib which converts the %A %T %J prompts into specific formatting instructions and then formats

the (c)

file is

file.

Finally,

depending upon what you specify, the

file

is

sent

either to the screen (default) or the line printer.

Use of Fields Not Included (1)

in the

The addbib program does not prompt you

Prompts

with

all

the possible

For instance, if a citation is an article in a book edited by someone else, you are not prompted for Editor?, although that prompt does exist. The following is a complete list of fields that the roffbib program recognizes: fields.

%A %B %C %D %E %G

Author’s name

book in which article is located City where published Date of publication Editor of book which contains the article being Title of

%H

Government order number Header commentary which is

%I

Publisher (Issuer;“P”

%J

Name

is

cited

printed above citation

taken by “page number’’)

of journal

%K Keywords used to locate reference %N Number of issue within the volume %0 Other information or commentary %P

%Q %R

Page number (s) Corporate or foreign author (name Report number

%S

Series

title, if

book

is

one

is

not reversed)

part of such a series

%T Title of book or article %V Volume of the periodical %X Abstract The REFER Program

41

(2)

There are three ways to include fields in your file database which are not in the prompts that refer automatically provides you: (a)

You

can place additional field identifiers and field information directly into the file using the visual editor. First type the usual vi database Shell command sequence. Next, enter the appropriate refer code (such as %E) followed by a space and the necessary information. The

Entering Additional Fields from

v/:

order that you include these fields is not important; refer will Be sure to place all information in an established order. include a blank line between citations. (b)

Entering Additional Fields Using addbib: When you have typed as Title?) all the information for one of the prompts (such key. enter a backslash as the last character. Then press the

®

I

i

For instance: Title: Psychoanalysis

Instead of a

new prompt, you

and

will

the

Couch\

®

be presented with a new

Enter the refer code and appropriate information. Then press RETURN. The next prompt will now be presented.

line.

(c)

Entering Additional Fields by Changing the Prompts'. The third way to use the other refer codes is to change the prompts

presented you to include the set you want. This approach

;

i

will

next be discussed.

(3)

have addbib provide additional prompts (such as %E for Editor of a book), or if you want to eliminate those which you do not use, you must set up your own

Changing the Prompts:

prompt

If

you wish

to

;

list.

addbib present only those prompts that you select yo\x must create a file named prompts which will include the screen prompts you want displayed along with the associated refer codes (%A %B %R %S or whatever). Each line of the prompt file must contain the

To have

following:

(a)

The prompt

(b)

A

(c)

The

itself is

positioned against the

left

single [Tab] character follows each prompt; refer

on the

412

j

code (drawn from the

line.

The REFER Program

list

above)

margin;

and is

the final entry

i

!

;

i

Each subsequent line separated by a [Tab]

will also

include a prompt and

its

refer

code,

.

Note: ITABI means Press the [TAB key. (If you do not have a [TAB key on your terminal, press CTRL-I.) With each [TAB] the cursor may or may not move, and no character will appear on the screen. Because the invisible |TAB| character can be confusing, it is possible I

to

have

on the screen

a character appear

where you

to indicate

entered each ITABI character.

From the Command Mode command (don’t forget the

of the visual editor, enter the following colon):

:set list

Your [Tab]

When

will

now

appear as the

"I character.

you want the [Tab] characters

to

no longer appear

in the ter-

minal output, enter the command: :set nolist

(4)

The prompt

file

which would result

in all fields

prompted would look

like the following display.

Named

Contents of File Author? ITabi

''Prompts'*

%A

Corporate or Foreign Author? [TAB] Article/Book Title? [Tab] %T Edited

Book

Title? |Tab|

%0

%B

Journal? |Tab| %J Edited by? |Tab| %E Title of Series? ITABI

%S

Volume? ITabi %V Number? [TAB] %N Report Number? ITABI

%R

Page(s)? [Tab] %P Publisher? [TAB] %I City? [TAF] Date? [Tab]%D

The REFER Program

413

Government Order Number Header Commentary? |TAB|

|TAB|

%G

%H

Other? [TabI %0 Keywords? |TAB| Abstract?

(5)

%K [TABl %X

established a prompt

Once you have

activated (whenever

the following Shell

you want

file

in

your account,

it

is

to enter citation information) with

Command:

addbib -p I

prompts

database

space

-p prompts included in the above command line instructs addcurrent bib to use the prompts listed in the prompts file in your

The

directory, rather than the standard set.

and print your database file, the sorting (sortbib), formatting (roffbib), and printing (Ipr) com-

When

the time

comes

to sort, format,

mands are the same as described earlier. They the method you use to create the database file.

are not affected by

Entering Bibliographies without Abstracts information without entering abstract comments. The Abstract? prompt will not be presented if you include the -a option with the addbib command:

You may want

to enter bibliographic

addbib -a space

All

prompts

will

database

I

now be used

except Abstract:.

Citing References in Papers

(1)

Incorporating Footnotes: The refer pre-processor not only creates bibliographies which can be appended to a paper, but also takes care of the

414

messy job of footnoting.

The REFER Program

For example,^ the footnote at the bottom of this page was produced by including the following lines in this file: For example, .[

Tuthill 1982 .1

the footnote at the bottom of this

You do

not have to include the entire citation

text; just

(the (2)

name

enough

to

let

refer

identify

page was

.

.

.

point in your

at this

which reference you want

of the lead author and the date

will usually

be enough

to allow refer to access the correct citation).

(3)

Obtaining Formatted Footnotes The

default option in refer is to have footnotes placed at the bottom of the page.

numbered and

Page Bottom Footnotes: When it is time to format and print a file and you want the footnotes placed at the bottom of the page, use the following Shell

command

sequence:

(4)

refer -p

Here database

database the

filename

nroff

-ms

Ipr |

®

of citations and filename is the text file that has the footnote calls embedded in the text. (The -p indicates that you are using the database in your current directory— your t^rivate database instead of the system database.) is

file



Listed Footnotes:

The

package will also place footnoted referthe end of a chapter, instead of at the bottom of

ences together at each page. The Shell prints

your paper refer -e -p

'

Bill

refer

command sequence

in this

form includes the

database

filename

Tuthill, Refer-A Bibliographic System,

fornia, 1982.

Computing

line

which formats and

-e option:

nroff

-ms

|

Ipr

®

University of California, Berkeley, Cali-

Services.

The REFER Program

415

With the wherever

-e option footnotes will not in the text

be placed on each page, but

you place the following three

lines;

.1

$LIST$ .1

(5)

Science citations such as this one numbered [Tuthill, 1982] are also possible in place of superscript footnotes. You enter the same footnote marker: Social

Bracketed Citations:

.1

partial citation .1

same manner, but use a different Shell command paper. The Shell command line which formats your

in the text in the

to

format the

paper must include the refer

-1 I

I

-p

-1

(“minus ell")

flag:

nroff

filename

database

-ms

1

Ipr

space

option the senior author’s name and publication date are bracketed at the appropriate text locations.

With the

(6)

-1

Use with Other Pre-Processors: pre-processor (perhaps

Command

tbl

If

and neqn)

you are using more than one for a paper, the correct Shell

sequence would be:

refer -p

database

filename

tbl

I

neqn

nroff 1

-ms

Modification of the Programs the bibliography produced with the refer package is useful for most paper and report writing activities. It does not, however, comply with the specific style requirements of many pub-

The format of

lications (such as the

APA

Psychological Association).

Manual published by the American may be necessary for you to modify

Style It

the refer and roffbib programs punctuate and order the elements of the bibliographic citations. Although such modifications

how

beyond the scope of this edition, the interested reader is prior page. referxtCi to the Tuthill monograph footnoted on the

are

This is an excellent source of information about the refer preprocessing package and describes how to modify these programs.

416

The REFER Program

7

A Sample The following

list

of citation information

which was used the end of this Module: database

%A %A

Bibliography

file

to

is

the contents of the

produce the bibliography located

at

Joel Kies Bill

Tuthill

%T UNIX

Text Formatting Using the -ms Macros

%I Computing Services, University of California

%C

Berkeley, California

%D 1983 %K software document preparation %X All commands and conventions

of -ms are explained for use with the Berkeley system, including table of contents and other fancy features.

%A

Bill

Tuthill

%T

Refer — A Bibliographic System %I University of California

%C

Berkeley, California

%D 1982 %0 Computing Services %X The most complete source refer program.

%A %A %T

A

must

W. Kerninghan Dennis M. Ritchie The C Programming Language Brian

%I Prentice-Hall %C Englewood Cliffs,

%D 1978 %K software %X This the is

%T %I

New

Jersey

handbook for programmers the C language. The rules of the classic

who work in game are carefully

%A

if

of information about the you intend to use refer extensively.

explained.

Joseph F. Ossanna Nroff/Troff User’s Manual Bell Laboratories

%C

Murray

%D

1976

Hill,

New

Jersey

The REFER Program

4

1

%K %X

software document preparation All the specifics of nroff and troff are included

in careful detail, including options,

%A %A %T

Neil

arguments

etc.

Postman

Charles Weingartner Teaching as a Subversive Activity

%I Dell Publishing Company %C New York

%D 1969 %X The classic if

book

for

assisting people to learn to think Heady with new

The bibliography on file is

anyone interested

skills,

is

of interest.

od a

Rhett decider to

the next page results

in teaching,

when

the above database

sent to the sorter and formatter with the following

line:

sortbib

418

table...

The REFER Program

database

roffbib \

Ipr |

command

BIBLIOGRAPHY

Kerninghan, Brian W. and Dennis M. Ritchie, The

Englewood

Prentice-Hall,

This

the

is

language.

classic

The

Cliffs,

Programming Language,

New

Jersey, 1978.

for

programmers who work

handbook

rules of the

C

game

in

Bill Tuthill,

C

are carefully explained.

UNIX

Text Formatting Using the -ms Macros, puting Services, University of California, Berkeley, California, 1983.

Kies, Joel and

the

Com-

of -ms are explained for use with the Berkeley system, including table of contents and other fancy features.

commands and conventions

All

Ossanna, Joseph

New

F., NrofflTrojf User’s

Manual,

Bell Laboratories,

Murray

Hill,

Jersey, 1976.

All the specifics of nroff

and

troff are

included

in careful detail,

including

options, arguments etc.

Postman, Neil and Charles Weingartner, Teaching as a Subversive Publishing Company, New York, 1969.

The

classic

book

learn to think Tuthill,

Bill,

is

for

anyone interested

in teaching, if assisting

people to

of interest.

Computing

Services.

The most complete source of information about if

Dell

Refer-A Bibliographic System, University of California, Berkeley,

California, 1982.

must

Activity,

you intend

the refer program.

A

to use refer extensively.

The REFER Program

419

Module Twenty-Six Setting Tables:

A

Busboy’s Nightmare

The TBL Pre-Processor

Introduction Text processing often requires that information be presented in columns or tables. Merely the thought of having to tediously count the needed spaces, divide by 2, center, backspace, etc., is enough to convince all but the most determined writer to seek

some

alternate

contains

tbl to

way

to present the information.

Fortunately UNIX

help with this task.

Prerequisites In writing this section,

that

(1)

Use the

(2)

Use the basic nroff commands words, and skip lines; and

(3)

Use

visual editor to

Shell

commands

line printer.

420

we assume

to

you are able

add and change text

format a

to

file

center

to:

in a file;

lines,

and send that

underline

file

to the

Objectives Upon completion (1)

Module you should be

able to:

Properly format multicolumn tables which contain numbers,

words or (2)

of this

text entries.

Systematically

troubleshoot

when

do

tables

not

work

as

planned.

Procedure The following introduction to table formatting starts with a two column format and, by adding commands, demonstrates some of the more complex forms which are possible. These procedure steps are grouped

The first simple two column

into four sections.

section presents instructions for formatting a

Section two describes how to send a file containing a table to the formatter. The third section builds upon the simple table by adding more columns and different kinds of data. The last section table.

coo

includes examples of boxes and the use of different sizes of type. mr

A An Example

Table for Two, Please

The following two column display was proUNIX tbi program. This table will serve as the the more complex tables to be presented in later

Table:

duced using the starting point for

sections of this Module.

produce

An

explanation of the

commands used

to

this table follows.

The TBL Program

421

Table

Equipment

Cost

Hammer Radial Arm Saw

14.95

389.50 39.50 69.95

Tool Box Electric

A

Sander

Work Bench

179.

Gasoline Chain

Saw

166.80

How

Tables are Formatted: Tables are formatted by giving specific instructions as to how each row and column are to be presented. Columns are the vertical, up and down units in a table; rows the horizontal, across units.

For example,

in Table

Column One

Cost

Hammer Radial Arm Saw

14.95

389.50 39.50 69.95

Tool Box

Sander

Work Bench Gasoline Chain

A

row

is

the two columns are:

Column Two

Equipment

Electric

A

179.

Saw

166.80

‘‘sliced” horizontally.

The

Equipment and the second row

The TBL Program

row of Table A

Cost

is:

Hammer

422

first

14.95

is:

and nroff

be able to format the display of a table you must provide specific instructions as well as the data to be entered. For all tables you must indicate:

For

tbl

(a)

The number of columns of information (in Table A there are two columns);

the table will contain

(b)

How

to

to

the information in each

column

is

whether each entry should be centered against a

left

or right

numbers, adjusted (c)

The

actual

column margin,

be displayed

in the

or,

column, pushed

the information

if

relative to a decimal point);

information

(data)

you

(i.e.,

want

is

and

placed

in

each

column.

Using the |TAB| Key: The directions were entered as follows:

for

Table

A

using the [TAB

.TS c c 1

n.

Equipment

Cost

.sp

14.95 Hammer Radial Arm Saw

Tool Box

389.50

39.50

69.95 Sander 179. Work Bench Gasoline Chain Saw .TE Electric

What

is

tricky with this

166.80

example

is

that in looking at the

above

you would never know the |TAB| key was used to separate the entries for each row into two columns. For instance, there is a TAB! entered between Hammer and 14.95 in the first row of data. There usually is no apparent symbol. (A |TAB| character tends to be quite secretive.) This is due in part to the fact that the [TAB] key does not adjust your screen display in the same way as the [TAB] key on a typewriter affects the typed page. display

Defining a [TAB] Character: Because the ITABI key can be very confusing to use when setting tables (and is almost impossible to demonstrate here) we recommend defining some other character

The TBL Program

423

which

will

show up on

following table instructions

above, only the plus sign In this

ter.

ded

(

+

)

is

defined as the separation charac-

example the separation character can be seen embed-

in the instructions.

.TS

Instructions for Table

(+)

tab

column entries. The produce the exact same Table A seen

the screen to separate

A Using

the Plus Sign

;

c c 1

n.

Equipment + Cost .sp

Hammer + 14.95 Radial Arm Saw+389.50 Tool Box + 39.50 Electric

Sander -1-69.95

Work Bench

-I-

179.

Gasoline Chain

Saw

-I-

166.80

.TE

(1)

Log onto your UNIX account. Select one of your practice files (such as the musty first file) to use with these exercises. As you read through the following examples, enter the format instructions at

some

interesting point in your

file.

you should follow the format instructions that we present. You could easily change the data to whatever content amuses you, however. In entering the tables into your

file,

Explanation of Instructions for Table This section

will

A

describe the function of each of the above Table

Format instructions used in setting Table A, beginning with the first command line. As you read the following, examine the effect of each command on the formatted Table A. .TS

Indicates that a Table Starts with the next line of text.

It is

one-way command and is paired with the Table Tnd (.TE) command (which must be the last command in the

a

424

The TBL Program

table).

The

entire unit,

from .TS

to

a separate file or placed in a text

where you want the formatted tab( + );Informs the

sign character

(

file at

+

)

in

the exact location

table to appear.

program formatter

tbl

.TE, can be located

that

you

will

use a plus

column

instead of a [TAB] to separate the

program will look for [Tab] characters. The semicolon (;) at the end of this line indicates that the options are concluded and that Without

entries in the input line.

the

actual

column layout

semicolon must appear c c

Instructs

the

first

(a)

(c)

instructions

will

follow.

The

any options are selected.

concerning how you want data entries placed row of the table, namely that: tbl

there are two symbols, therefore the table

matted (b)

if

this line the

in

the

first

(c)

and,

the

centered

be for-

to

two columns,

entry for the

first

column should be

centered

column should

also be

entry for the second

first

is

in

(c).

(These entries

will in fact

be the column

heads.) 1

n.

how

the data in the second row

be formatted. The first entry is to be placed against the left (1) margin of the first column. The second entry is to be one number (n) arranged in the second column so the decimal points are aligned. The period must be included at the end of whichever is the last line of table formatting commands. The period indicates that the formatting instructions are Indicates

is

to

over and that the data to be included in the table will start on the next line. Without the period, the table is not set, and no dinner

most Data

The

will

be served.

common

Failure to include the period

is

the

table formatting error.

actual table information

is

then entered, line by

with a plus sign (-f) separating the column entries. data entry for the first row of the table is:

line,

The

Equipment + Cost

+

move on to the next column. Thus, in the formatted output. Equipment will be in the first column, and Cost in the second.

The formatter reads

the

sign as

The TBL Program

425

When

the

®

RETURN

of the table has been entered the pressed. The next line is then typed,

line

first

key

is

followed by the next, until

all

the data has been entered.

Each row is a separate line in your lines would look like the following:

file.

These remaining

Hammer + 14.95 Radial Arm Saw + 389.50 Tool Box + 39.50 Electric

Sander + 69.95

Work Bench + 179. Gasoline Chain Saw + 166.80

When

.TE

the entire table has been entered you

the conclusion with the

must

indicate

.TE command.

Relationship Between Instruction Line and Data Line: Look back The first line of the format Table A. at the instructions for instructions (c c) and the first line of the data (Equipment + Cost) are both needed in order to format the first row of the table. The formatting instruction consists of two characters, c c which indicates that there will be ter

is

two columns. The

fact that the first charac-

a c indicates that the first piece of information

is

to be cen-

column. The scond c indicates that the data for the second column should also be centered. The first line of data provides the two pieces of information needed for the first row. They are separated by a plus sign ( + ). tered in the

first

The second

line

of instructions and the second line of data—



both the data and format instructions for the second row in the formatted table. In this row, the first entry for the first column is to be formatted left, and the second column entry lined up by its decimal point. The last instruction line (1 n.) is then used with all remaining data lines to format all remaining rows in the table. together

Having a Table Formatted

A

General Process Comment: The formatting commands and the table information are both entered into a file just like all other content and formatting commands. The only difference is that if a file

426

The TBL Program

contains a table, it

is

it

must

first

be sent to the

sent to the regular nroff (or nroff -ms,

tbl if

pre-formatter before

you use the -ms mac-

ros) formatter. (1)

A

copy of the formatted table can be displayed on your terminal screen by entering the Shell command line: (2) tbl

(3)

To produce mand line:

filename

tbl

page

|

®

a line printed copy of the table, enter the Shell

filename

tbl

The

nroff \

pre-formatter

table instructions

is

nroff |

Ipr |

a pre-processing

com-

®

program that takes your

and converts them into commands that the nroff

format program can understand. Once tbl is finished, the output must be sent (with the pipe command) to nroff (or nroff -ms) |

where the

table

is

finally

formatted.

Setting

Would

A

Amy

Different Table

Vanderbilt Approve?

There are innumerable variations to the ways tables may be set. A table can be centered on the page or spread out to full page width; entries can be placed differently in the layout; several columns can be created; entries can span columns; and text can be included in addition to words or numbers. Each of these will be demonstrated by making changes in the command structure of the sample Table A you have already examined.

(1)

Locating a Table on a Page: Table A was printed against the margin of the page. Additional choices exist, however.

The TBL Program

left

427

following set of instructions produces a formatted

The

which

is

centered

on the page:

Instructions for Table

.TS tab

(

+

)

Table B,

B

center;

c c 1

n.

Equipment + Cost .sp

Hammer + 14.95 Radial Arm Saw + 389.50 Tool Box+39.50 Electric

Sander + 69.95

Work Bench + 179. Gasoline Chain Saw + 166.80 .TE

The above

instructions result in the following centered Table B:

Equipment

Cost

Hammer Radial Arm Saw

14.95

389.50 39.50 69.95

Tool Box Electric

Sander

Work Bench Gasoline Chain

179.

Saw

166.80

Notice that the only difference between the instructions for Table

A and

Table

the tab

(

+

)

B

is

the inclusion of the

word

between Without the

center inserted

and the semicolon on the second

line.

center instruction, tbl defaults to placing the table against the left

margin, as

(2)

The

did in Table A.

expanded to the with the word expand.

table can be

ing center

Try making.

428

it

first

full

width of the page by replac-

centering and then expanding the table you have been

The TBL Program

(3)

Number Data Placement:

Center, Right, Left, and

In the preced-

examples the column headings were centered over the column, the items (first column) were placed against the left margin, and prices (second column) were lined up according to the decimal ing

points.

We

format the table with both the headings and the content pushed to the right margins. This is effected with the following set of formatting instructions for can just as easily instruct

Table

C

tbl to

:

.TS

Instructions for Table

C

tab( + ) center; r r r r.

Equipment +Cost .sp

Hammer -1-14.95 Radial Arm Saw-f-389.50 Tool Box -1-39.50

Sander -1-69.95 Work Bench -1-179. Gasoline Chain Saw -1-166.80 .TE Electric

The formatted and centered

Table

C

appears as follows:

Equipment

Cost

Hammer Arm Saw

14.95

Radial

389.50 39.50 69.95

Tool Box

Sander Work Bench Gasoline Chain Saw Electric

(4)

The only

B

differences between

179.

166.80

the instructions for

Table

C

and

which appear in Table C, replacing the c c and 1 n formatting instructions. Each set of instructions contains 2 characters, corresponding to the 2 Table

are the two

r

r

lines

(lines

3

and

4)

The TBL Program

429

columns

in

each

table.

The

r

calls

for the

column entry

placed against the light edge, while c formats to the center, the

left

1

to be

against

edge, and n adjusts numbers according to decimal points in

the respective columns.

r, 1,

(5)

Try various combinations of the column entry instructions n, and c.

Headings: Often

it

is

useful to have a table entry act as a

title

or as

This requires that the title be written {spanned) across more than one column. Try the following instructions for a sub-heading.

Table

D

:

.TS

Instructions for Table

tab( + ) center; c s c s c c 1

n.

Table

D

.sp 2

House Building Equipment .sp

Equipments- Cost .sp

Hammer -b 14.95 Radial Arm Saw-f 389.50 Tool Box4-39.50 Electric

Sander +69.95

Work Bench + 179. Gasoline Chain Saw + 166.80 .TE

430

The TBL Program

D

The

above

Table

D

produced

instructions

the

headings

following

in

\

Table

D

House Building Equipment Equipment

Cost

Hammer Radial Arm Saw

14.95

389.50 39.50 69.95

Tool Box

Sander Work Bench Gasoline Chain Saw Electric

The

179.

166.80

command

entered for rows one and two means center and span. Thus, the entry is spanned across both columns of the table. c s

Table Entry

The options

for specifying

Option

Command Summary

placement of table entries

are:

Function

r

Places the entries against the right edge of the column.

1

Places the entries against the

c

Places the entries in the center of the column,

n

Adjusts

s

Spans the previous entry across

all

left

edge of the column,

entries so that the decimal points are lined up. this

column.

The TBL Program

431

(6)

Try using each of the Table Entry Commands to vary the placement of the headings and data in your table. When finished go ahead and eat lunch — you deserve to eat from a table (considering how many you have set). There is more to come. .

.

.

Waiter, a Table for Four, Please

(7)

tables are created by: (1) changing the instructions to indicate the number of desired columns to be used as well as how

Multicolumn

you want the information placed needed table data.

in

them, and

(2)

including the \

Table

E

demonstrates

formatted Table

how

E follows

to create a four

tab(H-) center;

csss csss c c c c

n 1 r. Table E 1

.sp 2

House Building Equipment For Sale .sp

Equipment + Cost + Color -h Condition .sp

Hammer4-14.95 + brown + Beat up Radial Arm Saw + 389.50 + blue + New Tool Box + 39.50 +green 4- Fair Electric Sander + 69.95 + mauve + Untouched

Work Bench + 179. +grey + Bad news Gasoline Chain Saw + 166.80 + red + Trouble .TE

The TBL Program

table.

on the next page.

Instructions for Table

.TS

432

columned

E

The

Table E

House Building Equipment For Sale Equipment

Cost

Hammer Radial Arm Saw Sander Work Bench Gasoline Chain Saw Electric

(a)

The

The

Beat up

389.50 39.50 69.95

blue

New

green

Fair

179.

grey

166.80

red

mauve

Untouched Bad news Trouble

Instructions Resulted in Table

E

each instruction line has four characters means that there will be four columns;

in

fact that

csss) (b)

Condition

brown

14.95

Tool Box

How

Color

first

line

of instructions

should be formatted:

csss

tells

how

means

the

first

it

(such as

row of the

table

center the first (and only) data

entry across all four columns;

The

corresponds with the first line of data: Table E. Therefore, Table E is centered across all four columns. (c)

first

instruction

The second

instruction line

spanned across

all

(csss)

one entry

be four columns: House Building Equipment For also calls for

to

Sale. (d)

The

third instruction (c c c c) calls for centering of information in

each of four columns. Therefore in the third data line there must be four entries separated by the plus + character: Equipment, Cost, Color, and Condition; and (e)

The fourth

line

of instructions

(1

n

1

r.)

tells

the computer

how

format each of the remaining rows: \eft, number, \eft and Tight. Because all of the remaining rows of data will follow this format, the instruction line does not have to be repeated. The period (.) must follow the last character in this line. to

The TBL Program

433

Changing

(8)

In constructing a table

the Setting in

it

may be

Mid-Meal

necessary to change the format

Perhaps a sub-heading or related but different data must be entered. For instance, assume the house building equipment in our example is available at two

after

some of

different times.

the data are entered.

The following

table could

convey

Instructions for Table

.TS tab(-l“) center;

csss csss c c c c

n 1 r. Table F 1

.sp 2

House Building Equipment For Sale .sp

Equipment + Cost "H Color + Condition .sp

Hammer + 14.95-Fbrown + Beat up Radial Arm Saw+389.50+blue + New Tool Box + 39.50 -hgreen-l- Fair .T&

csss 1

n

1

r.

.sp

Available After June 30 .sp

Sander + 69.95 -F mauve -F Untouched Work Bench + 179.+grey 4-Bad news Gasoline Chain Saw + 166.804-red + Trouble Truck -F 1200 -F white + 200K miles .TE Electric

434

that information.

The TBL Program

F

The resulting table— with format middle— follows:

instructions

changed

in

the

Table F

House Building Equipment For Sale Equipment

Cost

Hammer Radial Arm Saw

Color

14.95

389.50 39.50

Tool Box

Condition

brown

Beat up

blue

New

green

Fair

Available After June 30

Sander Work Bench Gasoline Chain Saw Truck

69.95

Electric

The

initial

Table E.

The fourth

placed (1 n

1

r).

.T&

entered.

more

red

Trouble 200K miles

white

for

F

Table

how

Untouched Bad news

are

the

same

as

for

the table data should be

All of the data lines will be formatted following

.T& command

result

is

that

is

commands and you can format

the format of a table, enter

enter

166.80

1200

additional format

The

grey

line specifies

that specification, until the

the

179.

commands

format

mauve

more

encountered.

then

new

Following

data can be

a table, enter data, alter

data, alter the format,

and again

data.

Try creating your own table

in

which the format changes dur-

ing mid-course.

Using Text for Entries

(9)

numbers and

few words, tables can have entries which are entire blocks of text. The following example demonstrates the use of the blocked text option of the table program. In addition to

a

The TBL Program

435

Instructions for Table

.TS tab

(

+

G

center;

)

c s c s c c 1

lw(3i).

Table

G

.sp 2

Housebuilding Equipment

for Sale

.sp

Equipment -f Comments .sp

Hammer + T{ This

a standard 20 oz. nail

is

whomper, well used

in

construction of two houses. T)

Radial Arm Saw-I-T{ An extremely useful tool, can change blade direction for wide variety of cutting angles. T)

Tool Box H-T{

Standard carpenter’s multi level carry everything, find nothing tool box. T) Electric

Sander+T{

Vibrate your eyes out, ears ordinary sander.

fill

your lungs with dust, blast your

T)

Work Bench + T{ Wood,

3

ft

by 6

ft

8 drawer, one vise butcher shop.

T)

Gasoline Chain SawH-T{ Been through two forest fires and four friends’ fireplace supplies. T)

.TE

The

table generated with these

the next page.

436

The TBL Program

format instructions

is

presented on

Table

G

Housebuilding Equipment for Sale

Equipment

Comments

Hammer Radial

This

a standard 20 oz. nail

is

whomper,

well used in construction of two houses. An extremely useful tool, can change blade direction for wide variety of cutting

Arm Saw

angles.

Tool Box Electric

Standard

carpenter’s multi level everything, find nothing tool box.

Sander

carry

Vibrate your eyes out, fill your lungs with dust, blast your ears ordinary sander.

Work Bench

Wood, 3

Gasoline Chain

butcher shop. Been through two forest

Saw

by 6

ft

ft

8 drawer,

fires

one vise

and four

friends’ fireplace supplies.

When

using text blocks in a table you need to

remember four

things: (a)

The width of of the

a text block

table.

number can be brushes.

You

use

The T{

In Table

is

the

stated in the instruction section

G

w(#) where

notation

in inches, picas, points,

column

will

the

#

centimeters, or tooth-

this instruction line reads

cating that the second (b)

is

have a

vf idth

1

lw(3i)., indi-

of 3 inches.

placed after the [TABI character and indicates that a

text block will follow; (c)

The

text begins

(d)

The

T)

is

on the next

line;

and

placed on the next line after the end the text block.

'^Spanning'' Information Across Row^s Tables are seldom as neat and tidy as those we have presented so far. The following example demonstrates how to center an entry across two rows.

The TBL Program

437

.

Instructions for Table

.TS

H

tab (H-) center;

csss csss c c c c

n c n. Table H 1

.sp

Students in Braucher Elementary School .sp

Teacher 4- Grade + Gender + Number McKinney + 64- Boys + 13

V+\''+Girls + 18 Forbes + 7 + Boys + 16

V+V+Girls + 15 Place + 8 + Boys + 17 V+V+Girls + 15 .TE

The above commands produce

the following Table H:

Table

H

Students in Braucher Elementary School

Teacher

Grade

McKinney

6

Forbes

7

Place

8

Note the placement of the

Gender Boys

Number

Girls

Boys

18 16

Girls

15

Boys

17

Girls

15

commands

13

in the data field.

They

not to place any new element in that position, but instead to (2) pull down the information from the row above so that it is horizontally centered across both rows. Thus, instruct the formatter

McKinney and rows {Boys and

438

6

(1)

appear appropriately

Girls )

The TBL Program

at

the middle of the two

Using Troff to Format Tables

You

can format even fancier tables

typesetter.

if

you have access

to a photo-

Consider the following several examples.

Allbox: The allbox in the options line of the instructions results the centered Table I with each data item individually boxed:

.TS tab

Instructions for Table (

+

)

in

I

allbox center;

c c 1

n.

Equipment + Cost .sp

Hammer + 14.95 Radial Arm Saw+389.50 Tool Boxf39.50

Sander + 69.95 Work Bench + 179. Gasoline Chain Saw + 166.80 .TE Electric

Table

I

Equipment

Cost

Hammer Radial Arm Saw Tool Box Electric

389.50 39.50

Sander

69.95

Work Bench Gasoline Chain

14.95

179.

Saw

166.80

Box: The allbox option can be replaced wi^h box, which will produce a single box around the entire table. This is demonstrated in Table J, presented on the following page. The TBL Program

439

Instructions for Table J

.TS tab

(“I")

box center;

c c 1

n.

Equipment + Cost .sp

Hammer + 14.95 Radial Arm Saw + 389.50 Tool Box+39.50 Electric

Sander + 69.95

Work Bench + 179. Gasoline Chain Saw + 166.80 .TE

The box in the options lowing boxed display.

line of the instructions results in the fol-

Table J

Equipment

Cost

Hammer Radial Arm Saw Tool Box Electric

Sander

Work Bench Gasoline Chain

14.95

389.50 39.50 69.95 179.

Saw

166.80

Vertical and Horizontal Line Placement:

It

is

also

possible to

where vertical and horizontal lines should be included inside a basic box table. This is demonstrated in the following Table K, which appears on the next page. The instructions necessary to prospecify

duce the table are presented following.

440

The TBL Program

first,

with the finished formatted table

.TS

Instructions for Table

+ csss csss tab

(

)

K

center box;

c c c c

n c n. Table K 1

.sp

Students in Braucher Elementary School .sp

T eacher -h Grade -b Gender 4- Number Ca vette + 64- Boys 4-13 \^4-\^4-_4-_ \^4-\^ 4-Girls 4-18

Forbes 4-74- Boys 4-16 \^-l-\^-l-_4-_

\^-l-\^-hGirls-hl5 Koettel 4-84- Boys 4-17

V-hV-h_-i-_ -1-Girls 4- 15

.TE

Table

K

Students in Braucher Elementary School

Teacher

Grade

Cavette

U

Forbes

Koettel

7

Gender

Number

Boys

13

Girls

18

Boys

16

Girls

15

Boys

17

Girls

15

8

The TBL Program

The

pipe

placed within the format instructions calls for a single

1

vertical line, while a

double pipe

produces a double

||

line.

The

underscore _ in the data requests a single horizontal line (note that this underscore is not a minus sign, hyphen, or dash)', and an equal sign = results in a double horizontal line.

Changing Type Characteristics allows you to change font types or point size of your printed output. Font type can be affected with the follow-

The phototypesetter

ing line in your format instructions:

cfB

The cfB

s

s

s

s

reads center and span the data across all change font to boldface. Point size can be

s instruction

s

four columns, and affected with the following line in your format instructions:

cpl4

The cpl4

s

s

s

s

s

s instruction reads center

and span the data across

all

four columns, and change ^oint size to 14.

both font type and point size can be affected with the lowing line in your format instructions: Finally,

cfBpl4

The cfBpl4

s

s

s instruction

s

s

fol-

s

reads center and span the data across

four columns, change font type to boldface,, and change ^oint size to 14. The effects of changing font type and point size are demonstrated in Table L which follows on the next page.

all

,

Reference Material: With the material contained in this Module your table settings should please even the most demanding diner. Should you require additional help— and good help is so hard to find these days— you might look at a pamphlet available from Bell Labs entitled TbI—A Program to Format Tables.

442

The TBL Program

.TS tab

Instructions for Table

+

(

)

L

center box;

cfBplZ s s s cpl6 s s s cfBplZ cplZ cplZ cplZ n c n. Table L 1

II

I

.sp

Students in Pat Lloyd Elementary School .sp

T eacher + Grade -b Gender + Number McKinney + 6 + Boys + 13

\^+\^+_+_ \^+\''+Girls + 18

Calhoun + 7 + Boys + 16

\''+\^+_+_ \^+\^+Girls + 15 Place + 8 + Boys + 17

\^+\^+_+_ \''+\^+Girls + 15

.TE

Table L

Students in Pat Lloyd Elementary School Teacher

Grade

McKinney

6

Calhoun Place

Gender

Number

Boys

13

Girls

18

Boys

16

Girls

15

Boys

17

Girls

15

7

8

The TBL Program

443

Table Formatting Shell

Summary

Commands

Command tbl

nrofF

[filel

Function

-ms

Sends

to

filel

results

be

be

will

formatted;

displayed

on

screen.

tbl

[filel

nroff

-ms

|

Ipr

Sends

filel

sends

the

to

be formatted and

formatted version to

the line printer. tbl

[filel

troff

-ms

—Q

Sends

filel

to

be formatted and

sends the formatted version

to

the phototypesetter.

Formatting

Commands

.TS

Notifies nroff that a table follows.

.TE

Notifies nroff to return to

formatting.

Table

Commands

1

left justify

c

center

r

right justify

n

number

s

span

The TBL Program

normal

Module Twenty-Seven Equalizing Equations

The EQN Pre-Processor

Introduction Mathematical equations employing symbols and characters foreign to typewriters are usually hand-drawn for inclusion in papers and reports. With the text preformatters eqn and neqn you can have UNIX format extremely complex equations— regardless of whether they make any sense— allowing you to include equations in your written

work or

reports. wrcDO

Prerequisites Before working on this Module, you should be able (1)

Employ

(2)

Use

the visual editor to add text to a

nroff,

troff,

file;

and -ms macro commands

27

to:

0

and to

have

files for-

matted and printed.

Objectives After completion of this (1)

Module you should be

able to:

Write instructions necessary to properly format a wide variety of mathematical equations;

445

Have equations numbered, centered

(2)

as figures, or included in

the body of text; and

Make

use of eqn reference materials to solve cated equation formatting problems.

(3)

more compli-

Procedure format mathematical equations including a very wide variety of mathematical symbols— providing you include the proper instructions. Although this process is designed primarily for use

UNIX

will

with

more

versatile output devices

(such as a phototypesetter or

with graphics capabilities), basic equations .employing only keyboard characters can be displayed on a terminal of modest intelligence or a standard line printer.

terminals

This Module is in two sections. In the first, simple equations that can be displayed on most terminals will be employed to illustrate the general formatting processes. The second section will demonstrate several more complex examples which you will probably not be able to view on your terminal. Normally you will need to use a typesetter or similar device

(See

Module Nineteen:

to

properly format these equations.

Phototypesetting with Troff for

more

infor-

mation about typesetting.)

Single Line Equations

(1)

(2)

Basic Formatting Steps: Log onto your UNIX account. When the Shell prompt is presented start a new file called eqn, example. Enter the following two lines

in the file:

.PP This

Then

file is

an example

for equations.

enter the following three lines:

.EQ 6 times 5

.EN

446

file

eqn

=

30

The .EQ

is

a one-way

command

that tells the pre-formatter an

The conclusion of the equation specifications is marked with a .EN instruction. As with all formatting commands, the .EQ and .EN must be on lines by themselves and must start with periods. Whatever is typed on

equation

begin with the next

between the two commands

lines

(3)

will

line.

will

be formatted as an equation.

Formatting Files that Include Equations: To have the terminal display your eqn. example file with its formatted equation, you should return to the Shell and enter the following:

neqn

The

\

eg n.exa triple]

nroff \

-ms

|

resulting equation should appear centered

®

page

on your screen

as:

6x5=30 (4)

The neqn program formatting package. specific

commands

is

a preformatter for nroff with the It

-ms macro

translates your equation instructions into

that can be formatted by nroff.

Thus the

file

be sent to neqn and then piped to nroff. (In the above example, the formatters replace the word times with a multiplication sign, and then properly center and space the equation.)

must

first

designed to do the best possible job of formatting equations for terminals and line printers, given the constraints of available characters and full line spacing on most

The neqn preformatting package

is

terminals.

could just type 6x5 = 30 without ever invoking the preformatter,” you say. True, but the keyboard characters and spacing capabilities of most terminals would make the following equation a ‘‘But

I

tad difficult:

t

=

1.96

Although terminal display of such equations is seldom possible, you will soon be able to enter commands to have UNIX produce monsters like this one on a typesetter.

eqn

447

When

be produced on a typesetter (and not a line printer or your terminal screen) you enter the identical formatting commands in your text, but a different preformatter is employed. The troff preformatter is named eqn, while neqn is the nroff preformatter. The eqn preformatter interprets the same formatting commands, but in a way to take advantage of the wide the final output

is

to

range of symbols and spacing capabilities provided by a typesetting

machine.

When

neqn interprets the formatting commands, it uses the keyboard symbols to approximate as well as possible the mathematical symbols requested. As could be expected, the neqn interpretation of the formatting nals

(5)

is

commands

as printed

on

line printers

and termi-

often less than satisfactory.

you employ the -ms macro package with either nroff or troff, equations are centered on a page unless you instruct otherwise. To have the equation placed next to the left margin of the text, replace the .EQ with .EQ L (as in the fol-

Placement on the Page:

If

lowing instructions):

.EQ L 5 times 6

=

30

.EN The

resulting equation appears at the left margin:

5x6=30

(6)

Equations can be indented from the left margin much like paragraphs. To have the equation indented, use the starting command .EQ I (I Indent) followed by the content of the equation. For example:

.EQ

I

5 times 6

=

30

.EN The product, upon formatting,

5x6=30

448

eqn

is

in

an indented equation:

(7)

Identification: Equations can also be

numbered

or labeled.

Con-

sider:

.EQ (Equation-A-) 5 times 6

=

30

.EN The above

set of instructions

produces the following labeled equa-

tion:

5x6=30

(8)

(Equation-A-)

no spaces in the label. The formatter is programmed to accept only one “word.” If you do want a space character in a label (such as “Equation A”) you must specify the space with a backslash and zero \0 such as:

Note

that there are

.EQ (Equation\0A) 5 times 6

=

30

.EN The equation

with a space in the label appears:

5x6=30

(9)

(Equation A)

Inclusion within a Line of Text: The process of placing equations within a line of text text is slightly more complicated. First, the formatter must be informed of the symbol you are using in the text to indicate where an equation is to be included. Then it must

be given equation formatting instructions. signs can be used as an equation delimiter lines are entered in a file:

For instance, dollar if

the following three

.EQ delim $$

.EN Once

the formatter reads to the above lines

equation instructions

all

text located

it

will

then treat as

between two dollar

signs,

eqn

even

449

they are in the middle of a line. This process makes it possible to place equations in the middle of a line of text. The following if

line in a file:

Simple equations such as $5 times appear formatted

will

if

you need

=

30 $ can be included.

as:

5x6=30

Simple equations such as

What

6

can be included.

normal purposes? To do so you enter:

to use a $ for

have the delimiter turned

off.

its

You must

.EQ delim

off

.EN

Advanced Equations Using Mathematical Symbols The

following examples will not look very satisfactory on most ter-

minals.

the eqn

You should

enter

filename

you are not familiar with the

Nineteen: Phototypesetting with

to

troff \

then send them to -ms for formatting and file,

do

this will be:

-ms

troff text

processor see

Module

Troff.

Available Symbols: Table 1 presents a list of symbols available on eqn. They are approximated as closely as possible by neqn for line printers

(2)

your

The usual command eqn

(1)

into

preformatter, and then to troff

phototypesetting.

If

them

and terminals.

Marks: Quite often an equation requires that a vector, bar, underline, and other diacritical mark be placed on top or below letters or symbols. The commands which create Use

of the Diacritical

these effects are bar, dot, dotdot, dyad, hat, tilde, vec, and under.

The

450

selected

eqn

command,

if

placed after any letter, symbol, or

word

Table

1

Symbols Available with Mathematical Symbols Input

eqn

Greek Letters

Results

Input

Results

DELTA

A



GAMMA

r

grad

V V

LAMBDA OMEGA

half

'/2

PHI

n o

inf

oo

PI

n

int

I

PSI

approx cdot del

n

inter

SIGMA THETA

nothing partial

prime prod

I

UPSILON

d f

A

0 Y

XI

Tl

alpha

a

sqrt

V

beta

/3

sum

I

chi

X

times

X

delta

8

union

u

epsilon

e

eta

V

gamma

y

iota

L

« »

kappa

K

lambda

\

±

nu

V

omega

OJ

omicron

o

pi

7T



->

+ = —— -

mu

1

>

• • •

1

= >







>

rho sigma

P

X dotdot

X X X x

tau

T

X hat

A JC

theta

9

upsilon

V

X bar X

under

X dot

X tilde

X vec X dyad

X X X

psi

a

xi

zeta

c

eqn

451

the formatting instructions, will position the mark appropriately equation. in the output. This is demonstrated in the next

in

.EQ X hat

Y

+

dyad



OMEGA

under times

+

word vec

A

tilde

+

y dotdot

.EN The above

material produces symbols with diacritical marks:

X

(3)

T T—

_n X

word

+ A +y

A

wide range of equations is possible using the mathematical symbols, Greek letters, and words. Consider:

Greek Letters:

.EQ union 24 apples

+

dough

+

spices

->

4 PI

.EN The above instructions— when properly baked by

the formatter-

produce:

IJ 24apples^dough-\-spices^4U

Of course,

a corollary

is:

*

.EQ int 4

PI

+

4 people

-> approx

4

SIGMA

I

K

people

.EN

J (4)

452

4Y\-\- 4 people—^^41.1 Kpeople

Spacing and Lines: Before we enter more complicated equations it is necessary to describe how the eqn and neqn preformatters handle spaces between words, characters, and lines.

eqn

(a)

Spaces are used to delineate the “pieces” of an equation. For instance:

.EQ 5

OMEGA

times 6

= sum

+ LAMBDA

x dot

.EN is

formatted

as:

50 x6=^;c+A If

some of

the spaces are not included:

.EQ

50MEGA

times 6

= sumx

dot

+ LAMBDA

.EN the formatted equation

comes out looking

quite different:

IOMEGA x6=5w/7ix+A When

comes

50MEGA

does not recognize the string of characters as code for any symbol, so the string is printed out as is. Likewise, because sumx is not in its the formatter

repertoire,

the

sumx

is

to

printed.

it

Then eqn

follows the dot

instruction by placing a dot over sumx.

Summary: Spaces

are essential for the formatter to recognize

each part of instructions.

(b)

Extra spaces are ignored:

.EQ 5

OMEGA

times 6

=

sum

x dot

+ LAMBDA

.EN is

formatted with proper spacing:

5n x6=]^xTA

eqn

453

I

(c)

Use the

tilde

equation.

~

if

you want extra space included within an

For instance:

.EQ

OMEGA ~ LAMBDA ~

5 '

times

^

~

6

"

sum

~

x dot

'

+

.EN produces a spaced equation:

5

0x6=

Notice the differences

formatted

(d)

in (b)

and

in

+ A spacing between the equations as

(c).

example of diacritical marks (procedure step 2) each element was placed on a separate line, yet the output appeared as one ‘‘equation.” That is possible because the formatter treats spaces between words and the ends of lines simply as the “edge” of symbols. Thus one equation can be entered on In the

several lines in a

file.

To

offer another

example,

.EQ 5

OMEGA

sum

times 6

X dot

4*

LAMBDA .EN

.

continues to produce:

50 x6=51-^4-A This multi-line input property of eqn is especially useful trying to keep your formatting wits about you.

454

eqn

when

More Complicated Equations

Yet This

element examples of more difficult to format equations. The first seven steps describe how to effect changes in vertical spacing, such as: section

introduce

will

single

6x 3

Later

steps

together in

how

demonstrate

bracket

to

elements

which

go

more complex examples: 6U-f3)

(5)

Exponents: To have an exponent or sui^erscript added number, letter or symbol, the sup instruction is used.

to

a

For

instance:

.EQ

A

sup

+ B

2

sup

2

= C

sup

2

.EN produces a superscripted equation:

^2+52 = (6)

(^2

Subscripts: Likewise, subscripts are formatted with the sub instruction.

For example:

.EQ

X

sub

3

+ Y

sub

j

“ Z

sub

ii

+ R

sub alpha

.EN

Upon

formatting,

the

above instruction produces

a

subscripted

equation:

eqn

455

(7)

Subscripts and Superscripts: If you want both a subscript and a superscript on the same symbol, the subscript must precede the sup^/'scr/77nnstruction (alphabetical order). For instance,

.EQ

Y sub a sup 2 + X sub b sup alpha = Z sub garbage sup

3

.EN is

the instructions for sub and superscripted symbols:

ya_73

y2i ^

^garbage

a

Reversing the order of sup and sub results

in a

very different out-

put.

.EQ

Y sup 2 sub a + X sup alpha sub Z sup

b

=

3 sub garbage

.EN produces the following equation with subscripts on the superscripts:

2 ^garbage

y

(8)

Fractions:

The magic

instruction to format fractions

sider:

.EQ 30 PI over 6

=

5 PI

.EN will

produce:

30^=5n 6

456

eqn

is

over.

Con-

(9)

Limits:

Statistical or

mathematical equations

of limits on symbols such

etc.

as:

may

require the use

For example:

.EQ

Y =

from 0 sum from

int

^

to 1 1

~

x

dx

N

to inf

~

~

1

.EN The following

The

limited equation

from

instruction

is

produced:

identifies the lower limit

and

to identifies the

upper. (10) Brackets, Braces, Parentheses, large parentheses

tions

and

left

and Bars: Equations often require

around whole sections of symbols. The right

when

associated

with

brackets

and bars (the pipe) include an appropriately large symbol

parentheses

(

formatter to

),

braces

I

I,

instruc-

\

will \

{

),

cause the

in the output.

For instance:

.EQ left

A

(

over 6 ~

~

right left

)

{

3 over sqrt b right



-

~

}

left I

X dotdot over y sub alpha right

I

~

PSI

.EN The above

instructions produce:

eqn

457

(11)

Grouping Parts of Equations: What you have learned thus far will permit you to format a wide variety of equations. Problems arise, however, when it is necessary to use several elements following a format instruction (such as over or sup). Consider: ^cos a +

/

This looks like a simple figure to format. most people try is:

The

first

solution that

.EQ e

sup cos

~

alpha



+

~

t

.EN But the computer does not know that all of cos, alpha, and + t are to be placed as the exponent. In fact, it is programmed to superscript only the next symbol. As a result, the formatter produces an errant: ^cos

The way together.

^

J

avoid such surprises is to bracket symbols that go You must use, of all things, brackets { } .

to

For instance, the format instructions:

.EQ e

sup {cos

~

~

alpha

t}

.EN uses brackets to enclose those elements that are all to be placed in the exponent. The resulting output is appropriately superscripted: ^COS a

+

t

communicating with the formatter. In the previous section you were introduced to brackets

The brackets used

in this section are for

formatted equation to assist the reader. The difference is in the instructions left and right. If the bracket is used without left or right, it will be read by the formatter only as which were printed

458

eqn

in the

bracket

is

elements which

those

identifying

discarded.

together,

stay

the left or right

If

and

command

then

the

precedes the

bracket, the formatter will include the appropriately sized bracket in the final output.

(12)

Examples

of

Complex Equations Using Brackets: Each of

the fol-

lowing equations includes brackets that identify entire sections of the equations which need to be treated as units. Any complex group of symbols, letters, and numbers, if surrounded by brackets, can be used where just one symbol normally would be used. ations of the previous examples are:

Vari-

.EQ (Example\OA) {6

(x

-f

3)}

over {sqrt (3

+

X bar)}

.EN 6(x--h3)

(Example A)

V 3+x .EQ (Example\OB) {6

{(x

+

(sqrt (3

3)}}

+

e

over

sup (cos alpha}}}

.EN 6(x-h3)

.EQ (Example\OC) alpha Y~ =~ int from B sub (alpha sub 1} {

,

(Example B)

1}

to

{

delta

,

3}

+ C sub (beta sub 2} + D sub (delta sub 3} — (x + y -b z} bar .EN 8,3

y

=

J

(Example C)

eqn

459

.EQ (Example\OD)

Y {{

~ ~

~ ~

sin {(

omega

from

2 pi int t

+

to inf

1

6)}}

over {3 alpha}} •

dt

.EN oo

sin(ajr+6)

r

(Example D)

3a:

.EQ (Example\OE) ~ t

{X bar sub E ^

AT

X

bar sub C} over {sqrt {S sub X sup 2 left ( 1 over {n sub 1} •

=



~

-b

~

over

1

{

sub

2}

right

)

1.96

.EN

(Example E)



.EQ (Example\OF)

Y

=

-

sum from {

OMEGA

(i

4-

=

0}

3.7}

sqrt {alpha sub 1

to

{i

=

inf

}

over

+

beta sub 1}

.EN

r

'y /=o

n-h3.7

(Example F)

}}

.EQ (Exainple\OG)

=

sigma sup 2 ” 1 over k sup 2 sum from i = l left

1

"

to

k

(

over n tilde sub ~

over

delta sup 2

2m

{

right

i

sub

i

}

)

.EN 6

2

or

^

(Example G)

2m,

.EQ (Ex.\0H) {left

sup 2

+

(

{xi

}

over x sup 2

I

nu sup

2

}

over sqrt 6

right

1

}

"

sup 3 left

=

~

(6 sqrt (3 z times

I

OMEGA}}

over

Z sub nonsense •

-

41

+

-

right

1

psi hat

times left (

a

(

+

right

b

+

c

}

bar

)

.EN 3 1

6V3zx n

V6 x'

(13)

1

z ^nonsense

Arranging Several Symbols bols or

-41

(Ex.

a-\-b-\-c

in a Display: Vertical arrays of

numbers can be formatted with

example of

X

±\jj

this effect begins the

the pile

H)

sym-

command.

An

eqn

461

next page.

The

following instructions are interpreted to produce an equation

containing a vertical array:

.EQ

OMEGA {W

right



left

[

above 2 above 3 above

pile {1

pile

~

X

above

above

Y

4}

above Z)

I

.EN

a

The next example shows how justified

1

w

2

A

3

Y

4

Z the ‘‘piles” can be

left

or right

and rpile commands. Note the placement of elements between the two columns in

by

using

difference in

the

the formatted version.

column; the beta

Ipile

The alpha

is

against the left of the

first

to the right in the second.

.EQ

OMEGA left

I

(alpha above (2.78 over A) above (x

Ipile

4

left

I

I

rpile (beta

right

above 5.32 above (a

+

I

.EN a 2.78

13

A

x+y 4A

eqn

y)

LAMBDA)

right

462

+

5.32 -h

a-\-b

b)

above PSI)

above

The

(14) Matrices: If

command

formats each column independently. you have an array of elements that vary in height in different

columns,

pile

will

result

make

ments

in all

columns.

at

all

being

spaced

columns and

entries in the matrix.

all

that there be the

is

An

look

will

spacing decisions based on

The major requirement

columns

different

in

The command matrix

differently.

then

pile

same number of

ele-

example:

.EQ matrix ccol

~

~

OMEGA

'

left

l{

{

{alpha above

(2.78 over

A

}

above (4 LAMBDA }) ccol (beta above 5.32 above (a -f b} above PSI)

+

above (x

y)

1

1

right

1

.EN a 2.78

5.32

A

x+y

a-\-b

4A

The in

instruction ccol results in the matrix elements being centered

The

each column.

elements

at

the

left

and rcol, which place the of columns, respectively. Another

alternatives are Icol

and

right

example (and the formatted equation):

.EQ

Y

-

matrix Icol

(

ccol

(

rcol

I

=

>

{

X Y Z

sub alpha above (153 + 2z) above .09 t) sub beta above (186 - 5n) above 1.3 s) sub gamma above (264 -f 3s} above 80 g)

1

.EN

1534-2Z .09/

186-5// 264+3^ 1.35

80.C

eqn

463

(15)

Type Size and Font Selection: Point

size

and type font can be

specified for individual characters in an equation or for

all

charac-

For any specific character the point size of the type can be specified by the instruction size [N] where N is a point size from 6 to 36. Here you see a 36 point Omega and 6 point “D”: ters.

.EQ size 36 pile

A

{

right

~

OMEGA above

~

left

I

B above C above

size 6

D

}

1

.EN

A

B C

by the 36 point type size specification. The formatter reverted back to standard (11 point) type for all symbols, until it encountered the next point size change command. The D was then specified to be in 6 point type.

Note

that

only

the

Cl

was

affected

In addition to point sizes, the fonts can be specified by: roman, italic, bold and fat. The fat specification makes the letter or symbol slightly

For instance, these instructions different fonts for each column:

“heavier” result in

in

whatever font

is

in use.

.EQ size 36 pile

OMEGA

"

=

~

left

I

{

italic

{A

+

14

r

sup

2)

above bold {B - 12 c sup alpha above roman {C 4- 43 d sub j above fat {D times 78 del sup 2 right

I

.EN

A-h\4r^

B-12c" C+43dj

Z)x78V2 464

eqn

}}

(16)

Changing the Exact Location

of

Symbols:

If

you are unhappy with

the exact placement of characters in the formatted equations in the

copy of your output it is possible to “fine tune” the placement of symbols. When we saw that the H in the above equation was not centered relative to the equal sign, we modified the format first

instructions as follows:

.EQ down 60 size 36 pile

OMEGA

~

^

left

I

{

{A

italic

+

14

r

sup

2)

above bold {B — 12 c sup alpha} above roman {C + 43 d sub j } above fat (D times 78 del sup 2 }} right

I

.EN The

resulting formatted display has the

Omega

properly placed:

A-hl4r^

B-

1

2c"

C+43dj

DxlSV^ The down

Number]

command

symbol or brack-

In this case the instructions

about the size of the letter (in this case 36 point), the O

is

In addition, \

affects only the next

down 60 call for the omega be moved down 60 one hundredths of an “em.” Since an “em”

eted unit. to

\

the

m is

commands up

whatever type is being employed lined up with the equals sign.

in

\

Number]

,

back Number] \

,

and fwd

Number] will re-position the immediately following symbol.

(17) Global Font or Point Size Changes: The eqn formatter will type all equations in 10 point type unless you specify otherwise. You can

any point instruct the formatter to employ a different basic point size (or type font), which will be used until you specify another. (For more information on this process see the number registers section Module Nineteen: Phototypesetting with Troff.)

at

eqn

465

The

global

command

to affect the point size of the equation

The not the surrounding text— is gsize \Number\ [7^ is used to specify the font (where \Font\ is .

Roman). For

command Italic,

— but gfont

Bold, or

instance:

.EQ gsize 14

gfont italic

==

omega

from here

int

to eternity

LAMBDA GAMMA EPSILON .EN produces an

italic,

point size 14 equation:

eternity

APE

(JL>=

here

Changes specified.

sees

fit.

and font remain in effect until a new one is The size and font may be changed as often as the author These changes affect only the equation and not the sur-

in point size

rounding

text.

Obtaining Output: Typeset:

mand

If

the output

is

be typeset, the Shell execution com-

to

is:

eqn Line Printed: execution

If

the output

command

troff

,filename\

is

to

line printer, the Shell

be sent to a

is:

neqn

[filenamel

nroff

-ms

Ipr |

with eqn: If tables are also included preformatter should precede the eqn process:

Using

tbl

tbl

466

eqn

®

-ms -Q

[filename]

\

eqn

troff |

in the file, the tbl

-ms -Q

Using refer and are included in a

cessers

with eqn: If tables, references, and equations file, the proper order for using all three prepro-

tbl

is:

refer -p database

filename

eqn

tbl

-ms -Q

troff

®

Command

sequences include a -Q for placement of the job in the troff queue. If your installation uses some other troff queue procedure, remove the -Q and substitute the proper argument. Note: Three of the above Shell

Detecting eqn Format Problems: UNIX maintains a program which

check your equations for formatting errors. Before you have a paper containing sophisticated equations formatted you might want to let checkeq review your work. The program isn’t foolproof, but it can be of some help pointing out possible trouble spots.

will

The

Shell

command

line to

use checkeq

checkeq

filename

Additional Reference Material:

Two

is:

page pamphlets

in

wide distribu-

tion are:

TBL— A

(a)

Program Laboratories, and

(b)

Typesetting

to

Format Tables, by Lesk, published by

Mathematics— User’s

Guide,

by

Bell

Kernighan

and

eqn

467

Cherry, published by Bell Laboratories.

Module Twenty-Eight Troubleshooting

Introduction Problems encountered while using UNIX are both frustrating and not uncommon, owing in part to the complexity and power of the system (and the vagaries and moods of any electronic beast). This cannot be a comprehensive section, due to the incredible variety of We have, however, errors possible with the UNIX system. attempted to address the more common problems encountered by us and the many UNIX users with whom we have worked.

Prerequisites Before using (so,

what

this

else

is

Module you should have encountered

a

problem

new?).

Objectives After reading the diagnostic section of this Module you should, in many cases, be able to locate the appropriate remedy for your

problem in the second where to start).

468

part of the

Module

(or

have some idea as

to

Procedure The procedure section of this Module is presented in five parts. The first section is designed to help you diagnose your problem. you to the the Module where the remedy to your

This material should be read carefully, as appropriate location (s) in

it

will direct

problem may reside. The remaining four sections include descriptions of the most common problems we have encountered and our These problem-remedy paragraphs are suggested solutions. presented in four major groupings: /

Problems Logging On;

-

II

Unexpected Formatted Output;

-

and Error Messages; and

III

-

Shell Problems

IV

-

Editing Problems.

Each of these groupings begins with an index to the problems it addresses. The diagnostic section will refer you to the appropriate solution section.

The lier

section entitled Resetting Your Terminal Type referred to in ear-

Modules

is

part (H) of section

IV

-

Editing Problems.

Diagnosing the Problem working with UNIX you know you’ve got a problem when something unexpected happens (why did that funny message appear on my screen while I was editing this file?) or when you accidently do something resulting in an expected, but undesirable outcome (why did I delete the first thousand lines from the report To begin diagnosing your problem you I just finished editing?). should consider in which category your problem falls:

When

(1)

you are experiencing difficulty logging on the system, proceed directly to the first problem-remedy section

Problems Logging On: to

of this

(2)

Module

If

entitled Problems Logging On.

Unexpected Formatted Text Output: If your problem unexpected output of formatted text proceed to the problem-remedy section: Unexpected Formatted Output.

Troubleshooting

is

with

second

469

(3)

The other unexpected or undesirable Module can be classified as occurring either

Shell or Editor Problem:

events covered

in this

while you are interacting with the Shell or with an editor.

you know you were interacting with the Shell when your problem occurred proceed to the third problem-remedy section of this Module entitled Shell Problems and Error Messages. If

If

you were

in

an editor

occurred proceed to the

Mode when

final

the troublesome event(s)

problem-remedy

section: Editing Prob-

lems.

you are not sure where you were when the trouble began continue to procedure step (4), which follows. If

or

RUB

DEL or logged on you should press the |DEL

RUB

DEL

(4)

key can be your If

you are

light

still

through the darkness,

key.

nothing happens you are probably no longer in communication with UNIX. This means that either your keyboard has locked up, or the system has crashed or that you have in some other way been disconnected from the system. In this case we can offer little assistance and suggest you locate an experienced user near by or talk to whoever administers your local system. (As software types we can only offer the time honored response, '"Hey, what can I If

say? That's a hardware problem."')

communication with UNIX when you pressed the DEL or |rub| key one of three things probably happened:

If

you were

in

I

The terminal' "beeped". You are in the visual editor. If you were in Command Mode, you were left there and the beep sounded. If you were in Append Mode you were move d to Command Mode and the beep sounded. (The |DEL| key

works

Mode

like the |ESC| key, in that if

minal to (b)

moves you

to

Command

you were in Append. It will, however, cause the beep regardless of which mode you were in.)

ter-

The word "Interrupt" appeared on the screen. You are in the line editor. If you were in the Append Mode, you have been moved to Command. If you were in Command Mode, you

remain there.

470

it

Troubleshooting

A

(c)

process.

mark appeared on the screen. You were in a Shell By pressing the |DEL| key you ended the process

(killed

and are presented with another Shell prompt.

question

it)

At this time you should know were you are and have two choices about how to proceed. If you feel like your problem is solved — and have no need for further information — then continue with your work. If you desire to know more about the troublesome event you should examine the index of the appropriate problemremedy section of this Module and read the related information.

Organization of Problem-Remedy Sections: Each of the following problem areas is divided into symptom categories {A,B,C, etc.). Each symptom has listed under it one or more possible causes. The proposed remedies (identified with a •) are placed below each of the symptoms.

Section I

-

Problems Logging

On

INDEX (A)

No Cursor

(B)

Strange Characters Appear on the Screen

(C)

Cannot Get Logged In

(D)

No Login Banner

PROBLEMS

and

REMEDIES

No Cursor (1)

Brightness turned down, or terminal in,



is

not on,

not plugged

or in need of repair.

Make

turned up, switch is on, the terminal is plugged in, and you have given it 15 seconds to warm up. If still no cursor appears, try another terminal and report the problem. sure the brightness

is

Troubleshooting

471

(B)

Strange Characters Appear on the Screen Switch settings of terminal are wrong.

(1)

• Try a dilferent terminal. • Examine a similar terminal for proper settings.

Terminal

(2)

is

receiving noise from line or

modem.

• Try a different terminal. • Logoff (hangup phone and/or turn off the modem). second time.

Logon

a

• Report problem for service.

(C)

Cannot Get Logged In Error

(1)

made

in

entering either the login or password.

• Carefully enter each “word,” leaving no spaces between the characters in your login and password. There probably are no upper case letters or spaces in either (upper vs. lower case is critical).

The system does not recognize

(2)

either the

password or

login.

• First be sure you are correctly entering the “words.” Then check with the system administrator to be certain that you have an exact copy of a working password and account login.

(D)

No Login Banner (1)

Dead

connection with UNIX central.

• Try another terminal.

• See

if

anyone

else

is

logged into your system.

• Call the system administrator. (2)

System went down.

• Scream,

472

cry,

Troubleshooting

go play tennis; see system administrator.

Section 11

Unexpected Formatted Output

-

Many

formatting problems can be identified in advance of actually formatting the file by employing the check nxoff program. From the Shell enter checknr filename to locate potential problems.

Module Nine

for

more information about

See

the checknr program.

INDEX (A)

No Output

(B)

Margin

(C)

Extra Underlining

(D) Text (E)

Is

Not Where

Not

Is

Should Be

Filled

Missing Text

PROBLEMS (A)

It

and

REMEDIES

No Output Entered incorrect

(1)



Make

certain

command

the

Shell

line.

command

contains

all

the

proper

has the appropriate arguments (each separated by a space), and that the command line calls for the right

pieces, that

it

filename.

(2)

Logged out before job was finished.

• Unless your account is set up to continue work after logging out you should not do so until all processes are completed. Module Seventeen: Backgrounding a Process describes how this can be done. (3)



File contains

unbalanced

.DS, .KS, etc.

have a Table Start without a Table End or a Keep Start without a Keep End? Pairing these commands is essential. Check that you have not forgotten to match each .FS, .DS, or .KS with a matching .FE, .DE, or .KE.

Do you

Troubleshooting

473

(B)

Margin

Should Be

It

has unbalanced indent requests.

File

(1)

Not Where

Is

• Check that for each .RS there

is

.RE

a

to return the

margin

to its original position.

File includes

(2)

mixed .RS and

.in

formatting commands.

• These commands do not access the same number registers. Thus, indenting can quickly become fouled up when both are used. For this reason you should stick with one or the other. Error

(3)

in specification

of margin.

• The units you use are

critical.

For instance,

five spaces, while .in 5i indents five inches.

5P

.in

(C)

(pica)

does not equal

.in

.in

To

5 will indent

the formatter,

5p (points).

Extra Underlining

An

(1)



unbalanced one-way underline

command

used.

probably began underlining with the .1 command. You must return to non-underlining status with the .R command.

You

(When

using nroff both the .B and .1 result in underlining.) In addition, section headers are underlined if you use the -ms

macros.

(D)

Text

Is

Not

Filled

Unbalanced nroff requests.

(1)



You

probably inserted a .nf to isolate a block of unfilled text,

and did not include the matching Text does not begin at

(2)



A

line

left

.fi

command.

margin.

of text which does not begin

at

the

result in a blank space in the formatted text. lines in

(E)

file

begin

at

the

left

margin.

Missing Text ( 1 )

474

your

A

text line begins with period or apostrophe.

Troubleshooting

left

margin

Check

will

that

all



An

input line beginning with a period or apostrophe

is

con-

sidered by the formatter to be a formatting instruction and not text.

Make

certain that the missing text

is

not on a line begin-

ning with a period or apostrophe. Illegal text

(2)

included on a formatting

is

• Although a few formatting (.IP

commands

command

line.

take text as arguments

Any

(A) for instance), most do not.

text placed

most formatting requests will be ignored. instance, this input line would not print:

line

with

.ul distinguished scholars

Section III

-

Pulos and

Shell Problems

on

a

For

Chang

and Error Messages

INDEX (A) Messages Appear on the Screen

My

Prompt?

(B)

Where’s

(C)

Lost in a Directory

PROBLEMS (A)

and

REMEDIES

Messages Appear on the Screen (1)

Command

not found.

• Usually means the (2)

command name was

misspelled.

Cannot open filename.

• Usually means the filename you included in a command line is not in your current directory, or you incorrectly typed the filename. (3)



Broken

You

Pipe.

probably deleted the job while

it

was being executed.

Try reissuing the Shell Command (or, if wealthy, call a plumber). May also occur if the Shell must break a process for any reason (for example, if you route a formatting job into an already t\\sX\ng filename) Troubleshooting

475

Stopped.

(4)



note reading Stopped appears at the bottom of the screen, along with the Shell prompt, press these keys: If a

®

fg

(The source of your problem was pressing of the CTRL-Z key, which places a process into the background and gives you a Shell prompt. The command fg means lore ground, dind pulls this backgrounded process into the foreground.) There are Stopped Jobs.

(5)

• Will occur when attempting to logout and you have put a job into the background (with the CTRL-Z command). See (4) above.

Permission denied.

(6)

• Usually indicates you forgot to include the command in the command line. You probably entered a filename alone rather than a Shell command followed by 2 filename. i

you specified does not have execute permission. You must change the mode of a file to 700 for it to be executed. See Module Twenty-Two: Commands, Files, and Directories.

• The

(7)



(8)

file

Core dumped. was abnormally terminated. A file named core, containing an image of core at the time of termination, You may remove this core is added to your home directory. file and suffer no ill effects.

A

Shell process

Usage:

.

.

.

• Indicates incorrect use of Shell command (i.e., too few or too many arguments). For example, if you use cp with only one filename in the command line you will get a message something like the following:

Usage: cp fl f2; or cp [

Attempt

-r

] fl

to decipher the cryptic

to use the

command

and enter the correct Troubleshooting

... fn d2

message

(and just

made

command

line.

or, if

you know how

a typing error), ignore

it

(9)



No

match.

You were

probably using a filename expansion character to locate a file. No filename exists in the current directory that fits the expanded file name as you specified it. See Module Sixteen: Account

(B)

Where’s (1)



My

Stuck

in

Management

Activities.

Prompt? a Shell process.

you entered a Shell process (such as Mail or write) you (See will remain there until you end it. Try using a CTRL-D. Module Fourteen: Communicating with Others for assistance with Mail and write.) If

• Other Shell commands can have a similar effect. If you entered vi without specifying a filename, the visual editor will be invoked. You will be in the Command Mode, and can return to the Shell by entering :w filename (to save the file material) and

(C)

ZZ,

or :q! (to trash

it).

Lost in a Directory (1)

Do

not remember which directory

• Enter (2)

Want

pwd

to discover

• Enter the cd Shell

Home

in.

your current “working directory.”

Home

to return to

you are

directory.

command and you

will

be placed

in

your

directory.

Section I V

-

Editing Problems

INDEX (A) Deleted

Wrong Text from

(B)

Made

(C)

Display Went Blank

a Complete

(D) Display (E)

Is a

Mess

File

of File

Word Salad

Messages on Screen

Troubleshooting

477

(F)

Strange Characters on Screen

(G)

Numbers and Text Crammed Together

(H) Arrow Keys Don’t

Work

Correctly (Resetting

Your Ter-

minal Type) Cursor Skips Lines

(I)

PROBLEMS (A)

Deleted

Wrong Text from

and

SOLUTIONS

File

And you

(1) (2)

tally

have not entered another removing the text.

• Press the u key one time. last modification to the file.

You deleted the retrieve

text

This undo

several steps

since acciden-

command undoes

the

back and u does not

it.

(3)

• The visual editor saves the buffers

command

numbered

1

to 9.

last

To

nine

(9)

text deletions

access these buffers type

in

"#p

(double quotes, [1-9], p). If the desired text does not appear, type u (for undo), and then press the period (.) key. You can repeat this procedure (u.u.u.) until the desired text appears. See Module Thirteen: Truly Advanced Visual Editing.

Error was too far back for numbered buffers. •

you would rather go back to how the file was before you began this editing session (or last typed the :w command) you can return to the Shell without writing the present version onto the permanent memory. To perform

You have

a choice: If

this action

you:

First press the |ESC| key;

(b)

(B)

Made (1)

Second type :q! and you will return work of that editing session vaporized.

a Complete

May

Mess

of File

be caused by a variety of reasons.

• See (A) 3 directly above.

478

Troubleshooting

to the Shell, with

(C)

Display Went Blank (1)

You pressed ctrl-Z and stopped

• See Section III

(D)

Display ( 1 )



Shell Problems paragraph

From

the

(Z minus



(4)

Stopped.

be caused by a variety of reasons.

Command Mode

press these keys

®

z-

(2)

A

Word Salad

Is a

May

-

the process.



^

clear

and redraw the screen).

Your terminal needs

to

be

reset.

your screen regularly fouls up during an editing session (one common problem is text in your file cramming up against the line numbers displayed on the screen) try the folIf

lowing: Place yourself in the Shell, type

®

reset

and then again attempt

(E)

to visually edit a

file.

Messages on Screen (1)

Could be a note about completed process or a from another user.

write

message

• See Section III - Shell Problems for a description of various screen messages. •

message from another user, you might want to write back. See Module Fourteen: Communicating with Others.



If

If

it

a

you are

rid

(F)

is

of

it,

staring at a

message from UNIX and

just

want

to get

enter z- to redraw the screen.

Strange Characters on Screen (1)

Screen displays characters such as

"

PT f IC L.

Troubleshooting

479

You

probably tried to

while in the

move

Append Mode.

the cursor (using the arrow keys) These are th e control characters

Command Mode. Remove

move

Press |ESC| to

those keys.

associated with

into

the

the control characters, and con-

tinue your work.

(G)

Numbers and Text Crammed Together Momentary power outage

(1)



or other terminal disruption.

there was a power failure-— or you momentarily turned the terminal off— the text may be jammed against the editing If

numbers. Enter: (1)

(H)

reset

Arrow Keys Don’t Work Correctly (Resetting Your Terminal Type)

Login •

You

error.

probably

made an

error in informing

terminal you are using. enter the

command

To

command

will,

give yourself a second chance

(don’t forget the dot in .login):

source

This

UNIX of the type of

among



login

other things,

tell

UNIX

to ask

you

once again what type of terminal you are using. Refer to the section Accessing the UNIX System in Module Two for help with this step.

(I)

Cursor Skips Lines (1)

You did not use

® at the end of each

• What appears to be a discrete tion

of the prior line(s).

two or more screen

lines.

A

line

line.

of text

is

in fact a continua-

single very long line

You

is

occupying

probably noticed while entering

the text that the cursor automatically returned to the

of the screen; thus you did not press the

®

key.

left

The

side

result-

one line to the editor. Place the cursor on a space between two words, press r and the key, and the line will be divided into two lines. ing several lines of screen text are in fact only

®

480

Troubleshooting

Module Twenty-Nine

Where

to

Now?

Introduction Congratulations!

You have reached

the

Module in this book. of the UNIX operating syslast

So far, you have been using the features tem that we identified as most important for text processing and program writing. There are several other, more complex features also available on most UNIX systems which this final Module will briefly introduce. References will be provided for more thorough investigation.

• Prerequisites Before starting this Module you should have completed Modules One through Twelve. rnrcoog

Objectives 29 Upon completion

Module you

have introductory knowledge (and be able to access the appropriate documentation to learn more) about the following UNIX programs and resources:

(0

Sec/,

a

of

this

stream editor similar

in

will

command

syntax to the ex line

editor; (2)

a pattern

scanning language;

»

481

^ ^

(3)

Shell programming,

a

method used

create powerful Shell

to

scripts; (4)

C-Language,

the

programming language

in

which UNIX

is

written; (5)

data-base

a

Ingres,

management system

on some

available

UNIX systems; (6)

ISP and

(7)

Writers'

S,

and

interactive statistical packages;

Workbench,

a

collection

of programs

increase the overall effectiveness of written

work

designed

to

(particularly

helpful with technical writing).

Procedures This procedure section is presented in seven parts. In each section you will be provided with a brief description of a selected UNIX resource. Several of the descriptions include examples. You may wish to try out the examples presented, but this is not essential for understanding.

Sed, the Stream Editor Sed ex

is

an editor which performs

line

many

of the same functions as the

The

but in a different manner.

editor,

line

editor,

ex

command of a series to all lines in the file. Then second command is applied to all lines, etc. Sed, which is a

applies the first

the

stream editor, works

commands

to

one

next line of text,

line

in the

opposite way.

of text, then

it

It

applies

applies all

all

specified

commands

to the

etc.

The Sed editor is most useful when included in a series of ‘‘piped” Shell commands, because it performs its functions on the standard output to the standard output (the standard input and output were described in Module Seven). input and routes

its

For example, the following command sequence will format the file named test, remove all blank lines from the input, and send this abridged text to the page command: nroff

Where

to

Now?

-ms

test \

sed V"$/d'

1

page

®

Note how sed uses language

a

command

syntax very similar to the ex editor

(in this instance the special editor characters

Sed— A

Documentation:

Non-interactive

Text

and

Editor^

$).

from

Bell

Laboratories.

A wk, Awk

the Pattern

a pattern scanning language.

Scanner

very useful for performing more complex searches than are possible with the ex or sed editors. In addition, awk can be used to write simple programs which do not require detailed specifications. is

It

is

For example, the following procedures could be used to select from a large file all individuals taller than 70” who wear shoes larger than a size eleven: (a)

Create a

file

(referred to here as data) containing the per-

tinent data:

name

height

shoe

Paul-Johnston

71

Harold- A tkins

72

10 12

H- Dan-Smith

73

Lyle-Strand

70

10 10

Walter-Mitchell

73

9

Each of the above lines contains three pieces of data. In this example each record is on a line by itself and each datum is separated from the others by blank spaces. (b)

Create a second program: {if

(

file

(here called program) containing the

$2> =70 && $3> =11)

print $1

awk

)

“find the record(s) that have a second field (data point) greater than or equal to 70 ($2> =70) and

This line translates

(&&)

as,

a third field greater than or equal to 11

these cases print the

first field

($3>=11) For

(print $1).“

Where

to

Now?

483

A

Enter the

(c)

that instructs the Shell to execute the

command

in the file

awk program contained tained in the

file

data:

awk In our results

program on the data con-

-f

program data

®

example this Aw^k program would display the following on your screen: Harold- A tkins

Documentation:

from

Awk—

Bell Laboratories.

Programming

Shell

Shell

and Processing Language,

Pattern Scanning

programming

lies

somewhere

gray area between using

in the

pre-packaged software and actual programming. It offers a method and for adding programming control structures (e.g. if statements) setting variables in order to create powerful Shell scripts.

For example, the following Shell program would cause the Shell to evaluate whether or not a file contained any tables and would format the file according to this evaluation. (The program must be placed

into

Commands, able (a)

a

and made executable. Module Twenty-Two: and Directories describes Shell scripts and execut-

file

Files,

files.)

Place the following lines holding the Shell program into a

(here called check)'.

#

to avoid petes

foreach

file

set if

dilemma

($argv)

a=('grep

(Sstatus

-s

==

tbl $file

TS 0)

$file')

then

nroff 1

-ms

Ipr 1

else

nroff

endif

end

484

Where

to

Now?

-ms

$file

1

Ipr

file

Select a

(b)

file

to

be formatted and enter the Shell

command

sequence:

check

Documentation:

from

An

Introduction to the

liam Joy,

UC

UNIX

by Steve Bourne, the C Shell, by Wil-

Shell,

and An Introduction

Bell Laboratories,

®

filename

to

Berkeley Computing Services.

C-Language UNIX

is

programmed

in the

C

This makes

language.

it

appropriate

consider writing your own C programs to supplement those already available to you as UNIX commands. Before rushing off to write a C program, however, be quite certain that you could not accomplish the intended task by using Shell commands (including to

awk and/or The piled

Shell scripts) already available

following

C program

and executed, simply

on the system.

requires a four line

file

and, once com-

prints the phrase “hi there”:

mainO (

printfC'hi there\n"); )

Note, however, that the same task with the Shell

Ritchie,

nighan

&

more

easily

accomplished

command: echo

Documentation:

is

The

Prentice-Hall

'hi there'

®

C

Programming Language, Kernighan & Publishers, and UNIX Programming, Ker-

Ritchie, Bell Laboratories.

Where

to

Now?

485

Ingres

Ingres

a data base

is

sions of UNIX.

It is

management system

available

on some ver-

useful for maintaining and updating large data-

bases which require frequent report generation.

Documentation:

A

Tutorial on Ingres

Database using Ingres^ both by E.

and Creating and Maintaining a Epstein, Electronics Research

Laboratory, College of Engineering, U.C. Berkeley.

ISP and S

buted by the University of buted by Bell Laboratories. tistical

analyses

— including

highly interactive manner.

learned and so

makes

more powerful and

ISP is distriCalifornia at Berkeley, and S is distriEach can perform many common stamultiple regression and T-tests — in a Of the two packages ISP is more easily

interactive statistical packages.

ISP and S are both

a very useful instructional tool.

S

offers a

sophisticated system.

Documentation: ISP is described in A Tutorial Introduction to Berkeley ISP, from UC Berkeley Computing Services; S is described in S—A Language and System for Data Analysis, from Bell Laboratories.

Writers'

Workbench

Workbench is a collection of programs designed to help you improve your writing. The package can be used to identify, and in some cases correct, grammatical, spelling, and stylistic problems in your written work. There are over twenty programs within the Writers'

Writers’

Workbench

package.

most instances you access a program by typing (from the Shell) the name of the program followed by the filename you want to have acted upon. A list of several of these programs and the functions they perform is presented on the next page. In

Where

to

Now?

Selected Writers

'

Command

Workbench Programs Function

findbe

file

Identifies

org

file

Prints text structure of file.

diction

file

Identifies

splitrules

suggest

words

Explains

all

forms of verb

to

troublesome syntax

be in

file.

in file.

split infinitives.

Suggests alternatives to words.

style

file

Analyzes surface characteristics of file.

topic

file

Locates frequent noun phrases

proofr

file

Invokes several Workbench programs which check spelling, punctuation, double words, syntax, and split infinitives.

punctrules sexist

[file

in file.

Displays rules enforced in the proofr program. Identifies sexist phrases in

file.

Where

to

Now?

487

Shell

Command Summary Special Characters

Command

Function

Routes standard output from a prior Shell

I

command

>

next Shell

command

to a specified

file.

Routes both standard output and error from a prior Shell

command

into a specified

mand ;

line.

Allows you to type several Shell

on one the

$$

;

line

(each

command

is

commands

separated by

).

ID of current

UseFor ful for generating a unique filename. example, vLn\(\file > file.%%, results in a new containing uniqw^ lines and named file where somenumber is the file, some number,

Expands

to process

Shell.

process ID of the parent Shell. ?

488

file.

Causes Shell command line to run in the background when appended to end of com-

&

*

(Pipe).

Routes standard output from a prior Shell

command

>&

to the

Matches any

single character.

Matches any sequence of characters.

Commands

Shell

Command alias

0

awk

1

command

\pro^\ [filel

Function

Makes x an

alias for a

awk program on

Executes an high

command

line.

filel.

awk

is

a

scanning and numerical programming language very useful in database management.

batch

scriptfile

cal \month\ [year

cat

[filel [file

pattern

level

Executes a batch scriptfile. Almost any job can be submitted to batch, which can normally run a job more cheaply then interactive work. Prints a calendar for the specified year

1983).

A

number

(1-12) before the year.

Concatenates catenated screen. If

is

By

file(s).

>

specified

by

the

default,

a

con-

be displayed on your to redirect output to new file. will

file(s)

Use

output

may be

month

(i.e.,

displayed on screen, press CTRL-S

to halt scrolling.

s cd [directoryname

Changes directory ryname must be

to a

directoryname

subdirectory

{directo-

of current

directory).

checkeqn

[fUel

check5

filel

(containing eqn constructs)

for

problematic eqn commands. [filel

checks

filel for

clikps

checks

process

checknr

some

(Available

E L L

C

nonbalanced formatting constructs {nxoff and -ms commands). status.

H

only

on

systems.)

O

M M A

N D S

Shell

Command Summary

489

Command chmod mode#

filel

Function of filel to mode# (which specifies the permissions attached to a file). Permissions are read, write, and execute per-

mode

changes

mission for owner, group members, and others (see

dear col

Module Twenty-Two).

clears screen and places cursor at top.

reverse line feeds from a text file. used as a filter when piping output

Removes Often

from

tbl

an output device that can’t do

to

reverse motion

comm

filel

file!

filel

cp filel file2 crypt

line printer).

words common to two sorted lists (filel and filel). Identifies words in one file and not the other or words found Selects

both

in

compact

(i.e.,

or

rejects

files.

Reduces disk space occupied by file, compactet/ version of filel will have .C appended to filename (filel. C). Must use uncompact before editing or otherwise using file (if this command does not work for you try pack and unpack).

compacts

filel.

Creates a second cop>^ of filel called £/ crypts and decrypts a 7

file

(see

file2.

Module

Six-

teen).

date dc

deroff filel

Displays the current date and time.

Performs arithmetic calculaEasy to use once you learn assembly tions. language programming.

desA: calculator.

Removes

formatting constructs from filel (de

//roffs a file).

diction filel

490

Shell

Identifies problematic diction in filel.

Command Summary

Command dirs

Function

Displays pathname of current directory: dir^c-

(Works faster than pwd but only available on some systems.) tory status.

du

displays disk usage in blocks.

is

(Available only

on some systems.) echo

string

eqn

[filel

Displays (echo6’s) string on screen.

Preformats all equations in filel. Output should be piped to the trojf formatter (use

neqn

as a preprocesser for /7ro#formatting).

Recalls a backgrounded process into the ior-

become your current only on some systems.)

grounfi this process will (Available

process.

find

find5 file specified with -n option.

-p option to

pathname of file ^printed Fifteen, The UNIX Directory

have

Module

(See

Must use

full

Structure)

grep

strin^\ [filel

Locates

all

instances of string (a global regular

expression or ipattern) in filel.

head

[filel

history

Displays

ten lines (head) of filel.

first

Reports history of

commands, where

last

#

is

# number

of Shell

number

that his-

the

tory variable has been set to.

with

jobs

C

(Available only

Shell.)

Displays

list

of

processes

(jobs)

currently

stopped or running in the background.

kill

#

process logout

number number (#).

kill5 process

(#); kill -9

#

will

nuke

Ends communication with UNIX.

Shell

Command Summary

491

2

Command look

[string

lookbib database

Ipr

[ft lei

Function looks in dictionary for words that match string and displays on screen this list of words. looks through a hihliographic database file for references containing specified keywords.

Causes

copy of

a

filel

to

be printed on the

\ine printer.

Is

Displays a

1/st

of

all

files

in

your current

directory.

mail

[lo^in

man command

Sends a message to login. End message with a CTRL-D (see write). When used without a login as an argument initiates a mail receiving session and displays a list of all messages sent to your UNIX account. Displays the

UNIX msmual information about

whatever command you

mesg y

or n

Permits other user to write mes^7g^5 to your terminal (and you to write them). Default value

mkdir

directory

more

mv

[ftlel

[ftlel\ [file

specify.

is

m^7k^s a

yes (n for no).

new ^uectory named

Displays filel one Similar to page.

directory.

more window

mov6»5 filel into filel (changes

at

name

a

time.

of filel

to filel).

neqn

[ftlel

nroff

[ftlel

Output Preformats all equations in filel. should be piped to the nroff formatter (use eqn as preprocesser for rrc# formatter).

Formats

filel

according to

nroff

commands

embedded in the text (n^’w run off). Must use nroff -ms to format filel when -ms macro calls are embedded in the text. 492

Shell

Command Summary

Command

Function

pack

[filel

pack5

page

[2^

Displays filel a page at a time (file can not be edited, only viewed). Similar to more.

passwd ps

pwd

Reduces disk space occupied by version of filel will have .P file. }) 2LQked appended to filename ifilel.P). Must use unpack before editing or otherwise using file (if this command does not work try compact and uncompact). filel.

Changes your passwo/tl. Provides process status information will provide more global information).

(ps -g

Displays pathname of current directory (print yv or king directory).

refer

[filel

Prepares filel containing refer bibliographic fields for formatting by a macro package (i.e., -ms).

reset roffbib

[filel

resets terminal to a sensible state.

out fields from a bibliographic data base as endnotes instead of footnotes (as refer does). Generally used with sortbib as Prints

follows; sortbib filel

rev

[filel

revmcs but

rm rmdir

I

[filel

directory

sed

it’s

all

roffbib. |

lines in filel

(why? don’t ask

great fun).

removes filel (be

careful!).

removes directory directory. tains files you must use rm stream

us,

editor.

ful as a filter

(If directory

con-

-r directory.)

Uses ex-like syntax. Most useto modify information passing

through a pipe.

Shell

Command Summary

493

.

Command set

set noclobber

Function With no arguments set displays variables have been set for your account.

that

Prevents overwriting (clobber/>7^) an existing file.

set ignoreeof

Prevents CTRL-D from logging you out of UNIX (ignoreeof — ignore end of file\ CTRL-D is the UNIX “end of file” message). "

sort

[filel

sorts filel into ascii sequence.

sortbib

[filel

sorts a hWiliographic data base (see roffbib).

source

[filel

Asks

Shell to execute filel containing Shell

commands

(uses filel

Most

Shell).

tail [filel

code

in filel

for

file.

Compares spelling of all words in words in UNIX dictionary and reports found

stty

source

useful for requesting Shell to

re-read your .login spell [filel

as

and not

filel all

to

those

in dictionary.

Sets terminal type parameters.

Displays

last

ten lines (tail) of filel.

thWMl

Preformats all tables in filel. Output must then be piped to the nroff ox trojf ^oxm 2d.Xex

tee [filel

tee

Catches output within a pipeline and puts a copy in filel. For examIpr will format tee ntext ple, nroff textfile textfile and place a copy of the formatted output in ntext while sending an additional copy is

a pipe fitting.

\

\

to the linepr inter.

translates

some

specified characters or range

of characters from the standard input into a different

set

of characters

and sends

translation to the standard output.

494

Shell

Command Summary

this

Command troff

[file I

Function

Formats

embedded

in

commands

according

to

the

Formatted version

filel

text.

troff

be phototypeset (typeset run off). Must use troff -ms to format, /z/c/ when -ms macro

will

embedded

calls are

tset

sets

the text.

in

terminal erase,

and other

kill,

special

characters.

uniq

[filel

Removes redundant only uniq^/c

vi [filel

Starts

a

from filef leaving

lines

lines.

or

file

an

retrieves

existing

file

Moves you into Command Mode. See summary section which follows on Commands to Enter an Edinamed

filel

for

y'xsual

editing.

tor.

wait

Causes Shell

wc

[filel

Shell

wait

to

command

Displays total

backgrounded

until

complete.

is

number of

lines,

characters in filel (vtord count).

words, and

Very useful

for high school English papers that

“must be

500 words or longer.”

whatis command

Displays

synopsis

specified

command.

line

Tells

from manual for what command is all

about.

whereis command

Displays Tells

who

full

pathname of

where command

Presents a

list

of

who

specified

command.

is located.

is

currently logged onto

your UNIX system. write lo^in

Immediately wTites are logged on (see CTRL-D.

Shell

to login while niuil);

both of you

end session with

Command Summary

a

495

Commands

Enter an Editor

to

Command

Function

vi [filel

Starts

a

named

filel

into

vi

H-#

[filel

or

file

retrieves

an

existing

file

Moves you

for \\sual editing.

Command Mode.

Puts you

Mode

the

into

at line

#

yisual editor

in filel.

If

#

no

Command is

specified,

places cursor at last line of filel.

vi

+/

I

word\

[filel

Moves you

Mode vi

at first

when

Moves you [filel

instance of

editing

into

Shell

in filel.

or

retrieves

Starts

a

named

filel for line editing.

file

Command Summary

terminated.

session

Command Mode.

the (extinct) line editor

496

word

Command

Creates a buffer for yisual editing. Material must be given filename (with :w name) to be

saved

ex

into the y'xsual editor

an

existing

file

Moves you

into

Command Mode.

Command Summary

Visual Editor

• Commands

Cursor Moving

Command

BEEB

Function WQ-HOeS

(h

j

k

Moves

1)

one space

cursor one line

up/down

right or left.

0

(zero)

Moves

$

Moves

cursor to the end of the current

cursor to the beginning of

line.

line.

42 (or any number).

42G

Goc5

to line

G

Goes

to the last line in

L

Positions cursor

your

file.

at

Low

point on the screen.

M

Positions cursor at

Mid

point on the screen.

H

Positions cursor at High point

w

Moves

Moves

e

Moves your

Moves word

B

on the screen.

in

your

file.

cursor forward to the beginning of the next Wo/^yin your file, ignoring punctuation.

in

b

#

cursor forward to the beginning of the

next word

W

or

in

Moves prior

cursor forward to the end of next word file.

cursor backward to the beginning prior

your

file.

cursor

word

in

Backward

your

file,

to

the

beginning of

ignoring punctuation.

497

Command

Function



Moves

cursor forward through text to next



Moves

cursor backward through text to prior



Moves

cursor forward through text to next



Moves

cursor backward through text

word

Moves

cursor

forward

through

To

text

b.

b.

prior

to

b.

b.

next

word. 9

word

Moves

cursor backward through text to prior

word.

n

Repeats

ward ter

N

)

last

/ or

?

search:

Moves

cursor for-

backward) through text to next characor word. (or

Repeats last / or of search.

Moves

?

search but reverses direction

cursor forward through text to begin-

ning of next sentence. (

Moves

cursor backward through text to begin-

ning of prior sentence.

)

Moves

cursor forward through text to begin-

ning of next paragraph.

(

Moves

cursor backward through text to begin-

ning of prior paragraph. II

Moves

cursor forward through text to begin-

ning of next section. II

Moves

cursor backward through text to begin-

ning of prior section. f /

(Two

single quotes)

tion in

498

vi

Command Summary

file.

Moves

cursor to prior posi-

Display Adjusting

Commands

Command CTRL-D

Function Scrolls dow/7 or

moves on

to

more

moves on

to

12

text in the

file.

72CTRL-D

Scrolls

down

text in the

or

more

lines of

file.

CTRL-U

Scrolls

CTRL-F

Goes forward

CTRL-B

Goes hack

CTRL-E

Displays an additional line at bottom of screen.

CTRL-Y

Displays an additional line at top of screen.

Z.

z4.

z-

z

®

CTRL-R

wp or moves back

a

to prior text.

to next block or

window of

window of

text.

text.

Redraws screen, with the current of the window.

line in

Makes screen show only 4 lines of number can be 1-23 (don’t forget the

middle

text.

The

period).

Redraws screen, with the current tom of the window.

line

Redraws screen; current

of window.

Redraw

line at top

on bot-

screen.

Undo Commands U

(lower case u) undoes the effect of the

last text

change command.

U

(Upper Case U) Undoes current

all

changes made

to the

line.

vi

Command Summary

499

Text Changing

Commands

One- Way Commands {Leave You In Append Until

You Press ESCAPE)

Command a

Mode

Function one space

Starts adding text

to the right of the

cursor i^ippend).

i

Starts adding text

one space

to the

left

of the

cursor (insert). 0

O

opens a line for text below the cursor

(Upper Case) Opens a cursor

A

line

line.

for text above the

line.

(Upper Case) Starts adding text

at

the end of

the line (Append),

1

(Upper Case) Inserts text

at

the beginning of

the line (Insert).

cw s

changes the one vford to the right of the cursor. (lower case) substitutes text for a single character.

S cc

(Upper Case) Substitutes text for an entire Substitutes

same

C

text

for

an entire

line

line.

(cchanges\

as S).

Substitutes text for the rest of the line (Changes

from the cursor position forward).

R

Replaces characters

you type over with new

characters (overlay type).

500

vi

Command Summary

^atholocy SERVltf VA MEDICAL CENTER 4150 CLEMENT street '

SAN FRANCISCa CA 94121

Text Changing

Commands

Two-Way Commands {Return You To

Command Mode)

Command

r

Function

X

Erases the character under the cursor (x out).

X

Erases the character before the cursor.

xp

Transposes characters.

0

replaces the character

under the cursor with the

letter b.

dw

deletes

from the cursor position forward

to start

of next Yford.

db

deletes

from cursor position backward

to begin-

ning of previous word.

dd

D

Deletes the entire cursor line iddeletes). Deletes the rest of the line

(from the cursor

position forward).

:T26d

deletes lines

1

through 26 (you select the

line

numbers). J

>

Shifts cursor line right

one shiftwidth (distance

of one TAB, normally 8 spaces). •

(Dot)

Repeats

last text

vi

change command.

Command Summary

501

Commands

Text Relocation

Command yy

6yy

Function

unnamed

of text and places buffer {yyanks\ same as Y).

Yanks

lines

Yanks the cursor

6

a yy

and places

(Double quotes) Yanks cursor stores in a register (registers

"

0 -^yy

(Double quotes)

Yanks

3

^7

@dd

to z available).

in

b register

of text

and

to z available).

(Double quotes) Deletes cursor stores

buffer

of text and

line

lines

stores in c register (registers

"

unnamed

in

command).

(See Put ”

in

line

{Meletes\

line

of text and

registers

a Xo z

available).

P

(Upper

Case)

register just

Puts

text

in

unnamed

line (or

before the

stored

above the cursor

cursor).

P

(lower case) ^uts the yanked or deleted text just

below the cursor

"@P

line (or after the cursor).

(Double quotes) Puts the text stored in register a just above the cursor line (or before the cursor).

"Bp

(Double quotes) pi//s the deleted text stored in register 6 just below the cursor line (or after the cursor).

Note:

last

9 text block deletions are

automatically stored in registers :1,26

m

82

:C26 CO 82

moves

lines 1

copies lines

1

1

through 26 to after

to 9.

line 82.

through 26 and places after

(52.

:w Jilel

502

vi

writes current

Command Summary

file

to disk

— names

it

Jilel.

line

Command :J,26

:U26

w

»

w

Function

filel

yv rites lines

filel

Appends

1

new

to 26 as

lines

— names

it

filel.

26 to end of existing

to

1

file

file

filel.

:26 read file!

Places contents of filel into current line

after

26 {reads mfile).

Commands

Miscellaneous Additional

:sh

processing— places current file in background and moves to the shell (return to file with CTRL-D).

'Acommand

Temporary Shell escape. Insert whatever Shell command you wish. Output from command, if any, becomes part of current buffer.

Q

Stops

Moves from

Mode CTRL-G

vi

the

to

(Return to

vi

with vi

file

file:

displays filename,

RETURN

CTRL-Z

Stops processing— places current with

available

U]

abc

Creates 1)

to the Shell

file

in file.

line.

in

back-

(return to the

command).

the fg Shell

Note: Not

on some systems.

own Command Mode command. You and

abc

any

(#1 for function of

actions

for

phrase

Command Summary'

503

with

(remove with :unmap phrase

one

character: advances cursor

replace $ with any character

key

Command

command).

CTRL-M

file

abc

editor

and cursor position

edited,

ground and moves

:niap

line

Status check of current

percent of

:ab

file

series

$).

abc as dH^breviation (remove with :una abc).

Establishes

17

Quit Working on the File and

Return to Shell

Commands

Command ZZ

:w

®

Function changes made to the file during an editing session and returns to the Shell (the “I am finished working on this file” command).

Writes

Yirites all

you the :q!

®

®

the changes

made

in the visual editor to

and leaves continue working on in a file

file.

an editing session and returns you Shell, but does not write changes made to

to

Qiuits

(the

:wq!

all

“can

I

start

over” command).

changes made in a file during an ing session, quits and returns to the Shell.

writes

file

all

edit-

Regular Characters for Search and Substitutions

c

When

placed at end of search

confirm substitution. tution; press

d

When

® to

it

prompts you

to

Enter y to execute substi-

cancel

it.

placed at end of search

it

deletes pattern

found. g

When

beginning of a search it addresses all lines in the file; at end of search it functions on all cases of pattern within specified lines. all

placed at

When

vi

in

both places

it

functions on

cases of pattern within current

search).

504

used

the

Command Summary

file

{global

Commands

Enter an Editor

to

Command

Function

vi [filel

Starts

a

named

filel

into

vi

-h#

[filel

or

file

word\ [fUel

Puts you

the

into

at line

Moves you

Mode vi

#

[filel

Command

\isual editor

in filel.

If

no

#

is

specified,

filel.

into the yisual editor

at first

Command

instance of word \n filel.

Creates a buffer for \\sual editing. Material must be given filename (with :w name) to be when editing session terminated. saved

Moves you ex

file

Moves you

\isual editing.

for

places cursor at last line

+/

existing

Command Mode.

Mode

vi

an

retrieves

into

Command Mode.

or

retrieves

Starts

a

named

filel for line editing.

file

the (extinct) line editor

vi

an

existing

file

Moves you

into

Command Mode.

Command Summary

505

Special Characters in

Command

Append Mode Function

BACKSPACE

Backspaces one character.

Append Mode and Command Mode.

(rubout)

DELETE

you

in

ESCapes

ESC

CTRL-H

Interrupts

to

places

Command Mode.

Backspaces one character.

CTRL-I

TAB

CTRL-V

Allows input of a SPACE, TAB, or

character

(moves

8 spaces right).

RETURN

char-

acter.

CTRL-W

Backspaces one word.

Allows input of a CTRL-H, BACKSPACE, or

\

character.

@

Erases

Summary Affected Text

word

input on a

line.

of Text Operators

move

to

delete

change

yank

lines

®

dd

cc

yy

to right

w

dw

cw

yw

b

db

cb

yb

word

to left

right to

g

dtg

Ct^

yt?

left to

g

dT^

cT^

yTg

right including

g

fg

dfg

cf^

yf^

including g

Fg

dFg

cF^

yF^

left

506

all

v/

Command Summary

@

Formatting

Command Summary Commands

Nroff/Troff

Command .ad b

.bp

Function

begins 2iAjusting text (this

temporary

Causes

a

begins a

new page of

is

the default state).

between

pages’,

A number

used as

break text.

an argument becomes the page

new page .br

Causes

a

(e.g.,

bieak

number

of the

.bp 4). in text filling;

begins a

new

line

of text.

# number

.ce

#

centers

.cu

#

continuously underlines for

of

lines.

next

# number

of

lines; italicizes in troff.

Begins a macro definition; replace

.de

character

macro .ds

XX

string

.fi

.ft

X

..

with two

to indicate

end of

definition.

defines string in

.ex

macro name. Use

XX

XX as

the specified

string.

(See \(*

Escape Sequences section.)

exits

from nr off ox

Resumes Changes

troff.

the Wiling of input lines (default). fo//t to

R

X where X

is

either

B

for Bold,

Roman, or S for Special Mathematical; default is Roman. Use \fX to

I

for

Italic,

for

change font within

a line.

507

Command

Function

Starts hyphenation (this

•hy .in

#

a

#

[This

left

the

is

command.]

return

.11

the default state).

margin # number of spaces. one-way command; .in 0 (zero)

indents is

is

# number

Sets line length to

(default

6 1/2

is

inches).

.Is

#

(lower case

number ing

.It

#

is

1)

(i.e.,

Sets the linespacing of paper at .Is

2 double spaces).

#

Single spac-

default state.

Sets the length of

title

to

# number

(default

is

6

1/2 inches).

Leaves right edge jagged; no adjusting. (This is a one-way command; .ad b returns to normal

.na

justification.)

.ne

#

Checks

if

# number

of output lines available;

if

premature page break occurs number of continuous lines).

not available a

(need

#

no f/7/; Stops the way command;

.nf

filling .fi

process.

returns

to

(This

is

a one-

normal

text

filling.)

.nh

.nm

# .nn

,

no hyphenates stops hyphenation. numbers next

# number

of

lines.

Stops numbering (no number).

Defines

number

register

XX

as

the

specified

value.

.pi

#

Sets ipage length at

.pn

#

Sets ^age

Format

number

Command Summary

# number

(11 inch default).

for next page at

#

number.

Command

Function

.po [#

Sets p7/ size to

Use \s#

point).

#

(default

change point

to

is

10

size within a

line.

.rd

[file

be read from file if file specified. The standard input (usually your terminal) will be read if no file is specified (see

Causes

Form .so

[file

input

Letters

sources in

to

Module).

named

file

(which

file

macro

definitions) to current

.sp [#

sp^7ccs

down # number

.ss

[#

Changes space character default is 12/36 em.

.ta

#

TAB

may

contain

file.

distance.

size

to

#

number;

# number

of characters; this distance can be a series of numbers, each indicating a separate TAB stop (default is 8 characters

Sets

to

per tab).

.ti

#

temporarily

indents

left

margin

# number

of

spaces (next output line only). Prints a three part tide line.

.ul

w

underlines next

# number

of lines;

will italicize

in troff.

.vs

#

Changes

\ertical spacing to

# number

(default

is

12 point).

.wh

#

A'A'

Calls

macro

reached; also

XX when known

Format

page

position

#

is

as “setting a trap.”

Command Summary

509

Escape Sequences Allowing Printing of Nroff/TrofF Special Characters (Special Mathematical Characters Available

Described

\S \e

Module)

in Phototypesetting

Command

Function

The backslash prevents

interpretation of a.

I

Allows printing of current escape character.

\'

Prints an accute accent in

\'

Prints a grave accent in

\-

on Troff

Prints a

minus

sign in

troff.

troff.

troff. I

\0

Creates an ''unpaddable” space the width of a 0

i

.

\

[SPACE

Creates an “unpaddable” space in the current space size.



I

\|

Creates an

“unpaddable’’ space the width of

\

1/6 em.

\&

\”

Deposits a non-printing character that occupies no space (zero width character).

When line

\d

placed at the beginning of line,

from formatter (allows comment

Shifts text

down 1/2 em

in

troff,

masks

in file).

1/2 space in

nroff.

Shifts text

\f

X

Format

em

in troff,

1/2 space in

nroff.

Changes type iont to X where B is boldface, I is Italics, R is ^oman, and S is Special Mathematical font.

510

up 1/2

Command Summary

!

Command \h'\E'

Function

Shifts right

#

distance (hor/zo/?/^?/ shift).

\v\E'

Draws

a horizontal line

\v\E'

Draws

a vertical

\o

'

#

#

Line

distance.

distance.

overstrikes characters xyz.

\P

Breaks

\r

reverses

and spreads out

filling

print

line-feed in

direction

line (pr///s).

em

1

in

reverse

troff,

nroff'.

\n([XF

Causes value stored in XX number register to be read in (where XX is a two character name for a number register). See .nr.

V(\XX

Causes string stored in XX string register to be read in (where XX is a two character name for a string register). See .ds.

\$1

Causes

argument

first

to

macro

call

to

be read

into a macro.

-ms Macro Commands Paragraph Macros .PP

Begins a standard,

five

space indented

Vara-

graVh.

.LP .IP

Begins a Left block Paragraph (no indenting).

Begins an

Indented Paragraph

the entire paragraph

.IP

fll

is

(left

indented right

margin of 5 spaces).

Begins a labeled Indented Paragraph. the

X

Replace

with numbers, letters or a word that you

want placed

to the left of

Format

your paragraph.

Command Summarv

51

Command

Function

X

Begins a labeled Indented Paragraph. Replace the X with numbers, letters or a word that you want placed to the left of your paragraph. Replace # with a number indicating indentation

.IP

of paragraph.

QP

Quote Paragraph. Indent 5 spaces from both left and right margins. Automatic Begins

a

single line-spacing not provided.

Begins an QXdented 'Paragraph. The first line of the paragraph is at the left margin, while the

.XP

remaining lines are indented.

Footnotes, Keeps,

and Displays

Text between an .FS and an .FE command is formatted as a footnote. Footnotes are not numbered. (Some systems will allow you to produce numbered footnotes. To do this you must also place these three characin the text where you wish the numters bered footnote to appear.) (.FS is a one-way command; .FE is the return command.)

.FS

Starts a footnote:

.FE

Ends

.KS

'

a footnote:

Starts a Keep:

command

is

Returns to normal text layout.

Text between a .KS and a .KE

printed on a single page.

neces-

If

new page is started. (This is a one-way command; .KE is the return command.) sary a

.KF

Begins a floating Keep.

If text

current page and a page break

is

will

.KE 5

1

2

Format

(This

return

command.)

Ends the Keep: Returns

Command Summary

fill

to

on

rest of

one-way command; .KE

page.

a

fit

required, text

following the keep will be used to is

not

is

the

normal page layout.

Command

Function

.LG

Increases point size by two points {harGer).

.SM

Decreases point size by two points iSMaller).

.NL

^ormaL

point size; resets point size to original

value (the value of the nr

.RS

register).

margin of text to the value specified the .nr PI register which has a default value

Indents in

PS number

left

of five spaces (Right Start). Can be repeated (This is a one-way for additional indenting.

command; .RE

the return

command.)

.RE

Moves left margin back five spaces (Right End). (Number of .RE commands used must match number of .RS commands used.)

.DA

Provides today’s DAte as center footer of paper. (This

.DA

is

\date

.ND

is

the default condition.)

DAte

Prints

as center footer of paper.

Suppresses printing of today’s date as footer on paper (No E^ate).

.2C

Column

Will format of paper. (This is a automatically cause a page break. one-way command; .1C will return to single

Begins

2

column output.) .1C

.MC

[#

Returns Sets

to 1

Column output on

column width

to

a

new

# number

Will automatically cause a break

page. characters.

page

(Multi-

(The number of columns is computed automatically, based upon line length.)

Column).

Format

Command Summary

5

1

Command .AU

Function

Centers following text line(s) as KXthor's name(s); troff sets name(s) in ten point italic type.

.AI

Centers Author’s Institution; Use repeated .AU and .AI calls for multiple authors from different institutions.

.AB

XXX

Begins

If

label. will

Absract,

nothing

is

is

entered for

not be labeled.

and adjusted

XXX

where

The

the

abstract’s

XXX the

abstract

abstract will be filled

to a line length of 5/6 the

normal

text line length.

.AE

Ends

Abstract.

Other -ms Macros .UL

word

\JnderEines word.

with the .1

Only the one word on the

.UL command

will

Begins underlining of text;

line

be underlined. will Italicize in troff.

one-way command; .R returns non-underlining in nroff and Roman type (This

is

a

to in

troff.)

.B

Bolds text, underlines in

nroff.

way command; .R returns nroff and

.R

5

1

4

type in

Draws

type in a

is

non-underlining

nroff,

will

troff.

BoX around

word.

Begins a block of text to be enclosed in a

.B2

Indicates

end of passage

Command Summary

in

return to

.B1

Format

a one-

troff.)

Stops underlining text in

Boman .BX word

Boman

to

(This

to

Box

be enclosed by

Box

Command

Function

.LG

Increases point size by two points {harGer).

.SM

Decreases point size by two points (SMaller).

.NL

NormaL

point size; resets point size to original

value (the value of the nr

.RS

Indents ing.

(This

is

a

register).

spaces

five

(Right

for additional indent-

one-way command; .RE

is

the

command.)

return

.RE

Moves left margin back five spaces (Right End). (Number of .RE commands used must match number of .RS commands used.)

.DA

Provides today’s (This

.DA

margin of text

left

Can be repeated

Start),

PS number

is

DAte

as center footer of paper.

the default condition.)

date

Prints date as center footer of paper.

.ND

Suppresses printing of today’s date as footer on paper (No Date).

.2C

Begins

Column

format of paper. Will automatically cause a page break. (This is a one-way command; .1C will return to single 2

column output.) .1C

.MC

Returns to Sets

1

Column output on

column width

to

a

new

# number

Will automatically cause a break

page. characters.

page

(Mw///-

(The number of columns is computed automatically, based upon line length.)

Column).

Format

Command Summary

515

String Definition

Commands Function

Command

X in

.ds

LH X

heft Header: Puts

.ds

CH X

Center Header: Puts all

RH X

.ds

top

X

left

corner of pages.

in top center position

of

upper right corner of

all

pages.

X

Right Header: Puts

in

pages.

X in

.ds

LF

X

heft Footer: Puts

.ds

CF

X

Center Footer: Puts of

.ds

RF

X

all

lower

X

left

in center

corner of pages.

bottom position

pages.

Right Footer: Puts

X

in

lower right corner of

all

pages.

Note: the % symbol may be substituted for X in any of the above headers or footers, and page numbers will appear in that position.

5

1

6

Format

Command Summary

Summary Register

of

-ms Number Registers

Function

Default Value (for nrojf)

.nr

LL

L/>7^

Length of text

6 inches

.nr

PO

Vage

Offset

0 inches

.nr

FL

Footnote Line length

.nr PI .nr

QI

Faragraph Indentation

5.5 inches

5 spaces

Quote paragraph Indentation

5 spaces

.nr

HM

Header Margin

1

inch

.nr

FM

Footer Margin

1

inch

.nr

PD

Between Paragraph

Iv

Distance .nr

PS

Foint Size

lOp

.nr

VS

V ertical Spacing

12p

Distances

may be

indicated in inches, centimeters, em’s, v’s, or Picas; point size and vertical spacing is specified in points.

Format

Command Summary

5

1

INDEX 1

207

(in editor)

1

r

208 111

(in editor)

1

b

345 111

nrqtf Qon{xo\ character)

(

(in editor)

171

account management

272

addbib

405

addresses, text

232

\fR

w

341

.AI

\

341

aliases

207

alias

\< \>

(in editor)

(in editor)

\fB \fl

(in editor)

A K L

49

J keys

206 44

(in editor)

goofed

/

349 252 233 139, 206 91, 290 209 274, 308 95,

(pipe) 1

(tilde)

"#P $ (in editor)

&

(in Shell)

* (in editor) * (in Shell)

® .

13 .

(dot-dot; in Shell)

268, 330

335

account customizing account establishment

394 206 206 319 319 319

\&

98

manual accessing macros access the

2

72

adjusted text

227

adjusting screen display

73

.ad .

AE

398 398 277 277

'

439

allbox, in tables

ALPHALOCK

9

key

90

alternate phrases

ampersand

91, 290

(in Shell)

any character, match apostrophe A7rQ)7control character) (

Mode

Append Append Append Append append

special characters

Mode, ex Mode, leave Mode, vi

208 345 224 191

25 49, 110 23, 129

text

99, 380

apropos

.

{moff'Qon\To\ character)

345

arguments, to Shell command arguments, within macros

.

(in editor)

208

arrow keys

/usr/lib/eign

363

/usr/lib/tmac/tmac. s

352

.AE awk

398 483

b

123

/

267

(dot; in Shell)

.

43

word

374 298

/ (in Shell) $1 (in Shell)

96

< >

117

89

BAC KSPAC E key -j

batch job, remove

»

186

batch job, submitting

? (in Shell)

308

batch processing

24,50

a

batch queue, check

A

129

batman

.AB

398

batq

107

beep beginning of line, character beginning of word, character

abandon a file during abandoning a paper ‘Abbreviation

editing

command

absolute position indicator, in nr off access deleted text

518

76

239

349 233

bibliographies, formatting bibliographies,

337 41

background a process backslash, double

bartm

92

no abstracts

90, 176, 289

341 17

298 298

297 295 298 299 298 26, 42

206 206 172, 404 414

bins bin bin

blank

searches

lines,

Bo/^/font

book conventions book objectives boxed tables boxes, trqff-ms boxes, (rqff box, in tables .bp brackets, in searches brackets, with eqn brackets, with filenames

break

command,

nroff

372 375 207 318

colon

106, 179

buffer and disk, save both

183

buffers, lettered

135

numbered

135

buffers, search

234

buffers, text storage

232 318

Bo/Jfont b

C C- Language

center text,

in nroff'

centering a table .ce

interpreters, interactive

115

interpreters, non-interactive

1

Command Mode, Command Mode, Command Mode,

leave

27

ex

190

110,49

vi

Command not found command order, when using command synonyms (alias) command syntax

12,

-ms

commands, arrows commands, formatting commands, one-way commands, two-way comments from others

common

15

475 161

277 92 14

110 111

14,111 175

English words,

list

363

compact a file compact compare two files

276 277 361

compatibility, /zro^and

macros

144

conceptual overview

105

251

control characters, nroff

345

66 428

control characters. Shell

49, 66

66 49, 131

conventions used copy a file

in

16

48

CO/7V, in

check diction .check for format errors

163

check for eqn errors

467 89, 187

467 163

263

book

copy text, in editor Core dump corrections, in Shell

230 465 49 89

checkeq checknr Cheetos

112

361

change line change password change word changing text

check spelling

interpreters

comm

251

characters on screen, weird

command command command

95

131

change directory

character location, with eqn

423 305

241

cd

cb

136

columns, in tables combining files combining Shell commands

123

cc

cat

commands

communicating with others

485 475 87, 304 230 49, 130

Cannot open filename

clean up script, sample

439 325 319 439 153, 395 207 457 307 343

4

370 414 218 279 279

citations, in papers

clear

475 343

buffers,

chmod

2

broken pipe

buffer and disk

287, 294

clear screen

153

BSD UNIX

-iv

3

break page, nroff .br

chkps

editor

cp

3

84, 304

136

476 17

137

84

creating directories

172

cryogenics, microprocessor

crypt

292 275

CTRL-B

126 126, 281

CTRL-F CTRL-H CTRL-S CTRF-U

126 17 15

126

519

267

(.), in Shell

CTRL-V

225

dot

CTRL-VV

225

dot, in editor

CTRL-Z

293

dot-dot

.Ct

330

double backslash double spacing text

41

cursor

.), in

(.

208 268 341

Shell

71

45

122

dw

cursor skips lines

480

e

123

cursor, absent

471

echo

customizing your account

171

edit

cut and paste, in editor

133

279 282 236

cursor

moving commands

48

CH data base

management

data placement in table

486 429 15

date

230 44

db dd default values, nroff'

74

defaults, in Shell

93

environment, setting editing environment editing,

39

file recall

editor, line

217 177

electronic mail

242

end of file marker end of line, character end of word, character environment, editing

281

editor scripts

323 320

.EN

330 425

eqn output eqn with other pre-processors

definitions, string

159

equations, examples

delete a character delete lines

46 44

delete text

139

defaults, changing troff -ms defaults, rro#requests

define a

macro

defining a

TAB

delete words

deleted text, oops! deleted text, recall of

DELETE key delim, in eqn derofT .de

marks diagnosing problems

diacritical

45

478 233 64, 96, 291

449 356 330 450 469

206 206 236 447 445 466 466 459 172, 447 447 447

eqn

equations, formatting equations, in

files

.EQ

175

errors in formatting, check

467 26, 50

errors in eqn^ check

ESCAPE key escape character, nroff

341

executable

367 370 384 428

files

execute permission exit, from wro^formatting

expanding experience

.

a table

53

file

diction check

89

exponents, with eqn

455

diction

89

ex editor

177

250 257

.ex

384

cjcand

vi,

moving between

251

^-jcand

vv;

relationship

directories directories within directories

directory,

change

directory, lost within directory,

make

directory, parent

477 172, 250 269

191

fg

293

338 116

Eg macro

disk and buffer

106

file

descriptors

126, 227

file

length,

displays, with eqn

461

file

permissions

dollar sign, in editor

139

file

relocation

dot {nroff conixoX character)

345 283

file,

(.) files

520

195

Mode ex Command Mode

179

dot

5

189

ex Append

disk display adjustment

editors

file,

maximum

permanent copy temporary copy

190

troff

322 368, 378 250 106

106

filemodes

370 370 40 274, 306 40

filemodes, change

filename filename expansion character filename, misspelled

home-made macros horizontal lines, in tables

Houdini Award

329 440 32



50 129

1

I

filenames, examples

83

ignoreeof

281

filenames, rules on

82

improved editing indent, temporary

174

as sections of larger paper

files,

filled text

172 72, 343

filling

72

find

266, 286

find a lost

266

file

72

.fi

font change, tables

index, create index, formatting

management) macro use

Ingres (data base initializing for

input characters, translate

font changes, text

442 319

input, standard

font characters

321

insert text, in editor

font selection, with eqn

interactive

font. Italics

464 318 318 317

interpreters,

footer margin, change

159

.IP

footnotes, formatting

415

ISP

foreground

293

Italics

font, ^old font,

form

Roman

a process

382 68, 152 110

letters

format a file format commands format commands, conventions format commands, remove format errors, check formatted output, absent formatted output, with macros formatting formatting, volunteer with .fo

fractions, with eqn .ft

B

.ft

I

.ft

R

function keys g (in

editor)

G global search

Greek

letters

grep halt scrolling

65

356 163, 175

input

jobs joining

files

justified text

295 338 112

486

72

kill

292

killing a process

292 239 209 139 234 457

Kryptonite last line in file

lettered buffers limits, with

eqn ex

190

line addresses, rules

137

line addresses, in

ex

177, 189

numbers,

69 179

line editor, line length line

in editor

215 125

line print a file

68

line printer

210 451 273

line spacing

30 70

16

lines in boxes, tables listing files

login

87

440 30 69

.11

430

directory

115

317 394 293 303

invisible character

headings,

Home

package)

font

locating

.he

nroff

command

(statistical

159

head

interpreters

146

header margin, change in tables

memory,

152

42

50, 129

interactive processing

Kirk, Captain

macros 152 347 456 318 317 318

360 116

command

473 64

158

76

file

internal

66 172, 363 403 486

words or phrases

login banner, absent

347

.login file

250

logout

273 10

472 284 12

521

.logout

287

file

15

look

384 265

looping, in nrqtf' lost files, find

30, 68

Ipr

145

.LP

30, 253

Is

70

.Is

macro arguments macro calls macro definitions macro examples, paragraphs macro file, creating macro, define a

macros macros, arguments within macros, create your own

337 144, 328 330 145

332 330 144, 328 337

251

mkdir Module use more move

move

3

86 139 85

a file

195

moving between ex and vi moving cursor backward moving cursor forward moving text across files moving text, within a file moving the cursor Mrs. Zak

123

122 173 138, 173

122

88 142

-ms macros -ms macros, how read multi-columned tables multiple authors, refer

333 432

408 382

.

175

multiple copies of letters

home-made macros, how work

329 332

mv

85

n {next)

43

macros, with moff' Mail

155

naming macros

242

.na

accessing

242

needs

153

reading

243

neqn

244 243 245 250

neqn .ne

445 447 154

.nf

72

macros,

Mail Mail Mail Mail Mail

make

sending a

file

sending a note using

vi

with

a directory

man

98

management, account manual access

272 98

map

238

.NH

149

no break, in nrojf no fill, in nroff

345 71

476 281, 305

No match noclobber .nr

FM

159

12

.nr

HM

159

12

.nr

LL

157

A

8

.nr

PO

157

B

22

.nr

PS

C

40

.nr

VS

D

102

nroff'

E

200 473 226 308 308 463 322 227 475 204 292 407

nroff'dind

324 325 64 144 338 310 142, 327 338

margin, deviating

marking a position while editing matching a single character matching characters matrices, with eqn

maximum

file

length,

troff'

mb

(mark position 8) messages on screen meta characters, editor microprocessor cryogenics mistakes, refer

522

72

12

maps, arrows maps, boxes maps, symbols

Map Map Map Map Map

332

A7

macro compatibility

ro#internal

nroff' O'pXxons

nroff requests

memory

number registers number registers, changing values number registers, resetting 323, number registers, troff -ms numbered buffers numbered headings numbered text numbers in editing environment

157

156

324 233 149 136

282

384

.nx

Permission denied

0

51

permissions

O

51

petes

objectives of

book

2

73

offset output

one-way text change commands one-way commands 69, open a line above open a line below

129 73, 111

51, 71 51

231

operators, text

options

93

orphans

176

89

output, redirect

field

dilemma

phototypesetting

itrqff)

PID number piles,

with eqn

476 369 484 312 292 462

pipe reroute

95

pipe

64

place text in a buffer

placement of data

in table

.pi

point size point size changes

235

429 70, 154, 346 314 316 314 315 315 442 464

output, standard

116

point size, available on troff

output, troff

322

point size, default

overview, conceptual

105

point size, specifying

p (in

134

point size, tables

134

point size, with eqn

p (in ex)

215-

.po

pack

276 277 320

.PP

145

previewing a formatted paper

176

153

print

P

(in

vi) vi)

a file

pack page characteristics, page control

troff

page length

70, 154, 346

page length, /7ro//'’problems

page paragraph macro examples paragraph macros paragraph reset macro paragraph resets, with troff-m

70

73

print offset

73

working directory

265

printer selection

176

printing files

30 469

64, 86

problems, diagnosing

145

problems, formatting

144

469 469 470 470

paragraph, block {nrqff) paragraph, exdented

148

paragraph, indented

146

problems logging in problems. Shell or editor problems, unknown origin process status check process, background a process, foreground a

paragraph, labeled

146

process,

paragraph,

145

process, stop

292

148

processing, batch

295

66, 145

processing, interactive

295

parens, with eqn

457

Programmer’s Manual

98, 379

parent directory

269

and wholes passwd password password, change

301

programming in C prompt fields, in refer

485 407

path, search

375

ps

291

pathnames pathnames, copying pathnames, editing

258

.ps

316

261

put text

134

pwd .PX

265

pattern scanning

260 483

401

pattern searches

174

:q!

107

patterns vs. words, in editor

205

Q

195

permanent copy of

106

left

block

paragraph, quote paragraph, standard

parts

351

323 67

10 16

prompts,

files

file

Qe

in refer

90, 289

293 96, 292

kill

prompt. Shell prompts, change

16

291

11 in refer

411, 412

405

335

523

351

QP

148

.RT

.Qs

334

R LI BOUT key

quality of formatted output

172

ruined a

quit an editing session

107

S

quit editing without writing

181

s (in

Quote paragraph macro r

.rd

read

command

read text into current

file

read permission reassembly of files

334 46 383 383 186, 303 370

S

(statistical

48, 130

130

(in vi)

sample bibliography sample paper, formatted sample paper, input file save a

recall stored text

234 234

script file

redundant

lines,

remove

refer

refer refer,

formatting

refer,

printing

refer,

with other pre-processors

.

reminder

file

remove a batch job remove a file remove formatting commands remove magic, in editor remove spaces, in editor rename a file repeated characters,

in editor

replace a character Request, while logging in

360 404 415 410 410 416 283 298 85

356 209 216 85

209 46 9

327

requests, nroff

79 108

screen, clear

89, 117

80

file

233

redirect output

215 417

s (in ex)

recall deleted text

text

486

package)

vi)

scrambling

yanked

107

file

176

recall

64, 96

275 279

a file

script, clean

296 218

up

87, 127

scroll text

scrolling, stop

16

search buffers

234

search

command

43

search path

375

search path, setting

377

searches, excluding characters

208 174

searches, pattern searches, upper/lower case letters

207 207

section headings

149

searches, range of characters

sed (stream editor)

semicolon separating a

file

set :set all :set

ignorecase

482 96 302 280, 376 236 238

set ignoreeof

281

:set list

413

351

set noclobber

281

-ms macros

156

:set nolist

413

number

156

:set

resetting terminal type

480

:set

return to Shell, from ex

197

setenv

reroute, with pipe reset

95

macro, paragraph

resets,

resetting

registers

return to Shell, from

RETURN

key

rni

robin rotfbib

Roman

font

root

rows,

.RP .RS .RE

524

in tables

vi

nonumber number

EXINIT

27

setting a trap,

13

setting an editing option

85

setting your search path

macros

236 136, 179, 282 282 348 237 378

299 410

Shell

commands, combining

Shell

Mode

318 374

Shell

programming

Shell variables

281

423

.SH

149

398 342 342

single spacing text

70

slash-search

43

sort a

file

95 13, 81, 109

484

357

sort

357 410 335 286 335 65

sortbib

source

in a file

source .login .so

.sp

space down,

in

moff

spacing, with eqn

spanning entries

in tables

special characters.

Append Mode

special characters, editor special characters, in searches

65

452 431, 437 224 204 215

tables,

tables,

multi-columned spanned entries

TAB tail

432 431, 437 key 88

tbl

421

tbi

427 402 426

.TC .TE temporary copy of temporary indent Term type

file

106

66 11

terminal

11

special formatting tasks

174

terminal display of underlining

331

special rroy^'characters

321

terminal locations

247

specifying terminal type

41

terminal type, specifying

41

spelling check

89, 187

terminal, switch on

8

spell

88, 187

terminate a process

96

Spock, Mr.

239

text addresses

standard input

116

text blocks,

star (*) character, in Shell

308

text blocks, tables

Star Trek Addicts

239 486

change commands, one-way 129 text change commands, two-way 132 text changing commands 128, 229 text missing 474 text not filled 474

statistical

packages

stop scrolling

16

Stopped jobs stopping a process storage buffers, text

strange characters

stream editor

476 292 232 471, 479 482

232

form

letters

text

text operators

231

text storage buffers

232 66

.ti

string definitions

159

tilde (')

sub-directories

250 297 455 48

time share system

title

page, with nroff

130

title

page, with nroff -ms

submitting a batch job subscripts, with eqn

substitute a character

substitution

commands

title

252 41

lines

title lines,

substitution,

all

lines

213

titles, refer

substitution,

all

occurrences

213

.tl

substitution, current line

211

.TL

substitution, next occurrence

212

tmac. s

substitution, specified line

211

tr

346 header

&

footer

suggestions, typing

24

translate input characters

suggest

90

trap, setting

switch, on terminal

symbols, available with eqn syntax,

command

system crash

.T&

(in table)

tab(

+)

(in table)

table formatting table headings table of contents, formatting

8

trqff

450

trqff

92

388 435

-ms rrq/7'maximum

file

length

159 172, 393

393 408 346

398 352 360 360 348 312 312, 322 322 322 320

472 435 425

/rq//’output

//qZ/special characters

321

172

troubleshooting

468 424

430 172, 399

r/'q/f

request defaults

.TS two-headed arrows. Maps

42

525

!

two-way commands

42, 111, 132

u

314 317 24 44

U

140

ucb bin

315

type characteristics, determining type font typing suggestions

.ul

67

unadjusted text

72

111

uncompact

67

underline text

474 325 319

underlining, problems underlining, trojf'-ms

underlining, troff

44, 140

undo changes

.vs

317

:w

108

:w

command, forms

of

122, 303

291

wait weird characters on screen

49

wh who

348

widows word salad, display word salad, file

176



14

479 478 246

write write material into a

file

370 486

^rite permission

Workbench

Writers’

writing a

184, 185

108

file

71

writing for safety

182

uniq unique lines, locate UNIX Version 7

360

writing onto disk

108

361

writing out text

302

unpack

277

unfilled text

4

using the Modules

3

374 172, 355 440 317

usr bin utility

programs

vertical lines, in tables vertical spacing

23, 196

vi vi

Append Mode

110

V/

Command Mode

no

v4

with refer

408 86

view a file view end of file only view entire file view top of

file

visual editor,

commands

to enter

volunteer formatting, with -ms

526

writing,

UNIX

advance work

75 171

writing, grinding-it-out

173

writing, production issues

175

:wq!

108

X (in

vi)

46

.XA

400

.XE .XP .XS

401

X out

148

400 46 134

86

yank text yanked text, recall You have Mail.

234 242

87

yy

134

224

\

134

152

z#.

127, 227

ZZ

27, 107

88

only

writing process, with

QUICK ACCESS CHART

Add

Character

Word

Line

24, 129

24, 129

24, 129

a

i

A

I

O

0

a

47, 231

Change

Delete

Find

A

I

O

0

a

i

a

S

cc

229, 231

136, 229

yw

yy, :4co 6

24, 129

24, 129

i

A

I

0

O

a

i

A

I

0

44, 231

X

dw

dd

15

43

125

word

64G

/

24, 129 I

0

49, 231

24, 129 i

O

24, 129, 194

I

I

i

133

Join

J 231

Move

dw & p

Remove Substitute

Note: Page

0

45, 230

i

*

A

I

46

lb

Insert

O

0

cw

24, 129 i

A

1

48, 231

Copy

a

i

s

r

Create

*

46 X

45, 230

48, 130

48, 231

s

cw

number appears

in

139, 231

&

dd

command (s)

:

6 ni

33

44, 231

dw

top row;

n,

dd, :6 49, 130 cc

appears

in

S

bottom row.

527

Paragraph

File

Directory

24, 129

23, 191

172, 250

a

A

I

i

0

O

27, 107

49, 231

ZZ &

6S

7cc

ex

vi

6co

i

I

A

cd

24, 191

0

0

vi

ex

44

85

6dd

rm

226

266, 286 find

11

Add Change

Copy

cp

9

24, 129 a

250

84

136 Jyy, :4,

vi

mkdir

172, 251

mkdir 493 rmdir

Create

Delete

Find

Insert 87, 304

Join

cat

85

139, 231

6dd

&

p, :i,

5

85

6dd, :2,5d

rm

dec

6S

Move

mv

44, 139

49, 130

528

6m

493 rmdir

Remove Substitute

Map A

@ 3 O BC O Station 2

Shell (# $ Station 3

Mode

% &

or

Prompt)

^'^orcj

Station 4

ype

B Map

C Map

}

f

-n

amicuPftWOLO'sxsQmcEliW CENTER v^ MEDiCWSIRECT Tiso CieMENl 94121 cA.M cR^^iClSCO. CA

/M .asUS'l

PATHOLOGY SERVICE (USA) VA MEDICAL CENTER 4153 CLEMENT STREET StCi FRANCISCO, CA 94121

ClITllCAL

unixforpeoplemodOObao .n,x.orpeoplemodOOb,rn

nonintimidating “hands-on” guide to the UNIX Operating System that assumes no previous experience with UNIX or computing in general. Beginning programming stCidents and people in business and Industry

A

use UNIX through a systematic, step-by-step, at-the-termlnal Introduction to the various resources available on the UNIX system. Spiral binding, larger type, extensive field testing, and a tutorial format make this book easy to use and understand. learn to

SPECIAL FEATURES: •

Procedural Approach. Each concept

is

introduced with a “doing”

activity.

• •

Learning Objectives and Procedures. Clearly stated. Friendly Style. Directed to people with a variety of experiences, educational levels, and occupations.





Conceptual Maps. Visual representations of the system make the material easier to comprehend.

Sequencing of

Activities.

A method

that

Is

crucial in this kind of

book.

Also of interest: Illustrations (drawings and photographs) reinforce concepts and demonstrate actions.

a

PRENTICE-HALL,

INC.,

Englewood

Cliffs, N.J.

07632

ISBN 0-13-13?MS'f-0