The Interactive Programming Env

Download as pdf or txt
Download as pdf or txt
You are on page 1of 530

SmalltalkThe Interactive Programming Environment

Adele Goldberg
Xerox Palo A lto Research Center

TT

.. Addison-Wesley Publishing Company Reading, Massachusetts Menlo Park, California London Amsterdam Don Mills, Ontario Sydney

This book is in the Addison-Wesley series in Computer Science MICHAEL A. HARRISON


CONSULTING EDITOR

Library of Congress Cataloging in Publication Data


Goldberg, Adele. Smalltalk-BO. Includes indexes. 1. Smalltalk-BO (Computer system) I. Title. II. Title: Smalltalk-eighty. QA76.8.S635G638 1984 001.64 83-11856 ISBN 0-201-11372-4

Copyright @ 1984 by Xerox Corporation. All rights reserved. No 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 the prior written permission of the publisher. Printed in the United States of America. Published simultaneously in Canada.
ISBN 0-201-11372-4 EFGHIJ-HA-89

Preface

The user interface to the Smalltalk-80 system is a multipurpose interface, designed to facilitate text and graphics creation and manipulation, program development, and information storage and retrieval. You, as the user create, manipulate, save, or retrieve, either a visual form or specific information within such a form. You interact with the system on a bitmapped display screen, using a typewriter keyboard and a pointing device. The Smalltalk-80 system includes utilities typical of a computer's operating system: compiler, debugger, text editor. These are brought together on the display screen in the form of a collection of rectangular areas or views of information. One rectangular area might view the text of a program under development. Changing the text is accomplished by pointing to the parts to be changed, and typing new text or issuing an editing command such as delete. When the text is considered correct, an accept or compile command is issued. If any syntactic errors are detected, they will be indicated in the text in the window so that they can be corrected right away. Once all syntactic errors are corrected, the text is compiled into object code and linked into the system, as the system is running. The new code can then be tested by typing an appropriate expression, selecting it, and issuing an evaluate command. This process is immediate; no exchange of editing, compiling, filing, or executing ((modes" is required. Part One of this book is an introduction to the user interface to the Smalltalk-80 system. Part Two is an explanation of the support provided for finding information about objects that exist in the Smalltalk-80
iii

iv Preface

system. Part Three is an illustrated description of how to explore the class descriptions available in the system, and of how to use the editors for implementing new class descriptions. Part Four presents the support available for finding and correcting errors, while Part Five introduces access to external files and system housekeeping support such as crash recovery and change management. Parts One through Five explain how to manipulate the components of the user interface. They are written to encourage specific practice and exploration; each section includes suggested exercises. A brief introduction to the Smalltalk-80 language is also provided in order to explain the ways in which the interface components provide access to the language components. If you have access to a Smalltalk-80 system, you will need to read the book only once, after which you can rely on the on-line aids provided by the interactive system. The on-line aids consist of a menu-oriented interface to remind you of available functionality, comments for each class and method, an Hexplain" capability that can identify the tokens in a method, and a spelling corrector. This book is not intended as an introduction to programming in the Smalltalk-80 language. If an indepth understanding of the language is desired, you should use this book in conjunction with Smalltalk-80: The Language and its Implementation, by Adele Goldberg and David Robson (Addison-Wesley, Reading, Mass., 1983), which includes reference material for the system classes. Because of the detailed scenarios and figures, this book can be used independent of a running system to learn about the components of the user interface, and about the process of working with a graphicaloriented, interactive system development environment.

About the Described System

The system described in this book was released for general licensing in May, 1983, by the Xerox Corporation as the HSmalltalk-80 System Version 2." Version 1 was a preliminary version of the system that was originally released to several companies participating in a review of the formal specification of the Smalltalk-80 virtual machine, and provided by Xerox Electo-Optical Systems (now Xerox Special Information Systems, Pasadena, Calif.) in 1981-1982 as one of their software offerings on the Xerox 1100 Scientific Information Processor. Version 2 added functionality to the system, notably the spelling correction used in compiling and debugging methods; special browser queries about instance

v
Preface

and class variables, class references, and class hierarchies; and special inspectors. As a language, the Smalltalk-80 system Version 2 includes support for multiple inheritance and multiple language compilers. Some of the examples provided in this book use system user interface components from Version 2 that do not exist in the Smalltalk-80 System Version 1. The larger examples of Smalltalk-80 definitions given in this book are provided to Xerox customers or system licensees as part of the files on their disk or magnetic tape. This includes the protocol and project browsers described in Chapter 15, the model for financial histories developed in Chapters 17, 18, and 19, and methods for viewing and interacting with financial histories listed in Appendix 1. Glenn Krasner and Evelyn Van Orden have been the main motivators and supporters in getting the system releases and examples completed for this kind of distribution.

Acknowledgments

As the Smalltalk-80 system evolved and was tested by nonXerox commerical organizations and universities, this book evolved from a user manual to a general description of the programming environment. The choice of content and organization benefited from review by many people. Norman Meyrowitz of Brown University was especially instrumental in pointing out omissions of detail. I wish also to thank Susanne Bodker, Glenn Krasner, Michael Madsen, Paul McCullough, Michael Rutenberg, Rachel Rutherford, and Evelyn Van Orden, (all of the Xerox Corporation); David Casseres (Apple Computer), Pavel Curtis (Cornell University), Steve Draper (University of California, San Diego), and Trygve Reenskaug (Central Institute for Industrial Design, Oslo, Norway). The Smalltalk-80 System is the result of research and development of the Software Concepts Group of the Xerox Palo Alto Research Center. As the group manager, I took responsibility for documenting the system. It is not possible to identify the individual contributions made by each member of the group in the creation of the complete system. However, I would like to point to several aspects of the system documented in this book, and acknowledge several contributors: the system browser was first introduced by Larry Tesler and then enriched by Dan Ingalls, the debugger was introduced by Dan, the change manager by Peter Deutsch, the version handler by Steve Putz, the special inspectors and the file list view by Glenn Krasner, and the form and bit editors by Bob Flegal and Diana Merry. The first version of spelling correction was implemented by Steve and then incorporated into the system com-

vi Preface

piler by Dan. Ted Kaehler created the explanation utility on a suggestion by Ellis Cohen of Brandeis University. In addition, the example of a protocol browser given in Chapter 15 was suggested by Dave Wallace from the University of California, Berkeley, and that of the combinations of elements of a collection by Steve Putz. Many new ideas and bug fixes came from our colleagues at the Xerox Special Information Systems, including Evelyn Van Orden, who maintains the customer release version of the system (a system that includes network communication facilities), Rae Conrad, Bob Lansford, and Michael Malcolm (whose clever scrolling additions to the text editor are included in Version 2). Glenn Krasner, Dave Robson, and Steve Putz helped me complete Version 2 of the Smalltalk-80 system, create the images of the display screen for the book figures, and produce the magnetic tapes for the typesetter. As in the other books in the Smalltalk-80 series, the original text for this book was supplied to the publisher on magnetic tape that included formatting codes identifying the various types of textual entity in the manuscript. The software for the conversion from the Xerox internal formats to that of the typesetter was written by Dave Robson. The timely manner in which the production process was handled was due both to Dave's software and personal support, and to the efforts of Eileen Colahan of the International Computaprint Corporation and Fran Fulton, the production editor. The original syntax diagrams shown in Chapter 5 were prepared by Janet Moreland. All the figures that represent the Smalltalk-80 display screen graphics and the chapter opening artwork were created by me using the Smalltalk-80 system. They were printed on the Platemaker system developed by Gary Starkweather and the Imaging Sciences Laboratory of PARCo I would like to thank Gary, Eric Larson, and Julian Orr for making the Platemaker available. Registered trademarks mentioned in this book are Lisa, (Apple Computer Inc.); VAX 11/780 and VAXstation (Digital Equipment Corp.); and Smalltalk-80 (Xerox Corp.). Adele Goldberg Palo Alto, California October 1983

Contents

PART ONE

The General System Interface 1 Introduction to the Book and the System 1.1 Appearance of the Hardware System 1.2 Getting Started 1.3 Try It, Just to See 1.4 Stopping a Work Session 1.5 Summary of Terminology 2 Basic User Interface Components 2.1 Display Screen Visual Cues 2.2 Designating Rectangular Areas on the Display Screen 2.3 Menus 2.4 The System Menu 2.5 Standard System Views 2.6 Summary of Terminology

1 3
6

14
15 22 26
29
30

34

35 41 46
49

3 How to Use the Text Editor 3.1 Text Selection 3.2 Inserting Text

51 52

57
vii

viii Contents

3.3 Issuing an Editing Command 3.4 The System Transcript 3.5 Summary of Terminology 4 How to Use Projects 5 FundaJnentals of the Smalltalk-80 Language 5.1 Objects, Messages, and Methods 5.2 Expression Syntax 5.3 System Components 5.4 Overview of the Programming Process 5.5 Summary of Terminology: General Concepts 5.6 Summary of Terminology: Syntax 6 How to Evaluate Expressions 6.1 The do it Command 6.2 The print it Command 6.3 The System Workspace 6.4 Examples 6.5 Summary of Terminology 7 How to Make Pictures 7.1 Making Pictures with the Form Editor 7.2 Making Pictures with the Bit Editor 7.3 Making Pictures with Expression Evaluation 7.4 Summary of Terminology
PART TWO How to Find Information in the System

57 65 65 67 75 76 80 95 99 102 103 105 106 110 111 112 116 119 120 133 136 139
141

P.

8 Finding Out About Instances 8.1 The Structure of an Inspector 8.2 Changing the Values of Variables 8.3 Sending Messages to an Object 8.4 Special Kinds of Inspectors 8.5 Finding Out About a Running Process 9 Finding Out About SysteJn Classes 9.1 The Structure of a System Browser 9.2 Messages to a Class versus Messages to an Instance

143 144 147 154 156 159 161 163 168

ix

Contents

9.3 Browser Menu Commands 9.4 Browsing a Subset of the System

172 187

10 Finding Out About Messages and Methods 10.1 Which Methods Send a Particular Message? 10.2 Which Classes Implement a Particular Message? 10.3 Which Messages are Sent in a Particular Method? 10.4 Which Methods Reference a Particular Variable or Literal?

195 196 199


201 206

ART THREE

How to Modify Existing Classes and Create New Classes 11 Modifying Existing Class Descriptions 11.1 Modifying Existing Methods 11.2 Modifying Protocols 11.3 Adding New Methods 11.4 Modifying Class Comm.ents 12 Modifying Existing Class Definitions 12.1 Name of Superclass 12.2 Name of Class 12.3 Instance Variable Declarations 12.4 Class Variable Declarations 12.5 Pooled Dictionary Declarations 12.6 Class Category 13 Creating a New Class Description 13.1 Define a New Class 13.2 Define the Class Protocol 13.3 Define the Instance Protocol 14 IDlproving PerforDlance 15 ExaDlples of Creating or Changing Browsers 15.1 A Protocol Browser 15.2 A Project Browser 15.3 Modify Class Project 15.4 Change the System Menu

215

217
218 224 233 249

251 252 254 260 266 267 268 273 274 278 284 295 299 300 322 339 346

x
Contents

PART FOUR

How to Find and Correct Errors

351

16 Spelling Correction 17 Syntax Errors 17.1 Variable Name or Message Selector Errors 17.2 Poorly-Formed Statements or Methods 18 Notification of an Execution Interrupt 18.1 Incorrect Message Selector 18.2 Other Runtime Errors 19 Exantining and Debugging Execution State 19.1 The Activation Stack 19.2 The Structure of a Debugger 19.3 The Context of a Message Receiver
19.4 The Context of an Interrupted Method 19.5 Evaluation Within the Context of an Interrupt

353 363 364 369 375 376 383 385 386 388 394
395 396

20 Kinds of Execution Interrupts 20.1 Breakpoints 20.2 User Interrupts


20.3 Running Out of Space 20.4 Recursion in the System Error Handler

21 Single-stepping Through an Execution

401 402 409 409 411 415

PART FIVE

External Files

429
431 432 436 450 457 459 460 462 467 477 480

22 The File Systent 22.1 Writing Code onto a File 22.2 Accessing the Contents of a File 22.3 Retrieving the Contents of a File 22.4 Getting Started Revisited 23 Systent Backup, Crash Recovery, and Cleanup 23.1 Saving Your System State 23.2 The System Change Set 23.3 The System Audit Trail 23.4 Creating a HClean" System
23.5 Version Management

xi Contents

Appendixes 1 Financial History Views and Controllers 2 Smalltalk-80 Software Development Do's and Don'ts Indexes System Workspace Index
Menu Command Index Subject Index

485 499 503 510 512

The General System Interface

The Smalltalk-80 system consists of an object-oriented programming language and an integrated collection of tools for interacting with components of that language. In the Smalltalk-80 language, the fundamental way to indicate that something should happen is by sending a message to an object. An object is a representation of information consisting of private memory, and a set of operations to manipulate information stored in the private memory or to carry out some actions relative to that information. Sending a message is the Smalltalk-80 way of asking the object to carry out one of its operations. All information in the Smalltalk-80 system is represented as an object. Each object knows the messages it can understand. Associated with each such message is a method that describes how the object should respond to the message. The user interface to the Smalltalk-80 system can be viewed as a graphical way in which to identify objects and to choose messages to send to objects. When an object is sent a message, the appropriate method is invoked and some action is taken. The purpose of this book is to describe the varied ways in which objects and messages can be identified and methods invoked; its purpose is also to describe some useful ways in which information about objects can be retrieved. This book is written in a tutorial or "try and see" style. Each section describes the functionality of a part of the user interface and then encourages you to employ that functionality. Although this book does not substitute for a detailed exposition about the language, an overview is provided and a summary of the language syntax is included. The overview is sufficient information so that you can understand the chapters on evaluating expressions, on accessing objects already in the programming system, and on creating new objects.

1
Introduction to the Book and the System
1.1 Appearance of the Hardware System Appearance of the Display Screen Pointing Device "Buttons" 1.2 Getting Started System Files 1.3 Try It, Just to See 1.4 Stopping a Work Session Saving Information 1.5 Summary of Terminology

4 Introduction to the Book and the System

The Smalltalk-80 system runs on a microcomputer that includes a highresolution bitmapped display screen, a typewriter keyboard, and a pointing device. The display is used to present graphical and textual views of information to the user. The keyboard is used to present textual information to the system. The pointing device is used to select information on the display screen. The pointing device controls the movement of a cursor on the screen; the cursor shows the location currently being selected. The pointing device can be, for example, a mouse, a graphics tablet, or function keys on a keyboard. There are a variety of hardware configurations on which the Smalltalk-80 system runs. These configurations might have different resolutions for their display screens, different layouts of keys on their keyboards, and different types of pointing devices. Photographs of several Smalltalk-80 systems are shown in Figure 1.1. Several sections of this book depend on the particular hardware configuration that you, the user, have available. These are Sections 1.1 and 1.2, on the hardware system and on how to get started, and the chapters of Part Five on the use of an external file system. Much of the interface to external files is the same for all hardware configurations, but the particulars of naming files and creating system back ups may differ. For a description of the hardware devices you have available, the initial start up sequence you must follow, and the file-naming and back-up conventions you should use, you must obtain information specific to your system that is not provided in this book. Throughout the book, an indented paragraph of small print is used to provide information at a level of detail that may be of interest to you if you want to know a bit more about the structure of the Smalltalk-80 system.
For example, the names of classes that support a user ihterface component may be given, along with messages that implement a particular user interface function.

You can skip over these comments without losing information needed to interact with the system. Also, alternate designs are given in small print as suggested exercises that you might try if you are proficient with the language and the programming environment.

Figure 1.1 Top: Tektronix Magnolia, experimental workstation (photo by Edward L. Reuss, courtesy of Tektronix Inc.), Apple Lisa, experimental software (photo courtesy of Apple Computer Inc.); middle: Hewlett-Packard Laboratories, development station (photo by Rich Marconi, courtesy of Hewlett-Packard), Digital Equipment Corp.,VAX-111780 with VAXstation display (photo by Charles W. Gamage Jr., courtesy of Digital Equipment Corp.); bottom: Xerox Dorado and Xerox implementation on the SUN Microsystems Inc. workstation (photos by K. O. Beckman and Wes Dorman, courtesy of Xerox Corp.).

5
Introduction to the Book and the System

6
Introduction to the Book and the System

1.1
Appearance of the Hardware System
The significant parts of the hardware on which the Smalltalk-80 system runs are identified in Figure 1.2: the keyboard, the display screen, and a pointing device. These are the parts that playa significant role in the user interface of the system. In Figure 1.2, keys that playa specific role in the Smalltalk-80 text editor are labeled. Henceforth, the names of the keys as indicated in the following keyboard map are used, rather than the key-cap label. To use the system, you must determine the correct mapping for the hardware system you have available. Also in Figure 1.2, the coordinates of the corners of the display screen are marked. Notice that position 0, 0 is at the upper left corner of the screen, and that the y-coordinate increases as you move down the screen.
0,0 1024.0

Display Screen

0,808

_ _~.--

......_ _J

1024.808

Pointing Device

Space Bar
Figure 1.2

Keyboard

7 1.1 Appearance of the Hardware System

key names
backspace carriage return control delete escape line feed space bar

key cap label

BS RETURN CTRL DEL ESC LF


no label (bottom row, large single key)

Appearance of the Display Screen

The display screen has a light gray background. White rectangular areas containing text and/or pictures are placed against this background. Each of these areas is called a view. The content of a view is the text and/or picture within its rectangular border that you can examine, create, store, and retrieve. A sample image of a Smalltalk-80 display is shown in Figure 1.3. Most of the views on the Smalltalk-80 display screen are standard system views, meaning they provide some standard functions. In particular, you can visually identify a standard system view by a label change the screen location of a standard system view change its size replace it with an area containing only the label remove it from the screen

In Figure 1.4, there are several standard views. Each has a label in the upper left corner. Some, such as the two views in the center of the figure, consist only of a label. These are referred to as collapsed views. The views in the figure are in different locations and have different sizes. The view at the top of the figure consists of five parts or subviews. The content of a subview might depend on the content of one or more of the other subviews. When you are working on several different tasks, the tasks can be presented in a variety of ways: with each in a different view, with some or all in the same view, or with some tasks, such as background processes, in no view at all. Views are known to a special system object called a control manager. This manager's job is to let you move the cursor within the border of a view, and to interact with either the view itself or with the information inside it.

8 Introduction to the Book and the System

*,st

:~~~~~<!H::H:H:H::!<:::::H::::::v:::m:::H:V:::::WUUU::::::::::V::U:HHi
G a, II ey Form - e I,:" sS- fro mC;i a, II ey -, st, La, st Pa, t-en t - t;e reenO ut - C 1'"1 a, nl~e s, st, PressOut,st, t:ereene)lj t ,s t,

'From :3m,:..llta.1k-eiJ of 'le A,pril '1ge:3 [\/:31J on 26 ,.il,pril198:3 :3:04:66 pm PDT ("',,'lond,:..y)'! !FileDireetcwy cl,:..ss mett"lodsFor: 'utilities'! file s[1,11 ':., tel'"lin9: fileDesi9na tor ",.il,ns'",ver a, collection of the names of files tt"la.t ma.tch the strin9, fileDe5i,~n,:..tor. E>::ample: FileD iree tory fil esrv1a. tchin,~: <Systern>*,errors' "
p,3. ttem I dir .,. self l~ireetoryFromr',].:..me: fileDesign,:'.tor setFile[\Ja.me: [:pa.ttemJ. t'air files[" . .1atct"lir,,~: p,Htem!

I dir

System :3ystem Tra.nscript

\o\/or~:,sp,:..ce

Srnalltalk-80 of April 1, 1983 Copyright (e) 1983 Xerox Corp.

Imm:::!:!!:!!:!:!1 All rights reserved.


Create file System t;ourceFiles .,. ,.il,rra.y ne'.. v: 2. t;oureeFiles ,:"t:l put: (File::;trea.m oldFilef\Ja,rned:

'sma."ta.'k;3iJ'Soun::esill')~'~il~

Figure 1.3

9
1.1 Appearance of the Hardware System

matt"lematical fun testing . n .:tnd rOI


IrnplernerHor~

+
,..
"
" " "

of

r",lurnber

Point + .Small'nteger

I tempor-.5.ry
sta.ternents

"lariat

A+ aNumber ".".ns'Ner the sum of the receiver .5,nd a,r\lurnber, " self subcl.5,ssResponslbility

Grea te File System :30ut"ceFiles t- ,"".rray nevY': 2. :30urceFiles a.t: '1 put: (Filec;tre.5.m oldFiler\Ja.rne,j: 'c;ma.llta.lk8D.sources'), :3ourceFiles .5.t: 2 put: (Filecitrea.rn oldFilef'J.5.me,j: '::ima.llta.IH30.ct"I.5.rll~es'). (:3ourceFiles .H: '1) rea.dOnly.

Figure 1.4

10 Introduction to the Book and the System

mmm

System 8rovI'ser

lI:il l !ililil lijl i ilr~ ~Ju~r~o~ ~ri~c~, ~~~'1~a~q~n~it;"u:r============


{\JIJmgt"ie [\!ur;lbers Collee tions - ,6, bs tr 1>,<~nl~~>~'1 Collections-Unord ColIgctions-Tg),:t

iil!i.l!i:

":':""':"."",',','1 Coil get ion s- Ei equ ~


","!'!'!"!'!'!'!'!'!!!'!.".-

Jij~~~ooe;1 c I':.. s s

-I

bitrna.pped displ.:.,y sct"gen, .:.. typg\vritgr keybo,:'.rd, a.nd ':.. pointin!3 (JevIce, Thg displ,:.,y is used to prgsgnt qra,prdca.1 .:..nd textua.1 ',lie"""iS of inform,:'.tion to trle user, The keybo,:..rd IS used to present te:",:tua.1 informa.tion to the system, The pointin!~ de . . , ice is used to select inforrna. tion on trle disp!a.)1 scr-ggn. Thg pointing de...'ice controls trle mO'",'ement of a. cursor on the screen; the cursor ShOV'iS the loc,:..tion currentl~.,. bein!~ selected, Trle pointinq device c,:'.n be, for e>::a.mple, .3. mouse" ':.. gra,prdcs t,:"blet, or function key's on a, keyboa.n:J;.. ~ There ,:"re ':.. ',/a,riety of rla.r(j',I,0',:"re conflr~ur.:.,tions on ',vrdcrl the Einnllta.lk-eO system runs, These configur,:..tions might rla,.. 'e different resolutions for their display sct-eens" diffgrent l.3.youts of keys on trreir keyt,o.:..n:J, bno:! different t:.'pes of pointing de""lces, F'hotOr~r,:..ph5 of 5e'/er.:d :3m,:'.llta.lk-:30 systems aTe srlo\vn in Fi'3ure1.0.

Ill,lllllll!lllllill

:3ystgm \,Vorksp,:..c

Create file Syste


EiOUrcgFilgs ... ,6,n EiourcgFiles ,:..t: '1 oIdFi Ig r',J a. m12 d: ':; m,:'.11 t a IkeO, sour ::'ourceFiles a.t: 2 oldFilef',J,:'.m ecJ: '::i rna.llt a.lkeO, c rl a, n i g S"I,

Figure 1.5

11 1.1 Appearance of the Hardware System

Available screen space has been optimized by allowing the views to overlap, partially or wholly. The active view (the view in which you are currently working) is automatically moved to the top of any stack of overlapping views. Since a view often contains more information than can be displayed at any given time within its boundaries, an additional scroll bar area is associated with each view, where appropriate. A scroll bar presents a method by which you can specify the part of the available information that you want displayed. In Figure 1.5, a view of textual information is the active view, the one labeled Workspace. Its scroll bar area is shown at its left side. The fact that the gray area of the scroll bar fills only part of the scroll bar height indicates that you see only part of the information that can be accessed using this view.

Pointing Device "Buttons "

A likeness of a pointing device used by the Smalltalk-80 system developed at the Xerox Palo Alto Research Center is shown in Figure 1.6. It is called a mouse. The cursor on the display screen is moved by moving the mouse over a flat surface. The mouse has buttons on it which are used to make different kinds of selections. Some hardware configurations for the Smalltalk-80 system have buttons on the pointing device that can be used to select display positions or to request the display of a particular menu. Other configurations use keyboard function keys for the same purpose. Each configuration shares an identical collection of techniques for accessing objects and messages, and an identical collection of tools for manipulating objects. For example, each system shares a common editor for creating and modifying text or pictures. The Xerox mouse has three buttons on it. These buttons are identified in Figure 1.6 as red button, yellow button, and blue button.

III
Figure 1.6

red yellow button button

blue button

12 Introduction to the Book and the System


The names are for historical, not visual reasons. Some of the original Xerox mice had colored buttons.

Throughout the standard Smalltalk-80 system, red button is used to SELECT information yellow button is used to get a menu for EDITING the CONTENTS of a view blue button is used to get a menu for EDITING the VIEW itself In referring to the use of the buttons, we will use the following terminology: press release click double click
push and hold the button down remove finger from button, letting the button up press button, then release it, without moving the cursor click two times in succession, without moving the cursor

Some people refer to selection using a click as bugging. Their expressions take the form of "bug that command" or "bug outside the view."

Note carefully that we distinguish between pressing the button down without releasing (press), and pushing the button down and releasing (click). Note also that a selected item is highlighted, typically by complementing it. To complement text, black characters on a white background are changed to white characters on a black background. For many operations, pressing the button down is a separate action from releasing the button. Pressing down the yellow or blue button, for example, causes a list of items to appear on the screen; releasing the button chooses the selected item. This list of items is referred to as a menu. While the button is down, the system provides feedback about what can occur. For example, a menu item may be highlighted to indicate that it will be the one chosen if the button is released. This gives you a chance to confirm visually that it is the desired item, or to move the cursor to a different item and to see it selected (highlighted) before you release the button. Releasing the button chooses the item. The distinction between pressing and releasing a button is a significant one to learn in order to be able to interact with the Smalltalk-80 system. Most actions occur as a result of releasing a button. There are only two places in the system where the action is invoked when the button is pressed down: in controlling the scroll bar, and in selecting text. In Figure 1.7, notice the image of the pointing device at the lower left side. The image consists of a rectangle with three subareas; one of the three subareas is filled with black, the others are white. Each area denotes one of the buttons you can press. In the picture, the image indi-

13 1.1 Appearance of the Hardware System

This is sorne text that '''''''''--,-_ been typed into a work

Thi:;; i::: ~;ome t.ext. t.h; been typed in to a


"',1.,r

C \J t

..:t:5te

~:I!j':!\:::::!"!:i::jjjj::iii'.i.

or:ks})::tce,

Figure 1.7

010

This is some text that been typed into a workspace;."

~~cJ~O~1t~1 1 Il! il l l l l l l !l il :il il il II 1


1 ri nt it B.ccept cB.ncel

cates that the yellow button is currently being pressed, causing a menu to appear and an item in the menu to be highlighted. This image is used throughout this book in order to illustrate pressing a button, even though the three buttons on the hardware system you are using may not be grouped or packaged on a single rectangular-shaped device. The four possible button images that may appear at the lower left side of a figure are shown in Figure 1.8. Each button image represents a press of one or no button. When we wish to denote "clicking" a button, two button images will be displayed at the lower left side of the screen image. The first button image designates the button to press, and the second indicates that a release should follow. Figure 1.9 shows the three possible images for button clicks.

Figure 1.8

denotes no button pressed

denotes red button pressed

denotes yellow button pressed

denotes blue button pressed

100 010 001 000 000 000


click red button

Figure 1.9

click yellow button

click blue button

14
Introduction to the Book and the System

1.2
Getting Started
In order to get your Smalltalk-80 system started, there should be a separate document for you to consult that describes your particular hardware system and file-naming conventions. It will identify the files you need, the procedure for turning the power on, and the commands or buttons to push in order to install the Smalltalk-80 system. On most of the Xerox systems, for example, there is a small button located at the back of the keyboard that you push (called the "boot" button). A herald will appear announcing the Xerox Executive. If the Xerox Executive is installed with the proper files, you can then type
@st80.cm

and then press the "carriage return" key. After a few moments, an image of the Smalltalk-80 programming interface should appear on the display screen.

System Files

Although different implementations may have different start up procedures, and perhaps require different sets of system files, the basic Xerox Smalltalk-80 system requires four significant files.
ST80 < Version> .im
This is the Smalltalk-80 system image. It contains the compiled form of each method, as well as the initial bitmap that appears on the screen when the system is installed, and all the other system objects. This file contains the text for each method in the system. The compiled form of each method includes an index into this file so that the text can be retrieved upon user request. In the Xerox systems, when a network-based file server is available, this "sources" file resides on the file server and is shared by all Smalltalk-80 users. Initially this is an empty file. When the user interacts with the Smalltalk-80 system, each action that involves evaluating an expression is stored in this file. If the system crashes, it is possible to recover your work by evaluating the expressions stored in this file. See Part Five for more details. This is the "run file" or virtual machine emulator for the Smalltalk-80 language. The system is invoked by executing this file with the name of the image file as its single argument. The file ST80.cm is a "command" file; it is an indirect way of naming the two files.

STao < Version> .sources

STao < Version> .changes

STao < Version> .run

15
1.3 Try It, Just to See

Wherever we have written < Version> in naming a file, we mean that the file name actually contains a date indicating a particular system release. Typically the date should be the same for all the files. In the Xerox systems, capitalization in file names is not meaningful.

1.3
Try It, Just to See
The next chapters present details about the basic user interface components, the text editor, and how to evaluate Smalltalk-80 expressions. Before reading these chapters you might wish to try the system, just to see what you can do. This section illustrates an example interaction you can try in order to get an early introduction. You already know that the display screen has a light gray background and that there may be one or more rectangular areas containing text. Move the cursor so that it is not inside any rectangular area, that is, move it so that it is over the light gray background. Press the yellow button; do not release the button. A menu appears (Figure 1.IOa).

Smalltalk-80 of April
Copyt"jght. (c:) ,6,11
t"i!~ht5 '1ge~; '::<'E!ro~(

COt-po

t'eS,;w'ied,

Create File System


::iout"ceflles to. ,':::"tT.3.Y nev\,': 2. ::i(lut-c:eFtles .3.t: '1 plJt: (Flle:3tre03.rn
oldFile~.J". me,j;

'I" stl,3.stp"rent.sout'lces '),

This is some text that has been typed into a workspace.


This is
50rne

te>::t

t~I,9.t

h.3.::; been typed into

V'/Ot-kSp,3.ce,

This is some text that has been typed into '-\ works}Jaee.

Figure 1.lOa

010

16 Introduction to the Book and the System

Move the cursor up and down, noticing that different menu items are highlighted. Move the cursor so that the item workspace is highlighted. Release the yellow button. The cursor changes shape (Figure 1.10b). Move the cursor anywhere towards the center of the screen and press the red button. You have selected the upper left corner of a rectangular area. The cursor changes shape again (Figure 1.10c). Move the cursor around to select the lower right corner of the area. Release the red button. You have now created a small workspace on the screen (Figure 1.lOd).

Smdlltdlk-60 of April Copyright (c) 't983 >:.ero): Corp. ,".11 ril~~lts reserved. Credte File System
:3(1ut-ceFile" .,. .... tT.~.y new: 2. ::k,urceFile" .~.t:1 put: (FileStrea.rn (I IdFi Ie r.] arne d: ' Io. S t I." st Po. re n t. SCI U t-c e,,').

This is some text thdt hdS been typed into d workspdce.


This is
"//0 tk.s

5Qm12

te) t th,;.t has tleen typed into ,;.

p a. c e,

This is some text that has been _---IU"UUI t~"ped into i.l workSlli.lC~e.
Figure 1.1Gb

000

17
1.3 Try It, Just to See

text th,".t ha.s been typed into ,""

This is some text that has been t}'ped into a workspace.

Figure 1.1Oc

100
Srnallulk-80 of April 1, 1983
Copyt"ight (c) '1913:3 .>~,etJj::( Corp. ,"'.11 rights resen,'ed,

,~"

nev/: 2. ut: (FHeEitrea.m

This i5 some v,/or"ksp,".ce,

This is some text that has been typed into a workspace.

Figure 1.1 Od

000

18
Introduction to the Book and the System

Make certain the cursor is inside the workspace. Type


3+4

and then press the "escape" key. The three characters, 3, +, and 4 should be highlighted (Figure 1. lla). If not, place the cursor just before the character 3, press the red button, move the cursor past the character 4, and then release the red button. The characters should be highlighted. Note that they make up a Smalltalk-80 expression.

Smdlltdlk-80 of April 1, 1983 Copyd!jht (c) 198:3 ,:X:~ro> CI:lrp. ,':',11 ri!~~lts reserved,

'/' nQ\h':

2,

.:~.

Trli;; is

5Cim~ t

v',"ork3pa.CE!,

This is some text that has been typed into a worksllace.

Figure 1.1la

000
Be sure that the cursor is still inside the workspace. Press the yellow button so that another menu appears (Figure l.11b). Move the cursor so that the item print it in the menu is highlighted (Figure 1. llc). Now release the yellow button. Notice that the expression has been evaluated and the result printed in the workspace. The result 7 is highlighted (Figure 1. lld).

19 1.3 Try It, Just to See

Copyright (c) -19:3:3 ,::{ero>: COt"P'

,b,II ri9ht5 re5er"/ed.

,~!~a,in

undo

cut'\
p."ste do It ,rint it accE!pt co.ncel

v nQ"N: 2. IJt: (Fi!e:::itrea.rn

This is some text that has been t}'ped into a workspace.

Figure l.11b

010
CClpydgrlt (c) '19:=::3 ,:'{et"o", Corp,
.!;II li'~~lt::. resen,ed.

a.I~.~.in

undo

V~'Otk5p,;..ce.

This is some text that has been typed into a workslJace.

Figure l.11c

010

20
Introduction to the Book and the System
. .

,
.. . 11
1',>1 Smalltalk-80 of April 1, 1983

Iii I Copyri,~ht

(c)19::;:~: >::er"o', COt-p,

..

. ! . : -......................,
\\,'Ol"f spa c e

Ij

1:. ..

,j,:::

t: (FilJ::!::; t n:l ,j. m t p ,j, tOQ nt,::: I) IJ rc ~:::'),

'. .
.

This is some t workspace.

Figure l.11d

000

Press the blue button so that another menu appears (Figure 1.12a). Move the cursor so that the item close is highlighted (Figure 1.12b). Release the blue button. A special menu called a confirmer appears. You have requested closing a workspace, but the contents have not been saved. This is acceptable to you. Notice that as you move the cursor around, the shape of the cursor changes. When the cursor is over the part labeled yes, it is shaped as a hand with a thumb pointing up; when the cursor is over the part labeled no, it is shaped as a hand with a thumb pointing down. If you move the cursor outside the confirmer, it will "flash" or "blink" to indicate that you must answer the confirmer's question before proceeding. Move the cursor over the part of the confirmer that is labeled yes. Press the red button (Figure 1.12c). The item labeled yes is framed by a gray box as a way to indicate it is selected. Release the red button. The workspace will disappear. If you were able to follow the example, you successfully created a new view on the screen, used the text editor, evaluated an expression, and closed the view.

21 1.3 Try It, Just to See

Smalltalk-80 of April 1, 1983


CoPyri9ht (c) 19E:3
.::<.12TOX

C:orp .

."-,11

rig~lt;.

re,.;,r,/ed.

" neV'l: 2.

T~d,

i, ,c,rne te>::t

''1V'Jrk5p,~.ce,

This is some text that has been typed into a worksllace.

Figure 1.12a

001
Sma!ltalk-80 of April 1, 1983 C')P:"Tig~lt (c) 198:3 .~<.ero:< Corp . ."-,11 t'h~ht, re,etved.

ur,der
mO"iE!
fr,~rne

collap,e

Tr,is is some text "/%rUpa.ce,

This is some text that has been typed into a worksllace.

Figure 1.12b

001

22
Introduction to the Book and the System

I I I
r
yes
This

I
I
e

i5 somo;, te::<t t

WOrf(5pace.

This is some text that has been typed into a workspace.

Figure 1.12c

100
When you are ready to stop using the system, you choose a menu command quit. Move the cursor so that it is over the light gray background. Press the yellow button to obtain the menu and move the cursor so that the item quit is highlighted (Figure 1. 13a). Release the button.

1.4
Stopping a Work Session

Figure 1.13a

010

23
1.4 Stopping a Work Session

Another menu appears (Figure 1.13b), giving you three command choices.

Figure U3b

000
Save, then quit Quit, without saving
Creates a snapshot as described later in this section, and then takes you out of the system. Takes you out of the Smalltalk-80 system. (Each implementation of the system will differ as to what happens next. In the Xerox systems, you are returned to the Xerox Executive. You then type quit followed by a "carriage return" to blacken the screen.) Erases the menu and continues your use of the system.

Continue

Choose one of these commands by moving the cursor over the menu, press the red button, move the cursor until the item you prefer is highlighted (Figure l.13c), and then release the button.

Figure 1.I3c

100

24
Introduction to the Book and the System

Clicking the red button outside the boundaries of the menu will also erase the menu and allow you to continue your use of the system. There are times when you will save the current state of your work using a command in the user interface to create a snapshot. What you save is a version of the system image, that is, the compiled methods (the system ones and any you may have added to the system), all other system objects, and a representation of your current display screen. This saved image is referred to as a snapshot, and is stored on a file named
snapshot.im If you create a snapshot and then quit, you can use the saved version of

Saving Information

the system, rather than the original image, by executing the run file with the name snapshotim as its single argument. Most Xerox systems include a command file for this purpose, so that you simply type
@snap.cm

and then press the ((carriage return" key. Sometimes more than one user will share a computer and its disk space. Each may wish to maintain their own snapshot. Some care must be taken to manage this situation by maintaining both the ((snapshot" file and ((changes" file (backing up on a separate disk or changing the name on the current disk). Both files must be maintained in a coordinated way because the snapshot refers to source code written on the changes file. When you restart a snapshot, you must also be sure to use the same run file and the same sources file that were used when the snapshot was created. See Chapter 23 for more details about the coordination requirements.

Create a Snapshot Try to create a snapshot. There are two ways. Follow the instructions for stopping your work session given earlier and choose the menu item Save, then quit. Alternatively, choose the item save. That is, move the cursor over the light gray background, press the yellow button to obtain the menu, and move the cursor so that the item save is highlighted, as shown in Figure 1.14a. Release the button. A view called a prompter appears (Figure 1.14b). The name of the current snapshot image file shows in the prompter. Let's assume that you wish to use this same name. With the cursor inside the lower half of the prompter, press the yellow button and move the cursor so that the item accept is highlighted (Figure 1.14c). Release the button to choose the displayed name as the name of the snapshot. As an alternative to choosing the command accept to complete your response, you can type the ((carriage return" key.

25
1.4 Stopping a Work Session

Figure 1.14a

010

Figure 1.l4b

Figure 1.14c

26
Introduction to the Book and the System

The system now takes control to create the file. The cursor changes first to a slanted arrow with a star attached, meaning execution is taking place. It then changes to an hourglass shape, meaning ttwait." If you make a snapshot prior to quitting, then you will be taken out of the Smalltalk-80 system once the snapshot file is created. Otherwise, the cursor shape changes back to the normal slanted arrow shape and you can continue working.
In some of the Xerox systems, the screen turns to white while the snapshot file is being created. This is done to improve the speed with which the disk interactions are carried out.

When the prompter appears, you can choose to change the name of the file into which the image is copied. Simply edit the bottom text subview of the prompter before you choose the yellow button command accept (see Chapter 3 on how to use the text editor). The system will copy the existing changes file into a file whose name is the one you typed followed by a period and then the characters changes; the image file name is the name you typed followed by a period and then the characters im. You must respond to the prompter. If you move the cursor outside the prompter boundaries, the prompter will Hflash" or ttblink" to indicate that a response is required. If you have changed your mind and do not want to create a snapshot, then delete all the text from the prompter response area and choose the yellow button command accept. The prompter will disappear and you can continue using the system.

1.5
Summary of Terminology
button red button yellow button blue button button action press release click double click
Button on a pointing device, or function key on a keyboard, that is used to request some action. Used to select information. (Left button in all illustrations.) Used to get a menu for editing the contents of a view. (Middle button in all illustrations.) Used to get a menu for editing the view itself. (Right button in all illustrations.) The physical use of a button. Push and hold the button down. Remove finger from button, letting the button up. Press the button, then release it, without moving the cursor. Click two times in succession, without moving the cursor.

27
1.5 Summary of Terminology

confirmer control manager

A "binary-choice" kind of menu, that is, a menu with two items from which to choose. A system object that maintains a list of screen views; it lets you point to a view and interact with either the view itself or with information inside the view. A locator of information on the display screen, presented as a small graphical image, superimposed on the screen and controlled by a pointing device. Refers to a sequence of characters on an external storage device, such as a disk. Initially an empty file; when the user interacts with the Smalltalk-BO system, each action that involves evaluating an expression is stored in this file. A file that contains the compiled form of each method and the initial bitmap that appears on the screen when the system is installed. A file that contains the source text for each method in the system. A list or collection of selectable items; choosing an item from a menu invokes some action. A request for an object to carry out one of its operations. A procedure describing how to perform one of an object's operations. A pointing device that the user manipulates in order to move the cursor. A component of the Smalltalk-BO system represented by some private memory and a set of operations. A "fill-in-the-blank" kind of menu in which you must type your choice. A menu associated with a screen view; you use a scroll bar to specify which part of the available information you want displayed in the view. A file in which you save the current state of your Smalltalk-BO system image. A view contained as a subpart of another view. A set of compiled methods and global variables, and the initial display screen to be shown when the system is first installed. A rectangular area on the display screen in which to access information.

cursor

file

changes file

image file

sources file menu message method mouse object prompter scroll bar

snapshot subview system image

view

28
Introduction to the Book and the System

active view collapsed view standard system view

The view in which you are currently working. A standard system view that displays only its label part, but can be selected and expanded to show the entire view. A view that provides standard interface functions for manipulating itself, for example, for moving, framing, collapsing, and closing.

I
I

2
Basic User Interface Components
2.1 Display Screen Visual Cues Cursors Highlighting Flashing Screen Areas 2.2 Designating Rectangular Areas on the Display Screen 2.3 Menus Scroll Bars Confirmers Prompters 2.4 The System Menu 2.5 Standard System Views Standard Blue Button Menu 2.6 Summary of Terminology

30
Basic User Interface Components

In the Smalltalk-80 programming environment, a bitmapped display screen is used to present to the user graphical and textual views of the information about objects. Menus and views are the primary ways in which objects are visually presented. A cursor is used to select items in menus or in parts of a view.

2.1
Display Screen Visual Cues
A cursor takes on different shapes in order to provide visual feedback about where you are pointing and what system activities you are currently doing. Highlighting is used to indicate menu, view, and text selections. Flashing screen areas draw your attention to attempts to initiate inappropriate actions. There is only one active cursor and it is controlled by the pointing device. In the following table, each cursor is listed with its name, its visual form, and its typical use in the system. The cursor takes on different shapes when it is used in editors for text, pictorial images (Form Editor), and magnified images (Bit Editor); in controlling the views on the screen; and in interacting with the external file system.

Cursors

name normal

image

use

The cursor looks like this most of the time. The point of cursor selection is at the upper left corner, at the tip of the arrowhead. Wait. The system is executing some time-consuming expression. During this time, you cannot do anything else.

execute

origin

r
.J

Indicates that you should designate the top left corner of a rectangular area by moving the cursor to where you want, and then pressing, but not releasing, the red button. Indicates that you should designate the bottom right corner of a rectangular area by keeping the red button depressed while you move the cursor to where you want the corner to be, then releasing the button.

corner

31
2.1 Display Screen Visual Cues
,.-, .'-,

read write crossHair

~,:j

Wait. Information is being read from an external file. Wait. Information is being written on an external file. In the Bit Editor, indicates the location of the bit at which editing will occur. In a scroll bar, indicates scrolling the text to see the preceding text. In a scroll bar, indicates scrolling the text to see the succeeding text. In a scroll bar, indicates the proportional location to which you want to jump. Wait. The system is carrying out some file operation that is time consuming. Answer yes in the confirmer. Answer no in the confirmer.

:.1

...:1'

I
i

I
I
J
~

down (previous information) up (next information) marker (jump)

wait

thumbs up thumbs down

The Form Editor prefers to let the cursor take on arbitrary shapes that depict the current painting tool. To do this, the cursor is made blank, and the editor itself provides an image of the painting tool at the location of the cursor. The confirmer uses the cursor in the shape of a hand with either thumb up or thumb down, depending on which item is selected. Some versions of the system include storage reclamation in the form of a compactor; when compaction is taking place, an animated image of a cartoon character appears.
Class Cursor is defined in the Smalltalk-80 system as the representation of cursor forms. Cursor knows about several cursor forms that are predefined in the system and used in the interface. With the exception of the last two Cursors, the name of the cursor given in the preceding table is also the name of the unary message that should be sent to Cursor in order to gain access to the instance, for example, Cursor normal. Since a cursor is a kind of Form, it can be edited by sending it the message edit or bitEdit. See Chapter 7 "How to Make Pictures" to learn how to use the editors (the Form Editor and the Bit Editor) that you access in response to these messages. Sending the message show to an instance of class Cursor sets the form of the visible cursor to be that of the instance. For example, sending the object, Cursor normal, the message show, makes the visible cursor look like a slanted arrow (as explained in Chapter 6, sending such a message directly involves typing the expression Cursor

32
Basic User Interface Components
normal show in a workspace, selecting it using the red button, then choosing the yellow button command do it. The expression Cursor normal returns an instance of class Cursor; all instances of Cursor respond to the message show.) You can create cursors, instances of class Cursor, and use them as visual cues in your applications systems.

Highlighting

In using the Smalltalk-80 system, you will select various views or parts of views. For example, you will often select a sequence of characters using the text editor. When you do so, the system will highlight the sequence to indicate which one will be affected by the next editing command. Similarly, when you press a button to obtain a menu to choose one of its items, the system will highlight an item to indicate the current selection; the current selection is the one you choose by releasing the button. And when you select any standard system view, the system will highlight its label (located just above the view's top left corner) to indicate that it is the active view.
When you invoke a menu, the current selection is the item that you chose the last time you obtained this menu.

To highlight a selection, the system complements it. In complementing, the black bits on the screen are turned to white, and white bits to black. In particular, black text on a white background is turned to white text on a black background. All views except the single active one are Uinactive." Selections in inactive views are generally not shown. Selections in menus that are textual lists are still shown, but their visual emphasis is Utoned down" a little-the background of the selection is changed from black to a gray tone.
As a design decision, standard system views allow for only one active view. Using the multitasking capabilities of the Smalltalk-80 system, you can create multiple simultaneous activities, including "active" views that operate in tandem with system views.

Figure 2.1 shows examples of highlighted text within a sequence of characters (in the active standard system view labeled System Workspace), several lists of items with highlighted selections (in the inactive standard system view labeled System Browser), an inactive standard system view (labeled Project), and an inactive standard system view labeled System Transcript. Menu items that appear in inactive standard system views are highlighted using a gray background.

33
2.1 Display Screen Visual Cues

System

"(':;n~:a: te

"<::',"020: te a: '/iew few eho:nge ('eeo'\"lO'(~" f"\:;,,.n a: ,gi ~'en /'l,'lO" '\.. '~hanqeList . . . iew openun: (Cha.ngeList nev... r-ecoverFile: (File:3tream oldFilel\Ja.med: 'filel'oJarne')). "A fte,~ ." e,~o:sh., e,~e." te ." ,/ie\\ to' IJro1'.'/S'" eli'a:n' es since the Io:st sno: "sli'ot:' e::<a.mples of 8ro..sers,

example2 "E:x:a.mple .......3.its felt' you to click red button somewhere on the screen. The . . ie.. .. v.. ill sho\,.. . .vhere you point. Termina.te by ct-Ioosing menu comm.3.nd 03.ccept Ot typin,~ c.'9.r-ria.ge retutTI."

FilllnThe81.'9.nk

Figure 2.1

34
Basic User Interface Components

Flashing Screen Areas

A fiashing area refers to an area of the display screen rapidly alternating its black and white bits so as to draw your attention to it. This is used in the programming interface to indicate that what you are trying to do is currently disallowed or not appropriate. Flashing will occur, for example, if you attempt to invoke a menu where no such menu is available, or if you do not complete a response to a confirmer or a prompter.

2.2
Designating Rectangular Areas on the Display Screen
Several interactions in the Smalltalk-80 system expect you to designate (to show location and size of) a rectangular area of the display screen. When this happens, the system will jog your memory by changing the cursor shape to look like the top left corner of a rectangle. A possible screen image is shown in Figure 2.2a.

Figure 2.2a

After you have moved the cursor to where you want the top left corner of the rectangular area to be, press and hold down the red button. In response, the cursor will change shape again, this time to look like the bottom right corner of a rectangle. Where the corner first appears will delimit the minimum-sized rectangle for that particular kind of view. The cursor is shown on the screen in Figure 2.2b. While still holding down the red button, move the cursor around. You will see that, as the cursor moves, a flashing image of the rectangular area changes correspondingly on the screen. The area shown always maintains any minimum size that may have been assigned by the constraints of the view that will fill the area. When you are satisfied that the selected area is the size you want it to be, release the red button. A possible resulting workspace is shown in Figure 2.2c.

35
2.3 Menus

Figure 2.2b

2.3
Menus
A menu on the display screen is similar to one in a restaurant: it shows you the available items from which to choose. An item in a menu represents a message. The item workspace in one of the menus you used in Chapter 1, for example, represents a message that creates a new view in which text can be created and edited. In the Smalltalk-80 interface, menus are displayed as lists of words or of phrases. Menus come in several varieties, including fixed and pop-up. Examples of fixed menus were shown in the view labeled System Browser in Figure 2.1.

36
Basic User Interface Components

To make a selection in a fixed menu, place the cursor over the desired item and press the red button; this will highlight the item. When you release the button, the system will carry out the action corresponding to the highlighted item, leaving the selection highlighted until you select a new item. To deselect the current selection without choosing another item, simply choose the same item again (that is, move the cursor over the item and click the red button). To allow best utilization of space on the display screen, many menus in the Smalltalk-80 system have been designed to be pop-up menus. Fixed menus are already on the screen; pop-up menus appear when you press the appropriate button. The menu displays itself directly beneath the cursor. To see a pop-up menu, move the cursor into the background area of the display screen, outside the boundaries of any view. Press and hold down the yellow button. A pop-up menu will appear. (If you tried the various examples in Chapter 1, you have already seen several pop-up menus.) In order to make a choice, continue to hold down the button, move the cursor around until the desired item is highlighted, and release the button. When you release the button, the menu will disappear. In order to make no choice, continue to hold down the button, move the cursor outside the menu area until no item is highlighted, and release the button. Another variety of menu is one that appears in tesponse to some user action. This kind of menu remains on the screen until you either choose an item using the red button, or until you click with the red button at a location outside the menu area. One example is a confirmer. This is a menu with a noneditable text subview that describes a binary choice, and two items: yes and no. If you create a workspace, type some text, and then try to close the workspace, a confirmer will appear to verify that you want to delete unsaved information. Recall that this example was presented to you in Chapter 1. Another example is the menu that appears when you decide to stop your work session. As described in Chapter 1, when you choose to stop a work session, a menu appears from which you can choose to create a snapshot, quit immediately, or change your mind. A particular kind of fixed or pop-up menu is called a list menu. List menus appear as a sequence of lines, each one containing a menu item. For aesthetic purposes, and to help identify groups of items, lines of text in a list menu may be separated by a drawn line. Fixed list menus are used for choosing class names and messages in a system browser, for choosing class message pairs in a message-set browser or a debugger, and for choosing variable names in an inspector. (The differ-

37
2.3 Menus

ent browsers, debuggers, and inspectors, will be described in detail in subsequent sections.) List menus appear in standard system views in response to your pressing the yellow or blue button. If you press the yellow button while the cursor is in the background gray area, the list menu we refer to as the System Menu will appear (see Section 2.4). You can create different standard system views by selecting items from the System Menu. If a menu flashes when you try to make a selection, it has become locked. The system will lock a menu when you have not yet completed the activity associated with your current selection. This flashing is used as one of the ways to indicate that you have been editing text, but have not yet issued the command cancel or accept. (The use of a confirmer is another way the system indicates that text has not been saved.) The locked menu will become unlocked as soon as you properly complete the associated activity. Most of the subviews of the system browsers, which are the views for accessing class descriptions, fall into the category of lockable menus. Whenever the user interface directions say that you should choose an item from a pop-up menu, the directions will state which button to press (yellow or blue) and which command to choose. Selection in fixed menus is done using a red button.

Scroll Bars

A view on the screen may not be large enough to display all the information appropriate to that view. Additional user interface control is given to such views in order to assist you in exploring all the information. Especially in views of textual information, this control is provided in the form of a scroll bar. Assume you wish to examine a large document of information, and that you have created a view on the screen for this purpose. The view is likely to be too small to display all of the document. So a rectangular area known as a view (or often called a window) is defined by mapping from the area allotted on the display screen to a corresponding-sized area of the document. The mapping determines how much document information can actually be displayed in the screen view. The purpose of a scroll bar is to change the area of the document that can be seen in the view. A scroll bar is a rectangular area, displayed adjacent to the left side of the view it controls. The scroll bar appears in the active view only when the cursor is actually inside the view. If you move the cursor outside the view (without pressing a button), the scroll bar will disappear. It will appear as soon as you move the cursor back inside the viewing area. Thus the scroll bar is a useful visual cue that the view will notice your typing or button pressing. Scroll bars appear only in those views for which scrolling is appropriate, typically in any view in which text can be edited or in list menus.

38
Basic User Interface Components

The length of the scroll bar area is meant to represent the length of the entire document that can be examined. Inside the area is another rectangular area filled with a light gray tone. The length of this gray area represents the height of the window onto the document (as illustrated in Figure 2.3). The gray area is located within the scroll bar at a point relative to the location of the window: if the gray area begins at the top of the scroll bar, then the window is at the beginning of the document. If the gray area fills the entire scroll bar, then you can assume that all of the document is currently displayed (see Figure 2.4).

I
I
i

,.

TrJi::. I::' tt-,e cJocument \i... ;tr, text in it, TrJi::.

i::. trle

beginninl~

of the

dlJclJment.

r-+--------tf

. ~...... I

/%

Trds is tr,e p.3.rt of the document trl-3.t is cJispl-3yecJ,

I I

Tr,l::' i::. tr,e encl.

Figure 2.3

.'.

'i
..

":. <

,
window at the top of document window shows entire document

Figure 2.4

window at the bottom of document

39 2.3 Menus

You can change which part of the document is displayed by moving the window through the document. This action is called scrolling. It is done in one of three ways.

scroll next

The line of text nearest the cursor is moved to the top of the view. Move the cursor into the scroll bar area, in the right one-third of the rectangle and outside of the gray area. The cursor shape becomes that of an up arrow. Click the red button. Scrolling occurs.

scroll previous

The line of text at the top of the view moves to become the line nearest to the cursor. Move the cursor into the scroll bar area, in the left one-third of the rectangle and outside of the gray area. The cursor shape becomes that of a down arrow. Click the red button. Scrolling occurs.

jump

Displays a view of the document beginning with a location in the document relative to the gray area in the scroll bar. Move the cursor into the scroll bar area, in the middle onethird of the rectangle and outside of the gray area. The cursor shape becomes that of a right arrow. Press the red button and hold. The gray area moves to the cursor location and then tracks the cursor until the red button is released. The displayed document jumps to the appropriate location. While the red button remains pressed, a lighter gray image is left in the scroll bar area to indicate the previous position of the gray area.

In an earlier design of the scroll bar, jumping was done by moving the cursor into the gray area. The cursor shape changed to a small dot. While the red button was pressed, you moved the gray area to the desired location. This design was abandoned because users found it difficult, if not impossible, to grab the gray bar when it was very small. Another design that has been used in an application was to di-

40
Basic User Interface Components
vide the scroll bar into three parts horizontally, rather than vertically. When the cursor was in the small top part, the resulting action was to scroll next; when the cursor was in the small bottom part, the resulting action was to scroll previous. As programming exercises, you might like to experiment in creating different types of scroll bars.

Practicing To start learning how to use the Smalltalk-80 system, try using the System Menu. Get the menu by first moving the cursor into the light gray background area, then pressing and holding down the yellow button. This will cause a pop-up menu to appear. As long as you keep the button down, you can move the cursor around in the menu, deciding between various selections. You don't actually choose the highlighted item until you release the button, so be sure you have selected the item you want before you release the button. If you decide you don't want to make any choice, simply move the cursor out of the menu area completely (so no item is highlighted) and release the button. The menu will disappear. Practice getting the System Menu and moving around in it. Become comfortable using the System Menu without making any selections, so that it becomes a habit to move the cursor outside the menu when you are undecided. Read the subsequent sections to find out what choosing each of the System Menu items will do. Confirmers
A confirmer is a "binary choice" menu. That is, a confirmer is a menu with two items in it, where each choice represents opposing points of view. A confirmer consists of three parts, the top part is a statement or question; the other two parts are possible opinions about the statement or answers to the question. An example is shown in Figure 2.5. It is a confirmer that appears when you choose the yellow button command close in a workspace, after you have typed some text without accepting it. Choose one of the answers, yes or no, by placing the cursor over the answer and clicking the red button.

This is sorne te::<t.... Contents ria.ve not been saved. At-e }'ou cena.in tho. t you Ih'a.nt to close? yes no

Figure 2.5

000

41 2.4 The System Menu

Prompters

A prompter is a "fill-in the blank" menu. That is, a prompter is a menu in which you must type your choice. It consists of two parts: the top part is a statement or question, and the bottom part is a workspace in which you type. Two kinds of prompters are available in the system, as shown in Figure 2.6. One has a label and acts like a standard system view, with both yellow and blue button menus accessible. This kind of prompter is called a scheduled prompter. The other kind of prompter is unscheduled. It preempts activity and requires you to give a response. You press the "carriage return" key to indicate that your answer is completed. To give no response, type only the "carriage return" key. Unscheduled views like this prompter do not have a title label.

T~.,.'pe

the na.me of the file,

Type

,9,

n,:t.me for reca.llinl~ ,:to source Form,

Figure 2.6

2.4
The System
Menu
As noted earlier, the menu obtained by moving the cursor into the light gray background area and then pressing the yellow button is called the System Menu. It is shown in Figure 2.7. Each item or command in the System Menu is described briefly.

42
Basic User Interface Components

restorp di

rI Y

e::dt project project


file list

bro..ser .... orkspa.ce sY:5tern tra.nscript syst.:.m v.. orkspa.ce sa. .e


,~uit

Figure 2.7

010
restore display
Redraws the display, getting rid of anything which is not known to the control manager. Often the display screen gets cluttered with the side effects of drawing or the results of erroneous actions. Whenever things look especially bad, you can redraw the views by choosing this command. Another effect of restoring the display is to reset the cursor to the slanted arrow (normal) cursor. It is possible to create several different collections of views of information, each one called a project. Each project takes up an entire display screen for the presentation of its views. A project is accessed by creating a project view and then choosing the yellow button menu command enter. Once inside a project, it is possible to return to the project from which it was entered by choosing this command. At the topmost project, this command is equivalent to restore display. See Chapter 4 "How to Use Projects" for a more detailed description. Creates a new project view. You are asked to designate a rectangular area in which the project view is to be displayed. Short files can be read, edited, updated, and evaluated, using a view that is created by choosing this command. You are asked to designate a rectangular area in which a file list view is to be displayed. See Chapter 22 "The File Systern" for a description of this view. A browser is a special view that allows you to access hierarchically-organized information. Choosing this command opens a system browser that allows you to traverse infor-

exit project

project

file list

browser

43 2.4 The System Menu mation about the Smalltalk-80 system itself. You are asked to designate a rectangular area in which the browser view is to be displayed. See Chapter 9 "Finding Out About System Classes" for a description of this view of system information.

workspace

Creates a blank area in which to edit text. You are asked to designate a rectangular area in which the workspace is to be displayed. See Chapter 3 "How to Use the Text Editor" for a description of how to use this view. Most display screens in a Smalltalk-80 system have a special view known as a System Transcript. Because messages sent to the object Transcript affect this view, methods can contain expressions that print information in the System Transcript in order to create a form of user feedback. A view of the System Transcript is created by choosing this command. You are asked to designate a rectangular area in which the transcript view is to be displayed. See Section 3.4 "The System Transcript" for a description of this view. A special workspace is available that contains many useful message expressions that you can edit and evaluate, notably expressions about accessing files, querying the system, and recovering from a crash. You are asked to designate a rectangular area in which this special workspace is to be displayed. Periodically you might decide that you have done a lot of work that you want to save. One way to save your work is to create a complete image of the system (see Section 1.4). A new system image is created in an external file whenever you choose this command. When you are done working, choose this command (see Section 1.4 "Stopping a Work Session").

System Transcript

system workspace

save

quit

Keep Practicing Several exercises are provided here so that you can practice with menus, scrolling, and creating workspaces. Exercise 1: In the System Menu, choose workspace (Figure 2.8a). Designate a rectangular area in order to specify the location and size of a workspace (an example workspace is shown in Figure 2.8b). Do this several times so that there are three or four workspaces on the screen, some overlapping others (as shown in Figure 2.8c). The last workspace that you created is the active one. Notice that the label of this workspace is highlighted and that a scroll bar appears at its left side.

44
Basic User Interface Components

Figure 2.8a

010

Figure 2.8b

000

Figure 2.8c

000

45
2.4 The System Menu

Move the cursor outside the active view and into the gray background area. Click the red button. Notice, as shown in Figure 2.8d, that the workspace is no longer active, in particular, that its label is no longer highlighted. We refer to this action as deselecting a view. Typically, however, you do not explicitly deselect a view. Rather, the deselection takes place automatically when you select another view.

Figure 2.8d

100
Suppose no view is active (which would be true if you click the red button in the gray background area outside of all the views). Move the cursor into a workspace. Without your pressing a button, this workspace will become the active view. When all the views are inactive, whichever one you place the cursor into next becomes the active one. Place the cursor in one of the other workspaces and click the red button. We refer to this action as selecting a view.
A view can be deselected as described, or as a result of a message sent by selecting a menu item, or as a result of evaluating an expression. You can deselect a view by moving the cursor outside it, into the gray area or into another view, and then clicking the red button. Actually, you can press the yellow or blue button as well, which, in addition to deselecting the active view and selecting a new view if the cursor is inside one, may cause a menu to appear.

Exercise 2: To practice scrolling, choose the command System Workspace from the System Menu, or, if you have a workspace labeled System Workspace already open, select it. The System Workspace should have a lot of text in it. Try scrolling using it. Learn how to control the positioning of the cursor by watching for the change in cursor shape. Make the workspace larger by choosing the command frame from the blue button menu. You will be asked to designate a rectangular area. Notice the change in the scroll bar.

46
Basic User Interface Components

Exercise 3: Make an existing or new workspace active. Type a lot of keys on the keyboard and notice that the characters are displayed in the workspace; do not worry about typing correctly or meaningfully. Notice that the scroll bar does not change while you are typing. The scroll bar only changes (is updated) when you make a new selection, or you move the cursor into the scroll bar area or out of the view boundaries and back in again. Do not worry about editing the text just now.
Deferred update of the scroll bar can be changed so that the update occurs while you are typing. Once you acquire Smalltalk-80 programming expertise, you might try to make this change to text views.

Move the cursor outside the workspace without pressing a button. Type some keys. The characters do not show up in the workspace; they do not show up anywhere. Move the cursor back into the workspace and notice that the characters now appear. The cursor must be inside the active (text) view when you are typing keys on the keyboard in order to see the corresponding characters displayed immediately in the view. Select a different workspace. Again, type some keys on the keyboard. Press the yellow button and notice the menu that appears. Release the button without choosing any command. Select another workspace. Obtain the yellow button menu; notice that it contains the same items in both workspaces.

2.5
Standard System Views
There are a number of kinds of views that can appear on the display screen of the Smalltalk-80 system. Most of these are standard system views, meaning, among other things, that they are seen as rectangular areas with labels above the top left corner. They become active when you place the cursor inside their bounded area and click the red button. Each standard system view provides a general interface accessed through a pop-up menu. Standard system views can be moved, stretched, and removed from the screen; other abilities depend on the particular kind of view. Abilities shared by all views are presented in the blue button menu; abilities of a particular kind of view are presented in the yellow button menu. Access to the currently scheduled standard system views is maintained by a system component called the control manager. The references to views are stored in the control manager in a seemingly arbitrary order; ordering occurs as a by-product of the order in which the views are created and the order in which they become active. This ordering affects the way you can select views under one another.

47 2.5 Standard System Views


This control manager is referenced by the system variable ScheduledControliers. This name reflects the fact that the control manager consists of references to kinds of Controllers that provide interfaces to Views. The active view is always the first element of ScheduledControliers.

Standard Blue Button Menu

When you press the blue button while the cursor is inside a standard system view, the pop-up menu shown in Figure 2.9 appears. Each of these menu items represents a message to the view. They are

under
mo',/e ft,:t.rne
colla.~)5e

close

Figure 2.9

001
under
Since standard system views can overlap, this menu item is a request to give control to (to make active) the view located underneath the currently active view and underneath the cursor location. A view can be overlapping several views-the one that appears on top when you choose under depends on the ordering of the references in the control manager; under might have to be chosen several times in order to locate the desired view. Also, a view might be underneath the currently active one and not underneath the cursor, in which case it will not be selected. The view disappears with only its label remaining, and the cursor changes to the shape of the origin cursor. Move the cursor around. The label of the view tracks the cursor. When you press the red button, the view reappears so that the label is at the last location to which you moved it.

move

When you move a view, space that is simply gray area appears in its place. The standard system does not try to keep a clean, refreshed display, since it assumes you can clean up by choosing the command restore display from the System Menu. Solutions to fix this problem of redisplaying hidden parts of overlapped views exist, but were not included in the standard Smalltalk-80 system.

frame

The view disappears and the cursor changes to the shape of the origin cursor. You then designate a new rectangular area in which the view should reappear.

48
Basic User Interface Components

collapse

The view disappears with only its label remaining, and the origin cursor appears. Move the cursor around. The label of the view tracks the cursor. When you press red button, the label portion only of the view reappears on the screen at the last location to which you moved it. This considerably smaller area can be enlarged to show the full view by selecting it and choosing the blue button menu command
frame.

close

The view disappears. Unless you have a reference to it, that is, it is referenced by some other object, it can not be made to reappear.

If the task in the view is not complete (typically completion is indicated by choosing the yellow button command accept), an attempt to close the view results in another view. This is a confirmer. The cursor moves automatically into the confirmer's area, and the confirmer becomes the active view. The message in the confirmer is a warning that a task or information will be lost by closing the view. If the view has several subviews, a gray box is drawn around any information that will be lost. An example is that a part of a system browser was changed but not saved before the close command was chosen. The gray box surrounds the lower part of the browser, and a confirmer appears. Choose yes to indicate that close is really intended; choose no to continue using the original view. If you close a view, it is irrecoverably gone.
You can only recover it if you have made a snapshot and start over using the saved image, or if you have stored a reference to it. You can think of other messages to the view itself to put in the blue button menu. In some of the Xerox Smalltalk-80 systems, the message edit is available. When you choose edit, you can move the borders of the subviews (either up and down for horizontal lines, or left and right for vertical lines) in order to modify the layout of subviews within the view.

D More Practicing Select different workspaces. Try the various blue button commands such as under, move, and frame. Try the command collapse and then frame again. Collapsed views save space on the screen yet allow direct access to the task represented in the view-simply select the view and choose the blue button command frame. Try to close a workspace in which you have typed some characters. A confirmer view appears. Choose yes. The confirmer disappears and then the workspace disappears. Again try to close a workspace in which you have typed characters. Before doing so, choose the yellow button command accept. Now try to close the workspace. No confirmer appears; the workspace disappears. Because you issued the command accept, the system believes you have ((saved" your work.

49
2.6 Summary of Terminology

2.6
Summary of Terminology
Bit Editor browser confirmer cursor file list flashing area Form Editor menu fixed list locked pop-up system
A set of operations used to modify pictorial images that are presented in a magnified format (8 times original size). A view that allows you to access hierarchically organized and indexable information. A "binary-choice" menu, that is, a menu with two items from which to choose. An image on the display screen that is used to select information such as text, menu items, or parts of a view. A view that provides access to short files of text. Rapidly alternating the black and white bits of an area of the display screen (black to white, white to black). A set of operations used to modify pictorial images. A list or collection of selectable items. A menu, typically associated with a view, that remains displayed on the screen as long as the view is displayed. A menu appears on the screen as a sequence of lines, each containing an item; it can be of the fixed or pop-up variety. A menu that is in a state such that you are not allowed to change the current selection. A menu that appears when you press a button, and disappears when you release the button. A pop-up list menu that is obtained by pressing the yellow button while the cursor is located over the gray background area. A collection of views of information that takes up an entire display screen for the presentation of its views. A "fill-in-the-blank" menu, in which you must type your choice. A workspace. Text in a transcript can be edited as in any workspace. In addition, text can be printed in a transcript as the result of expression evaluations. A workspace that contains many useful message expressions that you can edit and evaluate, notably expressions about accessing files, querying the system, and recovering from a crash.

project prompter system transcript

system workspace

3
How to Use the Text Editor
3.1 Text Selection Extending Text Selection Beyond the Visible Text Selecting Text with the Escape Key 3.2 Inserting Text 3.3 Issuing an Editing Command Moving and Copying Text Searching for Text Issuing Editing Commands Using Keys and the "Control" Key Inserting Delimiters About a Selection 3.4 The System Transcript 3.5 Summary of Terminology

52
How to Use the Text Editor

The same text editor is used everywhere in the Smalltalk-80 system views. Learning how to use the text editor involves learning how to: make a text selection issue an editing command using a menu or the keyboard
Note that this is a text editor for a single paragraph of text, not for a large document. Paragraphs have extensive format and style knowledge; however, the generally-used text editor is a simple one that does not provide a menu-based interface for changing the format nor the style. More sophisticated document-creation systems can be created that provide function-key or menu-based access to these aspects of a paragraph.

3.1
Text Selection
Text is selected using the pointing device and the red button. Text editing can be carried out in those system views in which the information is textual. Examples are a workspace, a transcript, a project, a file list, and the parts of browsers that provide editing areas for Smalltalk-80 methods. Select a view that contains text, such as a workspace. A small caret (an inverted v") appears near the point you selected in order to make the view active. If there is no text in the view, then the caret will appear in the top left corner. Figure 3.la shows a workspace containing text. The caret appears at the end of the first sentence. Type some text. Move the cursor somewhere else in the view, either at one of the characters or between characters or at the end of the passage of text. Click the red button. The caret appears at the cursor location or at the gap just before the character. Notice that you are asked to point at a character or between characters, not under a character. Move the cursor to one end of the passage of text and press the red button (as shown in Figure 3.lb). Hold it down while moving the cursor to the other end of the passage (Figure 3.lc). The text that is traversed is highlighted. This activity is called draw through. It is not necessary to traverse intermediate characters en route to the destination (that is, when drawing through several lines). When the cursor reaches the other end of the passage, release the button (Figure 3.ld). The selected passage remains highlighted. The highlighted text is called the text selection. Pointing to a place in the text and clicking the red button creates a zero-width selection. The method of clicking once between characters is the one to use if you want to insert text. The method of drawing through a passage of text is the one to use if you want to replace, copy, delete, or change the font or emphasis (bold or italic face) of the text.

53
3.1 Text Selection

Trri:: is

.3: \\lork::p.3:Ce
30m~

cont.:t,ln;:

te:''I:,

..

trr,="t

,
or

Trli::

is

.3

\"iork5p,~('i;!

'th.3

t.

\ont.3in5 ::ome te>:t,


Trl8 t8>'I: (:t,n be empr-I.:tsi:ed in bold, l't.S::,',:, IJnljerlinoad, or mi:<tlJrE!5 such ,:;::. bold and

Trl8 1:8:,'1: C,3:n tie emph,:.siz8(J

in bold, i,,:,j)(''-:',

undernn~lj,

mi::<tlJres ;'1..Jcrl .:.:. bold and

underlilned.

underlilned

The text ':'tn be in different fonts, empha,;ized in bold, ,it"u',:'cs, ,:or underlined
ThE' text
(:.:'1"1

The text c:tn be in differenl f,)nt;., empha,;;ized in bold, .!t.cu',:cs, ,.,..r underlined,

be in cllfiererJ.f

000
Figure 3.1a

font;:-"

emph,3.;51ZeC' in bold,

~'t,)li(s,

or u.nd,erllned..

100
Figure 3.1b

The fext. can be in d ifferen t fonts., empha.sized, In bold, it,~~: tl'cs, or und,erllnec1.

Trl8 te:--: t (:.:.n be emprl.:' ;:i:eej


irl bold, 1"':.5i,;,:, urldertined, I)t"
rl-lj,:tljr-8'::

TrlE! te::<t

c: ,3. rl

tiE! emprl.~_5i2elj

SUI:rl 35

bold and

underJi'ned.

in bold. /t'5:,'ic, und~rlined) Dr rni::{tl.Jres 5l.JI:h ,:;,5 bold and underljlned,

The fezt ':.'lrl t,e In different f<,nt'. ernph.o":.lzed In bold, ,.t.,:d,l,:::. ,:,r underlined.
The t.ext
(,311

The text ,:an be in different ion1:';, ernpha,':ized in bold, It.~}l,(c.s, .:-r und.erlin.,'l

be

In

clIfferent

100
Figure 3.1c

fon 1.s, et{lph.3.;51Zed Hi bold,


itoli,.~~~,

or ullclerllnec1,

000
Figure 3.1d

The te:,:t (::;n l)e in different font,z" erflpha.sizecl in bold,


it(? lies,
(lr

unclerUned,

Clicking the button twice with the cursor in the same location selects different passages, depending on the cursor location.

To select
a whole word

Double click
Within a word, or just before or just after the word if the word is not just inside a delimiter (as demonstrated in Figure 3.2a, first click, and Figure 3.2b, second click).

54
How to Use the Text Editor

Thl2 tE!>::t (::rfJ be emprl.:r.5izer:l in bold, .;t,;d,;c IJndt;!rlirled. or


mi::o:tlJres 5uch as bold and

Trp~
irl

t8 t (3rt be ernprr':r sized bold, it6iil~, IJrll:lerlined, I)t"


,35

mi:o:tur-e::: ::lJch

bold a.nd

underlilned,

underJilned,

100
000
Figure 3.2a

The text can be in different fo::,nt:':, ernpha",ized in bold, itaUcs, or underlined,


The text
1::,;tTl l)e

in. chfferen t

font.;::, emph.:..zized, 111 bold, it(;.-U(S, I:,r u.nd.erllned.

100 000
Figure 3.2b

The text ,:an be in ,:lifferent f-:,n1"., emph",'"izeo:l in bold, ,:'t,'-"0:'C:, o:,r underlined
The te:,:t
it(.~' Ucs,
(:,:'1"1

be In d.lfffren t

iont;:., erilph.3.31ZeC1 In bold,

or und,erlln.ec1.

a delimited text

Just after the left member of a pair of delimiters or just before the right member (the delimiters themselves are not selected); recognized delimiters are parentheses, square brackets, angle brackets, braces ("curly brackets"), single quotes, and double quotes (see Figures 3.3a and 3.4a, first clicks, and Figures 3.3b and 3.4b, second clicks).

This is a, \,vork::.pa.ce tha,t


contbins some te it deJir,.,itE(j
tIY
~,:r. re n t

Trlis is ,3 v',"orVsp,:.cl2 tt"I,31:


(ont,:lIns 50me te',::1: delimit8(j

by,.

rl e::: es')

1:~'I1",,*)
[~~qlJ.3r12

[squa.re br.3ckets]

b,-.:;,Ckl2ts]

100 000
Figure ;3.3a

<,:tnl~lE!

tlra.ckets-'

100
000
Figure 3.3b
"doutde quote"

"double quote"

55
3.1 Text Selection

This is ,; '".vorLspa,c~ th.:'.t

Tt"ds is a 'y',/or-ksp.:t,ce HIo3:t

con'T:.:cins 50ml::! 1:12::1: Ijelirnited


tlY

cont.3.ins some te)::t delimited


by ..

(p ,;,r'en t rlE! ~es)

(p 3.ren tl'"le 512:5)

,100 000
Figure 3.4a

[5quar~

brackets]
~)rb(:f::.et5'"

[square brackets]

i,;.nqle

'sin9le quote'

"double quote"

100 000
Figure 3.4b

rd"

'sinljle quote'

all text in the view

At the beginning or the end of everything in the view (as demonstrated in Figure 3.5a, first click, and Figure 3.5b, second click, and Figure 3.5c, scrolling to see the rest of the text).

Tr-ds is tlY

.:t.

',/",'orkspace th,; t

\ont.:t.ins some 1:12::<1: (Jelimi1:ed

100 000
Figure 3.5a

,',;,n!jle br.;,ckets'-,

100 000
Figure 3.5b

56
How to Use the Text Editor

Figure 3.5c

000
a line of text the line is delimited by carriage returns) at the beginning of a line (just after a carriage return), or at the end of a line (just before a carriage return).
(If

Double clicking provides a faster way to make a text selection. Because double clicking will always select the designated text, it makes it possible to select text that is not visible on the screen. Suppose you wish to select text that is not visible on the screen, but that the text is not delimited in such a way that double clicking will support selection. Try the following technique. Move the Cursor to either end of the passage of text that you want to select. Press the red button. Hold the red button down while moving the cursor to the other end of the passage. So far, this is the usual way to select visible text. But the other end of the passage is not visible. You have to move the cursor outside the boundaries of the text view (either above or below the view). As long as you hold down the red button, the text in the view will be scrolled (to the previous text or to the next text), and the text that becomes visible will be selected. Keep holding down the red button until you see the end of the passage. Don't worry about scrolling past the end, because you can always move the cursor back into the view. When you move the cursor back into the view, the scrolling stops. You can then position the cursor at the desired end of the passage and release the red button. The distance that you move the cursor outside the view affects the speed at which the text scrolling takes place. The further outside the view you move the cursor, the faster the scrolling.

Extending Text Selection Beyond the Visible Text

r
Selecting Text with the Escape
Key

57
3.3 Issuing an Editing Command

The ~~escape" key on the keyboard can be used to select text that was typed since the last mouse click. Simply press the escape" key when you have finished typing. The characters you just typed will be highlighted. This is especially useful if, after typing in some text, you wish to make it the current text selection so you can copy the text to another place, or cut it, and so on.
The purpose of invoking this selection command from the keyboard rather than from a menu is to support the fast typist who wishes to select a passage of text that was just typed in order to issue a cut, a font, or an emphasis change command, which may also be invoked from the keyboard. Perhaps you prefer to have an item in the text editor yellow button menu that selects the most recently typed characters; changing the menu is an exercise you can try once you know enough about the Smalltalk-80 system.

3.2
Inserting Text
Pressing a key on the keyboard always replaces the current selection by the typed character and automatically selects the gap following that character. If nothing is selected, the uzero-Iength selection" at the caret is replaced. To replace a passage of text, first select it and then type the replacement. The first keystroke deletes the original text. To insert between characters, select the gap between those characters and then type the insertion. Essentially, you are replacing nothing with something. The destructive backspace function always deletes the character preceding the selection, even if that character was there before the selection was made.

3.3
Issuing an Editing Command
When you issue a text editing command, you are sending a message to the text about the current selection. Selection always precedes commands. Every command is executed immediately when you issue it. No confirmation is required. Commonly-used editing commands are found in the yellow button menu. A brief description of each follows.
again
This command attempts to repeat the last replace, copy, or cut edits you do.

58
How to Use the Text Editor

undo

The main purpose of undo is to reverse the effects of the last issued command. For example, paste in the last text cut out; cut out the last text pasted in; delete the last text inserted; or, if a text selection was replaced, paste it back. (Issuing two undo commands in sequence should leave you in the state you were in prior to the first undo.) Place a copy of the current text selection into a buffer. Delete the current text selection; save the text in a buffer. This command is illustrated in Figures 3.6a and 3.6b. Text is remembered in a buffer. Replace the current text selection with the remembered text. Assuming the text remembered is the text cut in Figure 3.6a, then the next sequence of figures illustrates the use of the paste command. Select the destination location (Figure 3.7a), select the command paste (Figure 3.7b), and then the inserted text becomes the selection (Figure 3.7c).

copy cut paste

This is a iliustr.Hion of the


tf!oxt f!odltor,
AI.

010
Figure 3.6a

000
Figure 3.6b

Suppose you just selected some text (text A, such as demonstrat as shown in Figure 3.8a) and replaced it with other text (text B, such as iIIustrat as shown in Figure 3.8b). The command again will find text occurring after the caret that is just like text A and will replace it with text B (as shown in Figures 3.8c and 3.8d on page 60). By holding down the "shift" key on the keyboard while selecting again, the replacements will be done as many times as is possible.

59
3.3 Issuing an Editing Command

\:.::t editor.

Thi::, is a. i'\lj5tr~_tiofl of th~

...T his is a. illustra.tion of


tE!xt editor,

ttiQ

again undo coPy

cut

100 000
Figure 3.7a

010
Figure 3.7b

000
Figure 3.7c

Suppose you just selected some text A and cut it out. The command again will find text occurring after the caret that is just like text A and will select it. You can then decide to cut it. Similarly, if you copy some text A, the command again will find text occurring after the caret that is just like text A and will select it (thus providing a text search capability in the editor). The again command is shared across views so that you can move into several views in order to do the same replacement in each.

60
How to Use the Text Editor

Tl"lis j;. ,:" illu5tr,9,tion of tt"IIO:! t~:d: .... ditor, This'" is ~Irne teo, t
lJs~d to demon::tr.=-.te hOI/,.. to move ':'.nd 1-10',../ to copy teo, t iJsirr9 the te', t editor.

used to (jernonstra,ti?
/Jsin9 tt"1I2 ted: f!,jitor,

riO'",',,,,

to

rfl(i",le .:'.rld r'o . ,, to copy t .... .- t

000
Figure 3.8a
This is a illustra )ion of the text editor. This is some text used to demonstrate how to move and how to copy text using the text editor.

000
Figure 3.8b
This is a illustration of the text editor. This is some text used to how to move .:..nd ho'.. . . to copy tQxt
usin!j the 1:8.\1: ec:litor.

_e

010
Figure 3.8c

000
Figure 3.8<1

From the menu description, you can see that there is a "buffer" of information into which text that is typed, cut, or copied is stored. The contents of the buffer changes whenever you type new text, or you issue the cut or copy commands. It is possible to take information from one view and paste it to another view because this buffer is shared across views.
Some people refer to this buffer as the scrap. The text editor in the standard system does not provide a way to view the information in the buffer; you can treat viewing the buffer as a possible exercise.

Moving and Copying Text

Some common editing commands such as "move text from here to there" and "copy text from here to there" cannot be issued by a single menu command because they require two parameters: the source selection and the destination selection. They may even involve more than

61
3.3 Issuing an Editing Command

one view. A llmove" is done by cut and paste. First, you select the source text and choose cut. The cut command deletes the selected text but leaves it in the hidden buffer where it can be retrieved by paste. Then you select the destination and choose the paste command to complete the move. This process was illustrated in Figures 3.6a and 3.6b. The destination can be in a different view than the source. A copy move is done by copy and paste, which is completely analogous to cut and paste, but does not delete the original text. There is no command for Hsearching for a sequence of characters." A search can be done as follows. Type the sequence of characters you wish to find, then select it and choose the cut command. Now choose the again command. If the sequence appears anywhere after the current selection (after the caret), it will become the text selection. If one instance of the text you want to find is already visible, select it, and choose the copy command. Then choose the again command. Various text editing commands can be issued by pressing the Ucontrol" key simultaneously with another key from the keyboard. When the Ucontrol" key is combined with a number, it means change the font of the current text selection. Conditional statements in the Smalltalk-80 language consist of the keywords ifTrue: and ifFalse:. Since these are frequently needed, llcontrol" combined with llt" or IT' effectively types the keyword ifTrue: or ifFalse:, respectively. A summary of the special editing keys is shown next. The symbol ctrl denotes the Ucontrol" key on the keyboard.
type keys
ctrlO

Searching for Text

Issuing Editing Commands Using Keys and the "Control" Key

action
Change the font of the text selection. The system default is sans-serif l2-point font. Changing a text selection to bold, italic, or underline is considered a change in font and is done by selecting the appropriate font number. The numbers depend on the current style being used. Change the font of the text selection. The system default is sans-serif lO-point font. Change the font of the text selection. The system default is sans-serif lO-point font, bold. Change the font of the text selection. The system default is sans-serif lO-point font, italic. Change the font of the text selection. The system default is serif l2-point font. Change the font of the text selection. The system default is serif l2-point font, bold.

ctrl 1 ctrl2 ctrl3 ctrl4 ctrl5

62
How to Use the Text Editor

ctrl6 ctrl7 ctrl8 ctrl9 ctrl t ctrl f ctrl w

"delete" "backspace"
ctrl ctrl b ctrl c

ctrl shift ctrl shift b ctrl shift c

Change the font of the text selection. The system default is serif 12-point font, italic. Change the font of the text selection. The system default is serif IO~point font. Change the font of the text selection. The system default is serif 10-point font, bold. Change the font of the text selection. The system default is serif 10-point font, italic. Insert the text ifTrue:. Insert the text if False:. cut the text selection and the word preceding the caret (typically used while typing and while there is no text selection simply to delete the last word typed). cut the current text selection. cut the text selection and the character before the selection. Underline the selected text. Make the selected text boldfaced. This is the system interrupt and should not be typed while text editing unless a process interrupt is desired (for details on such user interrupts, see Chapter 20). Remove any underline from the selected text. Make the selected text not boldfaced. This is a special system interrupt, used when the system seems dead and everything else fails (see Section 20.4).

Note that ctrl wand ((backspace" do a cut of the current text selection and of the word or character preceding the text selection. The undo command is supposed to be able to reverse the effects of a cut by pasting the saved information. However, in using ctrl w or ((backspace," two cut actions are really taken and only the last, the word or character deleted, is remembered. Therefore, undo will only paste the deleted word or character.
All fonts are instances of class StrikeFont and are stored as an array in an instance of class TextStyle. The system default is accessible by sending TextStyle the message default. The message fontAt: can be sent to a TextStyle to access the fonts. The default TextStyle has 24 fonts. Fonts are indexed from 1 to 24, where the first 9 are the ones listed earlier; the one numbered 0 is actually font 10. Fonts are stored in triples - base, bold, and italic. The system includes fonts 10, 11, and 12-sans-serif 12 point fonts 13, 14, and 15-serif 10 point underlined

63
3.3 Issuing an Editing Com.m.and fonts 16, 17, and 18-serif 12 point underlined fonts 19, 20, and 21-sans-serif 10 point underlined fonts 22, 23, and 24-sans-serif 12 point underlined Suppose you want typing the "control" numbers to change the text font to a sansserif 10 point underlined, rather than a serif 12 point. You can change the affect of the text editor keyboard controls by evaluating the following expressions.
TextStyle default fontAt: 4 put: (TextStyle default fontAt: 19) TextStyle default fontAt: 5 put: (TextStyle default fontAt: 20) TextStyle default fontAt: 6 put: (TextStyle default fontAt: 21)

Now when you type ctrl 4 or ctrl 5 or ctrl 6, sans-serif 10 point fonts, underlined, will display. Typically you should also store the fonts you replace so that you can get them back again; either create a global variable or copy the TextStyle.

Inserting Delimiters About a Selection

Make a text selection (including a zero-width selection), then type one of the following control combinations in order to insert delimiters about the text. The control combinations are toggles, that is, if the selected text is already surrounded by the indicated delimiter, then the command removes it.

type keys
ctrl ctrl ctrl ctrl ctrl [ (

insert delimiters
[and] (and) < and > " and " , and'

<
" '

An example of first delimiting some text using double quotes, and then removing the delimiters, is shown in the next sequence of figures. Text is selected in Figure 3.9a; in Figure 3.9b, the user types ctrl " to delimit the selected words. The text selection is the sequence of delimited characters, as shown in Figure 3.9c; in Figure 3.9d, the user types ctrl " again to remove the delimiters.

64
How to Use the Text Editor

This is some text used to Illustra te how to move and hO'N to u:5in,~ the

This is some text usel::! to illustra.te rlo . ."'/ to move a.nd


Mov... to "CCIPY t6!xr~' 1J5ing the

WAW'

te::.::t editor. This

j~a

te::<t editor. This is a


illustr,~ tion

illustration of the te>':t edit,)r.

of thE! tl2::.::t editor.

000
Figure 3.9a
This is some text used to illustra te how to move ~.nd
hO"N

000
Figure 3.9b
to

"WAe;"

using

thQ

tE!xt editor. This is a.


illustr09.tion clf the te::--:t editor,

This is some te::-::t IJsed to illustrate how to move and ho'vv to using the te>::t Qditor. This i:s a.

WAWi

illustra tion of ttle

te)~t

editc,(.

000
Figure 3.9c

000
Figure 3.9d
Clearly these kinds of commands could be placed on the pop-up menu as well, especially if you find it cumbersome to move from the mouse to the keyboard. There is a tradeoff, however, in the size of the menu. Cascaded menus, where selecting an item invokes a related menu, could be used. For example, the main text editor yellow button menu might include the item delimiters. Choosing this command would invoke a new menu whose items were each of the possible delimiters. The first menu could be left on the screen or not; leaving the first on the screen allows the user to change his or her mind by returning to it to select another item, rather than by aborting all action.

r'
65
3.5 Summary of Terminology

3.4
The System Transcript
A Utranscript" is a special kind of workspace known as a text collector. It is basically the same as a workspace in that you can use the text editor in it. In addition, it is possible to write and evaluate expressions in which messages to store characters are sent to a text collector. There is one special text collector that we refer to as the System Transcript. It typically appears at the top left corner of an initial Smalltalk-80 display. It is a standard system view, so it can be moved, framed, collapsed, and closed. If it is open on the screen, you will sometimes see text appear, informing you of some system event. You can use the System Transcript in the Smalltalk-80 methods that you write, sending the System Transcript messages to store descriptions of objects you create. For example, type, select, and evaluate the expression
Transcript show: 'some text' ; cr

For information on how to send messages by evaluating a typed expression, see Chapter 6. The System Transcript for the current project -----is referred to by the system global variable Transcript. The system transcript is primarily used as the place where comments to the user appear as a form of feedback when other visual feedback techniques are not available. For example, if the system scheduling mechanism fails, a message stating the problem and what to do about it is displayed in the System Transcript. When users are debugging methods and it is desirable to print periodic messages indicating the state of evaluation (rather than to interrupt execution), the System Transcript is a useful place in which to display the messages. When categories of classes are filed out or classes are recompiled, the name of each class appears in the transcript so you can tell what kind of progress is being made. If you do not already have a System Transcript on your display screen, you can obtain one by choosing the System Menu command system transcript.

3.5
Summary of Terminology
text collector
A workspace; the System Transcript is a kind of text collector. Whereas most workspaces are used for editing text directly, text collectors are primarily used for displaying information determined in print messages included in class methods.

66
How to Use the Text Editor

text editor caret draw through

A set of operations for creating and modifying a paragraph of characters. A symbol used to denote a text selection that contains no characters. The activity of selecting a passage of text by pointing to one end of the passage, pressing the red button, and then moving to the other end of the passage before releasing the red button. The sequence of characters of a paragraph that is currently highlighted.

text selection

i
1

I I I
I

How to Use Projects

68
How to Use Projects

Projects support your ability to manage several programming tasks at a time, without getting your work space too chittered. You use projects the way you might use several desks in an office or several offices in a building- that is, as spaces in which to manage related information or activities. You might, for example, be working on two applications programs at one time. So you might have two projects, the top one and another; each application is developed in a different project so that you can create workspaces with information related to just the one project. Each project maintains information about the changes you make to class definitions and methods while you are working in its views. Thus you can use projects to keep separate records of the methods you develop for each application. Or, you might use projects in order to keep programming tasks separate from access to mundane daily work (letter writing, receiving and sending mail, retrieving an address from a database). Any classes created in one project are immediately available to all projects in the system. The global name space for variables is also shared across all projects. Thus if you create a variable in one project and change it in a second project, it will be changed as well in the first project. The primary support provided by projects is
1. maintenance of separate lists of changes to classes, and

2. visual layout of a set of views. The separate list of changes is a useful way to distinguish the changes to the shared classes that were needed to support the application in an individual project. (For information about how the system maintains references to the changes you make, see Chapter 23,) To practice creating and using projects, try the following sequence of actions. Choose the System Menu command project (Figure 4.1) and create the project view (Figure 4.2). You can type characters in the project view that describe the project; this is a way of documenting the purpose of the project. In the project view, select the yellow button command enter. The yellow button menu is shown in Figure 4.3. The result of choosing the command enter is shown in Figure 4.4. The display screen is now blank-no views are displayed. No activity has yet occurred in this project. Choose the System Menu command workspace and the System Menu command system transcript. The two views are shown in Figure 4.5. The views in the current project are not immediately accessible from other projects. Now choose the System Menu command exit project as shown in Figure 4.6.

69
How to Use Projects

Figure 4.1

010

Figure 4.2

000

70 How to Use Projects

Figure 4.3

Figure 4.4

71 How to Use Projects

Workspace

!i !i ~li

Figure 4.5

8
restore display

::J
Workspace

file list bro'v\"5er \.vorkspa ce

P,t'oJ~ct '\

system tt-,3rrscript
5.'l5tem v...ork.space
S03:.VE!

....
System Tr.,nscr-ipt

quit

",,,,',,

0:

Figure 4.6

010

....

72
How to Use Projects

The display screen clears and the first collection of views reappears, including the project view (Figure 4.7). You can now do your work in this (top) project. Or you can re-enter the other project as you did before. Try re-entering, then return to the top project. Select the project view and then choose the blue button command close (Figure 4.7). Since there are views open in the project you are trying to close, a confirmer appears to warn you that you might be irreversibly destroying information (Figure 4.8). If it is okay, choose yes. The project view disappears and, with it, your access to the project's views and changes, if any.

Figure 4.7

001

73
How to Use Projects

Figure 4.8

100
This particular implementation of projects creates a hierarchical organization, where the path to projects is through a view that exists in the "parent" project; each parent can have several "children" projects. The analogy is to workrooms whereby each room has several doors into other workrooms. For this reason, some people can project views "doors." An alternative design is to create a project browser that can be opened in any project by choosing an appropriate command from the System Menu. A project could be named, described, and accessed by choosing items in a project browser, in a way analogous to the way classes are named and described in a system browser. Creating a project browser is an exercise you might try to do when you are proficient in Sma11talk-80 programming. It is given as an example in Section 15.2.

Fundamentals of the Smalltalk-80 Language

5.1 Objects, Messages, and Methods Classes, Instances, and Subclasses Advantages of Object-Oriented Programming 5.2 Expression Syntax Class Descriptions Method Determination, self and super 5.3 System Components The System Class Hierarchy 5.4 Overview of the Programming Process 5.5 Summary of Terminology: General Concepts 5.6 Summary of Terminology: Syntax

76
Fundamentals of the Smalltalk-80 Language

The particular kinds of user interface components provided in the Smalltalk-80 system are designed to give you access to the elements of the Smalltalk-80 language. To understand the descriptions for evaluating expressions and for finding information in the system, you need an introduction to the concepts of object-oriented programming and the syntax for expressions in the Smalltalk-80 language, and you need an overview of the programming process. Subsequent sections suggest various expressions to try and describe the system components that support program development. You should turn to the companion book, Smalltalk-80: The Language and its Implementation by Adele Goldberg and David Robson, for a more thorough presentation of the programming language.

5.1
Objects, Messages, and Methods
The Smalltalk-80 language is based on a uniform use of objects and messages. An object is a uniform representation of information that is an abstraction of the capabilities of a computer. The two capabilities of a computer that are of interest in the language are the capability to store information and the capability to manipulate information. An object has the capability to store information. We say that an object has private memory." An object also has the capability to manipulate its stored information or to carry out some activity. These are called the operations of an object. The set of operations is referred to as the object's message interface or message protocol. An object carries out one of its operations when an object sends it a message to do so. Each object knows the messages it can understand; associated with each such message is a procedure or method that describes how the object should answer the message. A crucial property of an object is that its private memory can only be manipulated by the operations in the object's interface. Computing is viewed as an intrinsic capability of objects that can be uniformly invoked by sending messages. Linking these concepts to ones more familiar to you, an object is like a computer consisting of data and procedures that operate on that data. An operation is invoked by calling on some procedure. Sending a message is the Smalltalk way to invoke a procedure; Smalltalk is a simulation of many computers communicating with one another. Objects and messages encourage modular design. The implementation of one object cannot depend on the internal details of other objects, only on how they respond to messages. In the Smalltalk-80 system, objects and messages are used to implement the entire programming environment. Objects are used to represent numbers, lists, text strings,

77
5.1 Objects, Messages, and Methods

dictionaries, spatial locations, areas, text editors, processes, compilers, debuggers, and all other system components. Once objects and messages are understood, the entire system is accessible. The messages an object understands depend on what the object represents. Objects representing numbers understand messages that request arithmetic functions to be computed and their results returned. Objects representing lists and dictionaries understand messages requesting that information be stored or retrieved (in the form of other objects, naturally). Objects representing spatial locations and areas understand messages inquiring about their relation to other locations and areas. In many respects, you can think about real-world situations and identify the parts or components that playa role in these situations. These are the objects. These objects act out their roles by communicating with the other objects; that communication takes the form of a language of words-commands or informational data. These are the messages that make up the interface to the objects. A basic problem in designing Smalltalk programs is determining which kinds of objects should be described and what message names provide a useful language of interaction among these objects. In Smalltalk, the choice of message names is arbitrary, although there is a concrete syntax that must be followed. Appropriate choice of objects depends, of course, on the purposes to which the application will be put and the granularity of information to be manipulated. For example, if a simulation of an amusement park is to be created for the purpose of collecting data on queues at the various rides, then it would be useful to describe objects representing the rides, the waiting lines, workers who control the rides, and the people visiting the park. If the purpose of the simulation does not include monitoring the consumption of food in the park, then objects representing these consumable resources are not required. If the amount of money exchanged in the park is not to be monitored, then details about the cost of rides do not have to be represented. There are many objects in the Smalltalk-80 system. Objects that respond to the same messages in the same way are grouped together. When they are grouped together, their private memory is represented in the same way and their methods refer to their data with the same set of names. A group of objects related in this way is called a class. Objects in a group are called instances of the class. Programming in the Smalltalk-80 language consists of creating new classes, creating instances of classes, and specifying a sequence of message exchanges among all of these objects. Every object in the Smalltalk-80 system is an instance of a class. All instances of one particular class represent the same kind of system

Classes, Instances, and Subclasses

78
FundaITlentals of the SITlalltalk-80 Language

component. Classes have names that describe the kind of component their instances represent. Instances of a class named Point represent spatial locations. Instances of a class named Rectangle represent rectangular areas. Instances of a class named Process represent independent processes. Refining existing class descriptions is a powerful way in which to approach Smalltalk-80 programming. Such refinement is supported by the ability to create a subclass of an existing class. A subclass describes a group of objects that inherit information from an already existing description. A subclass can add new functionality or private memory, and modify or prohibit existing functionality. Consider the amusement park example. Suppose we wish to create a simulation of this park. The first task is to determine the objects involved in the park. What do you think of when considering an amusement park? There is a merry-go-round, cotton candy, ferris wheels and roller coasters, tickets to buy, souvenirs to buy, a fun house, games, side shows (animals, strange people), a train ride, ice cream booth, cafeteria, sit-down restaurant, animal rides, lines of people waiting to get on a ride or to get a ticket, someone selling balloons, and so on. Oh yes, there are crying kids and crying parents, dizziness, stomach aches, and sunburn. Focusing our attention on the kinds of places, rather than the people or animals, we can organize the parts of an amusement park into rides, game booths, and places to buy things. One organization might divide the parts into places where you buy things and places where you do not buy things. Places where you buy things include rides, food vendors, and nonfood vendors. To create a Smalltalk-80 simulation, classes must be described for each of these kinds of objects. For example, we might create the class Ride; instances of Ride may be ferrisWheel or
merryGoRound. Each Ride has a waiting line of some kind made up of customers

waiting for service. This means that the private memory of each kind of Ride includes a reference to a waiting line. This line must be an instance of a class that describes the appropriate kind of data structure that can reference an ordered sequence of customers. Since everything is an object, and each object is an instance of a class, then a customer must be an instance of a class, perhaps of class ParkVisitor. At some time, a worker assigned to the ride announces ((next, please" to the line; the next customer waiting is given service. At various times, customers arrive and enter the line, or they get tired of waiting and leave. The customers in the waiting line can be different kinds of objects. However, they all must be able to carry out the behavior appropriate to waiting in line and getting out of the line. So customers might be instances of ParkVisitor or they might be instances of a special kind of visitor, sayan ElderlyParkVisitor, who gets preferential treatment at

79
5.1 Objects, Messages, and Methods

the park. ElderlyParkVisitor could be created as a subclass of ParkVisitor so that all of the capabilities given a ParkVisitor are inherited by ElderlyParkVisitor as well. In addition, ElderlyParkVisitor might act differently-always entering a waiting line at the front instead of the rear. To create the Smalltalk-80 simulation, we will have to decide what messages the ParkVisitor, and thereby ElderlyParkVisitor, will understand -perhaps
goToNextRide

and
buyTicket

Advantages of Object-Oriented Programming

Programming in the Smalltalk-80 language consists of identifying jects, classifying them according to similarities and differences, and signing a language of interaction among these objects. These important organizing skills and communication skills that can taught using this form of computer programming. What are the advantages of this form of programming?

obdeare be

1. The information known privately to an object is protected-this information can only be accessed directly by the methods of the object. This means that the structure of an object (the representation of the information of an object) can be changed without affecting interactions with instances of other classes. This ensures that there is a structure or discipline by which objects interact and that a user can make changes or additions to very complex systems without getting caught in a maze of interdependencies. 2. The user accesses existing objects as well as creates new ones or modifies existing ones. Modification is done by adding a new message and its method to a class description, or by adding new data slots to the private memory of all the objects in a class. This means that the Smalltalk-80 language provides a simple and expressive model for the relationship among parts and wholes so that the process of building a system can draw on one's intuitive ability to synthesize and analyze. 3. The Smalltalk-80 system is built on the model of communicating objects. Large applications are viewed in the same way as the fundamental units from which the system is built. The interaction between the most primitive objects is viewed in the same way as the highest-level interaction between the computer and the user. 4. Objects support modularity. The complexity of the system is reduced by a minimization of interdependencies of system parts.

80
FundalTIentals of the SlTIalltalk-80 Language

Complexity is further reduced by grouping together similar parts, where this grouping is achieved through classes. Classes are also the chief mechanism for extension in the system. And subclasses support the ability to factor the system in order to avoid repetitions of the same concepts in many different places. Managing complexity is a key contribution of the Smalltalk-80 approach to software.

5.2
Expression Syntax
The syntax of the Smalltalk-80 language is simple, providing a way to refer to objects and messages and arguments using alphanumeric names. There is no restriction in the language on the length of a name; there are some restrictions on the use of special symbols. In this section, syntax diagrams for the language are presented. The diagrams are like those used, for example, in the Pascal User Manual and Report, Kathleen Jensen and Niklaus Wirth, Springer Verlag, 1978. The term being defined is shown at the left margin; each term is defined with respect to other terms (shown in boxes) or literals (shown in ovals or circles) in the language. The diagram helps determine whether an expression is syntactically correct. An expression is a sequence of characters that describes an object called the value of the expression. The four kinds of legal expressions are literals, variable names, message expressions, and block expressions.

Literals Literals are numbers, symbol constants, character constants, strings, and array constants, as shown in Figure 5.1.

literal

..J

'"
'-

--I

number

1
1
F

--I

...J symbol constant

1 1

..J ch aracter constant 1 _"I 1 ..J


--I
string

I
1

..J
Figure 5.1

--I

array constant

1
I

81 5.2 Expression Syntax

o Numbers
3 30.45 -14.0 13772 8r153 16rAC.DC 1.586e-3 16r1e10

The diagram for numbers is shown in Figure 5.2. Example numbers are

digit

digits

.~
number

Figure 5.2

Characters The diagram for characters and character constants is shown in Figure 5.3. Note that in the syntax diagrams, a character is defined as any element from the ASCII character set other than double quote (") or single quote ('); the definition of character constant is a character or a double quote or a single quote. Example character constants are
$a
$M $-

$$ $[ $@

82
Fundamentals of the Smalltalk-80 Language

character constant character

letter

special character

character

Figure 5.3

83
5.2 Expression Syntax

Strings

Figure 5.4 is the diagram for strings. Example strings are

, hi' , the Smalltalk-80 system' 'can' 't'


string

Figure 5.4

Symbols

Figure 5.5 is the diagram for symbols.

identifier

symbol

I\..

-, _I -,
-J
/'

identifier

I ,
~,

binary selector

I
,
I

\..

l
symbol constant

_I I

keyword

.-

--

I
./

Figure 5.5

----------~ .. # )-------~

symbol

I~-------.~

84
Fundamentals of the Smalltalk-80 Language

Example symbol constants are


#bill #M63

There will never be two symbols with the same characters; each symbol is unique-that is, any reference to a symbol made up of the same sequence of characters is a reference to the same symbol. Examples of binary selectors and keywords are given in subsequent sections.
If you do look ahead, you will notice that the following are symbols.
Smalltalk is an identifier
*

is a binary selector

/ / is a binary selector

atput is a keyword selector

Arrays An array is a simple data structure whose contents can be referenced by an integer index from 1 to a number that is the size of the array (Figure 5.6).

array

number

symbol

string

character constant

array

_ar_r_a_y_c_o_n_st_a_n_t

..

~t------~ array I-------i.~

Figure 5.6

85
5.2 Expression Syntax

Example array constants are


#(1 2 3) #( 'food' 'utilities' 'rent') #(( , one' 1) (' not' negative) 0 -1)

Comments In addition, comments can be placed anywhere within an expression or sequence of expressions (Figure 5.7).
comment

Figure 5.7

Example comments are


" This is a comment" " with an embedded quote " " symbol" " and an embedded single quote ' symbol"

Variables The memory available to an object is referenced by the use of variable names. A variable name is simply an identifier (Figure 5.8).
variable name

Figure 5.8

-------------~~ identifier
By convention, when identifiers are created by concatenating words, the first letter of each additional word is capitalized. For example
BicPen redButtonPressed totalSpentOn:

Message Expressions Messages represent interactions between the components of the Smalltalk-80 system. A message requests an operation on the part of the receiver. A message expression describes a receiver, a selector, and possibly some arguments. The receiver and

Fundamentals of the Smalltalk-80 Language

arguments are described by other expressions; the selector is specified literally. A unary selector is simply an identifier, and a binary selector is either a minus sign or one or two consecutive special characters. A keyword is an identifier with a trailing colon; the keyword selector is a concatenation of the keywords in a message. The diagrams for unary selector, binary selector, and keyword are shown in Figure 5.9.
unary selector

----------.....;~ identifier
binary selector

special character

special character keyword

Figure 5.9

-----------~ identifier 11-------i~ )-------I~~ O


In the message expression
ages at: 'James' put: 25

..

there are two keywords, at: and put:. The keyword selector, that is, the literal part of the message expression, is at:put:. The two arguments of the expression are 'James' and 25; the receiver is ages.
Keyword selectors do not show up in expressions; hence there is no diagram for them independent of the diagram for symbol. However, they are the symbols stored as the keys of a class's message dictionary; they can be seen, for example, in one of the subview's of the system browser as described in Chapter 9.

There are three kinds of message expressions: unary, keyword, and binary. Diagrams for message expressions are shown in Figure 5.10. The following are unary expressions.
theta sin BicPen home Pen new home

In the third example, a unary expression (Pen new) is parsed as a unary object description that is sent a unary message (home).

11"""--

87 5.2 Expression Syntax


primary variable name

literal

block

expression unary object description

binary object description

1~

primary unary expression

~---

,...-----------.....,
unary object description

binary expression unary expression unary object description binary expression binary object description keyword expression binary object description keyword binary object description binary selector unary object description unary selector

message expression

- - - - - - - - - -.. . ~-----;-l .. .. I

.1

unary expression

It----~r---------I~~

,,
_ _.... b J
. 11-_ _ 1 mary expressIOn,

Figure 5.10

_~..... eyword expressIOn,'....- - - Jk . ~.,

88
Fundamentals of the Smalltalk-80 Language

The following are binary expressions.


3 + 4 previousTotal - expenditure (sum / count) * reserve amount

In the third example, the binary expression is formed as a binary object description (sum count) followed by a binary selector (*) followed by a unary object description (reserve amount). The binary object description is itself a unary object description that, as a primary, is a parenthesized expression. The following are keyword expressions.
3 max: 2 finances totalSpentOn: 'food' anArray at: 3 put: 100 HouseholdFinances expenditures totalSpentOn: (reasons at: i)

In the fourth example, the keyword expression is formed as a binary object description followed by a keyword (totaISpentOn:) followed by a binary object description. The first binary object description is a unary expression that is the variable HouseholdFinances followed by the unary selector expenditures. The second binary object description is a primary, the parenthesized keyword expression reasons at: i.

Parsing When the receiver or argument of a message expression is described by another message expression, the issue of how the expression is parsed arises. Parentheses can be used to indicate the order of evaluation when that order is different from the ordinary parse. The parsing rules are:
1. Unary expressions parse left to right

2. Binary expressions parse left to right 3. Binary expressions take precedence over keyword expressions 4. Unary expressions take precedence over binary expressions 5. Parenthesized expressions take precedence over unary expressions For example,

expression
4 + 5 -3 2 * theta sin

parses as
(4

5) - 3

2 * (theta sin)

frame width: otherFrame width * 2

frame width: otherFrame width) *

2)

89
5.2 Expression Syntax

Cascaded Messages Cascading specifies multiple messages to the same object. A cascaded message expression consists of one description of the receiver followed by several messages separated by semicolons. The diagram for a cascaded message expression is shown in Figure 5.11.
cascaded message expression message expression

1---"""'"

unary selector

binary selector

unary object description

keyword

binary object description

Figure 5.11

For example, a cascaded message expression is


BicPen home; up; turn: 89; go: 50+i; turn: 91; go: 200

which is equivalent to
BicPen BicPen BicPen BicPen BicPen BicPen home. up. turn: 89. go: 50 + i. turn: 91. go: 200

Assignments A literal constant will always refer to the same object, but a variable name may refer to different objects at different times. The object referred to by a variable is changed when an assignment expression is evaluated. Any expression can become an assignment by including an assignment prefix, that is, a variable name followed by a left arrow. For example
quantity +- 19 index +- initiallndex name +- ' Chapter 1 ' flavors +- # (vanilla chocolate strawberry rootbeer) foo +- array at: 4 BicPen +- Pen new home; turn: 89

90
Fundamentals of the Smalltalk-80 Language

Thus the definition of an expression is a primary, a message expression, a cascaded message expression, or an assignment, as shown in Figure 5.12.
expression

message expression

variable name

t------

Figure 5.12

cascaded message expression

Block Expressions Blocks are objects used in many of the Smalltalk-80 control structures. A block represents a deferred sequence of actions. A block expression consists of a sequence of expressions separated by periods and delimited by square brackets (Figure 5.13).
statements

block

variable name

Figure 5.13

Blocks may take one or more arguments. Block arguments are specified by including identifiers preceded by colons at the beginning of a block. The block arguments are separated from the expessions that make up the block by a vertical bar.

91 5.2 Expression Syntax

For example,
[ [ [ [ quantity + 19] index <- initiallndex. index <- index :array I total <- total + array size] :x :y I BicPen goto: x @ y]

1]

Since a block is a primary, the following assignments are expressions.


savedAmount <- [ quantity + 19] incrementer <- [ index <- initiallndex. index <- index sum <- [ :array I total <- total + array size]

1]

A block without any arguments is evaluated by sending it the message


value. A block with one argument is evaluated by sending it the message value: anArgument. Blocks with multiple arguments are evaluated by sending messages with a value: keyword and argument for each of

the block arguments. For example,


[ quantity + 19] value [ :array I total <- total + array size] value: #(a bed e f) [ :x :y I BicPen goto: x @ y] value: 100 value: 250

D Control Structures Two kinds of control structure found in most programming languages are provided in the Smalltalk-80 system: conditional selection and conditional repetition. Conditional selection consists of a message to a Boolean object with block expressions as the arguments. There are four such messages whose keyword selectors are ifTrue:ifFalse:, ifFalse:ifTrue:, ifTrue:, and ifFalse:. For example,
number < 0 ifTrue: [ absValue <- number negated] ifFalse: [ absValue <- number] number < 0 ifFalse: [ absValue <- number] if True: [ absValue <- number negated] number < 0 ifTrue: [ number <- number negated] number> = 0 ifTrue: [ number <- number negated]

Conditional repetition is provided by a message to a block with the keyword selector whileTrue: or whileFalse:, and another block as an argument. Evaluation of the argument continues until the receiver evaluates to true or to false, respectively. These are like the Algol

92
Fundamentals of the Smalltalk-80 Language

ttwhile" and nuntil" statements. Examples of two expressions that carry out the same actions are
[index < = list size] whileTrue: [ list at: index put: O. index index+ 1]

+-

and
[index > list size] whileFalse: [ list at: index put: O. index index+ 1]

+-

In each case, the idea is to put the value 0 in each position in an array list, starting with some value of variable index and continuing until index exceeds the size of the array.

Methods A method describes how an object will perform one of its operations. A method is made up of a message pattern and a sequence of expressions separated by periods. A message pattern contains a message selector and a set of argument names for each argument that a message with that selector would have. A method may obtain some other variables for use during its execution. These are called temporary variables. A temporary variable declaration consists of a set of variable names between vertical bars. The default value of a method is the receiver itself. When another value is to be specified, one or more return expressions are included in the method. Any expression can be turned into a return expression by preceding it with an up arrow. The diagrams for a method are shown in Figure 5.14. Note that the up arrow is specified in the diagram for ttstatements. " An example method in which a counter is incremented until the user presses the red button, and in which the final count is returned, is

I tempVar I tempVar +- O. [Sensor red ButtonPressed] whileFalse: [ tempVar rtempVar

+-

tempVar + 1].

The temporary variable is tempVar. It is initially assigned to the value O.


tempVar
+-

Then the expression


Sensor red ButtonPressed

93 5.2 Expression Syntax temporaries

~I----Y-v-ar-iab-le-na-me-;J---""~)--------'~
message pattern unary selector

binary selector

variable name

keyword

variable name

method

-----1-. message pattern

t---or----------~---------..."..~

Figure 5.14

temporaries

statements

is evaluated. This is a test of the hardware pointing device. As long as the red button is not pressed, the expression
tempVar
+-

tempVar

is evaluated. This assignment changes the value of tempVar, incrementing it by 1. When the user presses the red button, the current value of tempVar is returned. Each class has a name that describes the type of component its instances represent. A class name serves two purposes; it is a simple way for instances to identify themselves, and it provides a way to refer to the class in expressions. Since classes are components of the Smalltalk-80 system, they are represented by objects. A class's name automatically becomes the name of a globally shared variable. The value of that variable is the object representing the class. By convention, the first letter of names of shared variables are capitalized. A description of a class has four parts. 1. A class name. 2. The superclass of the class.

Class Descriptions

94
Fundamentals of the Smalltalk-80 Language

3. A declaration of the variables available to instances. 4. The methods used by instances to respond to messages. The methods in a class description are divided into categories; the categories have names that indicate the common functionality of the methods. The classes in the Smalltalk-80 system are also grouped into categories. These two kinds of categorizations in the system are orthogonal to the semantics of the language; they are used to document the intended use of classes and methods, and they are useful in providing a way to index the system's functionality. The methods in a class have access to five different kinds of variables. These kinds of variables differ in terms of their scope, and how long they persist. 1. Instance variables exist for the entire lifetime of the object. They represent the current state of an object. 2. Temporary variables are created for a specific activity and are available only for the duration of the activity. They represent the transitory state necessary to execute a method. 3. Class variables are shared by all the instances of a single class. 4. Global variables are shared by all the instances of all classes. 5. Pool variables are shared by the instances of a subset of the classes in the system. The majority of shared variables in the system are either class variables or global variables, most of which refer to the classes in the system.
Names of global variables are stored as the keys in a special dictionary named
Smalltalk. In order to declare a new global variable, you evaluate an expression of

the form
Smalltalk at: #VarName put: varValue

To evaluate an expression, you type the appropriate expression in a workspace, select the text of the expression, and then choose the yellow button menu command do it. You can then use VarName in expressions that you evaluate in a workspace.

We said earlier that all Smalltalk-80 system components are represented by objects and all objects are instances of a class. Therefore, the classes themselves are represented by instances of a class. A class whose instances are themselves classes is called a metaclass. In the description of a class, it is necessary to distinguish between the messages sent to the instances of a class and those sent to the class itself. Messages sent to the class itself are stored in the message dictionary of the class's metaclass.

95
5.3 System Components

A class's metaclass is automatically created whenever the class is created. In the programming interface to the system, a menu in the system browser supports the user in specifying whether a message is to be sent to instances or to the class itself. The programming interface also supports creating class and message categories. When a message is sent, the methods in the receiver's class are searched for one with a matching selector. If none is found, the methods in that class's superclass are searched next. The search continues up the superclass chain until a matching selector is found. The search for a matching selector follows the superclass chain and terminates at the root of the class hierarchy, which in the Smalltalk-80 system is class Object. If no matching selector is found in any class in the superclass chain, the receiver is sent the message doesNotUnderstand: with an argument that is the offending message selector (the one that could not be found). The response to the message doesNotUnderstand: is found in class Object; the result is to report an error to the programmer or user. A pseudo-variable name is similar to a variable name, however, the value of pseudo-variable name cannot be changed by an assignment. The names of variables in a message pattern are pseudo-variable names. In addition, there are special pseudo-variable names in the system. The pseudo-variable self refers to the receiver of a message. When a method contains a message whose receiver is self, the search for the method for that message begins in the instance's class, regardless of which class contains the method containing the pseudo-variable self. The pseudo-variable super is also available for use in a method's expressions. The pseudo-variable super refers to the receiver of the message, just as self does. However, when a message is sent to super, the search for a method does not begin in the receiver's class. Instead, the search begins in the superclass of the class containing the method. The use of super allows a method to access methods defined in a superclass, even if the methods have been overridden in subclasses.

Method Determination, self and super

5.3
System Components
The Smalltalk-80 system includes a set of classes that provide the standard functionality of a programming language and environment: arithmetic, data structures, control structures, and input!output facilities. The system includes objects representing both real and rational numbers. There are also classes for representing linear magnitudes (like dates and times) and random number generators. Most of the objects in the Smalltalk-80 system function as data structures of some kind. While most objects also have other functionality,

96
Fundamentals of the Smalltalk-80 Language

there are a set of classes representing more or less pure data structures. These classes represent different types of collections. Objects and messages implement the standard control structures found in most programming languages. They provide conditional selection similar to the ((if-then-else" statements of Algol and conditional repetition similar to its ((while" and ((until" statements. Two classes are provided to support these control structures. Booleans represent the two truth values and blocks represent sequences of actions. Booleans and blocks are used to create new kinds of control structures. Objects representing independent processes and mechanisms for scheduling and synchronous interaction are also provided. There are several classes in the Smalltalk-80 system that assist in the programming process. There are separate classes representing the source (human-readable) form and the compiled (machine-executable) form of methods. Objects representing parsers, compilers, and decompilers translate between the two forms of method. Objects representing classes connect methods with the objects that use them (the instances of the classes). Objects representing organizational structures for classes and methods help the programmer keep track of the system, and objects representing histories of software modification help link the efforts of other programmers. Even the execution state of a method is represented by an object. These objects are called contexts and are analogous to stack frames or activation records of other systems. Classes helpful for presenting graphical views represent points, lines, rectangles, and arcs. Since the Smalltalk-80 system is oriented toward a bitmapped display, there are classes for representing and manipulating bitmapped images. There are also classes for representing and manipulating the more specific use of bitmapped images for character fonts, text, and cursors. Built from these graphical objects are other objects representing rectangular windows, command menus, and content selections. There are also objects that represent the user's actions on the input devices and how these relate to the information being viewed. Classes representing specific viewing and editing mechanisms constructed from these components provide views for classes, contexts, and documents containing text and graphics. The views of classes provide the fundamental mechanism to interact with the software in the system. The Smalltalk-80 system allows communication with external media. The standard external medium is a disk file system. Objects represent individual files as well as directories. If a connection to a communications network is available, it can be accessed through objects as well.

The System Class Hierarchy

Figure 5.15 is of the system classes that are presented in the companion book Smalltalk-80: The Language and its Implementation. Lines are drawn around groups of related classes; the groups are labeled to indicate the numbers of the chapters in which specifications of the classes can be found.

97
5.3 System Components

IObject
Magnitude Character Date Time Number Float Fraction Integer LargeNegativelnteger LargePositivelnteger Smalllnteger LookupKey Association Link Stream PositionableStream ReadStream WriteStream ReadWriteStream ExternalStream FileStream Random File FileDirectory FilePaae UndefinedObject Boolean False True ProcessorScheduler Delay SharedQueue

11
12

14

I Process
9

Collection

SequenceableCollection LinkedList

15

I Semaphore
ArrayedColiection Array Bitmap DisplayBitmap RunArray String Symbol Text ByteArray Interval OrderedCollection SortedCollection Bag MappedCollection Set Dictionary IdentityDictionary

Behavior ClassDescription Class MetaClass Point Rectangle BitBlt CharacterScanner

16

18

Pen DisplayObject DisplayMedium Form Cursor DisplayScreen InfiniteForm OpaqueForm Path Arc Circle Curve Line LinearFit Spline

I 19

10 Figure 5.15

20

98
Fundamentals of the Smalltalk-80 Language

Several classes available in the standard Smalltalk-80 system are not listed in Figure 5.15. Some of these are the classes that support the implementation of the user interface, including View, Controller, ControlManager, and WindowingTransformation. The specific way in which these classes and subclasses of View and Controller are used to create the programming interface, as well as graphical and interactive interfaces to applications, will be described in a future companion book, Smalltalk-80: Creating a User Interface and Graphical Applications. Some of the classes that describe the standard program development tools are
Browser Debugger MethodListDebugger FileModel FileList Inspector Contextlnspector Dictionarylnspector StringHolder ChangeList Filii nTheBlank Project TextCollector SyntaxError

There is a subclass of View and Controller for each of these; the subclass of View supports the way information about the development tool should be presented on the display screen, and the subclass of Controller describes the way in which the pointing device, menus, and the keyboard are used to interact with the development tool. There are classes for organizing classes and messages, and for keeping track of changes to classes and methods; these are
ChangeSet ClassCategoryReader ClassOrganizer SystemOrganizer

There are classes that describe parsing, compilation, and decompilation.


Compiler ParseNode AssignmentNode BlockNode

99
5.4 Overview of the Programming Process

CascadeNode Decompiler Encoder LeafNode LiteralNode SelectorNode VariableNode MessageNode MethodNode ReturnNode ParseStack Scanner Parser

And there is a class that describes creating a new version of the system.
SystemTracer

5.4
Overview of the Programming Process
Programming in the Smalltalk-80 system involves the specification of one or more class descriptions, creating instances of classes, and sequencing messages to the instances. In the course of using the system, you interact with various views that give you access to the classes in the system, messages, methods that implement messages, expressions in which messages are sent to objects, and intermediate execution states. The programming environment supports describing classes in an incremental fashion. The ((class editor" is presented in the form of a browser, which is a way to present a hierarchical index to classes and to messages. Browsers are set up to help you find classes either by name or by category. You can find a message name under the class that uses it, and, given the name, you can find its implementors or senders.
To determine the class of an instance, you send the instance the message class. To determine the category of a class, you send the class the message category.

The browser is used to retrieve descriptions of existing classes. It also provides a structure within which new classes are defined and existing classes are modified. When you use a browser to examine existing class descriptions, the source code for each method is retrieved from a special file.

100 Fundamentals of the Smalltalk-80 Language


Some hardware/software configurations of the Smalltalk-80 system might not have sufficient local or remote secondary storage space for this file. In such cases, attempts to retrieve the source code will fail. In order to view the method, you must use the system decompiler. You decompile the resident compiled code by holding down the "shift" key on the keyboard while selecting the message selector to be retrieved. Alternatively, set the value of SourceFiles to be nil (that is, evaluate the expression SourceFiles +- nil), indicating that no sources and no changes files are available. Decompiling loses comments and the names of temporary variables.

A system browser looks like a rectangular area on the screen that is divided into five parts. The parts either indicate a categorization for classes or a categorization for the methods of a particular class. These categorizations are orthogonal to the language itself; they provide a way in which to orgahize and document the class description. Parts Two and Three describe the system browsers in detail. Classes are created by editing templates that are accessed via the system browser. The template for defining a new class as a subclass of an existing class, and for declaring the private and shared variables is
NameOfSuperclass subclass: # NameOfClass instanceVariableNames: 'instVarName1 instVarName2' classVariableNames: 'ClassVarName1 ClassVarName2' poolDictionaries: " category: ' Category-Name'

In order to create a new class, you edit this template. You specify the names of classes (replacing NameOfClass and NameOfSuperclass), and you replace or delete the place holders for variable names, e.g., instVarName1 or ClassVarName1. The result is a Smalltalk-80 expression. For example
View subclass: # FinancialHistoryView instanceVariableNames: " classVariableNames: " poolDictionaries: " category: ' Financial-Histories'

When you evaluate the preceding expression, you create the new class whose name is FinancialHistoryView as a subclass of View. It has no new variables declared. The yellow button menu associated with the part of the browser in which the template is displayed includes the command accept. When accept is chosen, the expression is evaluated. If there are no errors in syntax, then the new class is added to the system. If the class already exists, then it is redefined (its superclass or its variables may be changed); in this case, all existing methods of the class and its subclasses are recompiled so that references to variables can be rechecked.

101 5.4 Overview of the Progranuning Process

The template for defining new methods is


message selector and argument names "comment stating purpose of message"

I temporary variable names I statements


It is displayed in a part of the system browser as a result of your selecting a class category, a class, and a class message category. The yellow button menu associated with the part of the browser in which the template is displayed includes the command accept. When accept is chosen, the method is con1piled. If there are no syntax errors, the compiled method is stored in the selected class's method dictionary. You can develop your class description in parts. Each time you wish to add a method, you use the system text editor (as described in Chapter 3) and edit the method template. In order for the system to store the text as an actual method, you have to compile it. You compile the text by choosing the yellow button command accept. Compilation is done incrementally, method by method.
Compilation is from Smalltalk-80 expressions into a bytecode instruction set which is interpreted by the Smalltalk-80 virtual machine.

As expressions are evaluated in a workspace, or as class descriptions are developed using a browser, information pertaining to each action is saved on a special disk file that we refer to as the changes file." In this way, there is a file that represents an audit trail of each of your actions; this file can be used to recover your work in case of a system failure. A description of the recovery process is provided in Chapter 23. Your changes are also monitored in a kind of dictionary. We refer to this dictionary as the system Change Set." It is useful as a reference for writing out a description of your final work (any class changes) onto a disk file. Typically, users share information, such as method descriptions, by sharing files of incremental changes or files of complete class descriptions. The system Change Set is documented in Chapter 23. The process of developing class descriptions is supported by the browser. Using it you can ask questions about existing classes. You can find out which methods in which classes send a particular message. And you can find out which classes implement a particular message. Support for finding out such information is described in Part Two; support for programming is described in Part Three. An execution interrupt occurs when you encounter a runtime error, you evaluate a breakpoint that you inserted in a method, or you type ctrl c (the control" key and the c" key concurrently). You can create a debugging view onto the context of that interrupt. Notifiers for inter-

102
Fundamentals of the Smalltalk-80 Language

rupts and the debugger are described in Part Four. Note that you can edit a method within the debugger, compile it by choosing the yellow button command accept, and proceed with testing your work (without explicitly reloading the system). Changes you make are local to your copy of the system. When you have completed your work, you can save it in one of two ways. You can either save a textual description of your class descriptions by using the ((file out" command available in the system browsers (see Chapters 9 and 22), or save a new image of the entire system by creating a snapshot (see Chapters 1 and 23). It is useful to keep a snapshot of your work, expecially if you have created several kinds of objects that have information state that has evolved during your work session. Files created using the first approach can be shared with other users (they can file in the descriptions) so that your class descriptions can become part of their personal systems.

5.5
Summary of Terminology: General Concepts
argument name
Name of a pseudo-variable available to a method only for the duration of that method's execution; the value of the argument names are the arguments of the message that invoked the method. A description of a group of similar objects. An object that describes the implementation of a set of similar objects. A variable shared by all the instances of a single class. A variable shared by all the instances of all classes. One of the objects described by a class; it has memory and responds to messages. A part of an object's private memory. A variable available to a single object for the entire lifetime of the object. The messages to which an object can respond. A request for an object to carry out one of its operations. A message selector and a set of argument names, one for each argument that a message with this selector must have. A description of one of an object's operations; it is made up of a message pattern, temporary variable declaration, and a sequence of expressions. A method is executed when a message matching its message pattern is sent to an instance of the class in which the method is found.

class class variable global variable instance instance variable interface message message pattern

method

103
5.6 Summary of Terminology: Syntax

object pool variable primitive method protocol receiver subclass superclass system classes temporary variable

A component of the Smalltalk-80 system represented by some private memory and a set of operations. A variable shared by the instances of a subset of the classes. An operation performed directly by the Smalltalk-80 virtual machine. Is a term used interchangeably with "interface," as in message protocol or message interface. The object to which a message is sent. A class that inherits variables and methods from an existing class. The class from which variables and methods are inherited. The set of classes that come with the Smalltalk-80 system. A variable created for a specific activity and available only for the duration of that activity.

5.6
Summary of Terminology: Syntax
array assignment binary message block block argument cascading expression keyword keyword message literal message argument message selector
A data structure whose elements are associated with integer indices. An expression describing a change of a variable's value. A message with one argument whose selector is made up of one or two special characters. A description of a deferred sequence of actions. A parameter that must be supplied when certain blocks are evaluated. A description of several messages to one object in a single expression. A sequence of characters that describes an object; the object is called the value of the expression. An identifier with a trailing colon. A message with one or more arguments whose selector is made up of one or more keywords. An expression describing a constant, either a number, symbol constant, string, or array constant. An object that specifies additional information for an operation. The name of the type of operation a message requests of its receiver.

104 Fundamentals of the Smalltalk-80 Language

pseudo-variable name symbol unary message variable name

An expression similar to a variable name. However, unlike a variable name, the value of a pseudo-variable name cannot be changed by an assignment. A string whose sequence of characters are guaranteed to be different than those of any other symbol. A message without arguments. An expression describing the current value of a variable. When used in a method, indicates that the value of the next expression is to be the value of the method.

self

A pseudo-variable referring to the receiver of a message. Responses to messages to self are found by starting the method search in the class of the receiver, continuing up the superc1ass chain, and terminating at class Object. A pseudo-variable referring to the receiver of a message. Responses to messages to super are found by starting the method search in the superclass of the method in which super appears, continuing up the superclass chain, and terminating at class Object.

super

]I

-=:II

I~

....

How To Evaluate Expressions

I~

"

]I

-=:II

;z.

6.1 The do it Command


iIl:.

6.2 The print it Command

irr.r

"\~. ~~ ~
~~l1i

1:1

6.3 The System Workspace 6.4 Examples 6.5 Summary of Terminology

-., .
1\
"II!:lIL~:rt

1: )1:1
~~ ~:i

~.

!S.
]I

~
-=:II

106 How to Evaluate Expressions

Commands or items in menus correspond to messages for an object. Choosing a command corresponds to sending a message to the object. Messages are also sent, that is, commands can also be issued, by evaluating Smalltalk-80 expressions. Any Smalltalk-80 message can be sent simply by typing the appropriate expression in a view that can contain text, selecting the expression, and choosing the yellow button command do it or the yellow button command print it. You select text representing a Smalltalk-80 expression to be evaluated in the same way you select any text to be edited.

6.1
The do it Command
Whenever evaluation of expressions is possible, the item do it will appear in the yellow button menu; choosing do it provides immediate execution of any Smalltalk-80 expression or sequence of expressions that is selected. It is common practice to keep around a workspace in which to type expressions that can be selected and evaluated, or from which to select previously typed expressions. Whenever you want to reevaluate an expression evaluated earlier, simply select the appropriate text in the workspace and choose the yellow button command do it. You may of course edit some of the existing text before you select and evaluate it. In a sense, text left in workspaces form templates for commands. When you choose the do it command (Figure 6.1), the selected expression is compiled. If an expression is not syntactically correct, a message to that effect will be inserted in the text (Figure 6.2). The point of location will precede the erroneous place in the expression. The insertion will be selected so that you can cut it out or replace it as soon as the error is understood.

a.9 a.in
undo

copy

cut
pa.ste

Figure 6.1

010

107 6.1 The do it Command

Figure 6.2

000
As another example, the error might be that a term in the expression is not a variable that has been declared at a global level or as a temporary variable of a sequence of statements. If you evaluate an expression with a variable that is not recognized (Figure 6.3), a menu appears (Figure 6.4). It gives you the option to declare the variable, to call on a spelling corrector to help you determine the correct variable name, or to cancel the evaluation. One of the items must be chosen (Figure 6.5). Spelling correction is explained in Chapter 16. Evaluation is always carried out in the context of the view in which the do it command is issued. This is especially useful in a view of an interrupted process in which you are able to carry out debugging activities. In such a view, there is a menu from which you choose an interrupted message sent to an object, usually referred to as a messagesend; evaluation within the view is carried out in the context of the selected message-send. It is also useful in a view for inspecting the internal state of an object. In such a view, evaluation is carried out in the

a.~ja.in

undo copy cut


pa.ste

-It-in. it
.~.CC8pt

ca.ncel

Figure 6.3

010

108 How to Evaluate Expressions

Figure 6.4

000

cl e c I.3. re BicPen 3.5 temp cla55 '/,3.r qlob03.1 .. Ij n cl e c I 03. re)j correct It .3.bort

Figure 6.5

context of the variables of the object under inspection. An example of a view for inspecting an object is given in Chapter 8. While the expression is being evaluated, the scroll bar will disappear. It will reappear as soon as evaluation is completed. This is a useful signal to you that you have to wait for the system to complete the actions associated with any message. Keep the cursor inside the view in which the evaluation was requested so that the scroll bar can reappear. If the cursor is outside the view, the scroll bar will reappear but quickly go away again. In many cases, the cursor will change shape while an evaluation is being carried out; the shape may be that of an hourgiass (wait cursor) or of a slanted arrow with a star attached (execute cursor).

Practicing Suppose you wish to create a new variable name that is globally accessible so that you can assign different values to the vari-

109 6.1 The do it Command

able. First you have to store the new variable name in the dictionary Smalltalk. In the following example, the variable named is Frame.
Smalltalk at: # Frame put: nil

The above expression declares that Frame is a global variable name; its value is the object nil. Type the expression in a workspace, select it, and then choose the yellow button command do it (Figure 6.6). Now let's assign a new Rectangle to be its value. Type, select, and evaluate the expression (Figure 6.7)
Frame
<-

Rectangle from User

or
Frame
<-

Rectangle origin: 200@300 extent: 150@200

a.!~.:t.in

undo copy cut p.:t.ste

Figure 6.6

010
#Ft-.:t.me put: nil

Figure 6.7

110
How to Evaluate Expressions

Both expressions are used to create new instances of class Rectangle. The expressions are well-formed because you declared the name Frame in advance.
The system includes a dictionary named Undeclared. If you try to evaluate an expression that contains an undeclared variable name, then the name is stored in this dictionary. Before you can successfully declare it (that is, store it in the dictionary Smalltalk), you must remove it from Undeclared. You can remove it from Undeclared by evaluating
Undeclared removeKey: #VariableName

where VariableName is the name that was used without prior declaration. Alternatively, you can use one expression to remove the variable from Undeclared and store it in Smalltalk by evaluating
Smalltalk declare: #VariableName from: Undeclared

6.2
The print it Command
Evaluating an expression returns a result that is an object that can print a description of itself. The result obtained by choosing the do it command is not printed. The command print it is identical to do it with the exception that the object resulting from evaluation prints its description after the text selection. The description then becomes the text selection. In a workspace, type the expression
3+4

Type the escape key. This selects the expression. Now choose the yellow button command print it (Figure 6.8a).

::ima.llt,:..lk ,:..t: #Fr,:..me put: rJil

I
Figure 6.8a

Fra.me .;- Fiect,:'.rJ'jle o t-j tj i rJ: 21] I] (~:] I] I] e::<terJt: 151]@21]1]

a.1j a. i rJ urJdo copy cut

010

111 6.3 The System Workspace

The expression is compiled, evaluated, and then the result, 7, is inserted after the expression in the workspace (Figure 6.8b).

Figure 6.8b

000
A special workspace labeled the System Workspace is available in the system. Its purpose is to provide documentation or templates for some of the common expressions you might need to evaluate. Most of these expressions pertain to activities common to an operating system, activities such as opening or editing a file, reading a file, resetting the size of the display screen, or accessing the audit of changes you have made so far. There are also expressions for inquiring about methods, messages, and literals in the system. These expressions form templates for operations that you may wish to invoke. By editing the expressions in the System Workspace, you specify, for example, a particular file or a particular size for the screen. The System Workspace usually appears in the upper right screen area of an initial Smalltalk-80 system display. An image of a typical System Workspace is shown in Figure 6.9. An index of the use of expressions found in the System Workspace is provided in the back of the book. Notice that the System Workspace includes a template for declaring global variable names. You can find and edit it rather than typing the entire expression yourself (as suggested in Section 6.1).

6.3
The System Workspace

112 How to Evaluate Expressions

jmalltalk-80 of April 1, 1983


C:opyt-i,~rlt (c)

1ge:3:<.en:,:( C:orp, ,8,11 ril~r'ts reser"led,

Crea te File System


:::iourceFiles .;- ,8,t-ray ne"l'l: 2, :::;oun::eFiles at: '1 put: (File::::tream oldFiler\Jamed: ,Ia. stla. s tp ,3. t-en t, sout-ce s'), ::::out-ceFiles a.t: 2 put: (File::::tt-ea.m oldFilef",Ja.med: ,1 st la st p a. re nt, c rl a. n,~ e s'), a. (:::: 0 u n: eFile s ,3. t:l) re a. (j C) n Iy, ::::ourceFiles .;- Dish .;- nil.
~

Files (File :::i t tOe am 01 dFilef\Ja. med: ' c r,,3 r/l~e s, st') fil eln,
(File :::: t re ,3. m fil ef'"j a. me d: ' crl ,3. n I~ e s, st') fil eC'ut C rl ,3 n,~e s, (FileS trea m fi/ef".Jamed: ' file f",J ,3 me,s t ') edit,

Changes

Figure 6.9

000

(File :::; t re ,3.m fi Ie r'"j ,3 me(j: ' c rl,3. nl~e s, st') fi 1 C) ute rl ,3. nqe s, e ::::ma.lltalk noCrla.nqes,

6.4
Examples
In order to give you some practice evaluating expressions, some examples of system variables and messages you can send to them are given in this section. Exercise 1: In a workspace, type the expression
Transcript show: ' hello'

Select the expression and then choose the yellow button command do it (Figure 6.10a). The special System Transcript is referred to by the global variable name Transcript. This expression is a message to Transcript to insert the characters in the string , hello' (Figure 6.10b). The System Transcript usually appears at the upper left part of the initial Smalltalk-80 display screen. If one does not appear, you can create it by choosing the System Menu command system transcript.

113 6.4 Exam pes 1

System T t-,~ nsct-ipt

Figure 6.l0a

System Transcript
~Iello

Figure 6.lOb

114 How to Evaluate Expressions

Exercise 2: Type and select the expression


Rectangle fromUser

and choose the yellow button command do it. The expression is a message to Rectangle to create an instance of itself by having you designate a rectangular area of the screen. Evaluate the same expression with print it this time (Figure 6.lla). Specify a rectangular area (Figure 6.llb). A description of the Rectangle prints in the workspace (Figure 6.llc). Exercise 3: Display is a global variable name that refers to the display form that represents all the bits on the screen. It is an instance of class DisplayScreen. You can change the size of the full screen by send-

a.!~,:t.in

uncjo
R~(

ta ngle frornUse

copy cut
pa.:5t~

do It
a.cc~t
ca.nc~l

Figure 6.11a

010
R~ct,:t.ngl~ fromUs~

Figure 6.11b

100

115 6.4 Exalllples

Fi 12 c t.:t. rl!~ 112 fro mU 512 t 22:3@5:3 cornl2r: :396@'1:39

Figure 6.11c

ing a message to DisplayScreen, telling it the new coordinates. For example,


DisplayScreen displayExtent: 512
@

640

will modify the layout to be 512 dots wide by 640 dots high. An expression of this form is provided in the System Workspace. The width and height you try should not exceed the actual limits of the hardware you are using. You can change the image of the current display by sending messages to Display. For example, the expression
Display gray

will clear the screen to a gray tone.


Suppose you type this expression in a workspace and then evaluate it using the command do it. There may be a side effect if you keep the cursor in the active workspace-in particular, the workspace's scroll bar will probably display itself after the expression is successfully evaluated.

Exercise 4: You can access the cursor display coordinates by sending a message to Sensor (which is an instance of InputSensor), as shown in the following sample messages.
Sensor cursorPoint Sensor waitButton Sensor redButtonPressed
Will determine the screen coordinates of the cursor. Will wait until any button is pressed and then determine the current cursor point. Will determine whether only the red button is pressed.

116
How to Evaluate Expressions

Try these expressions using the yellow button command print it. Trying the third expression by evaluating it in a workspace is a bit tricky because you have to press the yellow button, release it to choose print it, and select the red button in the same time frame. It is simpler to evaluate the following two expressions
Sensor waitButton. Sensor redButtonPressed

The first expression will wait until you choose a button before evaluating the second expression. Thus you can use these expressions to experiment with testing pressing one of the three buttons. More information about controlling the objects Display and Sensor can be found by examining the definitions of their respective classes, DisplayScreen and InputSensor. See Chapter 9 to learn how to find these definitions. Exercise 5: You can create an infinite recursion by evaluating a message that simply calls on itself. For example, suppose Pen responded to the message go by evaluating
self go

If you sent a Pen the message go, you might notice right away that nothing is happening the way it should. Or you might not notice until your system starts running out of space and a notification, such as Hlow storage indicator," is displayed on the screen. In the first case, you can stop the recursion by typing ctrJ c, the system interrupt request. A view that is a notification that a process was interrupted appears. Chapter 18 describes how to handle notification views.

6.5
Summary of Terminology
compiling
Display
Checking for correct syntax and then translating into executable form. A global variable name that refers to the display form that represents all the bits on the display screen. It is an instance of class DisplayScreen. A message sent to an object. In a view of an interrupted process, the term message-send usually refers to a message from which a response has not yet been received. The only instance of class UndefinedObject; it is typically the value of variables that have not been assigned as yet.

message-send

nil

117
6.5 Summary of Terminology

Sensor

A global variable name that refers to an instance of class


InputSensor. User interactions with the system input!

output devices are tested by sending messages to an


InputSensor.

Smalltalk

A global variable name that refers to the dictionary of all variable names known globally in the system, in particular, the names of all classes. A special workspace containing expressions or templates for expressions that are useful for such operating system activities as opening and editing files, resetting display screen size, and accessing the references to any system changes. A global variable name that refers to a text collector, the System Transcript.

System Workspace

Transcript

How to Make Pictures

7.1 Making Pictures with the Form Editor 7.2 Making Pictures with the Bit Editor 7.3 Making Pictures with Expression Evaluation Pens 7.4 Summary of Terminology

120 How to Make Pictures

Now that you know how to evaluate expressions, you can try creating some graphical images. The Smalltalk-80 system provides support for creating graphical images by freehand drawing using the display screen as the canvas and the pointing device as the brush, and by writing methods in which graphical objects are sent messages to construct an image. Simple images are represented by instances of Form. A Form has height and width and an array of bits (a bitmap) that indicates the white and black regions of the particular image being represented. A complex image can be represented in either of two ways: by a very large Form or by a structure that includes many Forms and rules for combining and repeating them in order to produce the desired image. An image that is drawn as a sketch (in a freehand manner) is an example of the first; text is an example of the second. Two sections of this chapter focus on how to make Forms by Upainting" with a ~~brush" on the display screen using the pointing device to specify brush positions. These sections present the two interactive editors that are available in the Smalltalk-80 system: a Form Editor, which is a general set of tools for creating graphical forms; and a Bit Editor, which focuses on creating and modifying forms by selectively making each point (bit) of the form either black or white. A third section of this chapter discusses messages you can send to instances of Pen in order to create images on the screen. Chapters 18, 19, and 20 of the companion book, Smalltalk-80: The Language and its Implementation, provide further explanations and examples of methods for creating graphical images.

7.1
Making Pictures with the Form Editor
The basic idea of the Form Editor is to provide a canvas, an area of the screen in which drawings can be created, and a set of tools for placing paint on the canvas. All or part of the drawings can be saved on an external file and retrieved at later times. Figure 7.1 shows the canvas of the Form Editor on which some drawing has been done, and the menu of editing commands. The items in this menu are graphical images rather than text; as such, the menu is called an iconic menu. When the view for the Form Editor is not active, the iconic menu is hidden; when you select the view to make it active, the menu appears along the bottom edge of the view. Five tool functions comprise the basic graphical form vocabulary. These are: single-copy, repeat-copy, line, curve, and block. Each of these tools can be modified in its use by four variables that modify its effect on the screen: form source, color tone, grid spacing, and painting mode.

121

7.1 Making Pictures with the Form Editor

Figure 7.1

122
How to Make Pictures

The functions are represented in the iconic menu that appear when the Form Editor is invoked. To choose any tool or variable in the Form Editor, either move the cursor over the icon representing the desired action and click the red button, or type a corresponding key on the keyboard. You can press the red button and move the cursor over the icons; the current selection is highlighted by displaying a gray box within the icon. Releasing the red button chooses the current selection.
The use of a gray box rather than complementing the icon was the aesthetic choice of the graphics artist who was involved in designing the editor.

The Form Editor is in a standard system view so that the standard blue button menu is available. However, the size of the viewing area can not be changed. A full screen editor can be created as well. Create a Form Editor by evaluating an expression of the form
(Form new extent: 300 @ 400) edit

or
FormEditor openFullScreenForm

The message edit can be sent to any instance of Form. The system prompts you to choose the upper left corner of the viewing area. Note that the numbers you choose for the size of the Form should not exceed the width and height of your display screen. Moreover, in determining the height of the entire viewing area, you should allow for at least 112 pixels for the height of the menu. The second expression creates a new Form the size of the display screen and then creates the editor for it. The menu accessed by pressing the yellow button while you are in a Form Editor has two commands: accept and cancel. As in text editing, the picture being created does not modify the original Form unless the accept command is chosen. If at some stage of drawing you wish to experiment with different changes to a Form and you do not want to save versions on an external file, you can choose the accept command to store the current version, make some changes, and then choose the cancel command to restore the image to the earlier accepted version. An iconic menu appears at the bottom of the Form Editor view whenever the view is active. A labeled image of the menu is shown in Figure 7.2. The corresponding keys on the keyboard are shown in Figure 7.3. Notice that the keyboard arrangement lines up with the icon positions. A description of each icon follows. You can try each one. A suggested exercise follows the description of the editor.

123 7.1 Making Pictures with the Form Editor


form source

tools

modes

retrieve

,. NI . . _ 1:&aI~I"'I['::1
~

B[I]~
Figure 7.2
magnify color tones gridding save

Figure 7.3

Form Source

(Key a)
Used to select or specify a Form that is used as the "brush" for painting. You are asked to designate a rectangular area of the screen. The image within that area becomes the new brush. You are then asked to designate a rectangular area whose contents become the new brush shape. You can designate this area from anywhere on the display screen.

Magnify

(Key z)
Used for detailed editing of an area of the display screen. You are asked to designate the rectangular area within the canvas that is to be edited in its magnified form. Then you designate the upper left corner of the editing area in which each screen dot is magnified eight times its normal size. The upper left corner can be anywhere on the display screen such that the editing area fits on the screen. See the description of the Bit Editor later in this chapter.

Single-copy Tool

(Key s)
When this tool is selected, the form source is copied onto the display screen at the position of the cursor whenever the red button is pressed.

Repeat-copy Tool

(Key d)
When this tool is selected, the form source is copied onto the display screen at the positions of the cursor, as long as the red button is pressed.

124 How to Make Pictures

Line Tool

f) Used to specify lines between two points. The form source is used as the "pen" to connect the end points. Move the cursor to the position of one of the end points and press red button. Keep the button pressed and move the cursor to the other end point. The line image "drags" along. Release the button to specify the second end point. The line appears. (Note that when this tool is used with gridding assistance, graphs of horizontal and vertical lines can be easily created.)

(Key

Curve Tool

(Key g)
Used to specify a curve defined by three points (1, 2, 3). The curve begins and ends on points 1 and 2, and is tangent to the directed line segments formed by 1,3 and 2,3. As in the line tool, the form source is used as the "pen" to draw the curve. The three points for defining the curve are indicated by first moving the cursor to the desired position of point 1 and pressing the red button. Keep the button pressed and move the cursor to point 2. Release the button. Now move the cursor, essentially "dragging" out the curve to whatever shape is desired, and then click the button. The location of point 3 is implied by the positioning of the cursor. This technique implements a kind of "rubberband" approach to specifying the curve, similar to that used in specifying a line.

Block Tool

(Key h)
Used to fill rectangular areas on the display screen with color tone. Designate the rectangular area. It fills with the current tone using the current painting mode.

Color tones are set by choosing one of the five colors; each is shown in the menu as an icon that is a square of the tone.
White Tone

(Key x)

Light Gray Tone

(Key c)

Gray Tone

(Key v)

125
7.1 Making Pictures with the Forlll Editor

Dark Gray Tone

(Key b)

Black Tone

(Key n)

The form source is copied to the display screen according to one of the four modes that can be set. These are
Over Mode

(Key j)
Copy both the black and white portions of the form source onto the display. The result is to replace the currently displayed image with the form source.

Under Mode

(Key k)
Copy only the black portions of the form source onto the display.

Reverse Mode

(Key I)
Copy such that wherever the form source is black and the display is black, the display turns to white.

Erase Mode

(Key;)
Copy such that the black portions of the form source appear as white on the display.

The painting area has a grid associated with it in both the x and y directions. You can set the size of the gridding. When gridding is not used, the brush can place paint anywhere in the canvas. The horizontal and vertical gridding can be used separately or together. When gridding is used, the paint is aligned on the grid boundaries. That is, the x (when horizontal gridding is used) or y (when vertical gridding is used), or both x and y (if both horizontal and vertical gridding are used) positioning of the source upper left corner is forced to align with the grid boundaries. Three icons represent the gridding controls. They are
Horizontal Grid

(Key m) A toggle for turning the horizontal grid on and off. When the grid is on, the icon is highlighted. (Key,)
A toggle for turning the vertical grid on and off. When the grid is on, the icon is highlighted.

Vertical Grid

Set Gridding

(Key.)
Specify the horizontal and vertical grids. The integers represent the bits of the display screen. The initial value of

126 How to Make Pictures


both grids is 8 bits. A prompter appears, first for the horizontal and then for the vertical grid. Type the number, not to exceed the screen width or height, followed by a carriage return key. Type only the carriage return to keep the value shown in the prompter.

The image in the entire painting area is not saved on an external file. Rather, the current form source is saved. To save everything, select everything as the form source. When a Form is retrieved from an external file, it becomes the current form source.
Retrieve Form Source

(Key')
Change the form source to be the Form found on an external file. A prompter appears. Type the file name followed by a carriage return key. If no file name is given or if the name is not a well-formed file name, a confirmer appears stating that the file name is illegal, or the file was not found. You choose the menu item yes if you want to try another file name; choose no if you want to cancel the retrieve request. If the retrieval is unsuccessful, the form source does not change.

Save Form Source

(Key /)
Write a description of the current form source on an external file. A prompter appears. Type the file name followed by a carriage return key. If no file name is given, does nothing.

Note that it is possible to choose whether you want the paint brush/cursor to flash or not while you are ((painting." The initial system arrangement is that the cursor flashes. To change it, evaluate the following expression before opening the Form Editor.
FormEditor flashCursor: false

The argument is true if the cursor should flash, false otherwise.

D Default Setting When you first create the Form editing area, the settings for the tools and variables are
Form Sotirce-a small, 8 x 8 black square Tool- Repeat-copy Mode-Over Horizontal and Vertical Grids- both off Grid setting- 8 by 8

127 7.1 Making Pictures with the Form Editor

D Practice Painting Create a standard system view in which you can use the Form Editor by typing and evaluating the following expression (Figure 7.4)
FormEditor openFullScreenForm

a.~~a.in

undo

copy
cut pa.ste

Figure 7.4

010
This will create an editor for a Form that uses the entire display screen, with the exception of the space needed for the iconic menu. The initial painting brush is a small 8 x 8 square with black tone. The tone is placed on the screen using the over mode. The painting tool is repeatcopy. Try it by moving the cursor around the canvas area, holding down the red button. You can draw a sketch. When the button is not pressed, no tone is placed on the screen. If you want to start over, choose the yellow button command cancel. Try the different color tones. Move the cursor into the iconic menu area. Notice that the shape becomes a normal cursor rather than the painting brush shape. Place the cursor over one of the gray tones and click the red button. Now move back to the canvas and sketch some more. Do this for each tone. Notice that white tone is useful for erasing. The speed with which you move the cursor makes a difference as to the smoothness of the sketching line. Try the different modes. Choose black tone. Choose the yellow button command cancel so that the painting area is clean. Place a thick stroke of black across the canvas. You have been using over mode. Now choose dark gray tone. Paint over some of the black on the canvas. Choose under mode and again paint over some of the black area already on the canvas. Notice that the tone is placed under the black strokes, not over. Try reverse and erase modes as well. A possible image resulting from following these instructions is shown in Figure 7.5.

128 How to Make Pictures

Figure 7.5

You should try each tool as well, changing paint tones and modes to test the various effects. For now, choose black tone and over mode. Now select line tool. Draw lines. You have no assistance with respect to gridding. Choose the yellow button command cancel so that the painting area is clean again. Choose horizontal grid and vertical grid. The gridding is now 8 by 8. That is, the lines you draw can be lined up on every 8 pixels, horizontally and vertically. It is, of course, possible to use only one of the grids at a time. Draw some vertical or horizontal lines to see how you can make use of the gridding (Figure 7.6). Choose set gridding and set each grid to 32 (Figure 7.7). Choose repeat-copy tool. Now try to paint (Figure 7.8). Choose horizontal grid and vertical grid again. These items are toggles so that the gridding will no longer be used when you are painting. Try the curve and block tools with different tones and modes (Figure 7.9).

129 7.1 Making Pictures with the Form Editor

Figure 7.6

Current t"lorizont,3.1 gri,jding I::': :3, Type ne\l'i t"lorizont,3.\ I~riddinl~,

Figure 7.7

130 How to Make Pictures

.: :.' .:::'.:' .: ':.:'. :'.:1'. .'.' :.


:-. .-.~'

,.I:~ '. :.'~ ;I.: :.1'I~ i:;., ~ :'.~ ;I'. :,i


:.:l':':'::.i':':'.::'.,.':::::. :'. ..i

I I ,
.:::':.:':'::::I. . ' ..
::':'.::;:':::::::::'.'.':: :.'1.,.'.'.:.:.:.,.':':'.;.'":.:"':':::'::.::. :.':.'.:':::'..:.':::':.';::.::':'.:.:. .. .. ::.1 .. .'. :::' . .. .. . .

..:.':''.:'.':':':.':'.

:1:':'.:::'.' ...

'. ~:,.". ' ~~ " ~. . ';' ~.~ .

.: ....~~...

' ..:-. ::.~~'

~~~j~~~j~~:~:~:!:~:~:j~~j~:jtj~~j~~j~j~~jj~j~jjjt%;j~jjj;m{jrjj~jjtjj;jjjj~jj;jjjj:j~jjjjjjjjrjjj;jjjjj:j:

Figure 7.8

L..-

---..

Figure 7.9

L...--

-.I

Figure 7.10

131 7.1 Making Pictures with the Form Editor

So far you have only used one brush shape (the default small square). Choose form source and designate an area from which to select a new brush shape. Try painting with it. Be careful to select something, i.e., do not select an all white area, else there will be no brush shape and you will see nothing for a brush on the canvas. If you do, simply type the key labeled a in order to select a brush again. Try making a brush that is a horizontal or vertical line and paint using the repeat-copy, line, or curve tools. Set the grids and try these brushes. You can make grid paper this way. Be sure that the mode is over when you try these experiments. Now choose the yellow button command cancel and start a fresh canvas. Choose a small square or circle for a brush. Choose black tone and over mode. Draw a simple little sketch, of a flower with a bee on it, perhaps. You probably had some trouble getting it just right--the pointing device is not, after all, a fine pen for sketching. It would be better if the bits on the screen were much larger. Choose magnify, designating the area around the bee (not too much) and then designating the origin so that a magnified view of all or part of the bee can be displayed. The view area for the magnified version of the bee should not overlap the original image on the screen. An example is shown in Figure 7.10.
Note that you can not have a Form that contains more than 1024K bits. Since magnification is 8-fold, you should not select an area to be magnified that is larger than about 128 bits x 128 bits.

g.

132 How to Make Pictures

You are now using the Bit Editor (see the next section for details), While doing so, notice that the original bee changes while you are editing the enlarged bee. Click the red button outside the editor's area in order to exit the Bit Editor. Now make the bee your brush (choose form source) and turn the griddings on (choose horizontal gridding and vertical gridding). Choose repeat-copy and black tone and under mode and paint a swarm of bees, as shown ih Figure 7.11.

Figure 7.11 You can save your work using save form source. Remember that the image you want to save must be the current form source (brush). Close the Form Editor by choosing the blue button command close. In using the Form Editor, there are some simple tricks to remember:
1. The under mode is preferred to over, especially when you want to

place an image onto the canvas without erasing any portion of the neighboring image.
2. Modes reverse and erase are useful for obtaining interesting affects with mixing images. Using reverse, block tool, and black

tone, you can reverse the video of all or parts of an image. 3. It is often easier to make straight lines by making the border of a view the paint brush and copying it to the canvas using under mode and the single-copy tool.

________________________ 1_3_3 7.2 Making Pictures with the Bit Editor

7.2
Making Pictures with the Bit Editor
Typically, the Bit Editor is invoked from the Form Editor as described in the previous section, or by evaluating an expression such as
Form fromUser bitEdit

In each case, you designate the rectangular area on the screen from which the Form is defined. Then you designate the top left corner of the area in which the magnified view of the Form is to be displayed. This area is a view containing both the magnified view and a view of the actual image. Editing takes place in the magnified view (Figure 7.12). The view of the Form for editing obtained using the message bitEdit is contained in a standard system view, so that the blue button menu can be invoked for closing the view.

Figure 7.12
Note that there are only two things you can do in the Bit Editor, choose black tone so that you can turn dots to black, or choose white tone so that you can turn dots to white. Availability of some of the Form Editor tools would be useful in the Bit Editor. Adding these tools to the Bit Editor is an exercise you might try. Also, showing grid for the bits is useful visual information.

Entering the magnified area, the cursor shape changes to the crossHair cursor. The red button is used for setting dots in the magni-

134 How to Make Pictures

fied view to either black or white. A menu of colors appears below the magnified form. Choose one with the red button or by typing a key on the keyboard. The keyboard correspondences, which are aligned with the keys in the Form Editor, are

color
black white

key
n
x

The yellow button is used for the commands accept and cancel in a way analogous to the use of these commands in the Form Editor. The blue button brings up the standard blue button menu. You can also create the Bit Editor by specifying an existing Form and sending it the message bitEdit. For example, Figure 7.13 shows the magnified image of the read-a-file cursor (eyeglasses). The cursor is obtained by sending the message read to class Cursor. Thus, the Bit Editor on it is obtained by evaluating the expression
Cursor read bitEdit

.... > . . .

i.>i.> .

..!ii~
r
~'~'1

11111!11111!1111!1111!11!11!11111!lllllillllllllllllIIIIIIIIIIIIIIII!IIIIIIIIIIIIIIIIII"'IIP=W-'

_1_1 - -+ _I'

iii

Figure 7.13

135
7.2 Making Pictures with the Bit Editor

As another example, the result of evaluating


(Form new extent: 64
@

64) bitEdit

is an editor on a newly created Form whose bits are all initially white. It is possible to create a Bit Editor that does not appear in a standard system view. Rather, the editor grabs complete control until you click any button outside the bit-editing area. This is the Bit Editor as it is accessed from the Form Editor.

Opaque Forms The Smalltalk-80 system also includes a class named OpaqueForm that stores one of three colors, black, white, or transparent C(gray"). These Forms are especially useful in creating animations since any image that is underneath the transparent part of an opaque form will be visible. The message bitEdit is understood by an OpaqueForm to create a Bit Editor whose menu of colors includes a gray tone representing ((transparent paint" (Figure 7.14). The keyboard correspondences are color
black gray white

key
n

v x

Figure 7.14

136 How to Make Pictures

7.3
Making Pictures with Expression Evaluation
Pictures can be made by direct drawing using the Form Editor or the Bit Editor. Alternatively, pictures can be made by sending messages to graphical objects. Generally, pictures made this second way are constructed in a highly structured manner by creating instances of class View or one of its subclasses. The Smalltalk-80 system has many examples of such views: BrowserView, InspectorView, and NotifierView are the primary components of the user interface. These views, in turn, contain subviews that are CodeViews, ListViews, SwitchViews, FormViews, DisplayTextViews, or StringHolderViews. Examples of StringHolderViews are ProjectViews, TextCollectorViews, and FillinTheBlankViews. A StringHolderView is a way of creating an image of any object that can present itself using information stored as a string. Primitive graphical objects are instances of Pen, Rectangle, and Quadrangle. We have already referred to -Rectangle; you create a rectangle whenever you designate a rectangular area of the screen in which a view is displayed. The scroll bars are examples of the use of Quadrangle in the system. The next section explains how to use a Pen. In addition, the system includes the class DisplayObject; instances of subclasses of DisplayObject can be used in creating structured pictures. Example subclasses are Arc, Curve, Line, LinearFit, and Spline. A Pen is used for line drawing. It consists of a position on the screen, a direction in which to move, a Form that it uses for creating images, and a mask and a rule for combining the Form with its destination area on the display screen. A Pen is created by sending a message of the form
BicPen
~

Pens

Pen new

Here we refer to the new instance of the Pen as BicPen. Recall that if you wish to try this example, BicPen must be declared as a global variable. Rather than use the above assignment, you can evaluate
Smalltalk at:

# BicPen put: Pen new

We can constrain BicPen to draw only within a fixed boundary, which we call its clipping rectangle, by sending it the message frame; aRectangle. For example,
BicPen frame: (200@ 200 extent: 300@ 300)

According to the above expression, BicPen will only draw in a square area 300 pixels by 300 pixels, starting at location 200, 200. Without

137
7.3 Making Pictures with Expression Evaluation

such a constraint, BicPen could have drawn anywhere on the screen. The center of a Pen's drawing area is known as its home. We can place BicPen at its center by sending it the message home.
BicPen home

Initially, the tip or nib of BicPen is a 1 by 1 black dot with which we can draw thin lines. We can change the size of this nib by sending the message defaultNib:. The argument is an Integer, and the resulting nib is a square with length of side Integer.
BicPen defaultNib: 8

The nib of BicPen is now an 8 by 8 black square. Alternatively, we can send BicPen the message sourceForm:. The argument is a Form.
BicPen sourceForm: Cursor normal

The nib of BicPen is now the shape of the normal cursor, i.e., a slanted arrow. A Pen can receive messages asking it to change the state of its mask.
black white
Set the mask to black. Set the mask to white.

And a Pen can receive a variety of messages asking it to change its position, the state of its ability to draw, and its direction. These consist of
home down up turn: anlnteger north go: anlnteger place: aPoint goto: aPoint
Go to the center of the Pen's frame. The ink form with which drawing is done should be positioned for drawing when the pen moves. The ink form with which drawing is done should be positioned so that no drawing is done when the Pen moves. Change the direction in which the Pen will move by the amount, anlnteger, measured in degrees. Orient the Pen towards the top of the display screen. Move a distance equal to anlnteger pixels; draw using the source form if the ink form is positioned down. Place the Pen at location aPoint regardless of orientation; do not change the current direction, and do not draw. Move the Pen to location aPoint, ignoring the current direction, but drawing if the ink form is positioned down.

138 How to Make Pictures

As described in subsequent chapters, you can see various ways to make designs with Pens by browsing to the examples in the instance or class methods. Two examples for you to try are given here.
Pen new mandala: 30 diameter: 300

and

Pen new spiral: 200 angle: 89

The result of the first is shown in Figure 7.15, and of the second in Figure 7.16. After trying each example, you will want to choose the System Menu command restore display. Pen is the Smalltalk-80 version of the "turtles" designed many years ago at MIT's Logo laboratory and described in Seymour Papert's book MindStorms: Children, Computers, and Powerful Ideas (Basic Books, New York, 1980). Another excellent reference on the use of turtles is by Hal Abelson and Andrea diSessa, Turtle Geometry: The Computer as a Medium for Exploring Mathematics (Cambridge, MIT Press, 1981).

Figure 7.15

139 7.4 Summary of Terminology

Figure 7.16

7.4
Summary of Terminology
DisplayObject
A system class whose subclasses represent the graphical objects in the system, such as lines, circles, arcs, and splines. A system class that represents simple images. Instances of Form have height and width and an array of bits that indicate black and white regions of an image. A menu whose items are presented as graphical images rather than as text. A Form that represents an array of bits each of which can indicate a black, a white, or a transparent region of the image. A system class that represents a form source, a current display screen position, and a current direction in which to move. Instances of Pen are used to draw lines on the display screen.

Form

iconic menu opaque form

Pen

PART TWO

All information that you can seek about the Smalltalk-80 system involves information about existing objects or about objects that can be created. You can find out information about the internal state of an object using a system view called an Inspector. You can find out about the message interface to an object using a system view called a Browser. A System Browser gives you access to all the class descriptions available in the system, including comments about the classes, comments about the methods, and examples of how to use many of the classes. Other ways to find out about messages and methods involve creating system views called Message-Set Browsers. These views are created in response to queries to determine which methods send a particular message, which classes implement a particular message, or which methods reference a particular variable or literal. This part includes an introduction on how to find out about a running process, in particular, how to interrupt an activity to find out which objects are interacting to create that activity. The system views used in this exploration are Notifiers and Debuggers. More details about notifiers and debuggers are provided in Part Three. Several forms of on-line documentation and assistance will be identified: comments, explanations, templates, examples, and menus. In addition, the spelling correction capabilities of the Smalltalk-80 system are explained in Part Three. Comments. Each class description includes a command about the purpose of the class. A class comment is obtained (for reading or for editing) by choosing the yellow button command comment in the classnames subview of the browser. Other comments document the purpose of a method. These are found by choosing a message selector; the comment is the text within double quotes at the beginning of the method definition. Programmers can also document the design of a method by interspersing quoted text within the method itself.

;;:;:;:;;;;;;;:;;;:;:;:;;;::;;:::::;:: One form of explanatIon could be explanation about the tokens that ap- @::::::::::::::::::$.::::~:::~: j j j j 1j j j j 1j j j 11jj 1j j1j j pear in the ~ethod. You ca~ s~lect any token and then choose a com- ~1 1 1i1i1i1i~li1i1i i1~i1~1i~i i ::::::::::::::::::::::::::::::::::::: mand to obtaIn a short descrIptIOn of the role of the token. ;:::::::;;;::;::::::::::::::::::~:::: 1111111111111111111111111111111111111 Because .of the class .and message ~tructure of the syste~, it is p~ssi- ~~jjjjjjj~j~j~j~j~~j~jjjj~j~j~j :~:~:~:~:~:~:~:~:~:~:~:::::~:~:~:~::: ble to provIde explanatIons about whIch messages are sent In a partIcu- :1:::1:1:1:~:~1:~1:1:111~~~1:11:

III ::t=~h~:~da~~a~ic~~~:'=:":~~h~ha~::: :;r~~e:a~a':t~~:~


::::::::::::::::::::::::::::::::::::: Iar message, and whIch messages are sent In a partIcular method. ::::::::::::::::::::::::::::::::::::: . . . ::::::::::::::::::::::::::::::::::::: These are the kInds of querIes that a programmer must be able to make ::::::::::::::::::::::::::::::::::::: . :!:!:!:!:!:!:i:i:!:!:!:;;::;;:;!:;;;; to determIne the structure of the Smalltalk-80 system. The system :.:.:.:.:.:.:.:.:.:.:.:::::::::.::::: b h d'" f 'd th f k f :::::::::::::::::::::::;::::::::::::: rowser as t e program e ItIng Inter ace proVI es e ramewor or :::::::::::::::::::::::::::::::::::::. . . :!:!:!:1:!:!:!:!:!:!:!:!:!:1:!:1:::=: both the Incremental development of class descrIptIons, as wen as the :.:.:.:.:.:.:.:.:.:.:.:.:.:.:.:.::::: f .. f . b 1 E h I dd d t ::::::::::::::::::::::::::::::::::::: context or accessIng In ormatIon a out c asses. ac new c ass a e 0
:~:i:i:i:~:i:~:1:iti:::i:i:i:i:::::

:::::::::::::::::::::::::::::::::::::
::::::::::*::::::::::::::::::::::~

::::::::::::::::::::::::::::::::::~:

::::::::::::::::::::::::::::::::~:::

~1:~;:~1:~~~~1:::1:1:~;:;:~:
~:::::::::::::::::~~~~::::::::::
~:::::::::::::::::::~~~~::~~:

.:.:.:.:.:.:.:.:.:...::........:.:.:

i:i:i*i:::i:i:~~::i:if::i:i:i:i:i

.:.:.:.:.:::.:.:.:.:::.:.:.:.:.:.:.:.
::::::::::::~::::::~~~:::~*:::

In whIch InformatIOn should be provIded, a template or a default solu- ::::::=:::r.~:::::::::::::::::::::::: tion is ~rovided. The us~r edits the. template, replacing descriptive ~j~j~j~j~~j~j~j~j~~~~~~~~~j~ ::::::::;;::;::::::;:::;:;:;:::;::::: words wIth the actual desIred text. ThIs means that the user does not ::::::::::~:::::::~::::::~ \~\~\~~l\~\~\~\~~II~1~1~1~1 have to remember syntax and can be prompted on the kind of informa- 1i1i1i1i~1i1i~~111~i1111111~~11 !i!!!!i!fiii!!!i!i!i!iii!i!i!=!:!: tion that is required. Templates are used to assist in defining classes i:1:1:11;1;:1:1:~~~1:1:1:1:1~1;~;
i)i)i)i)j)i)j)i)j)j)j)jjj)j)j)j)iiiij

~~~~~1~;~~~~~ie:f::~r:i::;1:~;eK::~;~~:~:h:a:r:

~?l~;~E:::~::::lt:::::::i:::'::::SC~::~:~:::::~ I II,E~L~~~I~~i~~E~[!~~;i~~~:':~~~~:,,::,.,::::::::::::::::::::::::::::::::::::: sume that the system sources are aVaIlable to you and accessIble from
::::::::~::::::::::~~~::~~~:

::::::::::;:;:;:::;:::;:;:;:::;:::::: remember the correct key words and havIng to type the words correct:E:E:E:E:::E:E:E:::E:::E:::E;:;:;:;:_ '::;::;::::::::::::::;:::;:::::::::::' ly. Items In a menu represent the behavIor of an object; most lIkely, ::::::;::::::::::::::::::::::::::::::. . . . . . ::;::::::::::;:::::::::;:::;:::;::::: there IS a message In the class deSCrIption of the object that carrIes out

::::;:;:;:;:::;:;:::::::::::::::::;:;

~=ed::O:~t:V7~r::~:~ni:~ % ::~uO:t::'i:~~::~~a~=n:O~

Menus. Menus are a form of assIstance In the system. The Items In a

t;:e

::::::::*:::::::::~::::::::::::::

:::::::::::::::::::::::::::::~:::~

~*:::::::::~:::::::::::::~~~: ::::::::::::::::::::=*::?:==*:: .~~::::~:::::::::;-;.::*::~:::~

:::::::::::::::::::*:~~r:::*::

Finding Out About Instances

8.1 The Structure of an Inspector 8.2 Changing the Values of Variables 8.3 Sending Messages to an Object 8.4 Special Kinds of Inspectors Dictionary Inspector Model- View-Controller Inspector 8.5 Finding Out About a Running Process

144
Finding Out About Instances

In developing definitions or learning about the system, you can examine the named or indexable instance variables of an object. The message inspect can be sent to any object. The result is an inspector view of the object.

8.1
The Structure of an Inspector
An inspector is a view made up of two parts: one is a list menu of the names of the instance variables; the other is a text view in which the value of the selected variable is shown. As an example of using an inspector, try evaluating the expression
(Rectangle origin: 10
@

10 corner: 60

60) inspect

The result of evaluating the parenthesized expression is an instance of class Rectangle with origin at screen location 10, 10 and corner at 60, 60. Recall that 0, is at the upper left corner of the display, and that x increases to the right and y increases to the bottom of the screen. A message expression of the form aNumber1 @ aNumber2 denotes an instance of class Point; the Point represents a location on the display screen whose Cartesian coordinates are aNumber1, aNumber2. This new Rectangle is then sent the message inspect. The result is that you are asked to designate a rectangular area in which the inspector will appear. An example inspector on this Rectangle is shown in Figure 8.1.

self
ori!~in

corner

Figure 8.1

145 8.1 The Structure of an Inspector

The left subview of the inspector is the list menu. The menu contains the pseudo-variable name self, which refers to the inspected object. It also contains the instance variable names origin and corner. You choose items in the list menu by placing the cursor over the item and clicking the red button. Choose one of the variable names; a description of the value of the variable prints in the right subview (as shown in Figure 8.2a). Choose self from the list menu. A description of the Rectangle prints in the right subview (Figure 8.2b). Note the special print format for Rectangles that is displayed in the right text subview.

self

origin

Figure 8.2a

~
origin,\ corner

'1 O(~ '10 60@60

corner:

Figure 8.2b

146 Finding Out About Instances

Choose the instance variable name corner. Press the yellow button. The pop-up menu that appears contains the single command inspect (Figure 8.3a). Choose inspect. You are asked to designate another rectangular area in which to display an inspector for the object referred to by corner. This object is an instance of class Point. Notice that the label of the inspector contains the name of the class of the inspected object (Figure 8.3b). Close this second inspector by choosing the blue button command close.

@liM-

:3t=llf oriqirt

Figure 8.3a

010
60(~60

!i@rnwj:i:

oriqirt

::<

-------

Figure 8.3b

100 000

147
8.2 Changing the Values of Variables

8.2
Changing the Values of Variables
You can change the value of an inspected object's variables by typing an expression for the new value in the right subview and then choosing the yellow button command accept. Choose origin from the list menu of the inspector for the Rectangle you created earlier. Change the value 10 @ 10 to be 20 @ 15 simply by editing the text and choosing the yellow button command accept in the right subview of the inspector (Figure 8.4a). Now choose self in the list menu to see that the current description of the Rectangle has changed (Figure 8.4b).
The private memory of an object is supposed to be protected from such direct manipulation. However, for testing or for debugging purposes, the ability to directly set the values of instance variables is very useful.

c.:t. rft;:e I

Figure 8.4a

010

Figure 8.4b

:::::::::::::

148 Finding Out About Instances

Try another example. Create an array of arrays by typing and selecting the following expression in a workspace, and choosing the yellow button command do it.
#(($a $b $C) $d ($e $f)) inspect

The first inspector presents an instance of class Array (Figure 8.5a). The object has three indexed variables. If you choose the first item in the list menu, self, a description of the instance is printed (Figure 8.5b). Choose item 1 in the menu of the inspector (Figure 8.5c). A description of the first element of the Array prints. Choose the yellow button command inspect (Figure 8.5d). Another inspector is created; it presents another instance of class Array, this time one with the three characters as its elements. Try inspecting the different variables. Item 2 in this second inspector is a Character (Figure 8.5e).

self

,-, .::.
'-'
'-:.

'1

Figure 8.5a

(($03. $b $e ) $d ($e $f ) )
,-, .::.
,_I

.-:.

100
Figure 8.5b

.. .. OOO ~.;.;::~ .~...~::::~::::'::"~"".~~~ ::::;:::: ..


di~i~:[;n::n}:: !~it?[\[i ~:~ ::::j:~~.:: .:. :::"[.: .:

149
8.2 Changing the Values of Variables

($a. $b $e
self

Figure 8.5c

j,,:$a. $b $e )

,-,
0:::.
I~I

self

'-'

Figure B.5d

($,:.. $b

'-'

-'":'

.... "
self
'1
:] -------

$b

Figure B.5e

150
Finding Out About Instances

Choose the first element of the array in the second inspector (item 1 in the list menu) (Figure 8.5). Now edit the text view so that it contains the text #(1 2) instead of the Character $a. Choose the yellow button command accept (Figure 8.5g). The value of the first element of the current array is now the two-element array of numbers 1 and 2. Choose self in the list menu to see the change (Figure 8.5h). Close both inspectors.

($a. $b

'-:.'

'-'

Figure 8.5

($a.

#(.,
2

2~

'-'

'''':'

aga.in undo copy cut "a.ste do It print it

Figure 8.5g

151 8.2 Changing the Values of Variables

($03. $b

'-'

.-;.

~ ,-,
.:::. 1-:.

(('1 2 ) $b $c

'-'

Figure 8.5h

To see how the information about an object can be multiply-viewed by the system views, create two inspectors on the same object. For example, try to inspect another instance of Rectangle by evaluating the expression
Rectangle from User inspect

You will first designate the area for the Rectangle and then the area for the inspector. Choose the item self in the list menu (Figure 8.6a). (Your rectangle will probably have different coordinates.)

2:3@22
ori~~ln

corner:

corner

Figure 8.6a

152 Finding Out About Instances

Choose the yellow button command inspect (Figure 8.6b) to create a second inspector (Figure 8.6c). Choose origin in both inspectors (Figure 8.6d).

.,
ori9in corner

2:3@22 corner:

Figure 8.6b

010
2:3(~22

corner:

'165@-1:35

1".'

2:3@22 corner:

Figure 8.6c

100 000

153 8.2 Changing the Values of Variables

23@22
self

corner

!~

Figure 8.6d

100 000
You cannot use a more direct approach to creating the two inspectors, such as evaluating

I reet I reet ..- Rectangle fromUser.


reet inspect. reet inspect

because as soon as the first message, inspect, is sent to the rectangle instance, reet, the workspace loses control to the newly created and scheduled inspector. The last expression is never evaluated.

Change the value of one of the variables in one inspector (Figure 8.6e).

1I I I I I I I I m m:m: :m:m: : : :m: i! !I!i!i l! !I!1!1! ! ! im:~! ~m:i!i!i!m:~ :1~ ~ : :~:~ l~:~! ! ! !i!ili! !I!I! ! ! ! ! !I!I! ! ! !1
cut

co

aste do It

print it ca

Figure 8.6e

010

154 Finding Out About Instances

See that the other inspector knows about the change (Figure 8.6). If the variable is already selected in the second inspector when its value was changed in the first, you will have to reselect it to see the changed value. Similarly, if self was selected, you must choose it again to see the change. Close both inspectors.
The yellow button menu of the inspector's left subview contains only one item, inspect. Only the instance variables of the object are shown. As an alternative design, a command to inspect the class variables could be added. In some variations of the Smalltalk-80 system used within Xerox, this command is called classVars; it creates an inspector on a Dictionary whose keys are the class variable names and whose values are the values of the named variables.

4CI@:30

'!=
self

40@:30

Figure 8.6

100 000
Another use of the right subview of an inspector is to test sending messages to the inspected object, or to test evaluating message expressions. For example, Rectangles understand messages for determining width, height, and area. In the right subview of the inspector for the first Rectangle that was created in an earlier example, type and select the following expression
self area

8.3
Sending Messages to an Object

Note that in this example we assume the origin is at 20, 15 and the corner at 60, 60. Choose the yellow button command print it (Figure 8.7a). The result is printed (Figure 8.7b).

155 8.3 Sending Messages to an Object

again
undo
5121

ori

co

ori co

010
Figure 8.7a
512 1f '",'",' i (Jt 1'"1

000
Figure 8.7b

* 5 121 f
5121

(60 - 20)

I'"leil~l'",t_

(60 -

ori

15)_

co

co

000
Figure 8.7c self width * self height

000
Figure 8.7d

Is the result correct? Type and evaluate either or


(60 - 20) * (60 - 15)

as shown in Figures 8.7c and 8.7d. Both expressions compute the area and show that the result from evaluating the expression self area was correct. All evaluation in the inspector is done within the context of the inspected object's variables. Thus the expression
corner - origin

can be selected and successfully evaluated in the Rectangle's inspector because the variable names are known to the inspected object.

156
Finding Out About Instances

8.4
Special Kinds of Inspectors
The message inspect is implemented in class Object. Typically, the result of the method is to create the inspectors described in the preceding sections. In addition, the system includes two special inspectors, one for instances of class Dictionary and the other for instances of class View. Objects such as Dictionaries are represented with indexable instance variables. As demonstrated for an Array, the list menu of an inspector for such objects contains indices referring to the indexed variables. In the case of a Dictionary, the value of one of these variables is an association between a Dictionary key and a value. Figure 8.8a shows an example Dictionary. The special inspector for a Dictionary shows the Dictionary keys in the list menu, rather than the indices; choosing a key causes the associated value to display. Figure 8.8b shows this inspector for the example Dictionary. Editing the value and choosing the yellow button command accept stores a new value for the selected Dictionary key (Figure 8.8c). Since the system supports the special form of inspector for a Dictionary, you have to do something special to obtain the default kind of inspector. To create the examples, first create the Dictionary Test by evaluating the following expressions.
Smalltalk at: #Test put: Dictionary new. Test at: #first put: 1. Test at: #second put: 2. Test at: #third put: 3. Test at: #fourth put: 4. Test at: #fifth put: 5.

Dictionary Inspector

Now create an inspector for Test.


Test inspect

The inspector will be like the one shown in Figure 8.8b. In the text part of this inspector, evaluate the expression
super inspect

The new inspector that you create will be like the one shown in Figure 8.8a.

157 8.4 Special Kinds of Inspectors

Besides the command inspect, the yellow button menu of the left subview of a Dictionary inspector provides commands for adding and deleting elements from the Dictionary, add field and remove. Only add field shows when no item is selected. Certain Dictionaries in the Smalltalk-80 system are used for storing references to pooled variables; the keys of such Dictionaries are variable names that can be referenced in the methods of one or more classes in the system. The yellow button menu also provides a command, references, to search for and to create a message-set browser for all methods that contain references to the selected Dictionary key. Figure 8.8d shows the yellow button menu for the Dictionary inspector. Message-set browsers are described in Chapter 10.

I 100
000
Figure 8.8a

2
:~:

fourtrl- 4

4 5 6 7

10
11 12 1:~:

100 000
Figure 8.8b
# t.. .. 0 A r-.:<-,~-a"""i n..... uncJo

I
I
iliill

I ~~~J~I

fiftrl

1
fiftrl fir5 t fourtrl

coPy
cut p.:< 5te cJo It print it

EGestDil
trdrcJ

in5pect tOe fe tOe n c e5 .:<.cJcJ flel,]

010
Figure 8.8e

010
Figure 8.8d

158
Finding Out About Instances

Model- ViewController Inspector

Many objects in the Smalltalk-80 system are closely related to one another. In particular, the user interface of the system is implemented using subclasses of two classes, class View and class Controller. A View represents ways of presenting information on the screen; a Controller represents ways in which the user interacts with a screen view. Any View is related to a Controller and to another object, the object whose information is accessed in the View. This other object is referred to as a ((model." Whenever you inspect a View, you typically want to inspect its related model or Controller. There is a special inspector in the system for inspecting the two main objects related to a View, as well as the View, whenever a View is sent the message inspect. An illustration of this inspector is shown in Figure 8.9. It is an inspector containing three subviews, each of which is itself an inspector-one for the model, one for the View, and one for the Controller. In the figure, the model is a system browser.
In order to try to create a special inspector for a View, evaluate the expression ChangeListView new inspect. Very few of this View's variables will be initialized as yet, but you can at least explore the structure of the special inspector.

I/HHH?UI on~o3.niz.:..tion IH HUHUI 1><>1

self

~_: 0 II I c t ion sUn 0 n:J I re I:J

&im!M
m~to3

clo3ssr".Jo3.me protocol selector t e. t f''o''10 l:Je


\i i I 'i,..: .:.

I I

E: tOO 'i'i S I r\i i I "i'i J,;.=:<t"I:J,:.r':'I:JColl,:.c t ion (.:. :-;el,:.ctionlnLi s t \i Ie ''0'\' .:. ::;electior,lnList\iie"i'''' .:.. E;oole,:'.n\iie"i'i .:. E: 0 0 I I a. r, \i i I "i'''' a ::; I I I C t ion In Li s t
\i i I "i'i ':..

mOI:Jel I,:,:'<,:,:)d contn:llier

I'.".

! .

'i '!.!I.il~s~u~p~e~r"'~/i~':'!' o' '~i!~I


tr.:'.ns form.:'.tion redE;u t t onf"ilesso3ges Y I II 0 "i'i E; u t ton r.'" en u yello "."'i E:u t to nf"lle s s a.

:::elec t io rllnLi s t\iie"i'i a. COI:Je \i ie"i'.,

Controllet": .:. ::;to3.ndo3n:J:-:yst,:.m( :ontroll,:.r a F'opUpr',"'1enu

Figure 8.9

000

159 8.5 Finding Out About a Running Process

8.5
Finding Out About a Running Process
A notifier provides a simple description of an activity or process at the time that the activity was interrupted. Interruption can occur because of a runtime execution error, or because you purposefully cause such an interruption. This purposeful interruption is accomplished by typing ctrl c on the keyboard (that is, type ttcontrol" and the cC c" keys at the same time). The notifier displays the reason for the interruption in the label of the view, and displays the sequence of messages that were invoked but not yet completed. Try to create a notifier by typing ctrl c. The currently running process is interrupted. The notifier appears centered on the display screen. A possible interruption is shown in Figure B.lDa. Choose the yellow button command proceed in order to continue the process; when you choose proceed, the notifier is automatically closed.

::i t a. nda. rl) ::i y st e me:: on troll er( Co n t ro Iler):>:> isCon t ro I',/,/.:t. n ted

_.

[J inC on t rolr.. ' ,~.n a.!j er:>:> sea. rc hFo r,~.c t i.,'e c:: on t ro II er [J in ()rdere,)(:::ollectiOn(COllectiOn:>~",jone:
-.J .J. .. ()t"!:..terel:..tC:o II ec tlon.> .>1)0:

debl

() t"!) ere d Coil ec t ion (C 0 II ec t ion):>:> d etee t: ifr'.j 0 n e:

Figure 8.10a

010
Typing ctrl c can be used to interrupt a successfully running process that you wish to explore, perhaps to change the part of the system that supports the running process. Suppose you wish to know where text selection highlighting takes place in the system so that you can change the style of highlighting. While you are making a text selection, type ctrl c (Figure B.lDb).

160
Finding Out About Instances

U.5 12 r In t 12 rru p t

p.:.. r a.!j ra. ph:>:> d YFo rPo in t: Para 9ra.ph:> :>mou :::e::;elec t: to: ::;trin!jHo IderC ontroll 12 r( Pa ra. !jra.p r,E di tor):> >proce 5 :::Fie ejE: u t ton ::; trin!jH 0 Ide rC on t roller( p.:.. ra !jra. pr,E ejitor) >>proc e::::::r.,ou :::eE:u t ton::: ::; t ri n!j Hoi d 12 rC 0 n t ro II 12 r( P.:.. ra.!j ra. Pr, Edito r):>:> con t ro I.t.. c t i"'" it y

Figure 8.10b

000
The label of the notifier that appears indicates the reason for the interruption.
User Interrupt

The view displays a sequence of class names and message selectors whose method activations were interrupted. The notifier only displays the most recent class/message selectors of the interrupted execution. You can choose the yellow button command debug to obtain another view of the interrupted process. This view is called a debugger. It lets you explore the methods associated with the interrupted activity, to make needed changes, and then to proceed. Further details about the debugger are given in Part Three. A reason to interrupt a running process is to stop what appears to be a nonterminating process. When some activity seems to be taking too long, you can type ctrl c, and then determine whether to proceed or to terminate the activity. To terminate, choose the blue button command close. The notifier view is non-preemptive. You can just leave it on the screen and do something else, returning to deal with the interrupted situation at a later time.

9
Finding Out About System Classes
9.1 The Structure of a System Browser 9.2 Messages to a Class versus Messages to an Instance 9.3 Browser Menu Commands Class-Category Menu Commands Class-Name Menu Commands Message-Category Menu Commands Message-Selector Menu Commands Text Subuiew Menu Commands 9.4 Browsing a Subset of the System Class Hierarchy Browser

162 Finding Out About SysteIn Classes

The main way to find out about classes in the system is to use a system class browser. A browser presents a hierarchical index to information. A Smalltalk-80 class browser presents a hierarchical index to classes in the system. This index is independent of programming logic; it is designed solely for user access to class descriptions via subject categories. The browser presents categories that organize the classes within the system, and categories that organize messages within each class. The information about a class that you can retrieve using a browser includes a comment about the role of the class in the system a description of the part of the system class hierarchy in which the class is found a description of the variables of a class a description of the messages and methods of the class, including comments about the use of the message and the design of the method a classification of the class with respect to other classes a classification of the messages of the class access to all methods in the system that send a particular message access to all methods in the system that implement a particular message a list of all messages sent in a particular method The system browser also provides access to templates for defining new classes and templates for defining new messages, as introduced in Section 5.4. There are a number of class browsers in the Smalltalk-80 system, distinguished by the particular subset of classes that can be accessed. You obtain the browser for all of the classes in the system on the display screen by choosing the System Menu command browser. The browser that you see takes the form shown in Figure 9.1.

163 9.1 The Structure of a System Browser

CLASS CATEGORIES MENU

CLASS NAMES MENU

MESSAGE CATEGORIES MENU

MESSAGE SELECTORS MENU

in5t,3.ncel

cla.55
TEXT

Figure 9.1

9.1
The Structure of a System Browser
The browser is made up of five subviews and two menu items labeled class and instance. When you first create a browser, the menu item instance is selected. This means that the messages you are able to retrieve are the ones sent to instances of the class, rather than to the class itself. When the menu item class is selected, the messages you are able to retrieve are the ones sent to the class itself. Four of the subviews are fixed list menus; the fifth is a view iIi which methods can be defined and modified using the text editor. We will refer to the various subviews of the browser by their labels in Figure 9.1. There is a yellow button menu associated with each subview of the browser, as shown in Figure 9.2. The commands in each menu are described in this chapter. Classes in the system are organized according to categories. In the full system browser, these categories are seen in a list menu in the first subview, which is labeled class categories menu in Figure 9.1. Choosing an item in the class-category subview causes a list of class names to appear in the adjacent subview. This adjacent subview is la beled class names menu in Figure 9.1. For example, if you choose the item Graphics-Primitives in the class-categories subview of the class

164 Finding Out About System Classes

1//

/1 :=;ysti=lm E:ro'",'",'sert:
file out print out Sp,j. '","irl a.dd c,;. te90ry ren,jme upd.j e edit "
~

>
file out pr-int out
Sp,j."i'in

sp ,j "/'/ n rlie ra rc r, y hie t-,jrch y definition commerlt pn:1tocols Inst \',jT t-efs
CI.j55 ,/.;t- nat5

file out print out spa.\I,/n a.(jd pr-otocol ren,j.me remo',/e


al~a.in

file out print out sp ,;.. "i",'n senders implementors me ss.;.. qe s mO',/e remo\'e

undo

copy
cut pj5te (Jo It 1~lt"in tit .;'.ccept C,j.ncel tonli,3.t 5p.j. -'i-in e:.pla.in

CI.jS5 r"efs ren,jme remO"ie

Figure 9.2

browser, a list menu of four class names appears in the adjacent subview (Figure 9.3). One of the items that appears is the class name Pen. In addition, when a class category is selected, a template for defining a new class appears in the subview that is labeled text in Figure 9.1. The template is shown in Figure 9.3. You can edit this template in order to substitute proper names for the various parameters so that a well-formed expression is created that defines a class. When you choose the yellow button command accept, and if the edited information is syntactically correct, a new class is created (or an old one modified). The class is categorized under the class category selected in the first subview. The subviews of the browser are thus dependent on each other. A selection in one subview specifies the information for another subview. When a class is selected in the class-names subview, its list of categories of messages appears in the adjacent subview. This subview is labeled message categories menu in Figure 9.1. In addition~ when a class is selected, the class definition appears in the text subview. An example in which the class name Pen is selected is shown in Figure 9.4. By choosing yellow button commands in the class-names subview, comments about the class and the class hierarchy of the selected class can be explored, and, if appropriate, modified.

165 9.1 The Structure of a System Browser

1.lBrmIiDI_~ Po i,:to dt03.n9Ie n Cir03.prlics -Displ,:t ,. ()u


t

F'en

Gr,:t.prdcs-F',:t. tr,s Cir03. prl ic s- \/ ie'"",,, s Cit'03 prlic s-E ditor's

Fiec t ,:t.n9Ie

1,,j .:t. rn e() f::; up e t"C I03. S 5 sub cia. 5 5: # [\J 03 rn e() fC I,:to 5 5 ins t,:t.nc e\/ ,:t.r'i,:t.ble['"j,:t.me 5: ' ins t\/ 03. r[\j ,:t. me 1 ins t \/ ,:t.r[\j,:t.me2' cia. 5 5 \/ 03. t'i ,:to b Ie ['"j 03 rn e s: ' C I,:to 5 5 \/ .:t. rf'"j .:t. rn e1 Cia. 5 5 \/ ,:to d',.j 03. rn e2' pool D ic t ion 03. t'i e 5: " c ,:to t e 9 0 t'Y: ' Ci r,:t. prl ic s- Pri rn it i"/ e 5'

Figure 9.3

100"""""""""" 000
11_ . ' . " ' . ' .

) )]

(_:ollections-; Collections-:

I) }I (ir03.prlics-\/iE
Gt,:t. Prd c s- Ed i

<>1 Cit03.phics-Dis

}J Cit'03.prlics-P03

- -- - --- -- - -_ F'oint '\ ()u03dr,:t.n'jle Fiect,:t.n'jle ------------

initi,:t.lize-r'ele,:t.se 03.ccessinq color'inq mO\lin1jljeometric desi'jns

cl.:t.ss E:itE:lt subc 103. ss: #Pen inst,:t.nce\/,:t.riablef'"j,:t.rnes: 'fr,:t.rne IOc03.tion direction penDo',/,/n ' c I,:to S S \/ 03. t'i 03. b Ie f".J .:t. rn e 5: pooIDiction03r'ies: " ca. t e'jot'Y: 'Gr03.prlic 5 -F'rirnit i',/e 5'
"

Figure 9.4

100 000

166
Finding Out About System Classes

,:,:

I......... ,lImmli ramllDl


:~;:::~:~:::~ ~ =~',~~~':~: ~s

Colleetions-::;tt"ea. - --- -- -- --C: 0 II ee t ions- ::iUpp 0 I~ Point (jra.pt",ies-Dlspl.9. Y "-"Ij.=. elr =. nqlo:. F",:_-,_~.t .:t r,'..., I'~_- . "' ~ Graphles-Pa.ths ~ el

.i$

/m_19

initi.9.lize-relea.se .9.eeessIrl9 colorln'3

elo..n fjllln: '30: 0tO : '3eometne~_:jesll~ns t",ome not"tt",

mess.9.'3e selectot .9.nel ar'3ument n.9.mes "e 0 mment st.j tin,~ putpose of mess a.,~e"

tempor".jry ',,Iariable n.9.mes

sta tements

Figure 9.5

000
When a message category is selected, a list of messages in that category appears in its adjacent subview. The subview is labeled message selectors menu in Figure 9.1. An example is shown in Figure 9.5. In addition, when a message category is selected, a template for defining a new method appears in the text subview. You can edit this template, specifying the message pattern, a comment, and the sequence of statements. When you choose the yellow button command accept, and if the method is syntactically correct, a new method is created. It is added to the description of the selected class, categorized in the selected message category. Choose a message selector. Its method appears in the text view. An example appears in Figure 9.6. You can edit the method using the text editor. You then recompile it and reinstall it automatically in the system by choosing the yellow button command accept in the text subview. Information about the method is provided in comments that also appear in the text view, usually at the beginning of the method. You can use the browser to find a message and its associated method in order to read the comments and to learn about the intended use of the message.

167 9.1 The Structure of a System Browser

Collections- citrea. ----- --- ---c:: 011 e c t ion s- :::i up p olll~@.; Point Gra.pl"lic s-Displa. y f-',U:; cJr=t nqlE! C~ t",:.. p I"dc s- P,:.. HI s F:'e I~'t ':.. ~'9Ie (j t"a. p 1"1 ic s- \/ ie","'," s (::Or,:. prlic s-E di tors cl,:..ss

11 in it i.:.. 1i ze - tOe I
,:..ccessinq colorin!~ !~ e 0 rn E! t t"i c dE!

dO".',,'n fillln:
I~O:

qoto:

horne "F'I,:'.ce Hie receiver O.t n,e center of its fr,9.me," loc,9.tiorl ... ft",:'.rne center

100
0001::::;:.::::.;.:;8G~~~~~~~;:1
Figure 9.6
The browser search approach implies that you need to know the category of a class in order to find it in the browser. Besides exploring in the browser, you can find out the category of a class by sending it the message category. For example, the answer from the message category to the class object Pen
Pen category

is Graphics-Primitives. Type this expression in a workspace, select it, and then choose the yellow button command print it. The category name is printed. Also, as will be described at the end of this chapter, it is possible to create a browser for a subset of the information in the system. To get a browser for a single class, you create an instance of class Browser, specifying the class. For example, try evaluating the expression
Browser newOnClass: Pen

to get a browser just for class Pen. Another approach might be to add a subview to the browser in which you can type a keyword, like a class name, to get the browser to automatically select the correct subview menu items, thus showing you the index hierarchy. Another possible feature is to be able to save the selected "query path" (the one, two, three, or four selected indices) in an additional menu so that the path can be selected directly.

168
Finding Out About System Classes

9.2
Messages to a Class versus Messages to an Instance
In the preceding examples, we have assumed that the browser menu item labeled instance was selected. Now choose the item labeled class (Figure 9.7). All messages browsed will now be ones that are sent to the class itself. These are primarily instance creation messages. In many cases, these messages consist of documentation comments or examples of how to create instances of the class. A good way to learn about the Smalltalk-80 system is to explore the classes and see what examples are provided. The example methods typically include a comment that you can select and evaluate in order to invoke the example. Choose the class category Graphics-Paths, and then choose the class name Spline (Figure 9.8). The browser menu item class should be selected. In the previous sequence of instructions, you had been directed to browse through the messages that can be sent to instances of a class. Now we can browse through the messages that can be sent to a class itself, in this case, to Spline. Message categories that are typical for classes include class initialization (messages to create class variables), instance creation (messages to create new instances of the class), constants, queries, or examples. The description of class Spline consists of the message category examples. Choose it. In the message-selectors subview, choose the message selector

Ijljl:\.I\[\!I\IIIII~~I!~~~~Point Graphics-Display Quadrangle


I:;:;:).!)U)W:UI

Collections-Strea -----------Collections-Suppo

instance creation examples

ImmmmY<1

Graphics-Po. ths Graphics-Views Gra.phics-Editors

Rectangle ------------

instance Pen class .~::<::::::>:::'I insta.nce'./ a.riableNa.mes: "

Figure 9.7

100 000

169
9.2 Messages to a Class versus Messages to an Instance

example. The selection of browser menu item class, category examples, and message selector example is shown in Figure 9.9a.

~ -.I
instance Spline cl.9.SS in st ,;:l.nc e \/ ,;:l. r-i ,;:l.ble[',l03.rnes: "

Circle Cur',.,'e Line LinearFit

e::<03.mples

Figure 9.8

1:-:!'.I:::I:!I:~:I!1 Collections-Strea. Ii Collections-:3uppo

Circle Cur,.,'e Gro3.prtics-Prirnitiv - Line Graphics-Displ.9.Y Lineo3.rFit

l!III@i"M:P"M PiiI Gt"aphics-\/iews -----------I::::::::::::::::] (jraprlics-Editors


instance
I::;,;,;;;:,:,:;:;:,.

Exa.mple
"Desi9n03. te points on the F'.;:l. trl by clickin9 trle red tllJtton, TetTflin03. te by pressin'j a,ny othet" button, .~, cut"\le . . .,/ill be dis pia, yed, tr,rou'jrl tr,e selected points, using a, squa,re tda,c~:. fotTfI,"

I splineCur\,'e

Figure 9.9a

100 000

a.FotTfI fl,;:l,91 ,;:l.Forrn f- FotTfI ne . . .'/ e::<tent: aForm bl,;:l.ck, splinEiC:ut'VEi f- ::;pline ne"i'i, splineC:ur',,'e form: a,Form, fla,lj f- true,
- f
P " 1 -,

i::(!t:,

170
Finding Out About SysteIn Classes

The text subview now contains the definition of an example use of


Splines. Read the comment to learn how to use the example. Now scroll

to the end of the code and find text for the expression
Spline example

Select the expression and then choose the yellow button command do it so that you can try the example (Figure 9.9b).

i_""""""
Collectlons-3trea Collec t ions- ::;uppo C'ra ph i c s - F'r"irni t h,' E Gr"a.prdcs-Displ,:.,'o/ Cir"cle Cur',/e Li ne Linea.rFit

'_li4jDi

IdAnHa- .Di,' 1 ::~;:::'~:~:;:~:' -~",~f~":;:~s -----------insta.nce ifFa,ls e: [fla.,~'" fa,lse Jl splineCur',/e cornputeCur . . . e, sp lin eCur',.,' e is Ern p t y ifFa.lse: [splineCur"/ e cJispla, y I:) n: Displ.:., y, ::; en sor './.. '.:., it r",]oE:u t t on J. tsplineC:ur.. e

a'9 ain
undo
cop~~"

cut paste
I~,r"in,\ it

"MiU! 'M'M!W"

a,ccept c,:'.ncel fOtTn,:.. t spa, 'i.,.'n e>::pl,:'.in

Figure 9.9b

010
According to the documentation included in the method, you point to several places on the screen by moving the cursor and clicking the red button (Figure 9.9c); you terminate by clicking either the yellow or blue button. The result is a curve computed using the algorithms of the spline (Figure 9.9d). This example had the side effect of leaving marks about the screen. Choose the System Menu command restore display to clean things up. Explore other graphical objects and try the examples.

171
9.2 Messages to a Class versus Messages to an Instance

IH)} ::::] C~r,9. prl i c s-D i Spl,9.Y'

_Uill."i

Cit"Cle C:ur',,'e Line Lin e ,9. rFi t

u i&iii '

------

----

ifF.9.lse: [fla,!~"'fa.lseJJ. splineCur\le computeC.",e, splineCur',/e isEmpty ifF.9.1 se: [spl in eCur"/ e di spl ,9. y tJn: Di spla. y. :::ien::.or '",,. . r",]oEiutton], tsplineC:urve

Figure 9.9c

100.::.::..::. . .: 000
1 '.'

"M1.I4 '"Ms"

. '........ Collections-Strea. C:o lIec tion s- :::iUP po (~t'a. p r,!c s - F't~irn it i l l . , (.:it,9.prIICS-DISpl.9.y Llnea.rFlt Cir.9. p rlic s - \/ i e" '.'vs ...................... Gt'a.pr,ics-EeJitots

1,_9.....

-- - - - - - - - - - -insta.nce

i fF,9.lse: [fla.g'" fa.lsE!


splineCur',/e cornputeC'...........1Io.c splineCut"./e isEmpt ifF.9.lse: [spline(
t

".;;;if' aIM-"

splineC:ut,,,.e

Figure 9.9d

100 000

172
Finding Out About System Classes

9.3
Browser Menu Commands
A yellow button menu can be accessed in each subview of the browser. The menus were illustrated in Figure 9.2. The use of each command is summarized in this and in the following sections. There are three commands common to the four subviews containing list menus. These are commands for creating a file containing a version of the selected descriptions readable by the Smalltalk-80 interpreter (file out); for creating a file containing a human readable, well-formatted version of the selected descriptions (print out); and for creating a browser for a subpart of the system (spawn).
In the Xerox systems, the command print out also creates a hardcopy version of the file.

file out

Creates a file whose name depends on the current menu selection. The file contains a Smalltalk-80 readable version of the descriptions of the selected item (classes in a category, single class, methods in a class protocol, or single method). Creates a file whose name depends on the current menu selection. The file contains a human readable ("prettyprinted") version of the descriptions of the selected item. (In a non-Xerox version of the system, this command may be identical to file out.) Creates a browser in which only the classes included in the selected category can be accessed.

print out

spawn

Class-Category Menu Commands

There are five additional commands in the menu of the class-category subview that pertain specifically to modifying the class categories.
file out
Creates a file whose name is the selected class category, followed by a period and the characters st. The file con tains a Smalltalk-80 readable version of the descriptions of the classes in the selected category. Creates a file whose name is the selected class category. (In the Xerox system, the name is followed by a period and ~he characters press.) The file contains a human readable ("pretty-printed") version of the descriptions of the classes in the selected category. Creates a browser in which only the classes included in the selected category can be accessed.

print out

spawn

173 9.3 Browser Menu COITlITlands

add category

Adds a new item to the class-category menu. When you choose this command, a prompter appears in which you type the category name. Choose the yellow button command accept, or type the "carriage return" key, to indicate that you are finished typing. The new category name is inserted before the current selection, and then becomes the current selection. If no item is selected when this command is chosen, then the new category is added at the end of the menu. Changes the name of the currently selected category. A prompter appears in which you edit the category name. Choose the yellow button command accept, or type the "carriage return" key, to indicate that you are finished typing. Removes the currently selected category of classes from the system. If there are any classes classified under the selected category, a confirmer appears to make certain that you wish to remove all the classes from the system. Choose yes if you do, no if you do not. Displays the category names and message selectors in each category in the text view of the browser. The categories into which the classes are sorted can be changed using the text editor (see Section 12.6). Makes certain that the classes viewed by the browser contain the latest information about these classes. This command is needed if new class descriptions are created outside this browser, for example, they are created by reading an external file, or by evaluating an expression, or by using a different browser. Such classes are categorized in a category not currently displayed in the browser.

rename

remove

edit all

update

When no class category is selected, the yellow button menu only contains the items add category, update, and edit all. Commands in the yellow button menu for the class-name subview add queries you can make about the class-its position in the class hierarchy, a comment about the class, its definition, and its message categories. If no class name is selected, then the browser subview flashes to indicate that no yellow button menu items are appropriate.
file out
Creates a file whose name is the selected class, followed by a period and the characters st. The file contains a Smalltalk-80 readable version of the description of the class.

Class-Name Menu Commands

174
Finding Out About System Classes

print out

Creates a file whose name is the selected class. On the Xerox system, the name is followed by a period and the characters press.) The file contains a human readable version of the description of the class. Creates a browser in which only the description of the selected class can be accessed. Creates a browser for the superclasses of the selected class, the selected class itself, and its subclasses, in hierarchical order. Displays the names of the superclasses and subclasses of the selected class in the text view of the browser. The names are indented. A subclass name appears indented from the name of its superclass. Instance variable names declared in a class appear in parentheses after the class name. Displays the definition of the selected class in the text view of the browser. This definition can be edited. If you choose the yellow button command accept, the modified definition will be evaluated. In doing so, you can change the definition of the selected class; the system will recompile each method in the class and report any errors if previously declared variables are now undeclared. You can change the category of the class by editing the category name in the definition. The class-name menu will change appropriately. If you edit and change the class name of the definition, you can create a new class or modify one other than the selected class. Displays the current comment about the selected class in the text view of the browser. There is a default comment, namely This class has no comment, that appears when a more appropriate comment has not been provided. Edit the comment and choose the yellow button command accept to restore it. The message categories or protocols into which the messages of a class are sorted can be changed. When you first create a class, no message categories are defined. You must add a category before you can define a method. Modifying message protocol is described in Chapter 11. Displays a menu of the instance variables of instances of the selected class. Since instance variables are inherited, the menu shows the variables declared in each superclass, in alphabetical order; a line separates variables declared in each class. If you choose one of the items in the menu, a

spawn spawn hierarchy

hierarchy

definition

comment

protocols

inst var refs

175
9.3 Browser Menu COITlmands
message-set browser, as described in Chapter 10, is created for all methods that refer to the selected instance variable.

class var refs

Displays a menu of the class variables of instances of the selected class, Since class variables are inherited, the menu shows the variables declared in each superclass, in alphabetical order; a line separates variables declared in each class. If you choose one of the items in the menu, a message-set browser, as described in Chapter 10, is created for all methods that refer to the selected class variable. Creates a message-set browser, as described in Chapter 10, for all methods that refer to the selected class. Changes the name of the selected class. A prompter appears in which you type the new class name. Choose the yellow button command accept, or type the "carriage return" key, to indicate that you are done typing. Creates a message-set browser on all methods that refer to the class. Removes the selected class from the system. When you choose this command, a confirmer will appear so that you can verify that you really want to carry out this destructive command. There is no "undo" command for retrieving removed classes.

class refs rename

remove

Illustrations of some of the commands summarized above are given in the next sequence of figures. Figure g.lDa shows that class Pen is select-

.Iize-release ssing sP':;."i,m ing 5p a. "i','TI 1'"11 era. n: 1'"1 ~;I n 9 enic desitjns comment "EiitE:\t subcla.ss: insta.nce",/a.ria.ttlef",Ja. cl,:;.ss\i,:;.t'iabler",J,j.mes: pooIDiction,3.t"ies: " 'Irotocols IrIst "i,:;t" t"efs cla.ss "i':;.r t'efs CI,3.SS refs r"ena.me In dit'ec tion penDo","'in '

file out print out

ca. t ego t"y: ' G t" a p 1'"1 i c 5 1.-__t."e;,;.n;,;.'1C;.I";.i.... ;.:_ .....

Figure 9.10a

010

176 Finding Out About System Classes

ed and that its hierarchy is to be displayed; Figure 9.10b shows the hierarchy. Figures 9.10c and 9.10d show a comment about class Pen.

i.)bject

() EiitEI/t ('destForm' 'soureeForm' 'r,.:t.lftoneFot"m' 'comtdn,~.tionFiule' 'dest.><.' 'dest\" , ",...,..idtr,' 'r,ei'jt",t' 'source.::<.' 'source',." 'clip.>::.' 'clip',i' 'clip',/,/idth' 'clipHei'jtH' ) Pen ('fra.me' 'Ioea. tion' 'direction' 'penDo'','\ln'

Figure 9.10b

000
file out pt-int out

~~~~r ,a;;~:~i~::':ChY ~:r;OIQase


5

Fiecta.

amrm.... etnc
ren.:t.rne

definjtjo~,

Jlj- .

(jesH~ns

.;,;;;::;:;:::;:;:;::1.

leForrn' 'combin.~.tionFiule' remo/e 'dest.><" ',jest..,., ,.,..j,jtt"I' '~_l'I!I'I"l"I!""~~"'!I'I!!!'!I"!" . . source,.', 'clip.::<.' 'clip'"'" I : ( ( ] 'clipl.,l,t'idtrl' 'clipHei9ht' )

FH>d C'bject () EiitEilt C,jestForrn' 'sc

I!><n

Pen

('fr.~.rne'

'Ioc.:.. tion' ',jit-ection' 'penDo.. .,..n'

Figure 9.10c

010

177
9.3 Browser Menu Commands

::::

':,:::;:,:::

:,:;

::,;

I/'<n

Collections-~

----- ------Point ("Ij =t dr=t nql.:. F;el~t':<~I.~le -

- - --- - -----accessinq colm'in!~ geomett'ic cjesil~ns

Collections-;

111;1@I1 liniti,:<./ize-t'e/e,:<se

rno"iin!~

cl,:<.ss

Figure 9.10d

000
Section 9.4 illustrates the spawn commands. Examples for commands inst var refs, class var refs, and class refs are given in Chapter 10 in which message-set browsers are explained. And the command rename is examined in Section 12.2. The three common file and print commands appear in the yellow button menu of the message-category subview of the browser. In addition, commands that modify the message categories or protocols are provided. They are further explained in Chapters 11 and 12.
file out
Creates a file whose name is a concatenation of the selected class and message category, followed by a period and the characters st; spaces are replaced by hyphens. The file contains a Smalltalk-80 readable version of the description of the methods in the selected message category of the selected class. Creates a file whose name is a concatenation of the selected class and message category. (In the Xerox system, the name is followed by a period and the characters press; spaces are replaced by hyphens,) The file contains a human readable version of the descriptions of the methods in the selected message category of the selected class.

Message-Category Menu Commands

print out

178 Finding Out About System Classes

spawn

Creates a browser in which only the description of the selected category of messages for the selected class can be accessed. Adds another message category to the message-categories menu. A prompter appears in which you type the new name. The name is inserted before the currently selected category and then becomes the current selection. If no item is selected in the menu when this command is chosen, the new category is added at the end of the menu. If you type a name that already exists, it is moved to a new location (either before the current selection or at the end of the menu). Changes the name of the currently selected message category. A prompter appears in which you type the new name. If you type the name of a category that is already in the menu, no change happens. Removes the selected message category from the menu. If any messages are classified under this category, a confirmer appears to verify that you want to remove the messages from the system.

add protocol

rename

remove

If no item is selected in the message-categories subview, then only the

command add protocol is in the yellow button menu.

Message-Selector Menu Commands

Commands in the yellow button menu for the message-selector subview add queries you can make about methods and messages. file out
Creates a file whose name is a concatenation of the selected class and message selector, followed by a period and the characters st; spaces and colons are replaced by hyphens. The file contains a Smalltalk-80 readable version of the description of the method for the selected message selector. Creates a file whose name is a concatenation of the select ed class and message selector. (In the Xerox system, the name is followed by a period and the characters press; spaces and colons are replaced by hyphens.) The file contains a human readable version of the description of the method for the selected message selector. Creates a browser in which only the description of the selected message for the selected class can be accessed. Creates a message-set browser for all methods in the system in which the selected message is sent.

print out

spawn senders

179
9.3 Browser Menu Commands

implementors messages

Creates a message-set browser for all methods in the entire system which implement the selected message. Creates a menu of the message selectors for each message sent in the currently selected method. If you then choose one of these selectors, you create a message-set browser on all of its implementors. Moves the selected message to another message category. A prompter appears in which you type the name of the designation message category. If it already exists, the message is reclassified. If the designation message category is new, it is added to the message-categories menu, at the end. The current message category remains the current selection. You can also type the name of a class and a protocol in order to copy the selected message to a different class. The syntax is className > protocolName. (If you type the class name of the currently selected class, the result is the same as though you did not mention the class name.) Removes the selected message from the selected class. A confirmer appears so that you can verify that you really want to carry out this destructive command. There is no "undo" command for retrieving removed messages.

move

remove

The commands senders, implementors, and messages are explained in more detail in Chapter 10. Examples of modifying the protocols of a class are given in Chapter 11.

Text Subview Menu Commands

The yellow button menu for the text subview of the browser contains the text editing commands presented in Chapter 3 (again, undo, copy, cut, paste) and the expression evaluation commands of Chapter 6 (do it, print it). There are five additional commands.
format
The system has some notion of how to format a method so that the indenting and line breaks increase the human readability of the code. Choosing this command when the text view contains a method (that you have retrieved but have not modified as yet), creates a "pretty-printed" version of the code. You can then modify it to suit your own style. In the context of a method, this means "compile" the code.
If there are any syntax errors, display them; if not, the

accept

compiled method is stored into the system. In the context of a class definition or comment, the text is an expression that is evaluated. In the context of categories, the syntax is checked and the new categories stored.

180 Finding Out About System Classes

cancel

Text that appears in the subview has presumably been modified but you do not want to retain the modification. The text is replaced by the version prior to any modification. The commands accept and cancel work as pairscancel returns the text to the version last stored using accept. Creates a browser for the currently selected message and the current version of the method (which possibly has been modified but not stored). The text in the original browser will be restored as though you had chosen the cancel command. The text in the new browser is not yet accepted as the compiled method. The text in a method consists of a sequence of tokens, for example, syntactic entities such as T and ], and variable names. Select one. The result of choosing the command explain is to determine a comment that explains the use of the selected token. The comment is inserted into the text, after the token. It becomes the selected text.

spawn

explain

Spawning a Message Browser As noted in the summary of commands, a way to create a browser on a single message is to choose the command spawn from the yellow button menu of the text subview of a browser. Suppose you have been editing a method, you have not yet saved the method by choosing the command accept, and then you decide that you want to put aside your work for awhile in order to explore the previous version of the method or to search in the browser for other information. Choose the spawn command. You are asked to designate a rectangular area for a browser for the currently selected message, with the edited text as the method. The text in the original browser will be restored as though you had chosen the cancel command. The text in the new browser is not yet accepted as the compiled method. You might also use spawn to copy a view of a method onto the screen while you use the full browser to find other information. Any browser view of a method in which the editor is available can be used to change the method and then to recompile and re-store it. Changes made to a method in any view are shared by the whole system (although you might have to specifically request an update to see shared changes). In the next figure, the text in the Pen method hilbert:side: has been edited from the original (Figure 9.11a). Spawning causes the original method to show in the system browser and the edited version shows in a newly created message browser (Figure 9.11b). Note that the difference is in the formatting of the visible conditional statement.

181 9.3 Browser Menu COInrnands

,6,

cla.ss Hilbet-t Cut-',/e is ':. sp,:.ce-fillin,~ cur'v'e,"

a.,~a.in

uneJo

I
Figure 9.11a

copy

I,:.
n

I
[,:.
+-

n = I] ifTnJe: [tself tUtTI: 1::::I]J.

> I] i fT nJ e:
ifFa.lse:

9 1], m .... n -

1J

[a .... -9Ci, m .... r, +1 J.


C'.

self tUtTI: a, self rdlbet-t: Ci - m side: self tum: ':., self rdlber-t: CI - m sicje: s, self tUtTI: ,:'.; 90: s,

cut pa.ste eJo It -,t-int it .:'.ccept c,:'.ncel fOt-ma.t

010
::; y s t e m Ei tOO ''1\' S e t-

~~;~~f~i.~F,':':'~'~>"""-lllitlr~i"""I--hilbert: n -----~----C~t-,:..prlics-Displ,:'y side: s


(it-aprlics -F'a. t r,s (j t-a. p r, i c s - \/ ie'",'",' s (jr,:. p rill: s- El:Ji tors i)ua.dt-':'.nqle F,ec tan'~le

Collec t ion s- ::; t re,:..

ooooI':.

hilbert: n side: s
"Dra."""",s ,:.r, nth le'v'er Hilbet
,6,
A

Hilbet-t Cut-',/e is ':. sp,:'.ce-filli

I a. m I r, = Ci ifTnJe: [tself tum: r, Ci


if True:

I a m I n = I] ifTnJe: [tself tUtTI: 1eCiJ. n > () ifTrue: [,:. 90, m .... n - 1J ifF,:.lse: [,:. -9Ci, m .... n +1J.
self tum: ':., self rdlbet-t: Ci - m side: s. self tum: a, self rdlt,ert: Ci - m si,:Je: s, self tUtTI:

100
Figure 9.11b

[,:.

9Ci,

m
ifF,:.lse:

r, - 1J

a.;

I~O:

s,
I~O:

self rdlbert: m si,:Je: s, self tUtTI: Ci - a; s; tum: Ci - a, self rlilber-t: m side: s,

000

182 Finding Out About System Classes

Explanations There are several views in the system in which methods are retrieved and displayed, including the system browsers and the debugger. The yellow button menu in the text part of these views includes the command explain. You can choose this command to receive an explanation about a syntactic or semantic part of the method. The command explain works by examining the current text selection and determining what role the text plays in the method. The text selection must be a single token (such as a period, message keyword, or variable name) or a syntactic construct (that is, a single-quoted, or doublequoted sequence of characters, or characters delimited by square brackets). In Figures 9.12a and 9.12b, an explanation is requested and received for the left-arrow (+-). The explanation is inserted after the current text selection and then becomes the text selection. The most significant explanation is for a single token that is a variable name or a message selector. The explanation will identify where the variable is declared, i.e., global, instance, class, or pool, and in which classes the message is defined, respectively. In Figures 9.13a and 9.13b, an explanation for the global variable Sensor is requested and received; it is an instance of class InputSensor. In Figures 9.14a and 9.14b, an explanation for the class name Form is obtained. Typically the explanation is a comment, but, in some useful cases, it is an expression that can be evaluated in order to obtain further information. For example, if the token selected is a class name, then the explanation is a comment and an expression that can be evaluated in order to create a browser for just that class. The result of choosing do it when the explanation is selected (Figure 9.14c) is to create a browser for class Form (Figure 9.14d). The best way to learn about explain is to try it. Once you learn how to use a browser and can retrieve a method, simply make selections of parts of the method and select the yellow button command explain. If no explanation is possible, it will say so.

183
9.3 Browser Menu Commands

l?n?n?:J' Cir,9.pt"llcs-Pa. ths 1?i=UUi:i?J Cit",9.phics -\/ie',,,/s


.:':':':':':':':':':0

n.;,. Po i n FI--#I,o ft" a. l illl!i!!!lli!illllll('::lol";elic~t~icl' ~:::Zilu~P.Pao~II~i!;~,jr=t nqle II~irl'~it~i'ii9.~,i~I? ii-.re.'.e.o9..s.e.1 fritOemc t ion Cit",9.phics-DispI.9.y (',u ,9me:
t
12i-

C;ollections-Eitrea. --- ---- -- ---

(j

12

F":,",,_~

I~_~.t ,"'_.n ~ _. '-""=,11'~_-------- -- - -

=t

I~Ollit"in

n-~I'J 1-,.' I' n q_ a.ga.in

"""'-"7"""""11

geome

Ciro9.pt"lics-Editot"s

CI'9.SS frame: aRectangle ":::iet tt",e t"lO!ct ,9nqle in ".",/t"lict", tt",e t"ecei'',''e ,j 0 1t a. """", ," wint it fra.me '9.Recta.~lgle, ,9.ccept self clipFiect: a.Fieet,9.n!jle ca.ncel form.9.t

undo copy cut ),9.ste

loco9. tion ns sc'urceFot"m: ",,',/i,jtt"l:

Figure 9.12a

010
l:iill)iilii'iljiliIIC~:IOI""'i:lc~t~i r~1;~.-~:::i;'"JF'"'F.",~olll~i!;~ II~irld~t~ia~.I~i:1"el-~tl"el'ieial's .e.l,j itOe c t ion c.' Ii F'oint FI-FiEliD fr,9.me
Gr,9.pt"lic s-Displa.y Cit"a.pt",ics-F'a.tt",s '-'r- Ft"i- - ''''\':'''''(~t-:; F: r: i:;' ~ =~ ,ji~",;, ;~s C!.uadt"a.n'jle Fiecta.n'jle -----------cla.s5 frame: aRectangle ":::iet tr,e recta.nqle in ',.,vhict", tr,e receiver" ca.n dt",9.\V," fr",9.me self clipRect: a.Fiecta.r'!jle Collec tionS-:::itt"ea. ----- ------c olot"ing fra me: mo',/inq loco9. tion Ijeome-tric \jesigns sourceForm: '','\li,jtt"l:

iiii'.

~Rectanljle,

. . . .';;

Figure 9.12b

000

184 Finding Out About System Classes

111_
liil!!!!!i!l!!!i!!!!1 (:: co II e c: icon s- .:=: I.~ p. Pco
1/ }:)}]

CirclQ

...

;:/:::::::::n::: _lio.,,'M _lIiill'


I::'>:,:>:']
(~ra.ptdc s-\/i e'.. . .' s
-- -- -- -----(~r.:..phics-Editot-s

I:

C: u t.. e cira.ptHcs-F'nrrlltl.. ., Line Cir,3.phics-Displa.y Linea.rFit

aq.:..in I..if-Ielo

copy
cut paste elo It ,,.:,tint it a.ccept ca.ncel fOtTn.:'.t spa. "..,'n

insta.nce splineCut- e '"" :::pline ne'..... splineCur e form: a.Form.


f1.:'.'j '"" tnJe,

[fla.9J ...,. . tdleTrue: [ _ . .,,,:..itE;uttcon. :::enscot- tecJE:uttonF'resseeJ ifTnJe:

[s pli n eC u r.. e ':.. elel: ::: ens or \.. . . a. it E;u t t on. ::: ens co r '. . . . a. it r",JoEiIJ t t on. a.Fotm eJispla.y()n: Disp":'y .:.t: splineCur""'e la.stJ

i fF,:'.ls e: [fl ,:'.Ij '"" f.:'.ls e JJ.

Figure 9.13a

010

'-1

I . ,.-.

-,,- -II

C'I

.......

_,:,:.:.,.:,:,:.:.:., Collections-::iUea. Collections-:::uppo (it'.:.. ptd c s- F't'imi t i.. .:::::::::::,:::::::, (~ra.ptdcs-Displ.:'.y

Cit-cle Cur.e Li ne Linea.rFit

iAiiiili'

iAiiiili'

inst.3.nce splineCur.. e '"" :::pline ne.. '.. splineC:ur""'e form: .:t.Form. flo3.9 '"" true. [flo5.9J . ..t,ileTrue: [:::ensot "is a 910bal . . o3ri.3ble. '. ,......:t. it E: u t ton. ::;erJsor reelEiuttonF't'esseel ifTnJe: [splineCut.. e .:t.eld: :::ensor ,'''',:titE:utton. :::ensor ,'. .....:..itr\JoE:ut ton. ':.. FOtTn elisplay()n: Displ,:t. y o3. t: splineCut-.. . e las t J

::,en50r is an Input::,ensot-"

Figure 9.13b

000

-=,-'

185 9.3 Browser Menu Commands

Collections-:3trea. Circle
(~:ollec:-jons-.::i'~p.po

;';'

Cut've (.;ra.pl-i1CS-Pnmltl.. . e Line Gr.:tphics-Displa.y LinearFit

iiiii'I'."'.I1!OIi'
(it.a.pl-dcs-.v.ie s (] t.:.. pI-dc s- Edj tors

------------

1:::;lillill[:~:~=.::~.lIi~nlS!t~a.Lr~,cJ:eJIII.L__ I:

-l It

I
Figure 9.14a

splineCur\"e a.FOtTn fl.:.gl ne.. e::<tent: i:i(!:::. a.Form ... a.FOtTn bla.ck. splineCut'.. e ... ::ipline ne'..... spline(:ut,.,e form: .00.Form,

III

a.g.:tin un,jo copy cut p.:.. st e do 'It'int itt-......---------f< .:'.ccept c.:'.ncel form a. t spav\"n
\

_ii&iiII"

fla.g ... tnJe. [fla.g] ..I-lile Tt'ue: [::ienSOt "is a. ,~lob.:..1 ',,'09. ti.:'.!:,le. '...:..itButton. ::ienSOt t"edEiuttonPt'essed

::iensot is a.n Input::iensor"

010

~.

";' ";'

"""

'"

Collections-Stre.:.. Collections-::iuppo (it".:'.pl-dcs-Pt"imitiv Gra.phics-Displ.:tY

Circle Cut.... e Line Line.:'.tFit

e, am 'de

,,. . . .I1!OIIiIiIll'1 ~~~:: ~:~:::~: ~ = ~,~~;.:;:~s -----------inst.:'.nce

I
Figure 9.14b

splineCurve .:'.Form flagl "i.:- :. 'jlob.:. I "':, n 01 ble

For-m i5 ':. c I,:, 5':- 1,1 c:' te'jor",,'

I~r,:.phk':--['I.:pl:.. '='bJect.:-"

Bto '.. ',' .:er 'le"',,"=',,':=,I,:. 55 For rll

nev.. e>::tent: E:@::: . .:'.Form bla.ck. splineCut e ... ::ipline ne.., splineCut e fOtTn: a.FOtTn, fla.g ... tnJe. [fla.,~] ..I-lile TnJe:
'=;..
~l-'

000

11',_

,:1

-, .,,-

\",=' ..-""

.-.~-:;.

186 Finding Out About System Classes

1"",:,;;:'",,:'1 Collections-::itt-e,:.. Cin::le

I)U::U::Y] :.~ ;~I,~I ~ ~I~;'~ ~ ~,~i~:-:1


.""""""""",,,
C~t-a. prtie

n:,': c: ~ :"'" e
Line,:'.rFit

&liiiilh

llllliJiiiMmM
s- \/ ie "'o',/S

c~r,:..prtic s-Displ,:.. y

.",
- - - - - --- - - -inst,:'.nce

I":,:,::::,,,,,:,]

(~t-a.prdcs-E(jitors

,:'.FOtTrl black, splineCut-',/e ....

::;~dine

ne',/,/,

splineCur',/e form: aForm, fl':'.9 .... true, [fla.9J ',/,/rlileTrue:

Figure 9.14c

010
::;ystem E:ro',/,/setcl,:.ss

1:"---1 initi,:.lize-t-ele,:'.se
aecessin9

a (jlspla.ylrl'j
"pispl,:..yf"/1ediurli subcl,:..ss: #Form inst,:.nce",/ar-i,:.tdef",),:'rlies: 't,its "o'vidth rlei'jrlt offset c I':.. s::: \/ ,:'.ri able r'"j ':. me s: ")neE:itFo rom ' pooIDiction,:'r-fes: "
C ':.

e::lpyinl~

t e 'jory: "Jr,:. prli c s- D i::: pi,:. y (Ibjec t s'

Figure 9.14d

000

187
9.4 Browsing a Subset of the System

9.4
Browsing a Subset of the System
As noted in the previous sections, in each of the browser subviews containing list menus, the yellow button menu includes the command spawn. Choosing this command creates a browser for accessing a subset of the information available from the system browser. In particular, you can create a System Category Browser by choosing the command spawn in the yellow button menu of the class-categories subview (Figures 9.15a and 9.15b). This browser gives you access to all the classes within the currently selected class category only.

C: 1.01 S S \/.01 rr".J.:t. me2'

Figure 9.15a

0101111[11

11111

188 Finding Out About System Classes

~!!!!!!!!!!!!!!!!~- - - - - - - - - - -Pen Point C,ua.(Jr,Ct nljl e Fiec tan91e it-----t -----------1'"j,Ct.mel.J----in5t,Ct.nce 1'"j ,Ct. me C' f::; up e t'C Ia 55 5U tl CIa 55: # f'"j ,Ct. rn e I) fC I,Ct. 55 in 5t ,Ct nce\/ ,Ct.ri,Ct.bler'"jame5: 'in 5t\/ ad\ja. mel in 5t\/ atf',.j.Ct.rne2' c Ia 55 \/ a. ri .Ct. tile r.j Ct. me 5:'C I.Ct. 55\/ a tr'.j a. rn e1 C I.Ct 55 \/ a. tr.j a. rn e2' pooiDiction,Ctrie5: " cat eIj 0 ry: ' ,:; r.Ct p r-Ii c 5- F't'i rn it i'./ e5'

------------

1"",<

Figure 9.15b

000
You can create a Class Browser by choosing the command spawn in the yellow button menu of the class-names subview (Figures 9.16a and 9.16b). This browser gives you access only to the description of the currently selected class.

::~::~:::::~ ~::~:~:~=:
Gra.pr-lic5-Di5 Gt a. p r-d c 5- F' Ct, Gt'a,pr-lic5-\/i", I>

I, ,;.--------1il
iti
:",1:::1:,::,:

~r~;i~~i~~=;:I~~5e
e55irllj .rirllj I rllj netric de5i9n5

F'oint file out l)ua,(J pt'int out Fi ec t . ---- 5pa,,/.,,'n hiera~:r-IY

< .._G_r_,Ct_p_r-,_Ic_:

= _'

-_E_(_Ji__.......__ iti IIiIII1Il

~~I:;;'~I~'~:i:::~;'

I-------------------""~-------.F I

...E: it E: It 5U b c 1Ct. 55: # Pe n c o rn rn en t ,


in 5tar, c e \/ 'Ct t'i a bIe I'"j a !--.,.....4P_,t_c_, t_o_c_: ~. . ,:;=---10 n ,) ire c t ion pen D 0 ',/",' n ' c_d CI,Ct55\/,Ctriatder'"jarne5 1n5t \',Ct.t t'ef5 CI,Ct55 ',/a,r ref5 pooIDictiona,t'ie5: " cla55 ref5 cat e9ory: 'Gta.pr-,ic5 t'enarne terno'/e

Figure 9.16a

010

189
9.4 Browsing a Subset of the System

cl,':t.ss

.... E:itE:lt subc!.':tss: #Pen insta.nce\i,':t.r-i,':tbler",J,':t.mes: 'fr-,':t.me loc,':t.tion clit"ection penDo"i'in ' cla.ss\i,':tr-iabler",James: " pooIDiction,':tr"ies: " c ,':t te90t"y: ' ':.:ira. p ~Iic s - F'rimit i\les'
~

Figure 9.16b

000
You can create a Message Category Browser (or ((protocol browser") by selecting the command spawn in the yellow button menu of the message-categories subview (Figures 9.17a and 9.17b). This browser gives
Collection::;-::::trea. ----------Collec tions-::::uppo Point C1ua.dt-a.nqle F:ec t,':tnl~le

n
orne ......._ - -.....""'Ot-t~1

cl mess,':t.ge selector a.nd a.n~ument n,':t.mes "comment sta.tirll~ purpose of mess,':tl~e"

tempOt-,':tt-y '',''a.ri,':t.tde na.mes

sta.tements

Figure 9.17a

010

190
Finding Out About System Classes

Collectic Collecti, :~rD~:::

::~::::~:~::~~=I-: - - - - - - - - - - - - - - - - - - - - - - - - n (it-.3phic:: C;r.3. p hi c::

Il

ccln

tempor'3.ry ",o'ari.:.ble rla.me:;.

5t,3tement:;.

Figure 9.17b

000
you access only to the methods of the currently selected category of messages. And you can create a Message Browser by selecting the command spawn in the yellow button menu of the message-selectors subview (Figures 9.18a and 9.18b). This browser gives you access only to the method of the currently selected message. The purpose in providing so many optional views of the system classes is to support your ability to constrain the information with which you are working. You might, for example, be developing an application class and prefer to have a browser that only accesses this one class. You might be copying code from classes in one category into your new class, and thus you might find it convenient to focus your attention by having a class-category browser for this category. More signficantly, you might create an applications/programming environment in which you want your user to have access to a subset only of the system, to protect the user from dealing with too much extraneous information, or to protect the system from the user.

191 9.4 Browsing a Subset of the System

ill'-, ------------ '" -----~,-----"'"


I(C:~:CI-'g""'i:lc~t~0iln~::~,~::ii'~J~~-'~.-'~OIII~i!;~ 1in i t ia.1 ize - tOe I ~ Point a.ccessirll~
(jt",:..pr,ics-Displ,:..y
()ua.dt-a.n,~le

go'o
rio me nortr,
I~

cOloring

file out

1::111

:111

Ill~c~.r~a~.~:'r~d~c~s~-~E~d~it~_'-~-'t~"::~'JII.IJI:~~11::::JL-_-_-~-~-~-_-_-_-_-~-lIJ~~~ cla.ss

:.~:::::~:~:::~ ~ =~::~:"~:"~ ~~~.~ ~.~,~~- - --

,~e

me t t-ic de

I~ __ ~.PI)tl"ilnatILliu.t III!
send~-s

II'

implementors turn: degrees me 5 5 .:.. q e 5 "Cha.nge tr,e direction HI,:'.t tr,e t"eceh,'et- fa.ces by ,:'.n a.mol----(II-:,-v"""e--I!<I r to Hie a.n~ument, (Jegt-ees," na mo'",' e direction <'- (dit"ection + (Jegrees) \\ ::360

Figure 9.18a

010
::;ystem Collec tion 5-::; Collec tions-::il - oto:

qt~~~+~
(j r,:.. p r, ic 5 - Dis p

:,.:._~,tt~":,,,,,,,:~,~_",:;I'I,!,~::._._~.:,~4~:~A-tu~rn~:-d-e-g-r-e-e-s~~~~~~~~~~~~~~~~~~~~~~FI
r'

I.~.!.:

c,c,'

turn: de
11(:rl.:t

it .~~
i,\,

"Crla.rll~e Hie (Jit"ection tr',:'.t Hie r"ecei",Ier f,:'.ces b:,1 a.n a.mount equ,:'.1 to Hie ,:'.rgument, (Jegrees," (Jit"ection <'- (dit"ection + (Jegt"ees) \\ :]60

t 0 HI e ':.

t~.~

direc

[1:

!ll
(*~

Figure 9.18b

000

192
Finding Out About System Classes

Class Hierarchy Browser

Another interesting browser that you can spawn is a Class Hierarchy Browser. This browser gives you access to a class, its superclasses, and its subclasses. You create a class hierarchy browser by choosing the yellow button command spawn hierarchy in the class-names subview of a system browser (Figure 9.19a). The class-names menu of the new browser will consist of the names of the superclasses of the selected class, the selected class itself, and its subclasses, in hierarchical order. An example of a class hierarchy browser for Boolean, which is a subclass of Object and has two subclasses, True and False, is shown in Figure 9.19b. An example of a class hierarchy browser for Collection is shown in Figure 9.19c.

f<.ernel-CI,:O.S5 f<.ernel-r,...1 etr, f<ernel-Proce

1~~~~~~~~I~ol~gical

opera. tions trollin'g yin'g tin'g

I<.ernel- ::; Ijpp:t~l::EI!I!!!~;q- - - - - - - -Interface-Fr,


~)bject

;;ub,:I,,,,.;;;;: #E:ool

in;; t a. n c e""'" a. ri ,:0. bIe [",Ja c I':0. SS.. . . ,:0 t" i ,:0. ~) Ie [",J ,:0. me' f--,..-n.J:.'t""::....:,'.:..:.,"'....:.1'"":'r"":'e"'-:f:-,--I s: . pooIDiction.:<rie5:" CI':055 ',. . ax refs cla.55 t"ef5 cat e 'j 0 ry: ' I<.e tTl eI-'l---....:.re-r-,.:o-. e---I ri-j remo'.. e

Figure 9.19a

010

193 9.4 Browsing a Subset of the System

::; y 5t em E:ro'",'"" 5er

l!!!!:!!!!!!!!!!!~IC"j Ie ':. lop e r ':.. t ion 5


contt-ollinlj

II
(:Ibjec

I~EiBDm 1cop yinij


p t-i n tin Ij

class ...:;)bject subcl,:..ss: #E:oole,:'.n ins t


,3 n c e \/

':. ri ':.. bler",J a. rile 5:

cia ss\/a.ri,:'.[ller",Ja mes: poolDic tion ':.. t-ies: " ea.te1jot-y: 'I<ernel-I)bjeets'

Figure 9.19b

0001
I.. .. ~~d~~~~~~~~~~
,:..ceessinij

111111111' ,:.ddinijIj t est in .II


t-emo',/in1j enumera.tinq printinij con\lertinq pt-i,/,:,. te -

-----t

...:;)bjeet subela.ss: #Collection ins ta. ne e\/ ,:'.ria. bie['.Ja.mes: ., cia ss \/ ar-i.:'.ble r"J,:.. me;;: " pooIDiction,:..t-ies: " ca. t e 'jOt-y: 'Ccdlecti (In 5.":",[15 tt-,:'.ct'

Figure 9.19c

000

Finding Out About Messages and Methods

10.1 Which Methods Send a Particular Message? 10.2 Which Classes Implement a Particular Message? Renaming a Message Selector 10.3 Which Messages are Sent in a Particular Method? 10.4 Which Methods Reference a Particular Variable or Literal?

196
Finding Out About Messages and Methods

Message-set Browsers provide a way of collecting and exploring a group of related messages. The name reflects the idea that the response to the query is a set of methods. Since a method is specified by a class and a message selector, these sets are viewed as a set of class/message pairs. This kind of browser makes it possible for you to inspect and modify the methods associated with each pair. A message-set browser consists of two subviews. The top subview is a fixed list menu that indicates the names of the class/message pairs. When you choose one of the pairs, the associated method is displayed in the bottom subview. This bottom subview is a text subview in which you can edit the method and then choose the command accept to compile and store the changes. Message-set browsers are created in order to answer one of three kinds of queries about messages:

Which methods send a particular message? Which classes implement a particular message? Which messages are sent in a particular method? These queries can be made in a system browser by choosing the yellow button commands senders, implementors, or messages, respectively, in the message-selector subview. These are useful browsers to employ when you are tracking down erroneous behavior in your programs, or when you are interested in trying to find out how a :message is used or implemented in the system. For example, the combination of examining the hierarchy of a class and of browsing all implementors of a message defined in that class, helps identify where the method for that message is actually found by the interpreter during execution (in the class or in one of its subclasses or superclasses).

10.1
Which Methods Send a Particular Message?
Choosing the command senders creates a message-set browser for all methods in the entire system in which the selected message is sent. If no such methods exist, then the word Nobody appears in the System Transcript (if the transcript is a scheduled view and is not collapsed). Suppose that you wish to understand how a particular message is used in the system. You Can select the message in a class browser and read the comment. This will tell you the intended use of the message. You can then see examples of how to use the message by creating a message-set browser on all senders of the message. The next sequence of figures illustrates the steps: selecting a message in a class browser (Figure IO.la), then choosing the command senders (Figure IO.lb).

197
10,1 Which Methods Send a Particular Message?

1\_
add: newOb ject

r"jumenc-r',/1.:t.qnltu f - - - - - - - - - - - ['"jum et"j c - ['"j u r;1 b 12 t"S F,tT.:t. '",' e cJC 01112 c t io n ':. c c e s sin I~ MI$'@; t 12 s tin 9 Colle C t ion s - Un 0 r'cJ ::;12 que n c e.:t. b Ie Colli Collec t ions - ::;eque -- - - - - -- -- - r"emo,,,,'inl~ Collec t ions - Te:< t e numer'.:t. t inq Coliections-,.e.,tTay printirll~ cla.ss

!j~~(

I::1

111!1111

------------

"Inclucje ne',/,/C1bject ':..s one of tr,e recei',/er"'s elements, su , A b cl,:.. s s es of ,"-,tTa. '.,' ecJColle c tion," self sub c I':.. s s Fi e s p 0 n sib iii t y

,.e.,ns',/,/et"

ne',/,/':)bject, Trlis messal~e sr,oulcJ not be sent to inst,:'.nces of

Figure IO.la

100 000
g'
file out pr'int out spa.""'",'n

self subcl.:.ssFiesponsittility

Figure IO.lb

010

198 Finding Out About Messages and Methods

I\lumeric - r',..1.:. qni tu E:aq sortecJCounts I\J u me tOi c - [".j IJ rl~ b e toS E:a,~ s'~tt"te(jElements ,, _ t E:erl.:'. ''1'lor a ccumula teln st "i 3 to['.j.3mes:troa 'ietOse(j'._:/a. sses: E: e rl 03''1' i 0 r a. (j cJ ::; u l) c I.:. ss: C:ollections-::;e" Ul E:e r, 3. '.,. i 0 r 03.11 ,,i,.. c c e sse s To: Colle c t ion s 1'_...-4---------------------------1

~~~~~~?~,~~,~
~: :l
add: newOb "lnclucJe
ne"i'i('bj subclas self sub

Collections-

Figure IO.le

0001. . ~. ~ ... .. . .
::' :" stem Ein:t'o/ '"jumerie -r"il,~ [".J'~metOic~r\J'jl
C'l:l

.. t.m~~

.'."8".""g'--[ Collection .5sEiatj '\

'::1.:. ss['esc ription sube 103 55'~'f:oItY:::I.:. ~.5:irI5ta ne ~\i.5 d.5 bl

C:ollec'tj'onsCollec tiorls -

C,ollection ,5s::,et Collection CI.5.SS ',../itr,: Collec tion class ,,//itr,:"i/ itr,:

Colleetions- p, t addAII: aCollection Collee tions -."-.nOa} "Include ,:.11 trle elements of ,3Collection as

add: newObject
"Irlclu(je rle"i'i' n e "i'/ '::Ibjec t. subcl.5s5es
0

tOecei ', . er"5 eleroen t 5, ':. Collection,"

,,i,.. n s "i'i e r

,3Coffection clo: [:e.3ch taCollection

s e l f " e,3chJ.

self subcl,3SS

100
Figure lO.ld

r
10.2
Which Classes Implement a Particular Message?

199
10.2 Which Classes Ill1plell1ent a Particular Message

This gets the message-set browser (Figure lO.lc). Then choose one of the class/message pairs to see a method in which the message is used (Figure lO.ld).

Choosing the command implementors creates a message-set browser for all methods in the entire system which implement the selected message. If no such methods exist, then the word Nobody appears in the System Transcript (if it is scheduled and displayed on the screen). An example of finding all the implementors for the message selector add: is shown in Figures lO.2a and lO.2b.
>< .

,.1.<
> > ><

r'"j urn e n r: - r" ...l ,01. q nit u 1 f'"ju rn et'i r: - r'"jurI) bet'::: ,"-, n,s. \,'eeJ(:0 Ilee tiorr ,Ole ee 55 irrl~

.
DR
,jef'J,"-,II: file out print out 5p,j."i'in

C:: 0 II e r: t ion::: - Uno nj ::; e que n r: e.:. tJ Ie (: 0 11~1llmlin


C:ollec tiorr::: -::;eque - - - - - - - - - - - Coil ec t iorr5 - T e >: t C:ollec tion::: - ,"-,tT':'. Y r'erno ".. irrq errumer,j t in1j pr'in tirl'~

Dl'iJ,r-.iIji"',

t e 5 t i rr,~

ci,s::::::
t~,e

add: newObject
"lnclulJe ne',/,/I)L,ject ,j5 or,e of roecei',iero's elemer,ts, rre"i'i')bjeet, T~li;, me55.jl~e 5~,oulcJ riot t,e 5er,t to irl.:,t,jrl

rlie:::.:::"jqes~ mO"ie
rO_e_m_o_,i'-'_:......

.. .

"fUl' cia 55e::: of ."-, tT,j ....'e1jC: 011 ect'l orr,"

Figure lO.2a

200
Finding Out About Messages and Methods

Co II e c tior,:o-I
C:ollection':'-:~_+-

---I

Collec tion:3- Teo t Collec tion:o - /:,rr,;. y

add: newObject t:3elf ,jdd: ne . .,. . (,t<ject

',I,...

ith'='cclJt"rence:o:

add: newOb ject


"lncllJcJe ne',.. . . '= r,e',.. ,.. ,=, t,je c t, T :31Jt<cla:O:3e:o of

100
Figure lO.2b

Renaming a Message Selector

When you want to rename a message selector, you will find the commands senders and implementors very useful. Before renaming the message, you first find out if any subclasses exist that override the implementation of the message. You do this by choosing the yellow button command implementors in the message-selectors subview. This will give you a message-set browser that indicates which classes implement the message. Then you choose the yellow button command hierarchy in a class-names subview of a class browser. This will display the portion of the class hierarchy in which the selected class (the one that contains the message selector whose name you want to change) resides. If any of the subclasses of the selected class implement the message, you will have to rename them as well. In order to do the rename, first edit the original method in order to replace the message selector. Then choose the yellow button command accept. Now both the old and the new messages exist. Do the same for each subclass-you can do the editing in the message-set browser of the implementors. Second, select the message selector to be removed and then choose the yellow button command senders in the class browser message-selectors subview. This will give you a message-set browser on all methods that send messages with the old selector, unless none exist. Edit each method in which you wish to use the new message selector name. Close the message-set browser. Now choose the implementors command again, just to make certain that you found all the references

r
10.3
Which Messages are Sent in a Particular Method?

201
10.3 Which Messages are Sent in a Particular Method?

that have to be changed. If all are correctly changed, you can remove the old message in the class and in each subclass using the command remove from the yellow button menu of the message-selectors subview.

Choosing the command messages creates a menu of the selectors for each message sent in the currently selected method (Figures IO.3a and IO.3b). You can then select one of these in order to create a message-set browser on all of its implementors (Figures IO.3c and IO.3d). Notice that this menu is a list menu; it remains on the screen until you click a button. If you press the red button inside the menu area, you can select one of the menu items; when you release the button, the item is chosen. Like a pop-up menu, releasing the button outside the menu chooses no item. After clicking a button, the menu is removed from the screen.

.,.collect: aBlock
.jr-<jlJmerlt, Collect trle r-eslJltirllj \...jllJes into
t

m0 "", e r-emo,.. e
,01

'\I 1

collection tl""l.jt is like trle recei',..er-,

,<:',nsV'ier

rl e n e "/'/
collection. "

ne',,..,,..Collection

I
ne"i'i,

ne',,..,,..Collection ... self species self do: [:each tne ',. ... eollec tion

I ne"i'iCollection

.jl:Jd: (,jE:locf i,j.llJe: e,jcfJ)],

Figure IO.3a

202
Finding Out About Messages and Methods

1< > IIt;lauml.!IIIi~IJ!IIDIIDIi1~!lIII@gaI.1'lI!ulh ~1II11


C ollee t i on5- Uno n:J ::; 12 que r, e e,j b leCol1 Colleetion5-::;eque -----------Colle e t i 0 r,5 - T e \ t Coil ee t i 0 rl~' - ,.!!., n',j y el,j 55
'","i

['"j umerie -r"i'a qnit UI' - - - - - - - - - - - [",Jume r-ie -[",Jun1be r'5 ,.!!.,n,j \"12 dCo/lee tion ,j eee 55in rj

I!'iJl(;til
r:J 12 tee t: de tee t:i n,] one: do: 1 i nj 12 e t: in to: t'ejeet:

Ili~#Ii,~ii!Jjh~n~#IIi!\t'UIi1d!'
p r'in tinlj

t 12 5t irllj ,j d r:Jinq remo"iinq

...collect: aBlock " E "i ,j lu ,j t 12 ,j E: I 0 c f

,j,:Jd: f trl 12 t- 12 C 12 i', ' 12 "':. 12 112m 12 r, 1:5 ,j 5 t (rloekr:::opy: do: a r-tj u men t , Colle e t t r, 12 r,e"i'i ~ re:.ultir,rj 'i,jlue5 into ,j colleetirxr tr"jt 15 like the reeei'iet, 5peeie5 the r, e,,..,,' "i,jlue: coil e e t i 0 r" itrl 12 ,j c h
0

rr 12 'i'''' C 0 ii e c t i 0 rl

I I
r, e

r, e 'i'i Coil e e t i 0 r, ..... 5elf 5pee ie 5 r, e "i'i 5elf do: [: e ,j c rl


t

i'i Coil e c t i 0 r,

a r:J I:J: (a E: I 0 c f ',,' ,j lu e: e ,j c r,:, J.

rr 12 "i'iCO lie e t i r:r r,

Figure lO.3b

000
[",Jumer"ic -r",,'''j qnit u,- - - - - - - - - - - --

I lI.mD.lDIlII&1!II.'lnm.l1lIIIA!i-I1.D"iIi" 11 ta.ddinlj-q e 5tin C ollee ti on5 -Un or,:J ::,eqljeneeableColl


ColleetiorI5-::,eque -----------Colle e t i 0 r, 5- T 12 i t C ollee ti on5- ,.!!.,tT,j y el,j55

j r",Jumer"ie-r\Jun~ber5 ,.!!.,tTa.\le,:JColleetion ,jeee55in r

RDIA!
detect: detee t:iff",Jone: do: in j 12 e t: ir, to: rejee t:

1It-~*lii~e!Jjh~n~#aiEii'u'i1i1!'1
pt'in tin1j

remo"iinq

,...collect: aBlock "E"i,jlu,jte ,jE:loef "i'iitrl e,j,er, of tr,e t'eeei''i'et''5 element5 ,j5 t blocf::.CoF Y: do: ,jrrjumerl1:. Collect tr,e ne "/'''' t-e5ultiri lj ',',jIUe5 into ,j collection trl,jt i5 like tr,e recei"ier-, 5pecie5 t r, 12 r, 12 """i "i,jlue: eollectiorl, "

r,e "/'''' Colle e t ion

rle"i,/Colleetior, ..... 5elf 5peeie5 rre "i'i, :. elf I:J 0: [: e ,j chi rl e "I " C 0 ii e e t i 0 rr ,j d d: (,j E; ,0 e k "/ ,j ,u e: e ,j e h:1 ] '
t r, e ', . , . Colle e t ion

Figure lO.3e

100

203 10.3 Which Messages are Sent in a Particular Method?

[\juril e t-ic - r",.., ,':t qnit u,. ,"-,tT.':ty' e I)C olle c t io n ,':t d I): r'.jumer-ic-r'.Jun~l)et-:=: E:.':tq ,':tdd: OO.~t~6$'H~"~$~r Coli e c t ion ,j I) I): C: 0118Ct j 1:lr15 - Uno t'd Die t i on ,':try ,j d I): Collec t ion:=: -::;eque Fil eDir-e c tory .j d,): Collection:=:... Colleetion:=:-.'

~I ~

collect: aBlo "E,,...':t!u,':tt


,jn~urilent,
f

re:=:ultinl~

collectio
I

ne',,..,,..Co

ne',,..,,..Coll :=:el f 1)0: tr,e',,..,,..Col

Figure IO.3d

000
The messages command is useful in trying to understand how a method actually works. It supports your ability to track down comments about the methods for each of the messages sent.
Note that in the examples, the message blockCopy: appears as one of the messages in the selected method. This message is inserted by the compiler wh,rnever a block is used in a method.

Practice Investigating Messages Using the system browser, choose class category Collections-Abstract (class-categories subview), choose class Collection (class-names subview), and, in the class-names subview, choose the yellow button command hierarchy. The selections and hierarchy are shown in Figure lOA. Collection is the top of a large hierarchy of data structures for the system. It is an abstract class, meaning no instances of it should be created. It serves the purpose of defining a common protocol for several similar classes, such as Set and
OrderedCollection.

Choose message category adding and then message selector add:. The method is defined as self subclassResponsibility. This means that subclasses of Collection for which instances can be created must reimplement the method in order to complete the description of the class.

204
Finding Out About Messages and Methods

'_Imma

,;:.cce::::::inq t e::: tin Ij ,;:'I:Jdinlj rem 0 \!ir"j en u me tOO,;:, tin Ij print ir, q --c-I,;:.-:::-:::-I cor,\!er-tirI1j
1

,= 0 II e c t i 0 r, (:'
E: ':. Ij (' con t e r, to' ) h!1,:. p pe I:JColle c t io r, (' ,:Jo m':. i r,' . m,;:. p' )
',:, equenc e ,;:.\:Ile'=,ollec t lorl (',I ii, t-t-,;:, Y e I:J Coil e c ti,:, r,

Figure 10.4

100 000

,iI,rr,;:.y () E::de,iI,rray (:'

Co r,-, pile l:Jh!1 e t r, 01:J () Fiurl,iI,tT,;:'y ('t-un:::' '\/,;:.Iue::.' :'

1<

"'~~~~~~~rii.,:.:-\.I~t '~:'Fo+il~e,:.;.,iI~, 1:J.;.t.':J~reii,.;;:::"o;' :::-R,iI':,:,.:n~-aH..~!....'~':J,:,:.i " r~e~c~tC~'..:;"I"",!,'....,.,.""'!"""!''''''!''''''!''''''!''''''!'~~...,.,.l. r

><1

Suppose you implemented the collection data structures and you want to find out whether all the subclasses of Collection are complete with respect to the message add:. One way to make this determination is to find all the classes that implement the message add: and see if all the subclasses of Collection are in the list. Some will not be, for example, class SequenceableCollection. This subclass is itself abstract. You can find where add: is implemented by choosing in the message-selectors subview the yellow button command implementors. The browser thus created is a message-set browser giving you a list of the classes in which the message add: is implemented. If you choose an item from this list, you can see the actual implementation. By selecting Collection in the browser and choosing the command hierarchy, you can determine all the subclasses of Collection to be compared to those referred to in the message-set browser. Find the message addAIIFirst: in class OrderedCollection. The class is categorized under Collections-Sequenceable; the message is categorized under adding. In the message-selectors subview, choose the yellow button command senders (Figure IO.5a). Watch the System Transcript; the word Nobody will appear (Figure IO.5b). This indicates that no objects in the system send the message; it was included for protocol completeness. (Recall that if no System Transcript appears on your screen, so that you can not try this example, you can create one by choosing the System Menu command system transcript.)

-,
205
10.3 Which Messages are Sent in a Particular Method?

,jrl')n:Jer"edCollectiorl ,"e',:'er:::eDo: [:e,jCr,


t ,01 n '='n:J e r-e,:JC olle c t i 0 r,

:::elf ,jddFir":::t: e,jcrl].

Figure lO.5a

010,,',','1
::.
,

r",lobo,]:.'

I , <.'~.,.,.."!""'~ Collection:::-Te:,

I < < <I Collectiorl:::-::,tr-e MlWItOlJ'i'Jirp'G I Collection:::-,"-,tT,: ::;or-tedcollectior 1<


.<> >.'..>I .... addAllfirst: anOrderedCollection
","-, ,:J ,:J e ,01 c h e Ie rn en t c,f
0

LinkedLi:::t r',:,1app.:.dcoll.:.cti,

coP:.'in9 enurner,j tin pri,:"jte

'?'!~'f''''!'-'t;iii1 ,:" IlL,:, t,


dd,~, c,

rerno\'in,~

,jddFir:::t: ,j,:J,:JL,j :::t:


,~r"o',:,,:,

. > < 1 Collection:::-::,up -----------. > < I']r,3prlic:::-Primiti cl,j::::::

.~"

f a r, C' n:J er"e ,:JC 0 II ec t ion

,01

t Hie b e,~inrl in9

Hie recei",1er", ,"-,r,::: ':",1er ,jTIC'rder-edC:ollectior,,"

,jr,'='r-,:Jered'=:ollectior, r"e'"er":::e[',:,: [:e,jcrl


t ,01 n C' rd e re d ,=: 0 II e c t i 0 r,

:::elf ,jd,:JFir":::t: e,jch],

Figure lO.5b

000,,,,,,1

206
Finding Out About Messages and Methods

10.4
Which Methods Reference a Particular Variable or Literal?
A message-set browser can also be obtained by sending one of several available messages to the object Smalltalk, an instance of SystemDictionary. All of the expressions listed in this section are present as templates in the System Workspace, so you can find them, edit the arguments, and evaluate the expressions.
Smalltalk browseAIICallsOn:

# keywordSymbol

(where the keywordSymbol is a single keyword such as at, put, +, or up) will create a message-set browser for all messages whose methods send a message with keyword keywordSymbol. The result of evaluating
Smalltalk browseAIICallsOn: #add:

is shown in Figure 10.6.

"Include .311 Hie elerllent::: of .3Collection a.::: trle r"ec ej.. er'::: el e ment:::. ."'.n::: . .. . e r" 3 C o\\ect i on."

.:.Collection do: [:e.3crl


t':'.':::ollec tiorJ

:::elf

e.:.chJ.

100,

Figure 10.6

207
10.4 Which Methods Reference a Particular Variable or Literal?

The expression
Smalltalk browseAIICallsOn: #firstKeywordSymbol and: #secondKeywordSymbol

creates a message-set browser for all messages in the system whose methods send a message with both keywords firstKeywordSymbol and secondKeywordSymbol. For example, the result of evaluating
Smalltalk browseAIICallsOn: #at: and: #at:put:

is shown in Figure 10.7. The messages browseAIICallsOn: and browseAIICallsOn:and: can be sent to individual classes to obtain a message-set browser for methods in the class and its subclasses.

<

......

1< < > >

> I at: anlndex put: anObject


r (j 0 m ,Of i r,
,Of

t: (m ,Of p

,Of

t:

,Of

nl n (j eO)

pIj t:

,Of

n (I tr .i e r: t

Figure 10.7

100 000. .. .

> .. ><1.

In order to obtain a message-set browser that provides access to all methods in the system that reference a particular literal, aSymbol, (see Chapter 5 for the definitions of syntactic parts), evaluate an expression of the form
Smalltalk browseAIICallsOn: (aSystemDictionary associationAt: #aSymbol)

208
Finding Out About Messages and Methods

For example, the result of evaluating


Smalltalk browseAIICallsOn: (Smalltalk associationAt # Transcript)

is shown in Figure 10.8, and the result of evaluating


Smalltalk browseAIICallsOn: (TextConstants associationAt: #Centered)

is shown in Figure 10.9. An additional way to obtain all the implementors of a message is to evaluate an expression of the form
Smalltalk browseAlllmplementorsOf: #messageSelector

For example, the result of evaluating


Smalltalk browseAlllmplementorsOf: # atput:

is shown in Figure 10.10. An expression of the form


Smalltalk browseAIISelect: aBlockWithOneArgument

creates a message-set browser on all methods such that when the block is evaluated with the method as its argument, the result is true. As an example, you can try
Smalltalk browseAIISelect: [ :meth I meth numLiterals > 40]

creates a message-set browser showing methods that have more than 40 literals (Figure 10.11). Please note that the Smalltalk-80 system restricts methods to have no more than 64 literals.

209
10.4 Which Methods Reference a Particular Variable or Literal?

tileln
"C;;u.:u"a.ntee file::;tt"e.:'.m is t-ea.dClnly befot"e fileln for efficienc y ,:'.nd to elimin.:. te remote srlar"irll~ c onflic t.::"

iiA;;;;;' t-eft"esrl; cr; u; srlo',.... : 'Filirll~ in


crt,:.b; sri 0""""': self na.me; cr, self t-e,:.dC'nly. t super fileln

ft"om:';

Figure 10.8

100[..: . . . 000

/1

...........................................

F'a. r.:. 9r,:.. prl Ieft r,.. l.:.. r'='inFo t-Di spl.:. yFot-Li n e: ------------

I> > < > I centered


"::,et trle .:.liWlment for trle style . .,.. itrl . ... rllcrl trle recei'.. er displ,:. ys it::. te:'.t so th.:. t te.o:t I':: c entet"eel in the composition t-ec t.:. rll~le," te, t::;tyle .:..Iil~nment:

Ma.awl.

Figure 10.9

100 000

210 Finding Out About Messages and Methods

........................... ...

_
I

E;.j 9 01 t:put: ['Ietionary .:.t:put: FiljOlF'a.1je at:put:

<.

<.<.>, I

at: key put: value


"::,et trJe ',/.:.Iue .jt ke)' to be '/.jlue."

I imJe
inde
(~.elf
+-

.oelf findf.e.',n)r"r".Jil: key.

b,:,slc.c..t, in,:Je.)

==

nil

ifTt"lJe:
[t.:'/Iy' .,. 1:.:.lIy +1 .

Figure 10,10

100 000
. .

.oelf b.j5ie.c..t: 'mde put: fey].


......01 IIJ e .c.. tT.3 \.' .:t t: in I:J e.. put: . . . .:t IIJ e .

.:.elf flJllCrlecf.

r '/.:.Iue

,"

.'."

'" , , '.'."

'

E;i tE ,:Jit 0 t- cl.3 55 blJilcJColo d',/' enu: ': olor'=: oun t: E . PI 01 i n e r- e . p I .01 irl'=: rl 01 r-: Form cl.:. 55 5ereerl'='ut For"mEcJitor C!.:'55 .oetfe:"t;, o.:./"cJ/'./lap ~

......

......................... ,,>1
..

. .

"

."........ , >

...

.'.

>'1

y' ... .. /
......

<

.
.
.

"

r---....". . .
Figure 10.11

.'

'.'...
.

000

......" > . , . > ' , >, " " , " ,

..

"

..7 .. >

r
211
10.4 Which Methods Reference a Particular Variable or Literal?

The yellow button menu items in the class-names subview of a system browser also support making inquiries about variable references. If you choose either inst var refs or class var refs (Figure IO.12a), a menu of the instance or class variables of the class is displayed (Figure lO.12b). If you choose one of the variables, a message-set browser is created for each method in the class or its subclasses that references the variable (Figure lO.12c). If you choose the class-names subview yellow button command class refs (Figure IO.13a), a message-set browser for all methods in the system that reference the class is created (Figure IO.13b).

CollectionsCollections-: Collections-: '::::ollec tiorJs-:

:~;::~~:~:::~~ = ~',t;~""":1""'''_1&1. . . . . .
::ieqlJenc e ':. b Ie Coil e c t ion f - - - - - - - - I # (, nJ etOe cJ Coil ec t i0 rl ins t,:'.nce\i .:.tOiable[",J.:. c I':.. ss \i ':.. t-i a bIe r',J ':.. me slo..._t_Oe_rf...;1 _I e ___ C \I... pooIDictiorl.:.roies: " ca te'jory: ' Collee tion s-:::eqlJence.:.ble'

Figure lO.12a

OIOI,..

mrl

212 Finding Out About Messages and Methods

,:.cce33in'j copyin'j 1_ _iRl_I'I'.OlII!nI_~_1 ':. d din I~ remo\" irll~ enu mer,:' t irl'j pri . . . ,:.te cl,:. 33: #(lnJeredCollec tiorl I,:,,:, t Ir,de, ' c I':. .: .: ','" ':. t- i ,j b Ie r\J ,j me.:: " pooIDicticlnar-ie.:: " c ':. t e I~O t'Y' ' ,=: 1:,lle c ti or,.:, -::, e quenc e ,01 ble'

000:::::::::
Figure lO.12b

System Br erv.:t.1

.M@_'.M"mE
:::;equence. insqn cl,:.ss". poolDi c.:tte'jl

I ineie, I
inde, .... self find: old(lb iect,

100
Figure lO.12c

in cJ e, = ifTrue: [t:3elf errorFir'3t(I[,jeetJ ifF,:'.lse: [t3elf b,:,slc,iI.t: incie, :.:.<:.: ::<:':: .<'):::

'M.5

1J

::. O 00

",: :':' :::: :::::<:::

>:1

",:.< .::: :::::.::::

213 10.4 Which Methods Reference a Particular Variable or Literal?

C; 0 II E! c t ion sCollE!ctions-: r.:::ollE!ctior/s-; CollE!ctions-;

I-l=---,-.------=-~~....:::..I E! S sin 9

yin9 in9
o'./;r,,~

:~;:::~:~:;:~~ =~',t;i:,,4-",,*~. . ._:-....---l:.--=-':"':"':"":"""::-"'_-I ~~I ~~ a tin oj

~:: e q

Ij e nee a. b Ie Coil

e c t ion

i1I1i1Ii.i-;#~())~nd:J ~re~r;:J'C:::~o~lI~e~c~t~ic~'r~1-----1!11 ;:. ...


ten,j.me r'e rn e

ins tao nce \/.jria.bler',Ja. c I,j:, s \/.j t-i.j b I e r",J ,j rn e ~::lo" poolDic tion a.t-i e:,:"

',.,'

s tln,:Je> '

, - - - - - - - .. .

c ,j t e9or-y: 'Collect io ns - ::; equ ence,j.ble'

Figure lO.13a

010
U~~~~~~~~f
COIIE!ctio CollE!ctio Collectio

tm

E: el'"l.j. ',/io r ,01.11 D yn '01. mi c ::; Ij pe n:: I,01. sse s E: e 1'"1 ,j. ' 1'1 0 t ,01 Illn s t ,01 n c e s

1 N,'+"'tMiit4'tgji,i

:~:;:::~:~:::~ ~
5equencea.b/e inst,j.nce\/ class""/,jri, poolDictio

E:el'"l.:t."/lor a.ii:":',ubc:i,01 sses E:e 1'"1 ,j "/ i 0 r ,j II ::; u perc I ,j sse s

aillnstVarNarnes
" ."-, rl s ',,1,/ e r ,01 n ,"-.n- ,j y 0 f t rl e rl ,j m e s 0 f trl e t-ecei',/et-'s inst,jnce
,,/,jt-iable~,,"

! n,j.mes
njrnes
<'-

\ ne',/,/,

c ,j te I~ Ot"y:

self ac c umula t elns t \/ .j.t"f'"ja.mes: n,jm e s


t t',j '/erse,:Jel ,01 sse s: ::; e t n e ',/",',

tr/a.mes

Figure lO,13b

000

PART THREE
How to Modify Existing Classes and Create New Classes

In Part Two, you were introduced to four standard system views: inspectors, browsers, notifiers, and debuggers. These views are used to find out about the objects that exist in the Smalltalk-80 programming environment. You can program by creating instances of existing classes and sending messages to these instances. If the capabilities of the existing classes are insufficient for accomplishing your programming tasks, you will have to modify one or more of the existing classes, or you will have to create new classes. The purpose of Part Three is to show you how to use the system browser for modifying existing classes and for creating new classes. The examples given demonstrate how inspectors can support you in testing the new classes that you add to the system. The organization of classes (class categories) and messages (message protocols) act as a form of documentation. Thus it is important to understand the system class organizations and how to create organizations for your applications classes. As in Part Two, we assume that the system sources are accessible to you. Without them, you will be able to access the methods. But you will not be able to access the class or method comments, nor the actual method argument names.

Modifying Existing Class Descriptions

11.1 Modifying Existing Methods 11.2 Modifying Protocols 11.3 Adding New Methods 11.4 Modifying Class Comments

218 Modifying Existing Class Descriptions

Start by making certain that you have a system browser open on the display screen. If one does not already exist, choose the System Menu command browser. If one does exist, make it the active view. A newly created browser i~ shown in Figure 11.1.

['"j u rn e t-j c - r'"", 03 q rI i t u (J r",Jurn et-;c - r'"j un~tre to::; Colle c ti r1::; - ,":",t, ::;tr, Collecti rI5-UrlOr(J Collecti r1::;-::ieque Coil e c t i rl ::; - T eo t Collecti r15-AtT'3Y'-irl-::;r-_'3-r1-c-e

Figure 11.1

In order to learn how to make a change to the system, you will be asked to follow several examples in which you change existing methods and add new methods to existing classes. The three examples provided here use and modify the example of creating a geometric design with class Pen, add the ability to class Array to create a bar chart, a graphical display of an array of elements, and add the ability to class SequenceableCollection to compute all possible combinations of the elements of a collection.

11.1
Modifying Existing Methods
Exercise 1: Use class Pen to create geometric designs. For the first example, you have to find the existing method that you will modify. Choose class category Graphics-Primitives, class Pen, browser menu item class, message category examples, and message selector example. The method associated with the message example is shown in

219
11.1 Modifying Existing Methods

the text subview of the browser. The result of these selections is shown in Figure 11.2a. Notice that at the end of the method is a comment (text enclosed in double quotes). To try this example use of class Pen, select the comment

B1D.."Wiiiamttam Po in ijl::.~-I::m; I iAiiiJUi Iil.e.t.... -----------1 . II',:::110gll~eie~t~iel'r-Di::.plu~Fd'Fy'cm'j1~I~iii!#i~;~ llli~nI5mtm':.~n~cl: i:,.:.t~ie.'r.'111iAiiiJ.mDllii1l' n l:.:ir-,:.. prlie::. a. ')u,:'.dra.
t
rll~le

Collee tion::. - ::;trea.

:~ ;::: ~: ~: ::~ ~ =~,::~:-t:I~~


Gr-,:.. pr,ie::. - Edi tor::.
Gr,:..p rlie::. - Clo ek::.

~i~~:~ ~. ~'~~
in~. t.:'.nee
I~t-,:.y

...example
"Dr-,:.',,,,,,,,::, ':. ::.pir-,:.I in ".. ,.. itrl ':. pen trl,:.t i::. 4 pi,el::. . . .,.. ie3e,"

I tlie I tl i ': .... Pe r, r, e ',. .,.. , t,ic m,:.::.k: Form I~r,:..y, bic eJeT,:.uit[",Jib: 4, tlie eombin,:.tior,F;ule: Form uneJer, 1 to: 50 1)0: [:i I bie I~O: i+4, t,ie tUtTI: :::9J "Per, e:O:,:'.mple"

Figure 11.2a

Collee tion::.-::; ttea. --- --- - -- --t !i'm::iOg".... F IiiiilinUiiiarmDml F'o in t iAiiiJO' Gr,:.. p rile::. - D i::. pi,:.. y I)U ,:'.') t-,:,. n,~ Ie Gta.pr,ie::. - p,:' trl::' F;ee t ,:'.n,~ Ie Gr,:.. phie::: - \/ie',.. ,.. ::: - - - - - - - - - --Gr,:,. pr, ie::. - Edit or::. Gt-,:..pr,ie::. - C1oc k::. in::.t ,:'.nee

i:'I::.ilolnq::.~-~::I;UQF~'I 'cD'1~liii~#~,!

II~iinl::.gtl':.nnBeie.e.re.a tli.o.n.11iAiiiJ l - 11 . .mDllii1l -----------

.....
:~~;

example
"D r,:. ',,,,,,,,::. ':. ::. pi r,:'.1 i n
I~ t-,:,.

I
Figure 11.2b

Y ', , , , i t

r, a

pen tt"1,H i::. 4 pi>: alpin ~," undo

,wa,4 aMil"

bie I bie .... F'erl ne',.. ,.. , bic m,:'.::.k: Form I~r,:..y, bie ,)ef,:'ljltr",Jib: 4, bie eombir,,:'.tionFiule: For-m under-, 1 to: 50 do: [:i I bi,: I~O: i+4, bie tUtTI: :::9J

copy
cut pa.::.te
,~,tint

'It

,:..eeept e,:'.neel fotm,:'.t ::.pa.'",'",'n e::<pi,:'.in

010

220
Modifying Existing Class Descriptions

text (do not select the double quotes), and then choose the yellow button command do it (Figure 11.2b). A geometric design appears on the screen (Figure 11.2c).

example "Dr'3 "/'/5 a

I bic I
~)ic

... Pen ne',/,/,

bic mask: Form l~t,jY, bk (.lef,jlJlt['"jib: 4,


t';c comt,;n,j t;onF,u!e:

1 to: 50

(jo:

[:i

I bic

"'W"W;;;;ii5"
Figure 11.2c

OOOI~"""""""''''''''''''''''''''''''''''''''''''''''''''''~'''''''''''''''~1
To create this design, you sent the class Pen the message example. The method associated with example was found in the class protocol for Pen. The first statement of the method cre~tes an instance of Pen, and assigns it to the temporary variable bic. Instances of class Pen respond to messages to change their line drawing characteristics. In particular,
mask: Form gray
The halftone mask that determines "color" of the drawing ink. Other masks include Form darkGray, Form IightGray, and Form black. The shape of the source form or "brush" is a 4 x 4 square. Squares of different sizes can be used by specifying different integers as the message argument. The mode for mixing the bits of the source and destination Forms can be varied, either Form under, Form over, Form reverse, or Form erase, can be used as the message argument.

defaultNib: 4

combinationRule: Form under

The second, third, and fourth statements of the example method send these messages in order to set the characteristics of bic. The fifth message is an iteration in which the Pen travels some distance (go: i * 4) and changes orientation (turn: 89); as the Pen travels, it paints a line using its current brush, mask, and combination rule.

r
I
i

221
11.1 Modifying Existing Methods

You can now experiment with variations of the example design. First, erase the geometric design that was the side effect of the previous example by choosing the System Menu command restore display. In the Pen method example, change the mask. Select the message gray sent to the Form (the second statement in the method) as shown in Figure II.3a; then type the new message darkGray. The typing change is shown in Figure I1.3b. Change the size of the square brush. Select the message argument, 4, as shown in Figure 11.3c. Type the new argument, 2; the result is shown in Figure II.3d. Now choose the yellow button command accept (Figure I1.3d). The message accept in this context means ((compile the code." Compilation means translate the Smalltalk-80 statements into machine executable form (i.e., create an instance of CompiledMethod). The changed method is automatically loaded into the running system, ready for you to try. Select the expression Pen example (as you did earlier), and then choose the yellow button command do it. The modified geometric design shows on the screen (Figure 11.4). You can keep experimenting in this way. Instead of using the message defaultNib: to specify the brush shape, try the message sourceForm:. The message argument is an instance of class Form. (You can try using one of the cursors that exist, such as Cursor normal or Cursor crossHair). Also, try changing the mode of mixing bits to Form reverse when you use different Source Forms, otherwise the results will be mostly black.

I.

\IIIC~:C~dlne~e~tlEoIn::~~-~::D;~p.p'm:III~Itt-~9~'!I II~i.s1t,:..rgj'c~: l'.::tii"ei03~ti.o.nI11i!'&1_1_1_D!_'!IItl 1_1_1_1_ 11 u n __ LUADM:mnnP F'oin t Wiiii41e


(~t",3.prlie s - D ispl.:.. y Cir.:..prde s-F',:. trlS Cir.:.. prdcs-./ie'/'/5 Cora. phie:. -Edit ors ('r03.pr,;e:.-C:loeks
CI.U .:.. dr.:.. n'jle

Colleetions-::Hn:!03. ------------

F,ee t ,:.rll~le - -- - -- - - - --Inst03.nee


4

example
"Dt",:.'"",/:, ':.

spir,:..1 in qr,:.y ',,..,,..itt"i ':. pen tt"i,:.t is

pi,els ',,..,,..i,:Je,"

I tde ,
tlic tdc l)ie td e ... F'en ne',,..,,.., m,:..:.k: Form def03ultr",J;b: 4, , com bin 03 t ion F,u Ie: Fo rom un de to, 1 to: "=,0 do: [:i I \:Ik I~O: i+4, I)IC turn: :::9J "F'en e>:.03.mple"

!D

Figure 1l.3a

100

222
Modifying Existing Class Descriptions

Collec tion::: - ::;tre a.

..............IIICI: cm' UIIH"Mi,rmnmj C=ira prlic :::-Di:::pl.:.. y Gra prli c::: -Pa tr,::: C:it-apr,ic::: - \""ie',.. ,.. ::: l::ir,:..prdc::: - EI)i tor::: Gra phic:::- Clock:::

llli1Il i Cld~1e~cm:t~i&oln~:::ii-~::;Iu~~~'~I' 1~li!~'~I~iinl:::ltlannDcle.c.rie. r.,.llliWiimilli 111 :..t~icl' -----------F'o i n t i&iiiim


I)U a. cjran,~le Fie et ':. rll~le - - - - - - - - - - -in::: t ':.. nc e
Ijr':'y ...... itrl
,j

I
Figure 11.3b

example

"Dr,:.'.. .. ::: ':. :::pir.:.1 in

pen tr"H i::: 4 pi 121::: ,. ... ide,"

I bie I
tdc ... F'erl r,e'.. .'. . , tdc m,3:::k: Form cj,3t-f']r,3"", bie l)ef.:.u!tr".Jib: 4. ~ 'I>, t,i,: combinationFiule: FOt-m IJrII)er, 1 to: ,sCI 1)0: [:i I bic I~O: i+4. bie tUtTI: ;:;9J "F'en e>,3mple"

I.I.

III~C~:Cld~1emC~:t~_iEolni:::Q-~::DiuQl=~'~I'cm'jI~I~#@~;~I~iln.:::gti:,nnDcme.clrieialic'r.'llliWiitllEliDDu!i 111 .t iiiill'l"Marmom Po in t iEidgq l -----------Cir.:.. phic::: - Di :::pl.:.. y

Collection:::-::iuea

- - -- -- - -- ---

:~ ::::~:~:::~ ~ =~::r: ~:,.;~


C=ir.:..pr,ic::: -E dit Ot'::: Cit-,:'. pr,ic:::- Clock:::
example

(iua. dt-a n'jle

~i~~:~ ~~I~~
in :::ta.nce in
l~r.3Y

"Dr,:.'.. .. :::

,j

:::~dt-.31

'. ... itrl a pen trl,:'.t I::: 4 piel::: ". . . ide,"

I bic I
bie ... F'erl ne""""" t,ic m,3:::k: Form 1).3rkGr,3Y, tdc ')ef.3ultr".Jib: tlie combin'3tiorlf'Jle: Fot'm Un,)er', 1 to: E,I] ,)0: [:i I tlie 'jo: i+4. bie tUtTi: ;:;9J "Perl e>'3mple"

II.

Figure 11.3c

100

223
11.1 Modifying Existing Methods

1:111

I: 1IIIIIIIC~:lomll~eUc~:t~ilolnQs~-~::~;'uJ~p.PmcD'11~'!*!4~'~ III~ir.1~I:;tl"'i:<'p'n~c=:e.c.:rl-el,:<,.t~icl'r.,llliAiiiiamlil!oDI 11 _'Pbl,IN.,mn. F'c, in t .AmBo -----------(,rapt-llcs-Dlsplay ,jr-,=t nql., , F~'e ,;t a~I'~ Ie g~mi~: =~!f:~;5

Collections-:=;tr-e,:<

-- - --- - -----

-----------inst,:<.nce
I~r-,:<y

"~"u,=t

Gr,:<.pt-lics-Clocf::.s

example "Dr,:<,.. .. s ':< spira.1 in

,:<,~a.in

',,,,,,Iitt-I a pen tt-Ia.t is 4 pi>el

undo
cop~,!"

bic I b ic .... Pe nne ''1\1 , bic m,:<.sf::.: Fonn d,:<t-f::.C=ir,:<.y, bic def,:<ultr\Jib:

cut -',:<.ste do It pr-int it ca. :121 for-m,:<.t sp,:<,""""'n e::< -,I,:<.in

2..;
I bie
Ijo: i+4, bie tUtTi: :::9J

td c com bin ':<. t ion F; uI12: Fo tOm un d 12 to,


1 to: 50 Ijo: [:i "Pen e>,:<.mple"

Figure 11.3d

010

Figure 11.4

000

224
Modifying Existing Class Descriptions

11.2
Modifying Protocols
Exercise 2: Modify class Array to display bar charts. The next example demonstrates a way in which you can get another graphical effect on the screen. It was chosen primarily to introduce the mechanisms for adding a new method to an existing class, not to be a typical example of how to handle graphical presentation. There are a number of interesting ways to handle graphical presentation of information, such as views and menus. The approach taken in creating the Smalltalk-80 system user interface is introduced in Chapter 15. In this example, you will add one method to class Array. The result of the method is to create a bar-chart representation of the elements of an Array whose elements are numeric. As an argument to the message to Array, you specify the labels that will appear along the horizontal axis of the bar chart, one label for each element. To add a method to an existing class, you can use a system browser. Choose the class category Collections-Arrayed. Choose the class name Array. Make certain the menu item instance is selected. Your browser should resemble the one shown in Figure 11.5. Now you need to choose a message category. Let's assume the appropriate message category does not exist. You must create a new category.

(~;.; gjBJI~!!~~

..

Collection;;-:::tre,:. C ollec t ion;;- ::;uppo

comp,jrin'j con"/ ertin 9 pri rl t in 'j

l]rE'. phic5 -Primiti "/e

I]t-,jpr,ic;;- Di;;pl,j y C raphi c s -p,j HI S .. ::\::: ..."" n,j y eej(: ollect ion "/ ,jriat,le''::;ut,c\ ,j 55', # ,"-,tT,j >,' ins t ,jnc e\/ ,j ri,j ble [",J ':> mes: " cl,:.;;;; \/ ':. ri,:. blef",J,:'.me;;; " pooIDictior"jries: " c,:.. te90t-y:'Col/ec tion s- ,"",tT,:' ye,j'

Figure 11.5

225
11.2 Modifying Protocols

There are two ways to modify the message protocol of a class: 1. Use the commands in the yellow button menu of the messagecategory subview. 2. Choose the yellow button command protocols in the class-names subview. The first approach is the preferred one; the second, which involves direct editing of a textual presentation of all the categories, is available in case you have to do a large reorganization. An explanation of each follows. With the cursor in the message-category subview, but no category selected, press the yellow button. The menu has one item, add protocol (Figure 11.6a). Choose it. A prompter appears (Figure 11.6b) in which you type the new protocol name. After typing the name (graphical views is used in Figure 11.6c, although misspelled), choose the yellow button command accept or type the ~~carriage return" key on the keyboard. The new name is added to the message-category subview menu (Figure 11.6d). When you choose add protocol, the new protocol name is appended to the end of the message-category subview menu, and is selected. If a category was already selected when you invoked the add protocol command, then the new category is inserted before this selected one.

eo mp':.. t"i n,~ e on',/et"tin,~ COllections - ::;tre.:.. Collee t ion::: - ::;upp 0 ':.:ira p rl ie::: - F't"i mit i"", e Gr".;, p hie::: - D i::: pl.:.. y Gra.prlics -P.:.. trl s
pt"intin,~

i. rr,:.. y ed C: 011 e e ti 0n

"/ .:.. t"i .:.. ble ::; ub c1.:.::::::: #" ."-, rt-,:.. y ins tao nee\iat"ja. bler.Ja mes: " c I.:.. s::: \/.:. ri.:.. ble ['..J.:.. me:::: " pooIDiction,:'.r-ie:::: " c:.. t e'jor-y: 'Collec ti ons - ,"-,rr.:.. ~.I eel'

Figure 11.6a

010

226
Modifying Existing Class Descriptions

1: I:

1jl~~rm.B.~~~~~!!~~ 1eomp,;:..rinl~ eon\IQrtirll~


C:ollee tion::;- :::;tre,':<. c: ollee t ion;. - :::; uppo c. t-':' p r,i e 5- Pt-i mit i"", e (~t-,;:' prlie::; - D i5pi,;:. y Gr.:. prli e 5-p,;:' trl::; l,rr.:.. yedCol1 ee t ion '",',;:, ri,;:. ble:::;ube I,;:, 55: irl5 t ,;:.n ee \,1.:. t-j,;:..t,lef",J.:.me 5: " el,;:'55\,1,;:.ri,;:.t,ler",J,;:.me5: " pooIDietion.:.rie5: " e.:. t el~ory: 'C olle e t'l on 5,I:., t-r,;:,.

pt'in tinl~

n,:..me

ye1j'

Figure 11.6b

000
1 ,,~DE&~mIiDl~~~~!!!~ r
Collee tion 5-:::;tre.:. Collee t ion 5- :::;uppo Gr,;:. prlie 5- Primit i',,1e ("r-,:. prlie;. -Di 5pl,;:. y Gr,:.. prlie;:, - F',,:<. tt"i 5 eomp.:. rin9 c on ',,I er-tin I~ printin 9
';:'I~,:..jn

undo

copy
Erltet rle',,1',1 pr-otol tr,er, ,;:.eeept or Ij-J--.,.--...--t
I~r,;:. pic .:..1
',,I

l,rt-':'. y e cjCollee tion ',,.. ,;:. t-i.:.ble:::;ubel.:. 55: /1 ,I:.,t-t in5 t,;:.ne e"",1 ,;:.t-i ,;:.ble[,.j ,;:. me ::': " eI.:. 55"",1 .;:. ri.;:. b Ier",J.:. r,-, e 5: " pOI:IIDietion,;:.rie;:,: " e ,;:. t e I~ ory: "::::ollec tion 5- ,":",rr-,;:. yed'

ie',,..,,1::;..

Figure 11.6c

0101... ~~~~~~~1

r
I

227
11.2 Modifying Protocols

Collec tion:::-::itrea. Coil ect i on::: - ::iUPPO


(jt".~prlic;.

I ~~~~:::-~ti
~.~~

- F't"lml t(..,. e

if!

l]r.3. phic::: -Di:::pl,:.. Y Cir",:..pt-Jic:::-P.3 ttL:'


lne::::::.3.I~e

_"".'M
printing -

------------

:::elector" a.nd

,3.n~ument

na.mes

"comment :::tatin9 purpo:::e of me::::::,3.I~e"

tempor,:.r-y ",',:.r"i,:.ble n,:.me:::

:::t,:.. tement:::

Figure 11.6d

000
When a category is selected, the yellow button menu includes commands rename and remove, as well as add protocol. If you choose the command rename, a prompter appears that contains the selected name. Edit it, then choose the prompter yellow button command accept or type the Hcarriage return" key. For example, notice that we mistyped the name graphical views in Figure 11.6c. With the misspelled name selected, choose the command rename (Figure 11.7a). The prompter appears, showing the current name (Figure 11.7b). Edit the text and choose the yellow button command accept (Figure 11.7c). The name in the message-category menu changes (Figure 11.7d). If you choose the command rename, and the name you provide is the same as an already existing protocol name, then nothing changes.

228
Modifying Existing Class Descriptions

'_'t.3 prllc s- F'rl ml t 1"'1 e 1:.:11',3 pr,ic s- Displa. y Gr.3 prlic s-Pa. t r,s
lfless.3lje selector and .3njlJment names "c 0 r,',men t s t a tin1j plJrp ose of mess '3 Ije"

C (III ec t i on s- ::i t re ,3. '~: 0 II e c: ion s -,::i '~ P,P 0

tempor',3ry \1,3.ri,3[,le n,3mes

st,3tements

Figure 11.7a

010
li.rmrlBmr.nl~~~!~~IIIi
'::: 0 II e c t ion s- ::, t re3 Colle c t i on s - ::' upp 0 Gr',:, pr, ic" - Primi t i', . e '::;1',3 phi( s-Di,.pl,:. y Gr',:, pr,ic':;-P,3 ths lfleSS,3'je selector

11

1.01+'+,,##
Enter' ne"i'i

com pettinl~ c on',.. ,3. ri n1j p ri n tin Ij

ar'jlJment rl,3.mes

" c (I mmer, t .:; t ':.. tin 'j p IJ rl' 0 se 0 f me.:; sa 'j e "

tempot." t'Y ""',"Ti,:.ble r," mes .:;t.3temer,ts

Figure 11.7b

000

229
11.2 Modifying Protocols

laE~rllla.DIi~I'~~~~~ II
'=:ollection.:,-::;tre,:. Coil e c t ion::: - ::' u p p 0 'it',:' phic3-Prirliiti-'ie Gr,:. ph i c 3- Di 3p I':.. y G r',:. p rlic 3 - Pa t h:::

lt

com pa r'irlq c on"iert in q pt'irltirllj -

111"'."9@\,
,:'.'j':'

Enter' ne"i'i pro then ,:.ccept 'jr,:.. pric ,:'.1 "iie


,,',,'0

in ur,cio me cut

copy
t,~,ste

do It prirlt it

I t e mp ':' r' ':. r y 3t,:. t,;;.m,;;.nt.:.

"i ':.

r'i ':. b len ':. m,;;..:' I

Figure 11.7c

010
C:oJlee tion::: -::;tre,:t. Collec tion:::- ::;uppo (.:it-a p hic::: - Pt-i mi tl-'i e (-ir ,:to prll':::: - DI::: pi .:t. Y (jr.3 prli c::: - F'a t r,::: compa.t'inq con \,' e r-t in 'j printin1j

11ii"I1.'8W

..rne::::::,:t1je :::elector- a.ncj ,:t.t"ijument name::: "e ommen t ::: tao t irllj PUt"po::: e of me::: :::.:t.1;18"

t,;;.mporar-y ' ,' ,:'t'i,:t.ble n:t.me5

5t,:ttement.:.

Figure 11.7d

000

230 Modifying Existing Class Descriptions

If you choose the command remove, and there are no message selectors in the selected category, the category is immediately deleted. If there are messages in the selected category, a confirmer appears because the deletion means that all messages in the category are deleted (Figure 11.8). The second way of modifying the protocol for a class is to choose the yellow button command protocols in the class-names subview of the browser (Figure l1.9a). A list of message categories and message selectors within each category appears in the text subview of the browser (Figure l1.9b). The syntax for each category/selectors combination is of the form ( 'category name' selector1 selector2 selector3)

To add a protocol, insert a new name, delimited by single quotes and embedded in parentheses.
('new name')

An example is shown in Figure 11.9c in which the new category name graphical views is appended at the end. Choose the yellow button com-

,':::',re you c ert airl tria t you

',,1,,1 ':0

rl t to

rem':I\,'e ,:011 metrloc,L:: irl trli::. protclcol~'

.,[l' e::.::. ,:0 Ije ::.e I e c t or


" ( (I

,:0 t"ijumer, t L.._ _

\r ----......L-------...J
riO

m mer, t ::. t ,3 t i rl1j p u rp 0::' e 0 f me::.::. a 'j 8"

c' t

I t8mpOl,:O I> ,:0 t e r,, e r, t.:.

",1,:0

I-i,:o tile rl,:O me::. I

Figure 11.8

100

231 11.2 Modifying Protocols

I-,p,jt-inl~

~~~--.;..~~~~ . . enin1j '.

Collection5-:Collec tion5-:::

ntirlij

C;t-.3.prlic5-F'a.t

::~~:::~:~:::~;=~',t;~

I~,

',.,'.3. ri. ~---"':~":"":""---"':~_---1r,:; y in 5t.3 n c e \/ ,3 t-i a. b Ie r.j.3 cia. 55"'''''.3 r-i ,3 b Ie r.J ,j rn e::l,_ _.t....r.f1.o./.e_ _.. :

p 00 IDi ct ion ,3. t'i e 5: " ca. t e I~ 0 r-y: ' Coil ec t ion 5- ,"-, rt-,:;. y ed'

Figure 11.9a

010
1.1111 con"/ertinq cornp,jrinl~
Collec tion5-::: Collection5-::: (:1 t-,3 ph ic 5- F't'ir (.. r,j prlic 5-Di5 Graphic5-F'at I~. 'c 0 rnp ,j. t-in9' r,a.5r, r"OI. 5r,r.. ",OIppedE: y:) , con "/ e t-t i rll~' ,j 5."-, t-r.j y) 'pr-intirI9' i5Liter-al printCIrJ: 5toreCIrJ:) printin9 -

Figure 11.9b

OOOI mrn~~~~~~1

232
Modifying Existing Class Descriptions

,iJ:

11!!li'('::lo~""'i:lclti.o&nI51-.Tlea>~::t_I~.~i'!!~~ 1con'.,,'ertin'j co mp ':.. rin9 Byte,~,rr,:t.y


Collec tlon5-:3trea. Fiun,"-,tT,:'. y Coil ec t ion 5- :=i IJpp 0 pr-in tin,~

C:ollection5-:=;eque - --- -- -- ----

::~;:::~:~:::~ ~ = ~',t;~~,i,~~i ;::,e


C:' ra. prd c 5- F'a trl5
cla.55 'c 0 mp a. t"in 9' r, a. 5h r, ':.. 5r, r',,1! ':.. pp e (lEiy:) , con',,1ertin,~' ':.. 5,I1,rr,:.. y) 'printin9' i5Litet",:.1 pt"intC1n: 5tOt"e l)n:) ',~raphic,:..1 ',,lie ',/,/5 , .~

':'.909

in undo

cut la.5te do It

print ;t
ca.n 121 form,:.t 5p ':.. ",1',1n e>:: )I.:..in

Figure 11.9c

010
corn p a. t'i n l~ con"iertin9 Co lie c tion 5-:=; tre ':..
pt'intirll~
I~ra. p r,lc ,:'.1

:.~ ;~I,~I ~ ~,~; I~ ~~,~i~;.:~ f'j ~:,I~


C r,:..pr,ic 5-Di5pla y .. (3ra p rtic 5- F'a t r,5

\Iie '",',,1 5

l.rr,:.. yedCollec tion . . 'a.ria.t"e:=iubcla. 55: # ,"-,rra. y in 5t ':.. n c 12 \,1 ':.. t"j a.b Ie (",J.:.. me 5: " cl,:.. 55 \,1 a.ria. b Ie [",Ja. me 5: " poolDictionarie5: .. c ':. t890ry: ":::01Iection5- ,11,tra. yed'

Figure 1l.9d

000

r
233
11.3 Adding New Methods

mand accept in the text subview to have the system check the syntax of the category specifications, and to add the category to the menu in the browser. The result is shown in Figure 11.9d.

11.3
Adding New Methods
Choose the new category graphical views. A template for defining a new method appears in the text subview of the browser, as shown in Figure 11.10a. You edit this template with the desired message pattern, comment, and statements. In Figure 11.10b, the message selector and argument names part of the template is selected; typing the actual pattern replaces the selected text (Figure 11.10c). The example message pattern is displayBarChartWithLabels: anArray.
The name of the message argument has no semantic meaning in the Smalltalk-80 programming language. However, as a matter of style and documentation, the message argument name is made up from the name of the class or superclass of the instance that can be an argument to the message. In this example, the argument name indicates that the argument should be an instance of Array or of a subclass of
Array.

Now select the comment part of the template (Figure 11.10d) and type an appropriate comment. The comment shown in Figure 11.10e includes an expression that is an example use of the method. Users of this method can browse to read the comment, and then see an example use of it by executing the expression.

compa.dnl~

Collec tions-:::;trea. Collections -:::;uppo ':.:it"a. p r,i C:5 - Pri mi ti.. e Gt".:<pr,ic:5 - [oi spl.:< y Gra.prdC:5-P.3. trlS messa.ge selector a.nel
,:r.t",~ument

i
.~~
:::~

_on.G

con\let"ting pt'inting

.:f

n,3.me:5

"comment sta.tirll~ pUt'pose of mess.:<.ge"

tempot'ary ',. . a.tia.ble na.mes

st,3. tements

Figure 11.10a

000

234
Modifying Existing Class Descriptions

1
II
(C,-:ti0w"melicit,i'-1-lri1llsl-,TiieD>~::t Collec t ions-::ieque - - -- - - -- - - --

~1.~i~.~!!~ 1c Qmp ,3. ri n tj Eiyte,"-,tT,3.y cQn',/ertin,,j Collections -::;tre,3 Fiun,':",rr,3 y printing C: 0 II e c t ion s- ::; u pp Q - - - - - - - - - - - iiEi4n @f (jr',3. pr,i c s - Pt'lm I t I \1 e

l,

:~ ;::: ~:~:::~ ;, =~,',~~t~:

:}"

I ternpor,:.t'Y ',/ar'iatde n,:.mes I


st,:.ternents

Figure 11.10b

100
I:....... I:
11.(1:Cidmel'.::it\~CI'r'i::.'-IT.e~::<lt.J~.~i~.!!~~ 1com penin'3 E:'y t e ,"-,rr,3 y con',,! ,3 r'i n '3
l

Collections-::ieqI.Je - -- - - -- -- - -Collec tions-::itrea. F'un,.i:.,rTa. Y Collections-::;uPPQ C'r,3. phi c s - Prim it i"", e

_on.Me
cl,:..ss

printinl~

C'ra.phlcs -[Ilspl.;.y fir,;,. phic s -F'a t r,s

-----a.-------....- - - - - - - U dis p I,:~:~,~~I,~(:~=~~~a;::~"'~~::~':,~~~'~~'~, ;:n ;;";'r~~~~ s,~ e"


, ternpor,:.r'y ','!ari,jble n,:.me5 I st,:.ternents

Figure 11.10c

000

235
11.3 Adding New Methods

(j i 5PI ,3

YB ,3.r(:: r, ,3.rt '0/0/ i tl'", L,3. b 12 15: ,3. n ,i:..rt-,3. y

comment 5t,Ol ting put-pose of message

temporary "iaria.ble n,3.mes

5 t,3. tement 5

Figure 11.10d

100
Collections-::ieque ------------

I:....... I:

11.(i:c~"111e~rl_:lti~cl,rl'~I'-ITmej::<ltrd~.~i~;!4~~~ 1com p a. t-i n 'j E:yte,i:.,tT,3y con'",'et-tinq


Collection s- ::itt-e,3. Fiun,i:.,tT,3. y Colle c t ion s- I:; u pp 0 - - - - - - - - (ira. prl ic s - Primit I',,"~ 12 (ir,3.prlic s-Displ,3 y (it-a.prJic s-F'a. H,s
- - -

Will".'.''

printirllj

cla.ss

eji sp I,3. YE: a. rC ria. rt \"'/ it r,L,3 be 15: ,3 n ,i:., rt-a y


"Ct-e,3.te ,3. t',3T cr',3.t"t t-epresent,3.tion of tr,e numeric contents of tr,e insta.nce, Tr,e message a.njument is ,3 collection of la.bels to use in i,jentifyirllj ea.crl column of tr,e b,3r cr,at"t, If n,e ,3njUment is nil, use inljk:es for la.bels, Try #( 15 6 7 I::) displa.yE:,:Q-Crl,3t-t\o',/itrILa.[lels: #('5031125' 'pt-ofit' 'loss"tot.31'/':"

temp,jt",3t-y "','.3Tiable n,3.mes

sf:,:.tements

Figure 11.10e

000

1IJlIIIlJ.
0,)

, 0,) c
CI
~_-.r1

'""...c:: .,,~

roll: ...... 0.

0,)

(1)

()

..c. I~.

111

L
~.

~.

~~

,=,
C

(2.1

'1'
~.

0")
CI

'1'
,-.::i

SiS 2 0.-:.
...c:: .....
0,)0~O>.

0.",

I~I

'~

.l:i

CI

1..-,

CI

ro
~.

+
ro
~r)

C
1-,

C)
I

'11

,,,-,
~.

E ~
C

S
'"" ;:j

'11 .D ,-.::i

u
I}I

111

()

".J

'11

..,-.
...-.

,=.
~. ~.

,..,.
~-.r"

'.'-.
' '-1

0:

'11

-C....-i O:.::::....-i ~ (1) 0,)

..c.
~.

'11

=' ..c.
LT') L (.)

c=

C
(.)

,,.:..

1_'

ti

u ...-. u

.~

'11

(0
~

.... *
L

ro
(.)

0) C
C)

~.

,-,
C)

ITi

CI

IT,

.D
l-' (.,)

"D

III

1.,-,

ro
111
".J

0. -

'"" co ro .0
'-

E ~ .~ co - 0,) c ..... u (1)'B>~ ::0.- 0. co (1) 0,) .- I '"" <0><." > co ~ >- E ro ~ 0> ~ ~ C I-< 0 - ro Q..()o.
(1)",c .......... (1)

"'o~ (1) ..... -..--

......

0()

-~

c_= t:
u.. -:_
(J

0')

q:1

.~

.=,
C CI

."Ci

Il:i

:~: :tt
"D
--

~.

.=.
C

J1I
".J
~.

~1
L-J
1.,-.

E .~
~

'"

~
(2.1

~
...:L
'.'~I

q:t
~.

'1'
C
.~

il)

0].1_=
~_i'l

'11 Lt. 0') C


t"Ci'
...-.

'.,..
J1I .D
t'(i

1.,,

Lr)
'II

tTi

.~

;:: c c ,=, .=."c I:':"

~.

,-.:i
'11
L

Ir:.i
L L

.f-'

Q...

C 1.,-,

-of
1.,-, 1.,-, Ir:i
~-""'I
()

' '11 E

"-,

~--"'"

.11 ..,
...-,

'1 ..,-,

.~

- ..c. 0') .--"",


I-.:i

-4-~

~.

~.

,..-,

:;: +
i(;

CI C
1.'-1

'l:i
.~

.'ti

~.

-..c.
~.

.....J

.D
L

,-.:i

----.._",J

'..-, I

'11

J1I

C
I}I

C 'l:i
1..-.

'11

'11 ..c.

71

C 1.,-.
~.

:~:

u..1~
~ L

t:
I(i

CI
~'

'11

>::
Iti

,r;

::_:: -:J:
C

C.
"'-1

'II
~.

u.. ,=,

---~.

...::.::.

()

L-J.c
L

,-r:i -~

'II

:= I:i.' ro
CI
~.

lL.

...-.

'1
L

"---"
I

(.)

1.,-.
.~

E ---_
.c:
'II
~.

:::

fCi
.~

Iti

-~
~'

~"""I Iri

111 .D
~

111
(.,)

'li -:{
C
~--""

t:
~

C
C

...-. ='
0 ~

IIi

C
1],1

E ~ '"
0,) ()

U
L

E .-r::i =' -O)UJ


L

(2

..c.

~.

III
'''~I

III

...-,

I-I

C'

IT, ,:.:'

~,~ +
I
'11 .-,

c
II

E
L-J

,r:.i

,t '!I
....J

a. -,.=.
~

;:: '11

'

I~I
~.

I~i *g' ~ :~~


LI

"'-1

I
L-J

1..-.

(00:
L
u...~.

:~:
1"1)
I.,,~'

'...,

l"ti

:-"",

..c.
"D
~.

I(i

.~

:~ ~, >', :~

:_:'

~.

.::.:::

-~
C

,ri

>'.

'11

-:-=

..c.
0')

.r:.i

~"i--:

2~
CI
~.

.::

~::r,
C
(.)

'11
........ '11

..c.
~.
()

'1'

~.
.~

-+
'11

"'r:i U. 1,,-,

CI lL.

~_"""" W
-1-'

~ ...-.
I'Ci

'11
C
~

,,,-,

E
~'

(-'1

.9 +J
'C
U rJJ
(1)

s::

rJJ

~~2
~
......

E
CO
0,)

I~; (~ ~ ~ -Eo ;i;-~


I I
~

tti ..c.

.D

,-r:i

'11

''I:;

-Eo

'11 .D ''I:;

~ .~

...c::
~

en
U

!..r:., ::- ~ '.'-, '..-, l.L LJ l.L __:- W


C
'-I

-.=:
I

(2
u

C
I-I

I
1 .-,

0..

o
rJJ rJJ ('j

Z u ...... ro 0,) ...... 0,)

~ .~
0,)

..c

::

-=- -.::. _.=. _.::., .. "'1 _=", _=.--, "' ..=. . I"
....... .f-I

I....,

I 1.,-,

I
1 .-,

I 1.,-,

ID

C'CIL~LLL f_) () (5 C5 (~ C~ (5

==
'11 '11

()

C)

..c. ..c. ..c. ..c. ..c.


Iri ITi ITi ,ri

uu..uuu..
Iri

; ~~ ~~ ~ :
,'(i

~~ .~.~

.~'
~

..c.

'11

u ,,,-,
"D

:=

'T)

'II

L-J.D-D C '11 (.,) ::::.;:.:.

'11
L

a...~' 1..-.
.,~

-.::i

L-J+
IIi

' '-1

=' L

I"~I

...-,

c.
~'

Q...

co-

.~

+ +.
'11
L'

:i:
L L

LL
Q..
1..1

~~

(.,)

'11

'-.:.'

0:

---S
'+~:....,

'..-,

'11

"D
.......
.--,

'11

~' ()

~.

CI t':":t

==
u

"':::
L

'11

...-,
"D

I:'
C)

'_' L

1..0

~.
(.)

'J..
-1-'

.~

.J..

'II

~ :i~-

' '-1 '. -,

'11

()

uu.. CI ,..-,
'.,-.
-4-'

0:
-U

Il:i

,ti
1.,-,

...-,

Q...

'11

o.r.n

C3

.S
'~ ~

bJJ
rJJ

+J

c:=) c:=) c:=)


(5
~
~

bJJ

....
~:g

.~

s::

Q)

CDI

:e
0

;:j

...

iZ

on

r
237 11.3 Adding New Methods
Note that since the template is simply unstructured text, you can select all of it and replace it with the desired method. The example did the selection and replacement in parts to emphasize the parts of a method that can be specified. The system will not force you to provide comments, nor will it enforce naming conventions.

There are eight statements in the method that are commented here.
rect
+-

Rectangle fromUser.

Create a new Rectangle. The user of the method will have to designate the origin and corner of the Rectangle. Be careful to provide sufficient space for the Rectangle.

spacing

rect width

self size / / self size. Compute the amount of space that can be used for the width of each column. The pseudo-variable self refers to the Array.
Determine the largest element of the Array.

maxHeight

+-

O.

1 to: self size do: [ :i \ maxHeight +- maxHeight max: (self at: i)]. factor +- (rect height - 30) / maxHeight. Compute the scaling factor to get the bar chart columns to fill the available space. The height of each column is the Array element times this scaling factor. 30 is the space left for the labels. labeling
+-

(anArray =

= nil

or: [anArray size < self size]) not. Compute a Boolean (true or false) that indicates whether the bar chart will be specially labeled. There are no special labels if the message argument anArray is nil, or if the message argument does not contain a label for each element. When there is no special label, the element index will be displayed.

Display fill: rect mask: Form white. Display is an instance of DisplayScreen. The message fill: mask: is used to paint a rectangular area of the screen with some "color." Here the rectangle is the spare to display the bar chart; the color, all white, is the background for the bar chart.

The eighth statement is an iteration in which each column is printed. For each element of the Array, that is, for the index i starting at 1 and ending at the size of the Array, determine the label (it is either anArray at: i, or it is the index converted to a string, i printString) and display the label within and at the bottom of the rectangle (displayAt:). Make certain that the Array element is numeric; if not, report an error. Otherwise, compute the top (top) of the next column, then compute the column's ~ectangle (dispRect). Now modify the display screen to show the column; the column has a 2 x 2 black border, so first display the column all in black (Display fill: dispRect mask: Form black) and then

238 Modifying Existing Class Descriptions

display the gray area inset from the edge (Display fill: (dispRect insetBy: 2 @ 2) mask: Form gray).
1 to: self size do: [ :i I (labeling ifTrue: [anArray at: i] ifFalse: [i printString]) disp/ayAt: rect bottomLeft - (O@30)+{spacing ,. (i - 1+1)@O). ((self at: i) isKindOf: Number) ifFalse: [self error: 'element is not numeric'). top ..... rect top + rect height - 30 - self at: i) ,. factor) aslnteger. dispRect ..... (rect left+ 1+ (spacing * (i - 1))) @ top corner: (rect left + (spacing * i) - 1) @ (rect bottom-3D). Display fill: dispRect mask: Form black. Display fill: (dispRect insetBy: 2@2) mask: Form gray]

After you have typed these eight statements, choose the yellow button command accept. The method is compiled and loaded into the system; the message selector appears selected in the message-selector subview of the browser. Check that you typed correctly. If not, edit the method and choose the command accept again. If you choose accept but have mistyped something, a syntax error message may be inserted into your code just before the point of the error. If this happens, cut out the error message and correct the (probably misspelled) token. Then choose the command accept again. Alternatively, a menu may appear that indicates an undeclared variable or message selector. One of the commands in the menu is abort. Choose it, then edit the method to correct the error, and choose the command accept again. Try the new method by selecting the expression in the comment and choosing the yellow button command do it (Figure 11.11a). First you are asked to designate the rectangle in which the bar chart will appear in the same way you designate a standard system view. A possible result is shown in Figure 11.11b. (Note that the image is not in a system view and cannot be selected for reframing, moving, closing, and so on. To erase the bar chart, choose the System Menu command restore display.) If you did not copy the method correctly, but what you typed was successfully compiled, two things could have happened. 1. You successfully obtained a result, but it does not look right. Recheck your method to find the difference between code presented here and what you typed. Edit the method, choose the command accept again, and then try the example again.

2. You did not get a bar chart, but instead a view called a notifier appears to tell you something is wrong. This notifier indicates a runtime error. It is like the one described at the end of Section 8.5. In the notifier, choose blue button command close, and then

239
11.3 Adding New Methods

I:....... l.il.(I:cldllle,.: itiac1:.'-~T~el::<lt~~.~'~i~U!~~~ 1eo mp8rtinl~ ':. ri n9 g ,ri': I: 8 yte ,"-,rr,:t'y con'",'
Coileetions-::;t:reci RunA,rray C' 0 II e c t ion 5 - ::, u pp 0 Gr'3.phies -F'rimiti . .! e lir.3 prlic 5-Di5 pl.:..y Cir,3.phies-F"3. th5

Collee tions- :=ie'ilJe - - - - -- - - - ---

ii!1iJ4"8'.'#
,3.q,3in undo

printin9

c op ~,~"
of trle

displayBarChartWithLabels: anArray

cut "CnO!03te ,3. b,:'.t" erl.3r"t t"ept"e5ent.5.tion of tr,e rlumet"ic c pa5te

in5t,3.nee, Tr,e me55,:''je an~ument i5 ':.. collection of 1,5bel' in kJentifyin9 ea.ch columr, of tr,e b,5r" cr,,:.r"t, If the ,3rgurnerl'----'lu5e
irn:Jices for la.b8Is,

Tr"y

reet 5p,3einq m,5.>Hei9r,t f,3.etor labelirllj top

reet ... Fieet'3il'jle fromUser. sp,3eirl'j ... reet ',/"ddtr, + self size // self size, rt"!,3.:<Heiqr,t ... Cl,

Figure l1.iia

010

1 to: 5elf size ,jo: [:1

m,3,Hei9ht m,3>: (self at: 1)].

Figure 11.11b

240
Modifying Existing Class Descriptions

proceed as suggested for case 1. The most common runtime error is that an object does not understand a message sent to it. Often this is because a period or parentheses was forgotten, or you misspelled the message keywords. There are a number of ways in which you can modify the method to produce different effects. Try to change the background to light gray, rather than white (Display fill: rect mask: Form lightGray), and the column tone to dark gray instead of gray (Display fill: (dispRect insetBy: 2@2) mask: Form darkGray). A new bar chart created with these changes is shown in Figure ll.llc.

Figure 11.11c

Exercise 3: Modify SequenceableCollections to do combinations of the elements of the collection. This exercise is similar to Exercise 2 in that it demonstrates how to modify an existing class description in order to add new functionality to a class. It differs in that several methods, rather than just one, must be added. The new functionality is to obtain an OrderedCollection of all possible combinations (subsets or subcollections) of the elements of a SequenceableCollection. For example, the result of sending the Array #(a b c) the message combinations should be
OrderedCollection a b c ) (b c ) (a c ) (c ) (a b ) (b ) (a )

0)

241
11.3 Adding New Methods

The design of the algorithm is to recursively call on a method that computes subsets of all the combinations of elements, eliminating one element at a time, and collecting the result of each call into an OrderedCollection. The index of the element to be eliminated is called the order of the elimination; it is an index into the SequenceableCollection. The top-level call to this method (combinations:) uses the message argument 0; the top-level call is specified in the method associated with the message combinations. The two messages, combinations and combinations:, will be categorized in message category enumerating of class SequenceableCollection. An instance of any subclass of SequenceableCollection, such as Array or String, will be able to compute all of its combinations. The two methods are as follows.
combinations " Answer a collection containing all the combinations of the receiver's elements, e.g., #(a b c) combinations. " t self combinations: 0 combinations: order " Answer a collection containing a subset of all the combinations of the receiver's elements. "

I combinations I combinations +- OrderedCollection with: self. 1 to: self size - order do: [ :i I combinations addAII: ((self copyWithoutlndex: i) combinations: self size - i)]. rcombinations
The method for combinations: includes the expression
self copyWithoutlndex: i

The message copyWithoutlndex: must be defined for SequenceableCollections. In the example, it is categorized in message category copying as shown on the next page.

242
Modifying Existing Class Descriptions

copyWithoutlndex: omitlndex " Answer a copy of the receiver, omitting the element at omitlndex, e.g., #(a b c) copyWithoutlndex: 2 = #(a c). "

I copy I copy <- self species new: self size - 1. copy replaceFrom: 1 to: omitlndex - 1 with: self startingAt: 1. copy replaceFrom: omitlndex to: copy size with: self startingAt: omitlndex + 1. rcopy

Now that we know what we want to do, let's see how to use the Smalltalk-80 programming interface to add the methods. In a system browser, choose class category Collections-Abstract, class name SequenceableCollections, message category copying, and the browser menu item instance, as shown in Figure 11.12a. In the text subview, edit the text of the method template. Replace the message pattern, comment, and statements to specify the method for copyWithoutlndex: omitlndex. Choose the yellow button command accept (Figure 11.12b). The new method is added to the message-selector menu of the browser (Figure 11.12c).

:1~!!!~!!~lcl:Cldllemc~t Dlaml:, iiiSUW.i-!Q@H.np

r,.jumet-ic-r,.'1aqnitud - - -- -- - - - --r.jumet-ic -r",jun~bet-s ."-.rt,:. y edCollec t ion compa.r-inl~ n i.oi c ce ssinq Collections-Unor'cj .:.cjdin,~ C ollec tions -:::eque - -- -- -- - --- remo.,'inq Collec t io n s- Teo: t 1 .... . Collections- ,"-.rra. y enumera. tin,~ C:ollection::-::.tre.:. -c-:I.-:'.~-=:::-. f con",'ettin,~ selector .:.mj a.r9ument na.mes "comment st.:.tinlj purpose of mess':'lje" tempor.:..ry "iat'iat,le ri,:'.mes

111.-...

cop y From: t 0: copyFiepla.ce."-.II:.. ..1 copyFiepla.ceFrom: 1 cop y',.,',.,' i t h: cop y\,l,o'i tr,out: s'-":'.llo',.'",'Copy

lness,:..,~e

5ta tements

Figure 11.12a

000

r
('1)1 rn ~"tl
C\I

-..

_,-.~.""",----"-,-"

..

~.---,---.-",,.,~

..

,",.~"-.-,

~:-~

..t:: +J
C1)

:=
o

~
C1)

Z
bO

:.a "tl
~
~
~ ~

l::

ithH
g-g-g-g-g-~
Lt (,)
i....:.l ()
r'

"D C

']'1-'=
.::
C

']'
::"", 4-' "'-' -

0:0 CJ ~r. C l'(i :J


1"(1,

g- 3 ~~-i
.....
-:f

~'

~
I_I

c c I~i ~

~I :~ :~: ~
"I)

....:

c.~

G.,
III

0.....:1.,-,

'~

~ ti-~-~
:......,

-.,.:

~:]~ ~
il\

'1\

+-'

>. ,
a..
0
:,: I 01
I"(i

~
1

'1' .,.,

(-II :: 1

....'

u:: u::
:--~I.,

:~: :~:
:--......,

:=
o

.....
11)

-_I..

:---1.,

-I 1
1.'-1

.....
-:1:
;"T,

C)

1..-,

.....
C

c
.......' -:]"

0""1

o....o....D...Qo....
OCIOOC'
''''':'1

.....'
:....

.....
c
']' .=
-:]~
C
~r.

.....
'"(I

:=
q'
;::r:.
-.:;

']'

c:

IT'
C

']' ']'

~, ~~ _I::: ,...,

::::::::~::::::::::::;:;:;.:.:.;.;.;.,

....

::::::;::::::::::::~::::::::

.....'

']'

.....
I"(i .....' III 1.,-,

0'"1

']'

.... '
'.,-.

.1)

III

-~ ~~

Hr~
11)

l(l-';=;

.....
c
,n

1]1

l~i ~

.., c C: 0
']'

E ::-

~ ~

.....
_ :~:

.....
~.

1.,-,

..c
:~:

III

~
I.,,

:tl:
(-"J
r-J

~ -~
1.,-,

UrI
o ()
1"(1 T1 Iti

.c. ....
0"1

']' ']'

III

.....
-

.....
~.

c: ~

ITI

..c nl
...... rJ
-_-I,

c
C
0]'

1.,-,

1].1

:-.... a..
CI

o
I.. ~I

t: :tl:
CO.J
']1

C
CI
1"-1

,]1

a..
CI

'-'
c.

11)

']'

']'

1].1

C~I C "'0 _~

~
III III

-g
......

']'

;:::;

"D

I-I

']'

'-'

::']1 I_I III L


III

N
III

'II

()

']1
1 ..-,

....'
C III

>". (,) ~~ .~ I~::

III

~.

"D C

..c

......
CI

:J 0

__

"'D

-=
']1

,-

.....

=,
-~-~ ~ ~

~ ~~: ~. E.
C C C C C
elOCloO
() (.) () (j ()

-- u. a.. ::-" 0
Cl
11)
L

>',

~;"

:=:

~i; C~
o
L...

(:..) c: T1 0 Iii .~ :......, ()


:.....
~:f

C'

"D

~
0]1

.c
0

III

~'

~'

~~ CI
C)

c'

:=
0

'II

:=
CI

:~:

.....

:~:
111

O"D ~_ C

-;::;

C
I"~I

:=
o
L...

:-1"

-_':-1.,

II

- .= .=
L-

,]1

--

"D
C

((I I- -:1: ((I I I I I I 1.,-,1.'-.1..-. '.'1 '.,.,

+-'

,,,-,

t~~
III IT,) III I'tW

~~t:;'

']1

a.. a.. D ,-,


ITI

,]1
II

.= ,=
L...

-i:.-~-;:'-~-~

E := :J =' ZZ

III

III

~~~~~
-:IC10-:,0

~-~~;~
a..
C,
U
~--... ,
0')

'=.'

~ll -~:

=,
I
1.'-1

III

..0

III

+
111

((I I

I- -:f
I I

11'

+-'

CJ C
~'

((I I

1 .'-11.'-11.'-11.'-1

u..
:-"", :;"
G...

~ ~

G...

-g

>~

.................
() III () tIl Col 'II

C C C C C
0 0
Q
~'

Q
~.

Q..

C) C) () C) C)

LJJ_

C'

~]

= = c'ooc'c'
(J C)
(J C) C)

== =

() III

1:':1 III

~-~~~ ~-;.>.
1"-1

'~

='

'11

:~:

.....

t~ ~
1.'-1

III

tIl

Qi

ITj
Q...

It:i

+
III

a.. III
L

-.':r.,

a.. o

(J

ITI () LJJ _

Q...

Q...

CI

C'

~-~
_ L...

TI C

-;0(

i
I_I

+-

;~ff.:m:-iJ~?'~.PJE~~~ii~~r;::r.tf*~fi~~~fi~;~

<:::)

< -:::)
~
~

<:::) <:::) <:::)


(,)

C'\I
~

~ ~

,....;
~

if:

~
_ J. . . . . . . .

.,

244
Modifying Existing Class Descriptions

Formatting When we typed the method, we were not careful to format the statements (use indentation and line change so that the message selectors are clearly presented). Choose the yellow button command format to create a formatted version (Figure 11.13a). Edit the formatted statements to change anything you do not like. Choose the yellow button command accept to store the formatted version (Figure 11.13b). Testing Open a workspace in which you can tryout the new method (choose the System Menu command workspace). Type the expression
#(a b c) copyWithoutlndex: 2

Select the expression and then choose the yellow button command print it (Figure 11.14a). Make sure that you get the result (a c). Try other SequenceableCollections, such as a String.
'string' copyWithoutlndex: 3

The result should be a new String, 'sting'. These tests are shown in Figure 11.14b. If your results are different, check to make certain that you copied the method correctly. Edit the method if necessary, and then choose the yellow button command accept. Now choose the message category enumerating, as shown in Figure 11.15a. In the text subview, edit the text of the method template. Replace the message pattern, comment, and statements to specify the method for combinations:. Choose the yellow button command accept (Figure 11.15b). The new method is added to the message-selector menu of the browser. By choosing combinations: in the message-selector menu, it is deselected, and the method template appears again. Edit the template to specify the method for combinations. Choose the yellow button command accept (Figure 11.15c). The new message selector is added to the menu. In the workspace, try the new method. Type, select, and evaluate expressions such as those shown in the workspace in Figure 11.15d.

245
11.3 Adding New Methods

1:1111111111:1111111~!~~!~~!~.mimm.1I1!1i1I11 ,3. ddin 9:::inq I: Coller: tion:::-Unord ,:o. c ce::: 'C.:ollection:::-::ieque Collection:::-Te::<t Collection:::-,6.,tT03.Y Collection:::-::itre,:o.

comp,3.t-in 9

removin9 ._ enUmet"03. tin,~ -(-:1-03.-:::-:::"'"""4 con','ertin,~

. . .'.'rmm :::h03.llo'",vCopy
un,jo copy cut 1.3.:::te do It ",t"int it 03.ccept

cop yFt-om: to: cop y Fi e pi ,3. Ce .6., II: "i'ii c ':'pyFiepl,3. ceFrom: cop Y\,\,' it r,: copy\,Vitrlout:

- - - -.....- - - - - - - -.....-....-01 03.9,3.in

cop,y"/'/ithoutlnde>::: omitln,je>:, ",6..ny,,''ier ,3. copy of trle receh"er, omittinq trle element ,3.t 0
E.,~,

#(03. tl c) copy'",',/itrloutlnde>:: 2

= #(03

c)

\ cop'y' \ copy .... ::: elf :::pecie::: ne\"i: :::elf ::: ize -1, copy r"epl,3CeFt"om: 1 to: omitlnde>:-1 \',/ith: :::elf :::t.3.rtirll~,6.,t:1, omitlnlje::<+l,

copy t"eplaceFrom: omitlnde:< to: copy :::ize "."",'itr,: self st03.rtin,~,6.,t: ca.ncel Sp,3. 'T' 12>: ",I03.in

Figure 11.13a

010
copyFt"om:to: cop Y Fi e pia c e .~.II: "i'/ i copyF;epla.ceFt"om:
COP)/ \tll,llj trl:

.w".'rmm sr, 03.11 Cop Y


0 "i'i

copy\'Vitr,out:

"f0pyWithoutlndex: .ornitlndex
",':::'.ns'/,/er 03. copy of tr,e recei"ier, omittinq the element ,3.t ,3.q03.in 12::<, u'i-,,:Jo E.,~. #(.:0.. b c) copy"/'iitr,outlnde>:: 2 = #(03 C) "

cOPy
COP~!I"

copy .... self :::pecie::: ne',/,/: self sizf- copy tOe pI,3 C 12 Ft-o m: to: omitln,je> -

'1.

cut p.:o..:::te (Jo It print it


c,3.nce~

'",',d t r,: s 121 f


:::t,3.r-tin,~,6.,t:

1.

format spa "i'in e>pl,3in

Figure 11.13b

010

COP~!I"

246
Modifying
E~isting Class

Descriptions

~-Jumeric-r.",'-~.qr..

"'.1/J me ri c - ('-.j /J r;:; :~~@~~p.~ C:ollections-U Collections-::i Collections-T Collection:s-,"-, C:ollections-:::;


copyWithoutl ","-,ns',.,'/et'

-~9a.in

."'.11:""""'1 From:

undo
CCrp~.,.'

cut ',,:'.:ste do It ,:t.cce c,:lnce

I copy I
copy'" :self :species ne'"v: self :s;ze - '1,
COp~',J'

t'epla.ceFt-om: to: ornitlnde::< ""',,..itr,: :self startin'l,,-,t:1,

Figure 11.14a

010

COP~~I'

':stt-in9' copy',/,/itt-,outlnde>::: : : : : : _

copyWithoutl
",6,rJs""I,,'er

coPY I copy'" self species ne'",,,,,: self size - '1, t-epla.ceFt-om: to: omitlnde>: '/,,'itt-,: :self :sta.rting,t..t: 1.

cop~,,,,,

Figure 1l.14b

000

COp:,;'"
r .. nl.=t .-:.:.Frnm'
:,::

,-,r,-,;1"lro.-l- \.
::::

,::: ::::

r
f.Jumeric - r,.'.:' qnit U(J f"'J urn 12 ri (- f.J ur;:' b 12 rs A,rr,:'.yedCoile Collection Collections -U nor',j Collec tion s- :::eque Collec tions - T eo t Collec tiorl=:'- ,"-,rr.:. y C:olle c tion =:. -::: t n~.:.
j.rle55.3.t~e

247
11.3 Adding New Methods

collect: do: fintjF\r=:.t: fin,jL.:.st: re,,erse tln"i@iiiiin~ re',.'er=:.eDo: con . . . 12 tt in,~ =:.elect:

cornp arin 9 ,:..ccessinq ,:.ddin,~ re rn 0 ',... i n q coPy in 9-

:::elector .3nd .3r,~ument n.:'.me5

"comr,',er,t :::t,,,tin,~ put'po:::e of me:::;,,:'t~e"

tempor'ary ',....:.ri,,,[)le r,,:.r,",e:::

SUi. t 12 mer, 1:5

100
Figure 11.15a

000
I 1~!!~!~~!~'I~m~~BDII!l1m1
Collection=:.-Ur,ot"j Collec tion =:. - ::,eque ':::01112 c tions - Te 0 t Colle c t io n s- ,"-, rr,,, y Collection5-:::tre,:. :com[)in.3. tions: order Hie recei,.. er'::: elements," corn p.:. t'i r'9 ac c e=:.=:.inq .:.ddinl~ t'emo",'inq cop yin,~ collect: do: findFirst: findL,:.=:.t: re, et"se tOe ' e t'se Do: 5el- . ......I--~ a. q .31 n .....------4i. ur,do

~li~9~,~u~i~"~i~i~P~i~,li, 11
con . . 'ertin9

__ C_I,_:.._s_s_.....

" ,"-, n ::: ', . . , , 12 r' ':. colle c t i 0 r, con t ':. i n in 9 ,3 sub::: e t 0 f ,3.11 t 1"", 12 corn

coPy
cut 'Iaste do It print it (.3.ne _ forrna.t 5p.:..',.. /n eo ,I.:'.in

of

comt,in.:.tion:::

comb in ,3 ti 0 n 5 .... ')njere,jC 011 12 c ti or, """ii tr,: 5e\ f, to: 5elf 5i::e-or',jer (jo:

[ :i I combin ,3 tio n 5
lcombirJ,3 tion5 ....

,3. d(J,-",II: r:r:5elf eopy\I'iithoutlrrde,: i;, cornbin,3t;orI5: 5elf 5i::e-i)J,

Figure 11.15b

010

248
Modifying Existing Class Descriptions

It...... :1!:~!~!~~!!~I(I:::=ol"De~;:m: t~i'i)inmlmlilm I: 'Collections-Unonj ."W';;li1i4inIR


Collec tion s- ::;eque - - - - - - -- - - - Collections- Te >: t Coil e c t ion s - ,"-, tTa y ..... Collections-:::t t"e.:.. cia ss combin,:o. tion s ","-,ns',/,/er
,:0

f'"ju meri c -1',,..1 ':.. qnit ud f\j ume t"i c - f'"j u r;~ b e rs ,"-,rt",:' \,'edCollec tion

comparin'j

Jlti~i~QI"~Ii~#i~.~.~i,IIl"!II 1
con'",'ertin'j

,:0 c c e ssin q addin'j remo',/ in'j copyin1j

combin,:.tions: ,jo: findFirst: findLast: t"e'v'et'se re',/ et"seDo: se I e c t: \,''o''itrl:do:

collection cont,:oinin'j collections of a. I

a.'ja.in undo

"Ibin,:o.tions of

n,e recei',/er's elements, e,,}, #(a b c) combinations tself combin,;t.tions:

coPy
cut paste do It print it c,:.rf\el format sp,:'.""',/n e>::pl,:..in

Il

Figure 11.15c

~~~~OO$p~
Collections-U Collections- ::; Collections-T Collec tions - ,"-, Collec tions-::: combina.tions ","-,ns\,\ler the t'eceh,'er'

['"jumeric-I",'1aqr. ' f'"j ume t"i c - ['"j u n~

copy'",'",'itr,outlnde>:: 2 (,:.

#(,:0 b c) combin,:otions ()rljet'edCollectiorl ((a [I


:1 ([' )

(a. c ) (C ) (a. b ) ([, ) (,:0 ) () )

'a.bc'

iH

combin,:otion:l'l"i'MiM'M,p4;;; , of
,_:. . .

tself com L . . . _......

----I

Figure 11.15d

OOOI . :.. :.. ~~~~~~~1

249
11.4 Modifying Class Comments

11.4
Modifying Class Comments
In the previous section, you saw how existing methods can be edited and recompiled, how protocol names are specified, and how new methods are added to a class description. A method can include a comment about its intended use; comments can be interspersed among the statements in order to explain the algorithm. Comments can be provided for the class as a whole, to document its potential use in the system. In a system browser, choose class category Graphics-Primitives, and choose class name Rectangle. In the classnames subview, choose the yellow button command comment (Figure 11.16a). A comment about the selected class appears in the text subview (Figure 11.16b). You can edit this text. For example, you can insert more commentary. The changed comment is stored when you choose the yellow button command accept in th~ text subview (Figure 11.16c).
file out print out (]ra.phics-Dis
Gra.p~dcs-F'.:.. Gra.p~lic s-\/ie Gra.p~dcs-Edi
Gr,:,.p~lics-C:lo Gr,:,.p~lics-::;up

5-, ':. . ,.' . ~;I ~.;~"I~~. rco ~I y -;~r~I!~


I"":

1~~~~.dlelflinlltllcl,n

~llIat~.:..~-c:~ly

qle- function

.;tion ,:'.nd t-Ol t----T-'-----'........"....--t0 rrn i n I~


I~

()bject subcla.ss: #Fiecta.n!::r-t in 5 t a.nc e \/ ,:t.ria.ble[\Ja.me ren a. me 1 cia. ss\/ ':.. t-i a. til e [\J ,:to me s: " ,-_t-..r_'-II_: e_..... e \_" pool Dic t i 0 na. t-i e:::: " ca. t el~o t-y: 'G ta.p~1 ic s- Pt-i mit i',/e s'

Figure 11.16a

010

I~!,~:"I,~ ,~ ;
~'';;'UJ.10J

010
'S8ItiU';;'~:'8.1

::>9rn a.m~!~

~, ~u!.1d ~I op

ail
8~1

pu

~~!i:,~!:,:~~ ~~;j.~~~: ~fi~~ ~~;~~~:;':!~J:':':~:',~: :.::::~i~~~,:i~J'~~~~l.~~~~~;:


u

!:~
l;l:

~SUO!SU8UJ!P ,';UJ 8U!'UJ.h:t~8P U.;;':' I pU';;' 'S8P!S pU';;' S.j8U.W:' 81.n UO nUlod

JO 8f.iP8I/'I\OU'i 8/',';;'1..l I 'U88.DS, 8\.n UO ';;'8.1';;' .1.;;'\ntiU';;':':'8J ' ;;' :'U8S8.1d8.1 "(II.;;'nSn I

ti U !UJ
I 0.1

.1~~,'~ ~':~'~:~~'~

i'll

S S.;;' I:'

P U.;;' U0 !

~~;J:; ~~'~ ~

- - - -

I,@wiw.

~.1;:';~:~~' :3: =~~: ::~ :~~::~ ~:


S

~ :~:"~~~'I~ =~~: ;:~ :~~: :; ~:

Uo!~:,unJ 8Iti U';;':':'8.J

8ItiU'';;'.1v.;;'n()

Sl.n';;'d-S':'!I..l,i';;'.1t)

~~!t,:~~~~

"~~,~ e=!~f:fi'iiiiW,1
q9rn a.In~!~

000
'S81f.iU';;'~:'8.1 q~!/,/" S8/f.iU';;'~:'O.J JO sUOP:'OS.Jo~U!
/'/',8U 8:'';;'8.D SIJOI:.:,unJ 81f.iU';;':':'8!::J

tilJ!U!I.U.Jo~op /q Solt'U';;'~:'o!::J

'S81f.iU';;':':'8!::J /'/',81J 8:'';;'8.D 0:' SIJ0!:'';;'.18do

f.i1J!:,,;;'/sU';;'.J:' pu.:' f.iU!I';;':'S :.no /.u.;;':, pu.:' s:,uol.Unf.i.J';;' S.;;' s:.u!od 8f';;':' SUo!:.:,unJ :'!:'8I.Uq:,!.1',;'

'U88.DS 81.n uo ';;'8.J';;' J';;'lnf.iu';;':')8.J';;' :,uos8.Jd8.J ,';II.;;'nsrl I

tiuIUJ.w~su.;;'.n 10.1 pU';;' UDJ:..;;' .'un.1,.

6u!>:do)

I
,

"~I'

,.f.i U!:. s 8:' 1J0p:,ur'J .8,1f.'U.;;':n8,.J t'U!.1,;;'duJ!:':' t'U!SS8:':'';;'

}',*'5.'1
8It'U'';;'.1p.;;'n() :'U!Od Ui3d

. I~~=:~:~~:;~:
0

,." d n '::: - S:,! q d.;;'.1 r:)

';;'d-S:,!qd';;'.1f' S!I] - s:'!'-ld,;;,.1~-)

~' ' ., ::

, ': ' ' '',.,.,',: ,.,:,.",.:.,'

~)

H: ~: T~ ~:: (:' ~

." '.....

.. ....'

.. I

:::-SUOP')811 :)

suondposaa

SSgIO

.BunS !X3: .BU!AJ!pOW

09Z

Modifying Existing Class Definitions

12.1 Name of Superclass 12.2 Name of Class 12.3 Instance Variable Declarations 12.4 Class Variable Declarations 12.5 Pooled Dictionary Declarations 12.6 Class Category

252
Modifying Existing Class Definitions

The class definition of an existing class is obtained by choosing the class name in a system browser, or by choosing the yellow button command definition in the class-names subview of a browser. The definition Consists of six parts: name of superclass name of class instance variable declarations class variable declarations pooled dictionary declarations class category name Each of these parts can be changed by editing the text of the definition that appears in the text subview of the browser, and then choosing the yellow button command accept. The consequences of these actions will be described in the following sections.

12.1
Name of Superclass
Changing the name of the superclass means that you are changing the (inherited) methods to which instances of the class can respond, and you are changing the (inherited) variables that describe each instance. In the browser shown in Figure 12.1a, class category Graphics-Paths and class name Arc are selected. The superclass name has been selected in the definition of Arc. Change the superclass name by replacing the text. In Figure 12.1b, the superclass for Arc has been changed from Path to Object. Choose the yellow button command accept to indicate that you are done editing and that the change should be made. If the new name already exists or if the first letter is not capitalized, a notifier will appear on the screen. After you understand the problem, close the notifier and correct the definition. If the new name is acceptable, the system recompiles all the methods and will report if the change causes some methods to refer to undeclared variables. The report is displayed in the System Transcript view, as shown in Figure 12.1c. Both Arc and its subclass Circle have been recompiled. One of the methods of Circle refers to the variable form, which was declared in Path and is therefore no longer within the scope of the methods of class Circle.

r
253
12.1 Name of Superc1ass

1\ 1

l:.:it',:,pll ic::; - . . . . ie',...,.. ::; Gra.phic::; -Ecli tOt'::; G t',:.. p II i c::; - C I 0 c k::; Co r.:.. p II i c::; - ::; IJ p POt ??~mmn f' emel-I)bject::; I f<.emel-CI,:'.::;::;8::;

,:.cce::;::;inq di::;pl.:.yin,~

::;lJbcl,:..::;::;: # ,"-,n: ::;t,:'.nce"""',:'.r'i,:'.blef",J,:'.rne::;: 'qlJ,:'.cJt',:'.nt raclilJ::; center' c I a::;::;""'" ':.. ri ':.. b 1 ['"j ':.. rn e::;: " e po olDi c tiorl ':.. ri e:3: "

c:.

tel~ory:

'Gr,:,pllk::;-P,:.th::;'

Figure 12.1a

ODD,,,,,

1=1 b j e c t... ::; Ij tl c I':.. ;, ;':

# ."-. n:

irl ::; t ':. r, c e ........:. r i ':.. tile f",J ,; rl', e :3: ' q IJ ,; d r' a rl t r ':. I] i IJ::; c e r, t e r c ,;:3::;""'" ':.. ri ,; t, e [",j.:. rn e::;: "
I 1

pool Dic t ion ':. ri e:3: ..


C ':.. t el~orY:

'Gr,; p II iC:3 - F',; til::;' c,:'.ri7)el fo t'rn ':.. t ::;p ':.. ', . ... rl e'pl,:'.in

Figure 12.1b

DID"",,,,,,,

254 Modifying Existing Class Definitions

recompilinl~

,"-,re

Cir"cle " (form i5 Un(Jeclar"ecJ'i cJorleA ,

recompilirll~

,'e

1 1 f)tlject 5IJbcl,:t55: #,"-,r"l: ir, 5t ,:t r, c e ""i ,:t r i ,:to b I e [",J ,:t r,', e 5: . q IJ ,:t (J " ,:t r, t r':t cJ i IJ 5
C I ,:to 55""i
C e r, t

e r'

,:to r"i ,:to til e f\J ,:to me 5: ,.

pooIDictiorl,:txie5: .. c ,:to t e Ij 0 r' y: 'I:; r' ,:to phi c .:' - F' ,:to t r, .:' .

Figure 12.1c

000.. . . . ./ . . .
As will be illustrated in the section on changing instance variable declarations (Section 12.3), adding or deleting instance variables means that any existing instances will automatically be updated. When appropriate, you must check to make certain that all existing instances properly initialize any new variables.

12.2
Name of Class
Editing the class name is a way to create a new class description with the same definition as the old. The new class will be categorized in the selected class category, unless the class category is changed in the definition text. Editing the class name is not the way to rename a class. You rename a class by choosing the yellow button command rename in the classnames subview (Figure 12.2a). A prompter appears in which you type the new class name. Type Pare. When you are done typing the name, terminate by choosing the yellow button command accept or by pressing the carriage return" key (Figure 12.2b). This prompter is unscheduled, so you must respond. If you change your mind, simply leave no characters in the prompter and terminate.

255
12.2 N arne of Class

recorf is Un,l:.:it-,jprli c S- \/ Cir,j prlie s - EI Gr,j prl ic s- C Gt-,j prl ic s- ::; f: er-nel-C't,j f<emel-CI,j:: --C't,ject sut,cl,jss: # ,"-, r-, ... IrIst ',/,jr' t'efs ,01 S S "/ ,01 r t'e fs ins t ,01 r, c e \/ ,01 r'i ,01 t,l e f" cla.ss refs cia ss\/ a r'i ,01 b 1e r",J ,01 m pooIDictior"jr-ies: ' r'emo'.,.'e

,f-I-----,--r----=-.,-------"-I- - - - - - - - -

I/\>?.............. 1< <I

rn

DIa_1I1III

c ,01 t e'~ ory: ' Gr,:. prdc s -p,:. tr,S'

Figure 12.2a

010

"

1 ...... 1

::i ys t em T t'a.ns crip t

recompi1in9 ,"-,tT", clone

t-ecor~:_"'" .-,'--"'-'m is I In',_, t-,j Pr,l c s "/ Ie "/'/ s Gt-,j pr, ic s- Eeli tOt'S Gt',j pr, ic s- Clocks Gr'apr,ics-::;uppOt ~7mm f<emel-C'bjects f<em"'l '-;I,jss"'s

~Di("',~""

t-i i

------------

1//

Cin::le Cu t'''/ e Line Lir,e,jr-Fit

,jccessinq eJis pi ,01 Y ir,

'='t,jec t... subcl,jss: #,"-,t-C iriS t


,01

ric e\/ ,01 r'i ,01 b 1 r",J a me s: ' qua. eJ r',j r, t r'a cJi us c ~.....-..,.,.......... e

c I ,01 SS\/ ,01 t-i ,01 b 1 f'"j ,01 me s: " e po olDic t ior, ,01 rie s: " c ,01 t e'jo roy: 'Gr,j p r,i c s - F',j t r,s'

,....--------l Er,ter- r

a,~

,01 I

r,

uneJo

copy

1------...... ,sf'"j,jme
CFi

cut p,j.ste eJo It prirlt it


C ,01. r'i\ e I

Figure 12.2b

010

256
Modifying Existing Class Definitions

When you rename a class, the name in the browser menu is updated and is selected. All subclasses refer to the class by its new name. Compiled methods that refer to the class are also correct. However, since the system source code is just text stored on a local disk or stored on a remote file server, all the source code text does not have updated references to Parco (This is potentially confusing. The system compiled-code references to Arc have effectively all been updated to Parc, but the source code text is handled independently.) To remind you to find each method in which the class is referenced, the system searches for all references to the class (as indicated in the System Transcript). If any exist, a special browser is created (Figure 12.2c). This is a message-set browser, as defined in Chapter 10. You are asked to designate the rectangular area for the browser. The browser menu will contain references to class/messages whose associated methods contain references to Parco However, the text will still show the word Arc (Figure 12.2d). Replace the word with Parc and choose the yellow button command accept (Figure 12.2e). If you do this for all the methods, when you later browse the system, you will have the correct source code text.
::iy:::tem Tran:3ctipt

tecompilin9 ,"-, rc " , 'Jone


r.:.compilinl~ Circle", (form

i::: Iindeclar-ed)

done
I'~

::i e a. tOc r, in I~ fo t re fe tOe n c e::: to trli::: cl,~.::::::",

~.rFit

.............................

......

II...............

J~f<;e~tT~'e~1 ~,~.~,~~:~~.~~-e-);~mple
1':)bjeC
::i:~:

1'"""'I'!'*'n.l...'l.!----------------------1
1III
l.i:1
::::::

F',~.rc di:::pla.yCln:tr,~.n:::fotm,~tion:clippinl~E:o\:rljle:ma.:::k:

~r~

IIIII

Figure 12.2c

000-:.. : :

.lli

257 12.21Name of Class

r,::.compi1in9 ,"-, rc " , clone


n~compilin,~ Circle", (form I:: Undecl,:<.t'ed) done
,,~

::;e,:<t"CrdrJl~

fOt' reference::

to trd:: cl,:<.;;;;."

............ I
,~

F',;.t'C cia.;;;; e::<a.mple

cl. aTransformation clippingBox: c1ipRect rule: anlnteger

po mask: aF orm c'; I ne,,I,,I,"-.t'C tempCenter ne',,I,,I,"-,rc ~ ne',,I,,I, tempCentet' center,


~

,;Tran;;fotTf,ation ,;pplyTo: ;;elf


'0:'.'

ne',,I,,I,"-,rc center': tempCentet >: tt'lJnc,;.ted tempCenter' y tr'unc,;ted, ne",I,,I,"-,rc qu,;dra.nt: ;;elf qua.dt,;nt,

Figure 12.2d

ODD,

ne""",1,"-,rc t.;.cliu;;: (;;elf t'a.diu;;

:+

a.Tr,;.n;;fotm,;.tion

................ , < . >


r'ecompilin,~

,"-,tc". clone clone


.'~

r'ecompilin,~ Circle", .: fom',

i;; Undecl,;recn

:::ean:rdrJl~ for' reference;; to thi;; cl,;;;;;"

;.rFit Ie

........................ ........

F',;.tc cia;;;; e:O::,;.mple C'I::,j,::.c

a.,~,;in

I) )tH )1

unclo copy r--.I.I",I",;~--------------"'"cut nteger aTransforma tion clippingBox: c1ipRect p.;.;;te mask: aF orm do It I ne',/,/,"-,rc tempCenter I pt'int it ne',/,/,"-,t'C ~ F',;rc.... ne'/,,I,
i r..

center,

tempCenter' ~ ,;Tr,;n;;formatiorl ,;~ c.;.r~el ,elf form,;t

Figure 12.2e

010>1

r,e",1,/,"-,n: cer,ter': tempCenter' tt'u tempCer,ter' y tt'ur,c,; ted, ne',,I,,I,"-,t'C qu,;,:Jrar,t: ;;elf qu,;,:Jt,;nt.

~~'~;':;'r~, ~

ne . . . .',"-.rc r,;.,:Jiu;;: {;;elf r,:'.diu;;+ ,:'.Tr,:'.n;;form,:'.tion

258
Modifying Existing Class Definitions

Alternatively, you can evaluate an expression to rename a class. The message rename: is understood by all class objects; the message argument is a String representing the new name for the class. For example, let's do the previous example again (the illustrations assume that you did not do it before) and change the name of class Arc to be Pare. As shown in Figure 12.3a, type and select the expression
Arc rename: ' Pare'

and choose the yellow button command do it.

I) 0 r '31}~~1~' unCJI_' copy ::;e,3r'crdnlj for" r"efer cut to tt,i::: CI,3.::::::", p,3.:::te Arc rena me: 'Pa tc'

i1in i::: Un I) e cia. re ,:J'I recornp 9 ,

Circ,e"'l~!'~IIIIIIIIIIIIIIIIIII
,3cce::::::in lj I)i:,pl ,3. y in1j cia.::::::
r",3') i Ij:::

I I C11.),Iect

:::ubcl,3::::::: #,"-,rc ir,::: t ,3 nce \,1 ,3 ri,3. tllef",] ,3. me:::: 'qu,31)r,3n t cla::::::\,1,3ri,3bler",J,jme:::: .. c ,3. t e IjO r"y: ' Ci r",j p rlic::: - P,3 t r,:::'

c en t e r"

pooIDictiorl,3rie:::: "

Figure 12.3a

010

The task is complete, although the view in the browser has not been updated (Figure 12.3b). Deselect the class category Graphics-Paths by pointing to it with the cursor and clicking the red button (i.e., choosing it again). Then choose the category again (Figure 12.3c). In this way, you request that the menu of class names be updated. Notice the item Pare is now at the end of the menu.

259
12.2 N arne of Class

::' y::. tern T t".j n ::.crip t


recompilin,~ Circle ... (form

acce::.::.in,~

Cur',/e Line Line,jrFit ::,pline

(jj::.pla.yinq

1<

)<)I~)tl.iel:t ::.ut,cla::.::.: #,"-,r'c


in::. t,jn ce \'! ,jri,jble[\J,jme::.: ' qu ,j(Jra.n t r,j. (Jiu::. cent et" cia.::'::' \/ ,j ri ,j b le[",J ,j me::.: " pooIDiction.jt"ie::.: " c ,j teqory: '<:.:ir,jphic::.-P,j. tr,::,'

Figure 12.3b

0001: : : .
::' y::. tern T r.j. n::. c t"i p t
t"ecompilinq Cit"Cle", (fot'm I::' Un, - - - ._.',

!!r~:!!!

Cin:le Cut',/e Gr'apr,ics-Clock::. Line Gr,j. p r, ic::. - ::' u p POt Line,jrFit V..::.rnel-I)bjec t::. F',:.n: f<emel CI.j::.::.e::. ['"j,j.meC1f::,upercl.j::'::' ::.ut'cl,j::'::': #['"j,jmel)fc:la::.::. in::. t ance\'!.j t"i.j blef'"jame::.: 'i n::. t \/ ,jr[",J,j mel in::. t \/ ,j r[",J,jme 2' c I,j::' ::.\/ ,j t-i,jbl e[",Ja me::.: ' C I,j::'::' \/ ,j d",Ja mel Cia.::'::' \/ a.r['"ja.me2' pooIDiction,jrie::.: " c ,j
tel~ory:

I I

'Gr,j p rlic::. - F',j t r,::,'

100
Figure 12.3c

ODD

260
Modifying Existing Class Definitions

If you now select the definition of a subclass of Pare, Cirele, in Figure 12.3d, its superclass properly refers to the new name. All of the compiled code works correctly. However, the source code has not been changed; it still shows the word Are in the text. To update the source code, you will have to edit the text yourself. In the System Workspace, edit the template for browsing all calls on a particular object. Find an expression like the following and change the argument symbol to be #Pare. Smalltalk browseAIICallsOn: (Smalltalk associationAt: #Parc)

r-ecompilinl~ Circle", (form

I::: Un,- - - - .- -,

. - :~:::

Ie;r-,j.prlic:::-::; 1>~!"""""""1 f<er-nel-C1bj.: 1>1 f<,:.rn,:.1 C:I,jc

~;;~;;i~E'

.l.i,il.i: ..

_ _

_ _ cJi:::pl,jyinl~ Cur\le '\ cJi:::play bo.' ,jCC': Line -----------Li n e ,jr-Fi t p,jr-c

1>1

F',jrc :::ubcl,j::::::: #Circle ir,::: t ,j n c e \/ ,j t-i ,j [) Ie f",J ,j me:::: " cl,j:::::: \i ,j ri,j blef",J,j me:::: " pooIDictiorl,jr-ie:::: " c ,j t eqory: 'Gr,j pr,ic::: -p,j t r,:::'

100 000
Figure 12.3d

1.............1

Select the expression and choose the yellow button command do it. In this way you obtain the message-set browser that gives you access to all methods whose text references Arc rather than Pare, as previously shown in Figures 12.2c and 12.2d.

12.3
Instance Variable Declarations
To illustrate the effect of changing the instance variable declarations, an example of modifying Pare is given in this section (Pare was formerly Are if you followed the previous example). Start by undoing the ex-

r
261 12.3 Instance Variable Declarations

ample of Figure 12.1b, so that Pare, once again, is a subclass of Path. Open a workspace and type the expressions shown in Figure 12.4a. Evaluating these expressions declares two temporary variables, aForm and anAre; creates a new instance of Form referred to by aForm; creates a new instance of Pare referred to by anAre; initializes the new Pare with radius 50.0, quadrant 4, and center wherever you point with the cursor and click any button (Sensor waitButton). (The cursor changes to an arrow with an asterisk-the execute cursor-until you click the button.) The Pare is then drawn on the display screen (Display). And, finally, an inspector for the Pare is created. The image of the Pare and the inspector for the instance are shown in Figure 12.4b.

Collec t ion s- ::; uF C:;r-,:opr, ic s-Proi mit I:':;r,:opr,i c s- Dis pi,:

~~e~~~~t~,~

Gr-,:o prli c s- E(J it or P,:otrl subcl,:oss: ins t ,:0 nc e \/ ,:0 C I ,:0 S S \/ ,:0 r-i ,:0 [I poolD ic t ior" cat e I~ 0 roy: 1~m"M~~~~------------~'m"''m''''''''//.

Figure 12.4a

DID /

Notice that the instance of Pare has five instance variables; their names appear in the menu of the inspector. Two of the variables are declared in the superclass Path, and three are declared in Pare. Now return to the browser and change the superclass of Pare to be DisplayObjeet (Figure 12.4c). The inspector is no longer correct. Close it by choosing the blue button command close (Figure 12.4dL Return to the workspace and once again evaluate the expressions that create a Form. A notifier appears (Figure 12.4e). The message form: was implemented in class Path. By changing the superclass of class Pare, the message form: is no longer part of the protocol of Pare. The instance variable form and the message form: must be specified in class Pare.

262
Modifying Existing Class Definitions

1,3Fot-m ,3.r,,"-,t-C
I_:ollection;;-::;u~ Line (:;r,3.phic;;-Pr-imit Line,

I._lr-a. ",r'IC;;- \"le',,1',1 ,3n,"-,r,: r-,3.diu;;: 5Ci,CI, Gr -Editot~ .::. r, "- ,-- -. -,r,t" -,,"' '=;en;;or ",1',1a.itE:utton, 1,.....;;elf for-m collectiorl qu,:.eJr-,3.nt ra eJ i u;; center
: 4,

Gt}prl i ':,c.,~,[I,i~.F,I,': ~4r~ ~rq~~;,;r~ffi~ :~; plin ,3rl,"-,rc fot-m: ,:.Fot"m,

,3Form .,.. Form ne',,1',1 e:<tent:1 (s:!:~;Ci, ,3For-m bl,3.cf', ,3n,"-,n: .,.. Par-c ne ', 1, 1 ,

I: Di;;pl,3.y,

Figure 12.4b

000
Collection;;-::;uF Line

I .. I~(~:;~t-~,3.~p~r~d;C~;;~-;.F~'r~ir~n~it~~L~i~n~e~a~.r.F.i .-u",'.,.iI 14.. :~;:::~:~:::~~ =~',~f~":~:t -----------Gt-,3.pr,ic;;-Di;;pl,_


t ." 1

::;pline

,3.,c c e;; yln!j dl;;pl,3. ;; i, -----------,3.q,3.in


u~ndo

n,~

Cl.3;;;;

Di;;pl'3.yC1bjec t...

;;ubcl,3.;;;;: #F',3.rc cut irl;; t ,3. r, c e \,1 ,3. ri ,3. til e f\J ,3. me;;: ' qu ,3. eJ ra. n t ra.,j i "',3.;;te cl,3.;;;; \,1 ,3. riabler",J am e;;: " eJo It print it pooIDictiorl,3rie;;: " c ,3. t e I~ory: 'Gr,3. pr,ic;; -P,3 th;;' C,3. -:el fot"ma.t ;;p,3.",1',1n e>:: ",1,3.;n

cop ~./

Figure 12.4c

010

r
263
12.3 Instance Variable Declarations
, ,, .
'i'i

orLsp.jc,:, L < : : . : . <: <> < :

.",::<':< <<::"':: <:<:<>" .. ",<: >:':'<> <

::;ystem E:ro'//set
'_:ollections-::;u~ Line I]raprlics-F't'imit Line.jrFit accessinq Gt.jpr,it:s-Displ,:I':t'<i"''':'~':' < ,< ':" :':, ,,: (Jispl,jying

>do

--=Di

~rQN~f~4m~

:~:;:~~. -~= ~" I~ f;~": ;:jt1i-i3-~-~-li-ii-[-:-;;:-[-;:-~-dL-,.


,-:1,::",',

--J

self fot-rfl collection qu,j(Jr,jnt t',j ,:Ji u s center

url,:Jer mo',/e fr.j.me coll.j.pse

Figure 12.4d

Un(Jefirle(J'=ibject' ,Dolt Com p iIe,' , 'e,,. ,:'<.Iu ':'< t e :i rl :to: riot if Yir"j :ifF ':'< ii'
:....[-.,-i

s-~-",~:'< ,~: ~ ;:: ~: :~~:~: ::~ : ;: :~' :~: ~: ~ ;: :~: ::: ;:,:' ,., ;~ ~:~ : e r,,.1 e r, u ,=: c~, t
': I':'< S S ... ' :'< ,'i ':'< bIe r",J:'< p ,:,,:,1 [, i c t i 0 r, ':'< ,'i e ':' ': ':'< t e'j,:,r':-, ':'< r, ,," ,',:
i r,

,'0 II e ,',

Irl'--_ _~--...,~-----------------------,.....J

sp e ': t

',=, ,',:,< prm~~"!""!"1"T"':"---------------""'--_...J

Figure 12.4e

000

264
Modifying Existing Class Definitions

First add the instance variable form to Pare. Edit the class definition and choose the yellow button command accept (Figure 12.4fL Now copy form: from Path to Pare. Choose the class category Graphics-Primitives, class Path, protocol accessing, and message selector form:. Choose the yellow button command move (Figure 12.4g).

System Browser

[, ,~ PI~ :.':' t'.I8 ':


Ir, ,
~ .~

t
~

~ IJ t,,: I~ , ,

'*'

p~ r

r, ': 8

t', .~ t, 18 I.) .~ rl'I8 ,

1= 1=1

P ~,'

': IJ ~

'.p~.

',I~,

r, r,

Figure 12.4f

010
System Browser

c C, 118 >: ~ i 0 r, ~ - ::' IJ ~ I r, ri r, i ~ 8 F':' r'm


':, r'~ p 1"': ~ - F'r', m I ~
'::;r'.~
':' p.~

q IJ 8 F,:, nl"

,::; r'.~

,:, r'.~

pl,i,:, p~ n,~ 1m, p II i ': ,. -'.i , 8,,' . - - - - p I' i ':, Ed I ~ ':' r

p~ r'~ '~1t'~

pi'

- - - - - - -

~f/~~,i.:"~ r"j ill


i

':J'~pl.~

Y t,,:,

tr'~ r"rc,n,'"

',::.,' """_~If'fP._'"

form: aForm
"r'.,",~f

~118

~t"jlJm8rl~,

~F,:,nl'l,

~118

t'8':8,

8t", r,:,n,',"

r':' n,', -

.~

F':' n,',

Figure 12.4g

010

265
12.3 Instance Variable Declarations

In the prompter that appears, type Parc> accessing and then choose the yellow button command accept (Figure 12.4h). This then copies the method to class Parco Do the same copying sequence for the message form so that both methods are in Parc (Figure 12.40.

5ystem Browser

lorrn: aF orrn
"r',',~f

'"

n,,,,

~t"'jum"",t,

~Fon,""

n,,,,

t"",c",i"""'t"~

f,:,!"m -

,~Font'

Figure 12.4h

010
laForm Collec tion ~ -::;Ij~ C; t-a p r, ic ~ - Pt-i mit Li n e l:::iraprtic ~ -[Ii ~pl.: Line.~rFi t
'_';t-,~prllc~- ',,I

.~n.,""rc

I
center:r.~dilj~:

I< IIdJiiIl,_.ni1ii~.BIl.@iI,',"/'/' ::,pllne Ielilillll~,g"i1 - - - - - - - -Gr,~phic~

di ~pla yilllj

- E,]it Ot

c e n t e r: r,~ ,] i Ij ~: q' form form: ~ q Ij,~ ,] t-,~ n t q Ij ,~ d t- ,~ " t :

l/,e~~a'je ~elector .~n,] ,~r'jljment n,~me~

" com m'" n t ~ t .~ tin 'j p Ij r p (I ~ '"

(I

f m'" ~ ~ .~ Ij e "

t",mpot".~

toy './.~ t"i.~ tole n~ me~ I

.:.t~

tement.:.

Figure 12.4i

000

266
Modifying Existing Class Definitions

Return to the workspace and once again evaluate the expressions that create a Form, a Pare, and an inspector for the Pare. This time the inspector shows four instance variable names in the menu (Figure 12.4j).

I,:, F':,,-m ':. r',~,t-':


,=: 0 lie c t i 0 r, 3 - ::' Ij ~
,::; t':'

C Ij r' '" Pt-, r,'" t Li r,e '::;/',:' pr'll: 3- ['13pl,: Line,

p r, i ':

3-

,:.F':,/-m - Fc,/'m r,e"i" e,ter,t: :. Fc,n,-, [:,1,:, c f

lJ:2:~;Ci,

G,.~hj~-Pi\ffisP
':~r,:. p

_.
3elf

.......~

':< n ,C:, rc - p,:' rc n e" '" ':. r, ,'-', t',: fc, t'm: ':. Fo t'r,', ::,plin ':. _ _l...- r, .::: r- c r' ':. d i Ij 3: 5 CI ,---. Ci

q Ij ':. d r':. r, t r:. ,jllJ 3

,pi,:. y

Figure 12.4j

000
The method for form: simply assigns a value to the instance variable form. If existing instances of Pare must have this variable initialized, evaluate an expression such as the following one.
Pare alllnstaneesDo: [ :eaeh I each form: (Form new extent: 1@30)]

12.4
Class Variable Declarations
Adding or deleting class variables is similar to adding or deleting instance variables in that the methods of the class and its subclasses are recompiled. If any method references a variable no longer in the scope of the method, the name of the variable is printed in the System Transcript. Typically, initialization of class variables is done in methods specified in the class protocol rather than in the instance protocol, although both are feasible. By convention, class protocol has a category class initialization and a message selector initialize whose method does the

r
267 12.5 Pooled Dictionary Declarations

class variable initialization. An example from class Cursor is shown in Figure 12.5.

WI''''

Di5pl,j yr',/le(JiurI"! Di 5pi ,jy ':'[,.112 c t Di 5p I,j Y ::,c ree r, Di5pl,jyTe, t

1r15tance cre,jtlor -----------CUtTer,t cur"50'" cor'5t,jr,t5

ins t,jnce tr,e 5t,jnd,jn]


cu,"sor,~

,=: u r 5 0 r

0 ," i ,~ i r,

'=:ur5Clr C Clt"ner

,=: u '"5':' '"


,=: U ," " 0 ,"

re ,j
'1,/
',1,/ ,j

,]

r i t 12

,=: U'"5':' ,"

it

,=: u r s CI r ttl ,j n f
'=:ur5c,r 5qU,j re

Figure 12.5

000

,=: ur"5 0 r

rio m"1 ,j

12.5
Pooled Dictionary Declarations
Adding a name of a pooled dictionary in the class definition means that any variable name declared as a key in that dictionary is now within the scope of the methods of the class and its subclasses. Deleting a pooled dictionary reference means that possibly several variables have been removed from the scope of the class methods. There is no special initialization needed if a pooled dictionary is added to a class definition. An example of class DisplayText in which a pooled dictionary, TextConstants, is declared as shown in Figure 12.6.

268
Modifying Existing Class Definitions

System Browser Gra hies-DIs lay [, i ,. PI.~ Yr"/1 12 'J i IJ m ,:.:; t-~ Prl i c .:: - F'.~ HI ,. [r'.::p I.~ yl:ll,jer: t ,=, t-~ Prl i ': .:: - \./ i e \"./ ,. Di ,. PI.~ Y::' c t'e 12 rr ,:.:; t-~ Prl i I: ,. - E'J i t ':1 t- ,. I!liNmm
'=i t-~ prll': .:: -,=: 101: f .:: I='r.~ pr,i ': ,. - ':,lJppor f .:.tTI.:.I-':'llj':'l. t.:: Form \rr ri rl i t 12 Fo rrr-I .:. c ce.::.::irr,~ di.::pl.:. yir,,~ 'J i.:: pl.:. y l,,:, c orl:' ert ir,,~ pri\ :.te

.:. ': ': 12

""[ 1

i,. PI .~ :." ,:' II .i e c t .:: IJ lr c I .~ ,. ,.: [r i.:: p I .~ Y T e t i rl :; t .~ rll: e \'.~ t-'.:' l'l e r.1.:. me.::: . t e t t 12 . 1:::, t y I12 ':1 ft.:: 12 t fo tOm
I: I .~ .:: .:: \.
.~ t' i .~

'*'

lr I e r.J .~ me.::: "


'Te t'=:':lrl,.t.:.rlt,.
.:: - [, i ,. P I~:o
I: 1

~1l:Il:tI[lictior,.~rie:;:

': .~ r e I~ ':' t- :.'

1=i t .~

Pr, i ':

llj e ': t .:: .

Figure 12.6

000
To change the category of class, you can edit the category reference in the class definition. The class is moved to the new category and the browser is updated. There are two cases of things you can do- move the class to an existing category, or move the class to a new category. In Figure 12.7a, the definition of class Path is shown in a browser. Part of the class category, originally Graphics-Display Objects, is selected. Replace the selected part by Primitives as shown in Figure 12.7b. Choose the yellow button command accept to indicate that Path should be moved to the existing category Graphics-Primitives.

12.6
Class Category

269
12.6 Class Category

Fonn

1\) I

:~::::~:~:::~~=~::~:"~:,'~, ~;';'i,~',~~;:~:~';";n
Pa. ra.1jta.prl

1<> <>.II:7it,:.prlics -E ditot's 1 < <>1 Graprlics-Clocks I> > ><1 Gr-aprlics-:::uppor' f<.emel-C1bjects

displ ':.. :~'inlj 1I111@Dl1Uiliilli ldisp'aybo,,:..cce -----------uansfor-minq cl,:..ss a (J(Jirlq

:~;~t~~~inlj

Displa.yC1bject sU[lclass: #P,:.trl in stan c e\/ a. t-i,:.. blef",Jame s:' fo rom colle c t io riC' fPoi n t s class\/ari,:'.blef",James: ,. poolDic t ionar-ies;" cate1jory: 'Gr':'PhicS-liDQf;W"Ma,

Figure 12.7a

,:.ccessirllj t est irl'j dis pi ':.. y i n'j IllijGDlUilil 1dis pi,:.. y b 0' tr,:'.nsforminq

Form InfiriiteFonrl Clp ':.. queFo rom P,:.. r,:'.'jr,:.. p r,

1 ~~1.4~~~~~~:'::~.III1I1I:::icL' ,:.~.~s~~,j~,:'~d~d~i~r ':.undo irl


I}:'

Displ,:.yC'bject subcla.ss: #P,:'.tr,

t - -.......- - - - - - - . . . . . .

.....

li-i!

ins t ':. n c e\/ ':. ri ,:.bl ef",],:.. me s: ' fo r'm c ollec ti cut cia 55 \/.:. ri.:.. blef",J,:.. me5: ,. -t03.ste (Jo It pooIDictiorl,:.ries: .' print it cat eqory: 'Gra phi c 5- Pr-imi t i\' e.:;.. el form.:'.t sp ':.. ',/,/n e.' -,I,:'.in
c':.

C I) P~~/

ill!!

Figure 12.7b

270
Modifying Existing Class Definitions

In Figure 12.8a, the definition of class MappedCollection is shown in a browser. It is categorized under Collections-Sequenceable. The class category is changed to Collections-Miscellaneous after you choose the yellow button command accept (Figure 12.8b). Because this is a new category, the browser must be explicitly updated. Choose the yellow button command update in the class-category subview of the browser (Figure 12.8c). Scroll to the end of the class-category menu. The new category appears. Choose the new category, Collections-Miscellaneous, to see that MappedCollection is in the class-names menu (Figure 12.8d).

I >1~!!!!I~~IIL~ilnnken(mJL~i tllllluJ
I ">:1 Collections-Te:<t I>'> <><>1 Collections-,"",tT,:':. C'r(Jet-edCollectior 1< I C:ollections-::;tre.: ::;ort:edCollect;on
::1'

Intet-',.. al

accessin1j ,j d d irflj copyin'j pt-intin'j pri",..,jte enumer,j t in'j

Collec t ion s- ::;upp'

cia. ss

Collection subcl,jss: #r',,..1appedCollection inst,jr,ce\/ari,jt,lef'o.James: 'dom,jin ma.p , c I,j S s\/ ,jri ,j blef",Ja me s: " pooIDiction,jries: " C,j te1jor-y: 'Collections

."I$;;;;iie-

Figure 12.8a

100

'. ' , '

'. ., . . '. ' .,.,.r.. '................

,....,>.
I'-....

'" bn 0

2
[/J

C)

~ [)

C'i ,...,

co

C.J
'11

C"J
IT)

,= ,=

III

-;;

11)

iT,

~I

e- ='
:=:
L'

:-....,

4-'

4-'
I.

'1' ~ ..... -......' _

6.."D "-

-~ o_~

il:l:g f:-~ t
~
IT) ,", .-, ..:. '.,-,

11)

'T:i 0... 0... .:1]1

IT.::'

,r::,

-~ I'-rr~: i
() '"D
Q.... C

() ""D
IT) 1T:1

O"L
(,) ..:.....

-c c
CL
lo-

>

';.-,0(
CIT)

...,

'1'
.D
iT)

1],1

c
III In

011

I-I

o
III
I~I

1.,-,-I.,",

,n

C
+-'
I_I

'1' '-'
C

'1'
COl
Iri -.-J
: 7'1

I,,=il C~I TI

~
~

'1'

-~ -~
1_1

III

-:. TI
:: III
~

111

1],1

~-g
4--'
~
I

~I

'1' 0... u..


11)

1,-.
III

::I
1'-1

'1'

~t
1,'-'

1,-. C

'1'
1,-.
1,'-'
11)

...,
o
'1'
I

lJ~1

1,'-1

(_-I

'-'

c -..::J
01'

"D
L
I

to

C'

~~~
1,'-'

:=

1.,_,

It'
-.-- _
L 0

'1'
c:

1'-1

C
III

...:.::J
I I I
I I -

h-,
111

'1'
1-'

..D

'.,", -:' c -~f ::;:'


1.,",1.,-,

~'

'.-

~ -',

~ of: ,~; '-~ I I


'.,-.1.,-. ,.,., 1 ..-,

~ ~ ~

.TI

:;:

-D

e c o 0
1]1

e c c c
I_I I_I

o .:. c' -:.


I_I

'-'

III

III

III

III

III

~~:~:~~'
u
1'--'

~ -~: -~

-~ ~ -~ -~~ ;: c
c ~> -~

._-"

I I I
--

Ill....::.,;,:."'D:"'"

='

"::

1,-,

-="..::J
'_

(:> I)~I
.",

~ ~ .D ---=-

o
'1'

h~1

'1'
,r.

-3

2
0

,-,

.....
--

'-"1 .- -I

o '='

I'M'-"I .- -, .-

C' Ct C 1 0
I .-",

::::::;:;:}

~:~:~:~:~~:~:~:~:~m~:~:~~ ~:~:~:~~:~~

.: : : : :

~:~:~:~:~:~:r:~:~:::::::::::::;::'

<=) < =)
..0
00
M

~ ~
C,)

C\i

C\i
M
<1)

00

:;j

....

bLl

"c~

272
Modifying Existing Class Definitions

:::' y stem -I::::ompiler :::' y s t e m - F, e I e ,j s i r,l Fi I e s - ::::' t roe ,j r(,s File s - ,"', ('S H,j C t Files-;:ero. ,"',Ito

r"i' ,j pp edC 0 II ec t ior

'!!'!o/!I_.~
r",j,j me'=' f:::, upercl ,j 5 s SU(, cl.j 55: #' [",j ,j me ,=, fC I,j S 5 ins t .j r, c e ""i ,j r- i,j b Ie r'"J ,j m e 5: 'i n 5 t ""i .j r f'.J .j m e1 ins t ""i .j r f",J ,j m e 2 ' c I,j s c, . . i .j ri ,j (,Ie[.j.j me s: 'CI,j s S ....i.j d",j,j m e1 C I,j s S""i ,jrf",j,j me2' p 00 ID ic t ion ,j rie s: " ': .j t e 'j 0 r- y' . Coil e c t i 0 r, s -

r"i' i sc e II.j n e 0 us'

Figure 12.8d

100 000
The two examples just presented show how to move a class into a new category, either one that existed or one that is created anew. It is possible to create a new category by choosing the command add category from the yellow button menu of the class-category subview. Adding a class category works in a way that is analogous to adding a new message protocol (see Section 11.2). The yellow button menu also includes the commands rename and remove. These also work in a way analogous to the commands used for renaming and removing message protocols. The command edit all is in the class-category subview yellow button menu. If you choose this command, the class categories and class names in each category appear in the text subview of the browser. The syntax for the categorization is like that for the organization of the message protocol! message selectors. You can modify the organization and then choose the text subview yellow button command accept. The syntax will be checked and, if correct, the class categorization will be updated. You should not attempt to remove access to a class by deleting it. You cannot specify more than one category for a class. And you cannot create a new class simply by inserting its name in a category.

"

Creating a New Class Description

13.1 Define a New Class 13.2 Define the Class Protocol 13.3 Define the Instance Protocol

274
Creating a New Class Descr,iption

Class Commander represents an object that controls several line-drawing Pens and coordinates their drawing a design. The class was presented as a graphics example in the book Smalltalk-80: The Language and its Implementation; it is presented here to illustrate the process of creating and testing a new class description. A Commander is an Array of Pens. Pens controlled by a Commander can be given directions by having the Commander enumerate each Pen and evaluate a block containing Pen commands. So, if a Commander's Pens should each go: 100, for example, then the Commander can be sent the message
do: [ :each I each go: 100]

Alternatively, the Commander itself can be made to respond to the message go: 100, where the method associated with the message go: consists of the enumeration message. A Commander also responds to messages to arrange its Pens so that interesting designs based on symmetries can be created. The message shown in the figures is fanOut. The purpose of fanOut is to arrange the Pens so that their angles are evenly distributed around 360 degrees.

13.1
Define a New Class
You have already reviewed all the parts of the browser that are used in creating class descriptions, with the exception of declaring a new class by editing the template for a class definition. When you want to add a new class description to the system, you first decide on the class category in which you want to access the class. Choose that category. A template for specifying the class appears in the text subview. (See Section 12.6 on how to add a new category.) Class category Graphics-Display Objects is an appropriate category for class Commander. Choose this category (Figure 13.la). The class definition template is in the form of a message to a class. The first word in the template represents the message receiver (NameOfSuperclass). It should be replaced by the name of the class that is to be the superclass of the new class. Select this word (Figure 13.lb). Type the superclass name; in this example, the superclass is Array (Figure 13.lc). The message pattern consists of keywords (those words with trailing colons) that should not be changed, and message arguments. None of the syntax for literals should be changed (that is, the hash mark # and the single quotes). The message argument for the keyword subclass: must be a symbol constant; the rest of the arguments must be string constants.

275
13.1 Define a New Class

Figure 13.1a

100 000

sub cl ':.

55:

8 f'"j ':. m8 5:

i rr 5 1:

# r'"j ':. m 8'=' fC I,~ 55 \ . . ':. t' r'"j ':. m8 1 i r, 5 1: \1

,~ t r",J ':.

m8 2 .

,:.d'"J,:. m8 1
I: ':. 1: 8 Ij 0

CI,~ 55""',~

d'"J,:. m82'

P CI CI I [, i': 1: i 0 r, ':. t' i 8 c,: " t' \,' ,:; t',~ Pr, i': .: - [, i .:' p I:. y '=, tl .i 8 ': 1: c'

Figure 13.1b

000

276
Creating a New Class Description

The desired class name is Commander. Select the first message argument NameOfClass (Figure 13.1c) and replace it with Commander (Figure 13.1d). Select the "dummy" instance variable names instVarName1

System Bro'o//ser

': I:..:: '::'.,..:. r'i.:. bIJ2r...j.:. mJ2'::: "=:1.:..::.:: \ ...:. d'.j.:. rJ'IJ21 CI.:. 33\" .:. t'r...j.:. rJ'I 122'

po ,:,1 [, i': 1: i ':' r,.:, ri 12 '" .. ': .:. 1: 12 'j c' r .,=, t':' Pr, i c ,. - D i 3 pl.:.

y ,=, [, .i 12 C 1: ,.'

Figure 13.1c

000
System Browser
,:.:; t-.:.

,=: cd I12 ': t ion.:: - ::' IJ p P, p r, i ': ,. - F' t- i rJ'I i t i'i

ClJt-3C't-

Wl!i'd1iW)"id
,=,,-.:. r:,hic .:: - P:. t h.::
'=-i to:. p i': , -'i i 12 ....... ,=-i t-.:. p I c ,. - E 'J it,:, t- ,. '.1 r:. ~,r, i':.:: ,'; k, ': I ,~
C:.. tT.:' :,.
I

[, i ,. pi:. >' r'i'J2 di IJ r,',


Di3pl.:. _,"'='biJ2': t ['i .::pl:. \. ::": t-J2J2r,
[, i ,. pl.:.

r, r,

>' T 12

1:

,IJ II C I.:. .:: ,.:

It ,=: 0 m rJ'I .:. r, d 12 t'

i:. ri:. t,IJ2(.]:' r'-IJ2'::: . . . . ': I.:. .:. t-i.:. ld 12 ['.. j.:. rl-,J2':: ',=: I.:. 3':: \ . '.:. d'.j.:. rJ'II2 1 CI.:. 3 3\i.:. rl".J.:. ~,,:,c:l['i,: rl,:,r,,:, ,-iJ2':: ...
r,,:: r:. r,l: 12

M'.fi....;i....Mi"piJ

rJ'I:2'\

': .:< t 8 'j ':' I'.

. ,=,

t-.:<

Pr,l ':

, - ['I ,. pl.:.

:" ,= ' bi 8 c 1: ,.

Figure 13.1d

000

277
13.1 Define a New Class

and instVarName2, and remove them by choosing the yellow button command cut (Figure 13.1e). Similarly, remove the ttdummy" class variable names ClassVarName1 and ClassVarName2 (Figur~ 13.lf). (Notice

1< < <

ClJr"50r" IfiI~imtr.l!l!fiM:rm. .1 Di5pl.:.yl'./1edilJm


Di~.pl ':..)" '='bjec t Dis pl.:.. y ::' c roe e n D i 5 pl.:.. y T eo t

cl.:. 5::.

,"-,rr-,:. :." 5IJbcl.:'.55: #C:omm,:'.nder


i r,5

t ':. r,,= e""/.:. r"j ':. t,l e f',j .:.. me 5: ' instVa rf'Jame 1 instVarf\Jame2

c I':.. 55.. . / ':. r" i.:. t, Ie f".j .:. me 5: . C I ass . . / a r-r'.j a rn el C I a 55.. ./ a d".J ':.. rn e ~' , poolDic tion ':. rie~,', .,

c .:. t e ,~ c, r y: . ,::; r" a p 1""1 i c 5 - Dis pi,:..)"

'=1 t, j e c t 5 '

.:'.ccept ca.ncel for-rn.:.t 5p.:'.'//n eo ",lain

Figure I3.Ie

010
TIIIIBDiIrm_1 Dis pi,:. )" r',/l e diIJ m
Di5pl.:. y('bject Di ::,pl ':-. :0" ',:,c\">:!>:!rl Di 5pl.:.. y T eo t
(/ ':. 55

C IJr5 c,r

."-. r" r" ':. :." 5IJ t, c I ,:t 55: # Corn m':. n ,] e r"

i r, 5t ,:t r, c e ".,. . .:t t- i ,:t b I e r'o,j.:. me 5: ..


,= l:t ,~ 5""/ ':. r"i.:t til e f".J ':. me 5: . ClassVarf\lame 1 Cla55Vo rName2 po 01[' i,= t ior, a ri e~,: ,. c ':. t e ,~ 0 r" y: ' ,::; r- ':. p 1""1 i ,= 5- Dis pi,:. y (, b.i e c ts .

5 P ,3. "i'i n

e, "iI,:.in

Figure I3.If

010

278 Creating a New Class Description

that if you do add class variable names, the first letter of the name should be capitalized.) Now evaluate the message expression by choosing the yellow button command accept. Class Commander is now defined in the system. Its name appears in the browser class-names menu (Figure 13.2). Because it is a subclass of Array, class Commander must be a ((variable subclass," which means that its instances may have different numbers of indexable instance variables. The system automatically made this designation. A.ll of the capabilities that support browsing, querying, and modifying system classes are available for this and any user-defined class.

Collec t;onsGraptlic;;-Pr

I
,x

1<<1 C:;r,:.phic:::-Ck -

1<).> ,( 1> >I,jr,:..phic;;-Ed

g~::~:~::~~=~:~ ~,

Commander Cur;;or ~ Di:::pl,:. yr',/1edil)m Di:::pl,:.yl)bject Di:::pl.:.y::;creen Di:::pl,:.yTe't cia.::::::

I''>,'.>J i.i:.,rr,:. y "/ ':. ri,jt,le::;ubcl,j ::::::: #Comm an(jer

in::: t .:.. nce\/ ,:'.ri,:.. t,ler'"J,:. me:::: "


e\ ,00 :::;,\/00 ri.j bler",j ':. me::: ,.

p ':' olDie tion,:. r-ie:::: " c.:. t e'jory: 'ir,:. phic::: -Di:::pl.:.. y ('bjec t:::'

Figure 13.2

13.2
Define the Class Protocol
An instance of class Commander should be initialized by sending the class the message new: with an integer representing the number of Pens that the Commander must coordinate. The message new: must be reimplemented in the class protocol of Commander in order to create the Pen elements of the array. Choose the browser menu item class (Figure 13.3a). The message-category subview displays the categories for the class protocol; none have been specified as yet. Add the protocol name instance creation by choosing the yellow button command add protocol in the message-category subview (Figure 13.3b). The prompter

279
13.2 Define the Class Protocol

D i::: pi ,3 Y r",.., edium Di:.pl.3 yl)bject D i::: p I,3:.1 ::,c reen Di:::pl.3yTe,t in:::t,3.nce

,=: 0 m r,', ,3 n c.J ere I,3 ::: :::


in::: t ,3 nee "'' ' 3 r' i,3 [:,1 e [',J.3 me:,: ..

100
Figure 13.3a

000

Figure 13.3b

010

280
Creating aNew Class Description

appears; type the new name and then choose the yellow button command accept (Figure I3.3c).

.:<Ij,:<in undo

~~~~ . .1l.J

r - - - - - - . . . . . L . - - - - i copy Enter ne'// protocol n


trlen accept or- CFi print it

Figure 13.3c

010
The new protocol appears in the message-category subview (Figure I3.3d). It is automatically selected and the method template appears in the text subview. Edit the method template to specify the new method for new: (shown in Figure I3.3e). This method creates an instance of Commander and assigns it to the temporary variable newCommander. For each element of the Commander array, a new Pen is created and stored. The new instance is returned as the result of the method. Choose the yellow button command accept in the text subview to compile the method and add it to the class description.

281 13.2 Define the Class Protocol

",ne::::::.j/je :::elector .jnd .jnjument na.me::: "comment :::t.jtifllj purpo:::e of me::::::.jqe"

I tempor.j.ry . . at-i.jble name::: I


:::t.jtement:::

Figure I3.3d

Coli e c t ion s - ::; up ....................... C-irapr,ic:::-F't-imiti"': Cur:::or iiiiJilii.... Dis PIa yr.. ' e 1:J i u m ... ......... :1 fir.j p 1"1 ic::: - p.j trl::: D i::: p I.j YC1t,je c t Di:::pl.j y::;c reen Gt-.jprl ic::: - . . . . ie'.. .. ::: ......... :1 Gr,jpr,ic:::-E,:Jitor::: Di:::pl.jyTe".t 1 > 1 Graphic:::-Clock::: in:::t.jnce

HDi

plinl.liiiMiilu~iiliil~-~-~-:-:-~-~-~-~-~-:-~-::r-~-~-~-~-4_~-~-~-~-~-~-Wl!1 .l IliBiEliEm.mlllml------------

ne,:.. : numben)fPen::; "Ct-e,j te ,j Comm,jndet- ,'. ... itll numberC'fF'efl::: element:::, e.j crl of .jlj.jin undo

ne.. .. Commander

copy
cut

fle.. .. Comm.jn':Jer - :::uper ne.. .. : numbet-C'fPen:::.


1 to: numberC'fPen::: do:

[ :inde

fle.. .. C,)mm.jnder at: inde . put: Pen fle.. ,:J.


A

t fie . .. . '=:omma n/:Jer

Figure I3.3e

010

282
Creating a New Class Description

,1,,1: rlumber"C'fF'en::, "C:re,:tte ,01. Comm,:trl,:Jer' ', 1, 1 i U'I rlumber",=,fF'erl:' elemerlt::"


'i'i

e,:tCrl of

rl i c rl i:. '01 F'e rl ,"


I

rl e 'i', ,=: ,=, rl"1 m,01 rl d e r"


,1'i:

rle',,1,,1'=:or(lm,:trlr:Jer' ... ::,uper" rle


1

rlurl'lber',=,fF'erl::"

to: rIUf(I[,er"C,fPerl:' r:Jo: [ :irlr:Je,

rle'.,1',1C,:,mm,:t rl,:Jer" '01 t: irlr:Je, put: Perl rre', i],


A

r rle',,1,, '=:,:,mm,:t rl,:Jer'

Figure 13.3f

000
The message selector new: appears in the message-selector menu (Figure 13.3f). Find out whether this method works. In the text subview, type the creation message Commander new: 4. (Note that we typically opened up a separate workspace in which to type and evaluate expressions. However, any text view in which the text editor and the do it command are available can be used.) Send the new instance of Commander the message inspect. The expression is shown in Figure 13.4. Select it and choose the yellow button command do it. You designate a rectangular area in which the inspector will appear. In the inspector, choose the pseudo-variable self. The value that prints shows that the array has four elements, each a Pen (Figure 13.5). Do not close the inspector because we will use it again. Now let's go back to the browser to add line-drawing messages to Commander. Before you will be able to make new selections in the browser, you have to indicate that the text you typed in the text subview was temporary and not to be saved. Do so by choosing the yellow button command cancel (Figure 13.6).

283
13.2 Define the Class Protocol

'"'.," 5

D i 5pi,,," Y r",:, e cJ i u rl"1 D i 5 pi ,"" y(,(,je c t D i 5 pi,,," :.1 ::' cr"e e r, D i 5 pi,,," Y T eo t In::,t,,,"nce

r,e"':'':' r,umber"'='tPer,5 "Cr"e,,," te ,"" Comm,,," r,,:Jer ',,:,,:itr, r,umber"l)tPer,5 elemer,t5, e,,,"cr, ot

r,e 'i'i ,=: o mr'-I,"" rJ':Jer r,e',,:,"'=:or,',m,,," r,,:Jer" - c,uper" r,e',,:,,:: r,1 te,: rlumber"'='tPer,5 do:

,:<'j,:<.in urJl:Jo

[ :i r, d e,

I r, e

"':'1

F'en r,e',,:,,:],

r r, e 'i'':' =: 0 rl"1 m,"" r,,:J e r

Figure 13.4

010

(Commander nev/: 4) inspect

Collec t ion::,- :::IJPP' e~Nri.t 'it",,," phi c 5- Primi t i ',,: Cur50r" $r~t.iP!t ... l)i$ptaY D i 5 PI,:<.y r',,..l e ':J i IJ m G r",,," prlie 5- p,:< trl5 Di5pla Y(lbject C,r,:< pr, ie 5 - ....,: le'.,",,1::Di5pl ,:<y ::,e reG to,,," p r,ie 5 - Edi t or5 D i 5 PI ':<. Y T eo t C,r,:< pr,ie=:, - Cloef5 nlJmber('tPen"

(a Pen Per,:,

rJ e "',,.. Com m,"" n d e r I r, e ,,:,,: ,=: 0 mrl"1 ,"" r, d e r' ... 5U t ':': r,u m(, e r"'=' tF'e r, c' d [ :i rJ de, I r, e '., i ,=: 0 n r r, e '':'i Com m,"" r,l:J e r

Figure 13.5

100 000

284
Creating a New Class Description

Figure 13.6

010
Now select the browser menu item instance and specify three protocols, distributing, moving, and geometric designs. You can use the add protocol command. A faster way to add more than one protocol is to choose the yellow button command protocols in the class-names subview (Figure 13.7a), and then edit the text subview as explained in Section 11.2 (Figure 13.7b). Choose yellow button command accept. Choose the category distributing and edit the method template to specify the method for fanOut (Figure 13.8a). This method consists of one enumeration statement in which each element of the Commander is retrieved (self at: index) and sent the message turn:. Each element is (3601 self size) degrees away from its neighbor. Choose the yellow button command accept. The message selector is added to the menu in the browser (Figure 13.8b). Return to the inspector for the instance of Commander created earlier. Inspect one of its elements by choosing the element (for example, element 2), and then choosing the yellow button command inspect (Figure 13.9a). An inspector for the Pen is created. Choose its instance variable direction and note that the value is 270.0 (degrees) (Figure 13.9b). This value is the default for all Pens.

13.3
Define the Instance Protocol

285
13.3 Define the Instance Protocol

file out pr'int out spa"i'in

s 'I.:' ii n

r, i e r:.. n: r, Y

hler.:.rcrIY definition comment Inst :. r'efs cl.:.ss :.r refs cl.:.ss refs
r_e_fl_'Il_:'_"i_e_ _..

:r

inst.:.nce\i.:.r'i.:. pool Die t ion a ri ~g,,

c.:. te1jory.. Cit.:..phic s- Di spl.:. y (Ibjec t s'

Figure 13.7a

010
Iq.~~am.1
Disp!.:. Displ.:. Displ.:. Displ.:. r"i1edium (Ibject ::1 cre en

Te

t
COP)/

cut ('cJisuibutin1j' ) I. 'mo"ilrI1j


-1,:t.5te

("jeomeu;c cJes;'jns'

l..

do It print it c:. el form.:. t sp.:. iir, ',I.:..in

e..

Figure 13.7b

010

286
Creating a New Class Description

fanC'lJt ","-,rr,jTI'je the Per,::, ::'0 H"jt their- ,jn'jle::. of or-ientation ,jr-e e\,'enly ,j'j,jin IJndo to: ::.elf ::.i:e do: [ :ir,de,
C (I P~~/

ClJt
-1)+
(:~; eo Ci

( c, elf ,j t: irll:J e, ) t IJ m: (i r,,:J e,

::.elf ::.i:e)l.

I:JO It print it

010,",",,",,,,,,,,,,,','.', .
Figure 13.8a

rno',/in1j Ij e 0 rn e tri c I:J

'6 00" "

","-,tT,jrl'je Hie Pen::. ::":' th,jt their- ,jn1jle::. of or-ier,t,jtion ,jre e',,'ertly l:Ji::. trib IJ t e,:J ,jTOlJr,,:J
:~:

eo CI ,:Je Ijree::.,"

to: ::.elf ::.i:e do: [irll:Je, ': c, elf ,j t:


i r,

,:J e, :' t IJ m: (i r, d e, -1) + (:~: eo Ci

Figure 13.8b

000

287
13.3 Define the Instance Protocol

... < >..... >.> '_:ollection'::-::'lJpp' ... 'Jr-,:.phic.::-Pr-imiti.. . . q"Q"cs-<Pi$~~Y ......... < ... Gr.:. phic.:: - P.:. t h.:: Gr-,:.phic.:: - . . . . ie',.. ,.. .:: > <.1 Gr,:..phic.::-EcJitor-.:: .. < ><.>< .. I Gr,:.phic.::-Clock.:: f,:.nC'lJt
","',tT.:.rl'~e

< ... ::,:.. .::tem E;r-o'.. .. .::erl<>>

J--==-~~-~-...l+4A44;;';";OAAAAF.;;;.;.~~~~~~~~~~~.;;;.;.4

< <

><>

>

>

< > <>

< ~I

CORiMridQr

ClJt-'::OtD i.:: pl.:. yr',,,,, e cJ i IJ m Di.::p I':. yC'bje c t Di.::pl,:. y:::ct-eDi.::pl.:.yTe t

mo.. inq

~~~~~tijg
'~eometric cJe.::i,~n::

.~
'::0

the Pen.::
:~;6CI

cJi.::tr-iblJtecJ .:.t-ouncJ

cJ

to: .:: elf .:: i:: e ,] 0 : [ :incJe (.:,elf .:.t: incJe, ) tl

I I~
i;.:
:~?

~f

~]
tt< >"T>"7<0>"7ttrrTIrr...TI:m.: .... ..::"T:::"7::.:::T .

Figure 13.9a

o 1 I0

>

<< < >.> > < << <.<.>> < .< / .


< < > : > < <>
. , ..

~yl~i:!

\~~~

: IT: .: TI:.TI.: :.>r : >TI:d~

.:., ... <

: ,y.::tem E:n:".. . . .::er


'_: 0 II e c t ion.:: - ::' IJ p p' 'CORi~dQr 'Jr,:.yrlic.::-Primiti,,,, ClJr-.::or~~~~~tijg qrq"~:...Pi$ph"Y D i.:: pi,:. y ".. ., e ,] i IJ m m 0 '... 1rl'~ .:>:> .. ::<. Gr-.:.phk.::-P,:.tr,,:: Di.::pl,:.yC'bject ,~eometric cJe.::iqn:: .. Gr,:. phi c.:: - . . . . ie '........ .:: Di .::pla<."::,cr-e - r, - - - - - - - - - - -. \ . : Gr,:.pr,ic.::-E,]itor.:: Di.::pl.:.yTe,t Commarll]et-I

'.:" <

C_'t_-.:._. r_d_c_.::-_'_:::_1 _' ~_' c C_f:_.::_j

nnan !IIo....'~: ..:..:.<.. .CQ I


271],1]

.:: elf

fanC'lJt "."'.r

>:: .:

the Pen.:: ,0 that

:1::

".. .. i,] tr,


. .

rleil~ht

....
<

Figure 13.9b

100 000

...

".

.,.

':,OlJrce: ' ,::olJrce ',' clip:' ,:Iip ',' clip'o,I'iicJtr, c lipHei,~rl t fr,:.me I,:,,:.:.tion

-...,.,</
...

m'8:"' penD,:,\:.(

"

288
Creating a New Class Description

Direct each of the Commander's Pens to ((fan out" around 360 degrees by evaluating the expression self fanOut within the text subview of the inspector for the Commander. Type and select the expression, and then choose the yellow button command do it (Figure 13.10>. Now check the value of the variable direction of the Pen whose inspector was created (Figure 13.11). This is the second of four Pens; each Pen orientation should differ by 360/4=90 degrees. The first Pen should remain at 270 degrees, the second should be at 270 + 90 = 360 = 0, as indicated. Continue to test the new Commander. In the inspector for the Commander, type the expression
self do: [ :each I each defaultNib: 4. each go: 100]

which directs each of the Pens to draw, with a 4 x 4 square brush, a straight line 100 pixels long. Type and select the expression, and choose the yellow button command do it (Figure 13.12a). The result is a ((plus" sign as shown in Figure 13.12b. Add more messages to the class description for Commander. Add the messages turn: (Figure 13.13) and go: (Figure 13.14) to the category moving. Add the message spiral:angle: (Figure 13.15) to the category geometric designs.

""',,@'G
1 t
I

,:'Ijain

undo
cop~~'

~,ourl:

e::-::

e ut
p,:. 5te
-,rir~ it ,:.ccept c,:.ncel

:.C1Urc. e 'I'

I: lip:: e lip ','


,:lip\"'iidtl'"l eli p H e i '::1 1'"1 t fr,:. me loe ':. t ie,n

Figure 13.10

010

__..........0004

dimction

.'. penDo',/,/n

r
289
13.3 Define the Instance Protocol

........

..................................................................... <. < > < < > >< . ....... . .. < ....

Collection,::-::,uppl CMmnCW~ . IJr,jprlic.::-Primiti',/ Cur.::or di$trl~~~g e:s..... p;~pt~y D i.:: p I ,00 Y("/' e diu rIi rIi 0 "/ i n 'j "r=.pr,i,-,-P=.tr" Di.::play(I[lject Ijeorlietric de.::iljnc I~ r-:~ prlil;;' - . ./'ie"/'/-~' Di .::pl,j y ::,cre - r, - - - - - - - - - - -'Jr,j p r, ic.:: - E(jit or.:: Di.:: p 1,00 Y Teo t Comm ,00 n(je r'l G r ,00 p r, i c .: - C I 0 c k.:: l-:i:--nn . -~ I-,-:1 -----------------T'-,j--F-'e-r-,-......11-.-------, .:--an- ...l ..... I-t-,j-r-,I-='-u-t----...L= =:ioi:iI ~ e, elf

qn.p..

",':::',r'

n,e Per,.:: ',/,/i'Jth hei'jht


5C 1Jt'C ~:.-::
1

'::0 nl,j\~>

.::elf f,jn(lut

~1:llJr( ~ 'I'

Figure 13.11

100 000
...................., ..

l:niMrpenD'? :r:

I: lip (lip ',' I: lip',,i,,iidth I: lipHei'jht fr-,jme lo(,jtion

C ollec t ion.:: - ::,Upp' Gr',j p 1'"1 ic.:: - Primi t i"/ ~ri1P p~+P;$~~y G r,jprlic.:: - p,j tr,,:: Gr',j p r, ic.:: - . . /ie',/,/.:: G r,j prlic.:: -Edi tor.:: Gr,j phic.::- Cloc k.::

CMlijlilicwr
Cunor' D i.:: p I ,00 Y r,,/, e diu m Di.::pl,j yC1bject Di.::play::,creDi.::playTe,t

mO"/lnq geome-UIe de.::iljnc

di$~rl~t~g

instanC'j

cl
.::elf f,jn(lut

...... . id tr, heiljrlt 1 tl .::oun:e:: clip: ' clip ',' I: lip',,i.,iidth eli p He iIj 1'"1 t fr',jme I,:,( ,00 tion

0.0
4

self do: [ :each


each

I
n undo
COP)/

ea ch defa ultNib: 4

90

100J

cut p,j.::te

Figure 13.12a

010

.I.-,..,...,..,...-t dirt:lctKm

290
Creating a New Class Description

'Ci r' ':=< p 1", ie e, - F' r' i r,', it i Oraphi~$-Oi$phk ,=.. r' ':=< p 1", ie ~ - F' ':=< H, ~ ,=r ':=< p 1", i': e- "/ i ~ "i',' .. 'Cir',:=< pl",ie .:' - E,:Ji tor' Gr',:=< pl",ie ~ - Clocf ~ t,:=< n'_'ut di.:,tr'it,u ''''iidth 1", ~ ilj I",t 1 t I .:,,:,ur,: ~:

,=: ':' II ~ e tie, r, e, - ::' Up

in:stari~

U,U

e lip
e lip ',' I: lip"-'''ii,:Jtl'', ': lip H ~ i'j 1", t
fr',:=<
m~

iiWiiiii!
distrit,utinq

I,:,,: ,:=<tion

Figure 13.12b

000

....._ _.... dimctioo


p~n['o 'i'ir,

':=< Ij':=<,in undo

turT,:

d~ljr~~~

copy
,:,f
H,~ F'~r,~

"T~II ~,:=<I:h

to tUtT,

1:J~ljr~~~,"

cut
-I,~,::: 1:e

I:JO It pr'ir,t it c,:=<,n, ~I format sp,:=<, "/'in ~, '11,:=<,in

Figure 13.13

010

291 13.3 Define the Instance Protocol

IlanlllllDEBaI Dis pi,:. y r',,..l e diu m


Dis pi,:. y ,=, t,.! e c t Displ,:. y::,cr"een Displ,:.yTe,t class di s t ':. ric e " Tell e ':. C 1""1 0 f
1:1""1 e

bddidi

,]istrit,utinq

IIUtl!l.il., 11

------------

'~eometr"ic desil~nc

,:.,~,:.in

F'e n s to 90 '] i st

,:'TI Ce, "

un,]o
(: (I

p ~~. .

cut
-11:t.5t~

do It pt"int it

Figure 13.14

010
> Ilpmi~IIIDI.1 Dis PIa y r"/l e ,] iu m
Dis PI ,:.y ,=, b"1 e c t Displ,:. y::,cr"eerl Displ,:.yTe. t
,:.,n,~le:

distr"ibutin,~ mo',/in,~
------------~~~~

,:.,~,:.in

class spir,:.I: number-('fLines de9r"ees


"H,:. ',,..e e,:, ch Pen dr,:.',,..,'" ':. double spir,:.I,"

undo

coPy
cut ",,:.ste do It pt"int it canel forma, t ::,pa,\.. .'n e> ",lain

t':': rlumber('fLir,e::, ']0: :i

self ,~o: i, self tUtTi: deweesl

Figure 13.15

010

292
Creating a New Class Description

Now let's test these new messages. Create a workspace or use any text view to evaluate the test expressions. For example, in the inspector for the Commander, set the brush of each of its Pens to be a 1 x 1 square, send each Pen home, and then direct the Commander to go: 50 and create the spiral geometric design. The expressions and the result are shown in Figure 13.16.

self I~O: 5Cl self spira.l: 60


a.nl~le:

:::9,;..

ODD::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::1

Figure 13.16 In a workspace, create a new Commander for six Pens, each with a 1 x 1 square brush. Direct the Pens to fan out, go a distance of 50 pixels, and then make a spiral design, as shown in Figure 13.17. You have now created and (incrementally) tested a new class description. To save your work, choose the yellow buttbn command file out in the class-names or class-category subviews. This creates a file in which the class description is written in a format that can be read by another Smalltalk-80 system. The file name is the class name or class category name followed by a period and the characters st (meaning ~~Smalltalk" file). The class description is still part of your system. But if you start with a new system (or someone else wants to use your work), then note that the System Workspace includes a template for the expression for reading the file ((FileStream fileNamed: 'fileName') fileln). Suppose you choose file out in the class-names subview, with Commander selected. Then the file created is named Commander.st. To

r
293
13.3 Define the Instance Protocol

"'com do:

[ :e.j.ch

e a. d-I cJ e f .j, Ij I tr'o.J i b:1 ,


ea.ch rlome],
com f ,j. n (:11j t , com I~O: 50,

com spit'a,l: 60 ,jrll~le: ;:;I~

OOOli::~i::~::::::::~:':::::':':i:.~.:::':::~:::::: ::':':i:':i:::~:~:i~i~~::Ti:i:i:iTi~~~~~:]
Figure 13.17

read the file and thereby bring the definition of Commander into a new system, evaluate the following expression in that system
(FileStream FileNamed: 'Commander.st') file In

More information about saving your work and about external files is given in Part Five.
As additional exercises, you might add the messages defaultNib: and home to class Commander. In each case, the Commander would distribute the message to its Pens. An interesting exercise to try is to modify the system browser so that you can retain reference to a full query-class category, class, protocol, and selector. The idea is to add a list menu subview to the browser that is initially empty. Add a browser yellow button command save query. When you choose this command, the current menu selections of the browser are saved as a menu item of the new list menu. If you choose such a menu item, the browser selections are all changed appropriately.

Improving Performance

296
Improving Performance

We have seen that you can determine whether your methods work Correctly by inspecting the state of the objects involved in the interactions. Another question you might ask is what percentage of the total time in evaluating the expression is spent carrying out various messages? You can answer this question by using the Smalltalk-80 spy. The purpose of the spy is to carry out an analysis of a block of code. The analysis consists of the (nested) sequence of message-sends and the total percentage of time taken up evaluating the original message. The spy creates a workspace labeled Spy Results in which this hierarchy is printed. The best way to understand the spy is to follow an example of its use. Suppose you are interested in analyzing the evaluation of the expression
Smalltalk keys asSortedCollection

This expression takes all the entries in the SystemDictionary, Smalltalk, and sorts their keys in alphabetical order. To spy on the execution of this sort request, evaluate the expression
MessageTally spyOn: [Smalltalk keys asSortedCollection]

In other words, the spy is run by sending the message spyOn: to the class MessageTally. The analysis is carried out on the argument. When the analysis is completed, you are asked to designate a workspace in which three levels of information are printed. First, it indicates the number of tallies, that is, the number of times the execution of the expression was interrupted to determine which message currently is being sent. Then it provides a description of the tree, and itemizes the ((leaves" of the tree (the messages at the lowest level of nesting). In sorting the keys of the SystemDictionary, Smalltalk, the tallies are
54 tallies

Note that if you try this example, you might get slightly different results because of differences in the statistical sampling (in the number of interrupts). The second level of information is the description of the tree itself. You can follow the sequence of message calls: 53.7% of the time was spent evaluating SortedCollection class new:; 22.2% in Collection asSortedCollection; and 24.1% in Dictionary keys. (By SortedCollection class new:, is meant send the message new: to the class SortedCollection,) Of the 53.7% in SortedCollection class new:, most of the time was spent in String < =, which in turn spent most of its time in primitives. The message asSortedCollection is primarily a call on addAII:, which calls reSort, which calls sort:to: recursively.

r
297
Improving Performance

Corresponding to each leaf of the tree is a number representing the relative amount of time spent executing the method. Thus, in sorting the keys of the SystemDictionary, Smalltalk, 37.0% of the time was spent executing the message compare: for a String, 7.4% was spent in the method for SortedCollection sort:to:, and so on. The purpose of the third level of information, **Leaves* *, is to gather in one place many occurrences of some message that, if listed separately, appears insignificant.

* *Tree* * 53.7 SortedCollection class new: I 51.9 String < = I 50.0 String compare: I 37.0 primitives I 11.1 Character asUppercase 24.1 Dictionary keys I 24.1 Set add: I 14.8 Set findElementOrNil: I I 13.0 primitives I 7.4 Set atNewlndex:put: I 7.4 Set fullCheck I 5.6 Set grow I 5.6 Set noCheckAdd: I 5.6 Set findElementOrNil: 22.2 Collection asSortedCollection 22.2 SortedCollection addAII: 18.5 SortedCollection reSort I 18.5 SortedCollection sort:to: I 18.5 SortedCollection sort:to: I 16.7 SortedCollection sort:to: I 14.8 SortedCollection sort:to: I 11.1 SortedCollection sort:to: I 5.6 SortedCollection swap:with: I 3.7 SortedCollection sort:to: 3.7 Set do: **Leaves** 37.0 String compare: 18.5 Set findElementOrNil: 11.1 Character asUppercase 9.3 SortedCollection swap:with: 7.4 SortedCollection sortto: 3.7 Set do:

When you know where the execution is spending its time, you can try to improve that method to run faster, thus impacting overall execution of the activity.

Examples of Creating or Changing Browsers

15.1 A Protocol Browser 15.2 A Project Browser 15.3 Modify Class Project 15.4 Change the System Menu

300
Examples of Creating or Changing Browser

One of the typical kinds of things that programmers do in the Smalltalk-80 system is create special purpose browsers, either as additional software development tools or as applications. Example browsers for applications might be:

calendar electronic mail book index

browsing personal or group schedules for visitors, talks, trips out of town, meetings browsing mail sent to you, your responses, and any notes about the mail browsing the information in a book (An example is given in a doctoral dissertation by Steve Weyer [Searching for Information in a Dynamic Book, Xerox PARC Technical Report SCG-82-1, February, 1982].) browsing a database of financial plans, income, and expenditures

budget

Example browsers that count as software development tools might be a protocol browser or a project browser. A protocol browser is one that lets you access the complete protocol of a class; by ucomplete," we mean the messages implemented in the superclasses as well as in the class. A project browser gives you direct access to all existing projects, regardless of how they were created. Implementations for each of these two browsers are given in this chapter as models to follow as you try to figure out how to use the system components for creating views and controllers. Detailed tutorials on the implementation of the user interface and on creating graphical interfaces to applications are provided in the forthcoming book Smalltalk-80: Creating a User Interface and Graphical Applications. In trying these examples, you should be careful not to make mistakes while typing the text. If you find that you are making many mistakes and are confused by the error handling mechanisms of the system, you might put off reading this chapter until after you review Part Four ((How to Find and Correct Errors."

15.1
A Protocol Browser
The first example browser is one in which you can examine the message interface of a particular class. This protocol browser should have the following characteristics: The browser should have two subviews, one containing a list menu and the other editable text.

301
15.1 A Protocol Browser

The list menu subview is a list of the messages implemented by a class and its superclasses. The text subview is an area in which to edit the selected method, as you would in a message-set browser. The message selectors should display in the list menu in alphabetical order. The name of the class in which each message selector is defined should be indicated in the list menu. Selecting a message selector should cause its method to display in the text subview. The method should be editable and recompilable. The standard queries about the message should be accessible, namely senders, implementors, and messages. We call this browser a Protocol Browser. This section contains stepby-step instructions for creating the browser. From this example, you can obtain a glimpse into SOme of the components that are available in the Srnalltalk-80 system for creating graphical user interfaces, namely StandardSystemViews, CodeViews, SelectionlnListViews, and ActionMenus. In a system browser, create a new class category named InterfaceProtocol (Figures 15.1a and 15.1b). The new category is automatically selected and a template for defining the new class is displayed in the text subview. Edit the template to define Protocol Browser as a subclass of Object (Figure 15.2). It should have four instance variables, as follows:
list
An OrderedCollection whose elements are Strings, each of which represents a message selector and the class in which the message is defined. This is the information that will be displayed in the list menu of the browser. A Dictionary whose keys are message selectors and whose values are the classes in which the message is defined. This is used for looking up methods when an item in the list menu is chosen. Either nil, if no list menu item is selected, or the class defining the selected message selector. Either nil, if no list menu item is selected, or the selected message selector.

classDictionary

selectedClass selectedSelector

302
Examples of Creating or Changing Browsers

I r, t e rf.Ol c e - :=:; u p p 0 r - - - - - - - - - - --

Interfa
Inter'~,:<

Ifltert,Ol Inter'fa

file out pr-int out 5p.Ol.'././r,

",/'/5er'\/ie'/,,' tr,odLi5tE;r-'=",/,,' ---------

in 5t Ol r, c e \/ Ol r'i.Ol b Ie r',.j.Ol me 5 ' i r, c' t',,: .Ol r- r",J ,Ol r'-I eli r, c' t "'/ ,Ol r'r\J ':. m e 2 '

( I ,Ol 55\,'
C ':.

,j

r'i 'Ol b I e [",J 'Ol me c': ' C I 'Ol c' C' "'/ 'Ol r- ['"J:. me1
,,:,,:

=: I':. 5 c' "/ ,Ol r' r"J ,j me 2 '

poolDi,= tion,:'t'ie5: ., t e 9(, r y: '\ n t e r f 'Ol ,= e - e r 0 5e r

Figure l5.la

010
System Brov/ser
Ir,ter-f,:. (e-:=:,uppor' Interf,:. (e-Li5C E:r-o ',"/5er E; r-,=, ',,:,,' c' e (', . Ie'" I fl t e t- f ,Ol ,= e - T e t I fl t I~ r-f ,Ol ,= e - r',:1 e r, u 5 r",:, e t h ,=, d Li c' t E: t',=, IfI t er'f,:. ,= e - Prom ',t
E f, t e r- fl'::''','
,j , } j

IfI

IJfld,=,
1=

,=" t 8'j ,=, r- ~ C Fi

up>'
,= IJ t

t r, e r,

,j (

C e p t ,=, t-

p ,=, 0 I [

, i ,=

t I 0 fl ,j n 8 5: "

,= ':. t 8'j'='("

'/rl t 8 r-f,j I: 8 - E;r',=,

581--

Figure l5.lb

010

303 15.1 A Protocol Browser

'='b.i8<:1: ~lJb<:l,j ~~: #F'r01:o<:oIE;r'O"i'i~8r-

inc, 1: ,j r, <: 8 ""i ,j r- i ,j t, I8 [",J ,j m 8 ~: ' I i ~ 1: <: I,j ~ ~ D i <: 1: i 0 r, ,j r-:-,'


~ 8 I 8 ': 1: 8 d ::' 8 I 8 ': 1: 0 r"

~ 8 I8 <:

1: 8 del ,j c, ~
,j'j ,j i

r,

c I,j ~ c, "'/ ,j r- i ,j

t, I8 [",J ,j r,', 8 c,:


"

"

ur,cJo

p ':":' IDie 1: i 0 r, ,j r' i 8 ~:

copy

': ,j 1: 8 'j I:' r Y', ' Ir,1: 8 r f ,j ': 8 - F'r I:' 1: 0 ': 0 I'

Figure 15.2

010
The Protocol Browser should have no class variables. Remember to cut out the "dummy" class variable names from the method template. After you have typed the class definition, choose the yellow button command accept. The new class is added to the class-names menu and is selected. In the class-names subview, choose the yellow button command comment (Figure I5.3a). The words This class has no comment appear in the text subview. Edit it to provide a comment on the role of the class (Figure I5.3b). Within the comment, you can also provide a template for creating an instance of the class, such as
ProtocolBrowser openForClass: className

Choose the yellow button command accept to save the comment.


The protocol name private has no special meaning to the system. By convention, we use this name to categorize messages that are sent by the object to itself, rather than by other objects to it.

The

next

step

is

to

define

the

instance

creation

message

openForClass:. Choose the browser menu item class so that you can de-

fine class protocol.


Note that when you choose class, the system attempts to guess what other selections you might also wish to see. Since you were examining the comment for class Protocol Browser, the system guessed you might want to see the comment about ProtocolBrowser's class (i.e., its metaclassJ. Currently this class has no comment.

Add the protocol name instance creation (Figures I5.4a and I5.4b).

304
EXaIuples of Creating or Changing Browsers

file (,ut print out


~p,:. "i'in Inter-f,:.,: e-E: rl rlier',:. n:rlY I rl t 12 r f ':. ': 12 - I rl rller,:. rc rl Y I rl t 12 r' f ':. C 12 - D definition Inter-f,:.,: e-Fi In t 12 r-f ':. C 12 - T I rl t 12 r f ':. c 12 - F'rL...Iiiiiiil....._ _r-:::-:-:~:.:-:::-:::~-:--t I rl t 12 r-f ':. C 12 - C rl ':. rl q

...::il)je,: t ~ubc I,:, 55: #F'rc irl5t ':. ric 12 ""/,:' ri,:. [,Ie r','I----- -rl-,j-r-CI-e----1 ic ti,:,n,j t'Y 512 lec te(JCI,j55 re 5elec te,j::::,ele': t,)r' '
': I':. e, 5 ',i ,j r'i ,j b I e ['"j ,j rCI e 5: ..

r'emo',/e
"
0

p ':' 0 I[ , i': t i':' r, ,j t'i 12 5:


C ,j

t e 'j ':' r' \': 'I rl t e r-f ,j c e - F'r 0 t

col'

Figure 15.3a

010

Thi5 cla55 t'ept'esents a [It'O''/'/set' in ',/,/hich you can e.,:.mine the

me55,:"je interf,jce of ':. p,:;trticul,:;tr cia 55,

copy
cut 'Iaste ,jo It print it ca. ::el form,:;t. t 5p,:;t'//n e> ',I.:;tin

Figure 15.3b

r
305
15.1 A Protocol Browser

w -----------In t e rfa c e - 8 reo '././ s~lilllrmlJl~. In t erf.:. ce -Inspec Inter-f,:. c e - Deb uq,Interface-File r,./leo In ter-f.3ce- Tr.3nsc ., ...... "" .......,. Interf,:.ce-F'reojec '1-:----~_ Interf.:. ce- Crj.:. n.-

mp" . .,

...

Figure 15.4a

010
In t e rf.:.. c e - E; r-eo '././ s~lilllrmlJl~IIErmll- - - - - - - - - - -Irl t erf.:. c e -In spec ,:'.Ijain In t er'f,:. C 12 - Debuql' un(Jo In t:er-f.3C 12 - File r.. leo Enter' r,e',/,/ pr-eot: copy I n ted ':. C 12 - T r .:.. n sc tr,en ,:.ccept: or cut: Int: erf.:. c 12- F'rojec In t er'f,:. C 12 - Cr,.:, nq

Figure 15.4b

010

306 Examples of Creating or Changing Browsers

openForClass: aClass " Create and schedule a browser for the entire protocol of the class. "

I topView aPBrowser label I


aPBrowser +- super new on: aClass. label +- ' Entire protocol of: " aClass name. topView +StandardSystemView model: aPBrowser label: label minimumSize: 200 @ 200. topView addSubView: (SelectionlnListView on: aPBrowser aspect: #selector change: #selector: list: #selectorList menu: #selectorListMenu initialSelection: nil) in: (O@O.O extent: 1@O.3) borderWidth: 1. topView addSubView: (CodeView on: aPBrowser aspect: #text change: #acceptText:from: menu: #textMenu initialSelection: nil) in: (O@0.3 extent: 1@O.7) borderWidth: 1. topView controller open

In this method, the temporary variable aPBrowser is created as an instance of class ProtocolBrowser and is initialized by sending it the message on:. The label of the browser is then defined to be
Entire protocol of < class name>

where < class name> denotes the place In which the actual name of the class appears.

307 15.1 A Protocol Browser

-I,:' 5 t

top"'" ie',.. ,,' ':. F'E;n:, ',. .,.. .::er I,:.[,el

c-lo It print it c':. nel fOtm,:. t

,:.F'E:to',.. ,.. .::et - .::upet" ne',.. ,.. ,:,r,: ,:.(:1,:,,::,::, I,:.[,el Entite pr':'tocol,:,f:', ,:.(:1,:,,::,:: r,,:.me,
t ':' p.. . . i e . . .'. .

.::p,:. ', . .,.. r,


e, "d,:.ir,

::' t ':. r, d ':. t",] ::' y .:: t em""'" ie',.. ,..

010.,: .,;,.,
Figure 15.5

mo,]el: ':. F'E;ro " '.. .:: er" I,:.t,el: I,:, t,el mir,imum::,i::e: 200'~200
t ':' p.. . . ie',.. ,. . ':. d ,] ::' u t, . . . . ie', , :

",,(,::',el :e.ctionlnLi.::t

ie',.. ,.. or,: ,:.F'E:to'.. ,.. c,et ,:.c,pect: #.::ele,:tor"

The rest of the method consists of four main steps. 1. Create an instance of StandardSystemView. 2. Create an instance of SelectionlnListView and make it a subview of the StandardSystemView. 3. Create an instance of CodeView and make it a subview of the
StandardSystemView.

4. Send a message to the StandardSystemView to obtain its controller, that is, the class that provides the user interaction scheduling (StandardSystemController), and then send a message to the controller to open a rectangular area for itself on the display screen and to make its view the active view. The user will be asked to designate the rectangular area. Each of StandardSystemView, CodeView, and SelectionlnListView, are subclasses of View. View provides protocol for managing a hierarchical nesting of subviews, and for managing the windowing transformations needed so that the user can move and reframe the view and so that all the subviews will maintain their relative positions and sizes. The subview insertion message used in this exampIe is addSubView:in:borderWidth. The first argument indicates the subview that is to be inserted, the second indicates the relative position and size

308
Examples of Creating or Changing Browsers

of the subview, and the third the width of the frame around the subview.
Once your example protocol browser works, you can play with these numbers to see the affect of any changes.

When the StandardSystemView is created, it is informed of the object to be viewed on the display screen, its label, and its minimum size. A SelectionlnListView is one of the kinds of menus in the system. Its instance creation message requires six arguments.
on: aspect: change: list: menu: initialSelection:
The object, one aspect of which is viewed by the list menu. A Symbol identifying the menu to other parts of the view. A Symbol denoting the message selector for changing the information that shows in the list menu. A Symbol denoting the message selector for retrieving the list of strings that show in the list menu. A Symbol denoting the message selector for obtaining the yellow button menu; nil if there is no menu. A String representing the initial current selection; nil if no initial selection.

A CodeView represents a view of text that is editable and in which the command accept means to compile. Its instance creation message requires six arguments.
on: aspect: change: menu: initiaiSelection:
The object, one aspect of which is text. A Symbol denoting the message selector for retrieving the text that is displayed. A Symbol denoting the message selector for changing the text that is displayed. A Symbol denoting the message selector for obtaining the yellow button menu; nil if there is no menu. A String representing the initial current selection (subpart of the text displayed highlighted); nil if no initial selection.

Once you have defined the instance creation message openForClass:, then choose the browser menu item instance so that you can specify the instance protocol. In the message-category subview, choose the yellow button command add protocol so that you can add the protocol private (Figure 15.6a and 15.6b). Do the same for protocol names list access and
text access.

309
15.1 A Protocol Browser

In t e r- f,:. c e - E: roo ', . , . 511i1mmml~:IE. 1 t 12 r f ,01 C 12 - Ins p e c r, In t er-f,j c 12 - [tebuq,Inter-f,jce-File r',/io I r, t 12 r f ,01 I~ 12 - T r 'O! n2' c Ir,terf,j c e-F'ro.iec Int erf,j I~ e-I:::r"j nq cl

;,='b.ie,:t 5ubcl,j 55: #F'rotocoIE:r-I:",/,,..5er

i r, 5t ,01 r, c 12 ",i ,01 r- i ,01 b I12 r'"j .:. m 12 5:


5 12 I 12 I: ted ::' 12 1 12 C t
I~ I ,01 2' ,,"i ,01

'j i 5t

c I ,01 55[t i c t ion ,01 r y 512 Ie ( ted C I ,01 55

r- ,

r i 'O! tile ['"j 'O! me,,: "

poc"e'ic tion,jrie5: ,. I:
,01

t 12 Ij ,:11" y: 'I r, t 12 rf ,01 C 12 - F'r 0 t ':": 0 I'

Figure 15.6b

010
5ysterrl Brov,/ser Interfa ce-Protod Irl t e r f ,01 C e - E: ro "i'i "~II;aMI1'mlil'Ei'Djj:l.jail.'ltl.m#a'll Interf,j c e-ln5pec Irlter"f,j c e-[Iebu'j" In t erf,j ': e - File r',,..10 I r, t '" rf ,'" ': '" - T r ,j r, 5 ,~ I r, t 12 r" f ,=t " e - F' n:, J,:. C I n t 12 rf ,=t " e ,-: 1'1 ,01 r, q

------------

_--------1 ,j.'j,j irl


En t 12 r n 12 "/'/
~
Ij

t------,

n (j (I

trlen ,jccep pr-i',,,,,:, te -

C (I P ~./

cut

...':,'bje': 1: ~lJbcl,~ ;'5: #Pr"otoc:oIBro'",'",'seri r'2' t ,01 r, c 12 '.... ,01 t-i ,01 td 12 ['0,1 ,01 r,",e,,' 'I is t c I 'j2'::

-1,~_5te

----lp r"'1 n t 'I t t - - - -......


c,O!n'.:-1

do It

5elec ted::'elec tor'


': 1,01

22' ' i

O!

ri 'O! b I12 [',j ,O! rIle 2': "


"

~1I:II:d

e, i': t i':' r, ,O! t" i 12 2':

':01

te'jor":_,

'Ir,tet"f,j ': e-F'r',:,toc ,:,1'

Figure 15.6a

010

310 Examples of Creating or Changing Browsers

Choose the protocol name private and edit the method template to specify the method for on:.
on: aClass
" Create the protocol browser for the class, a Class. "

I defClass I
list +- OrderedCollection new. classDictionary +- Dictionary new. aClass allSelectors asSortedCollection do: [ :selector I defClass +- aClass whichClasslncludesSelector: selector. list add: selector printString, ' (' , defClass name, ')'. classDictionary add: (Association key: selector value: defClass)]

Only two of the instance variables are initialized, list and classDictionary. For each selector specified in the class (aClass aIiSelectors), the class in which the selector is defined is determined (whichClasslnciudesSelector:) and then the selector, followed by a tab, left parenthesis, defining class name, and a right parenthesis, is added to list. The selector and the defining class are then stored as an entry in
classDictionary.
Remember to type carefully to specify a tab before the left parenthesis. The tab will be used in another method for distinguishing the selector from the class name.

Choose the yellow button command accept (Figure 15.7),


The protocol name priv~te has no special meaning to the system. By convention, we use this name to categorize messages that are sent by the object to itself, rather than by other objects to it.

You now have to define the messages that access the information for the SelectionlnListView and the CodeView. There are two list-accessing messages, selectorList and selector:; there are two text-accessing messages, text and acceptTextfrom:. The methods are shown in Figures 15.8, 15.9, 15.10, and 15.11. Note that in the implementaiton of selector:, the list menu item is a String that must be parsed to determine the selected selector and class. Instances of String respond to messages such as copyUpTo: that support the parsing. The message changed: is specified in class Object as broadcasting the fact that an object changed so that any dependents, such as a model, its view, or controller, can choose to update itself.

311 15.1 A Protocol Browser

1 t 8 r-f,:; c 8 - E: ro "/'/ :::~lilmmllllia.mIJ t e >: t a c c e:::::: n Irl t 12d,:; c e-In;,pec Ii:. t ,:..ccess In t e r"f,:; c e - De [, u W Interf,:;':e-File r',:'10 In t e r"f,:. c e - T r",:. n:::e Irl t erf,:.,:e - F'rojee In t erf,:. c 12 - Ch,:. nq ,:.CI,:.:::::: "':::re,:..te tr,e protocol [,ro',:,,:,:::er for tr,e c\,:..::::::, ,:..el,:.::::::,"

111111111111&11' 1

a,Ij,:.in undo
c:op~.,,'

cut ",3:::te ejo It pt'int it e,3n 121 fOt-rfl,3t sp,:..,',:,,:,n 12' -,1,3in

defCI,:. 5:::

Ii::: t -

'::' t',:Jere,:JColle,: t ion ne',:,,:,

e I,:;:::::: ['ie t ion,:. ry - Die ti,:,na toy rre "/'/, ':. '::: I':.:::::: ,:.11 ::,12 lee tor"::: ':. :::::,ort 12 ,:JC ollee t ion do: ::::elee tOt'

I C,
defCla.::.:: r,ame,

de fCI,:.:::::: - ':. CI,:.:::::: ',/,:,r,le""C/,3::: :::Inc lude :::::;12 Ie e t,:,r": :::12 lee tOt", li.::t ,:.dd: .::eleetor" pt"int::,trin'j,' ': 1,:.;,;Dic tion,:.. ry
,':11)1)',

'r

Figure 15.7

010
In t e t-f,:.. e e - E: tOO ',:,,:, s Inter"fa ee-Inspee Ir,ted,':I ce-[teblJqr Interf,:.ee-File ,",/10 I r, ~ 12 d ':. ': e - T t' ':. r, .:: ': Inter"f,3 ee-Pn:,je': I r, ted ':. ': e - C r, ':. r, q :.electc,rLi:.t

":',31ue: de fC:la.:: s)

'mi!"Fil-JiIWPi,1lOO*,e5 4geg;I; JI.~~@~.~,.,~,m~~~.111 gtie.tE".:"1'.: ------- ----DC

pri,,:,,:..te

","-,r,'::'o,"",er the li.::t of strineJs tr,,:;t sho'o,,',:, in tr,e list menu,"


r Ii::: t

Figure 15.8

000

312 Examples of Creating or Changing Browsers

In t erfa c e - 8 ro '.,..,,.. s iiiH+g-1 BtlelJ/ltaa~.CI:l~::ielsls lm~!.!~i~"!~~ : ... : Int et'f,Ot ce -Inspee - - - - - - - - - - - selectorList .:::::: :::. Irlterf.Otce-Debuqf pri'v'ate I::: .. : :1 Interf,Ot.ce-File ro,,..10

'j!Mi'd-ll

I.e,-;

II<1

I::::::.::.:: I Interf,Otce-Tr,Otnse

1<

<.1 Interface-F'rojee
In te rfac e -C:h.:. nq selector: ,Ot::,trinq
",~,ns',,..,..er

trle mess.Otlje selector' for crl.Ot.n1jirllj tr,e inform,Ottion trl,Ott

ShO'iiS in trle list menu," ,Ot::;uin1j==rlil ifTt'ue: [selected::;elector .... nil. tselfJ. selecte,)::,elector .... (.Ot::;trinq copyUpTo: Cr,.Ot.r,Ot.cter t,Ot.b) ,Ot.5::;ymbol, selec t e,)C I,Ot. ss .... cl,Ot ssDic t ion,Ot. ry .Ot t: selec ted::;elec tor, self chan'jecj: #te't;",

Figure 15.9

In t e t'f,Ot c e - E: ro '.,. , . s ~llm#lliD'I'I;I.DII:Jjllill.I#I.EglI-III'D'~ e.II;II;~4 ra Interf.Otce-lnspee list ,Ot.cceS5 Int e t'f,Ot. ce -Debuq'pri . .,' ,Ot. t e Intet'fOt ce-File r.. i o In tet'f.Ot c e - T rOt. nse Int erf,Ot. c e -F'r'ojee Interf.:.c e-':::r,anq

II!'I'IiJ.I1I?1

selec t ed::,elec tor= =nil ifTrue: [t" ifF,Ot Ise: ,Ot:,Te, t]

[t (selec t ed ,:::1 ,Ot. 55 :,ourc eC:ode.~,t: 5elec te(j::,elec tor) .Ot:, T e . . t


1"IOt.1 e::, ele I: t orE:o Idin: selec t edCI.Ot s5]

Figure 15.10

000

313 15.1 A Protocol Browser

'IlM,e.".." ,. ' _-
------------

li5t ':'.CC855 pr-j.,... .:. te

. . . . . . . .m'd
t8::<t

acceptText: aText from: aController


".i:..n5 .. ~r tr,~ m~::'5'019~ 5~18CtOr- rot- cr"OInqinl~ trl~ di::.pl.OIy~(j t8,t."

n~,. . ::,~18ctOr-

I
compil~: .:.T~.t

ne.. .. ::;81~ctor- ...


5~I~ct~dCI.:.55

cl ':. 55iri~d: (5818C t ~,jCI.:. 55 on}, ni:., tion C,. t rle, ::,8Iectorne, ::,elector
n~"""'" ::,~I~c torJ.
~9or-yl)rEI8m8nt:

5818C t~d::;elec tor)

notiryin'j: ,'.Contr-ollet-,

==

nil irTnJe: [H.,I:::e]. 5electe,j::,electot- ifF.,I:::e: [5elf ne'.. .. ::;elector-Li:::t:

Figure 15.11

OOOI<b+~~~~~~~~dL?1
Although we have not as yet specified the yellow button menus, you can now tryout the protocol browser. Evaluate an expression of the form
ProtocolBrowser openForClass: < className >

In the workspace in Figure 15.12a, we substituted True for < className > to open a ProtocolBrowser on the class True, a subclass of Boolean (Figure 15.12b). If you select a menu item, the method shows in the text subview. Scrolling works. So does the blue button menu for framing, moving, and so on. Much of the programming work has already been done for you!

314 Examples of Creating or Changing Browsers

I rlt e r'f.:. c e - E: r,:, '....'.. .:' t~'l(t~C@$S li5t ,:.cce55 Irl t e t"f ':. c e - Irl 5p e c Irlterf,:. I: e-[Ielluw pri" ....:.te Irl t e t' f ':. I: e - F1 r""" 0 Ie In t e t"f.:. I: e - T r ':. rl 5c Irltet"f,:. c e-Prl:ljec 'ho..................'""T----1 cl.:. 55

5elec t ':' r' ,:.rlcl ':. njumerlt n,:. me.:, ent 5t,:.tin lj plJt'p05e of

.3 Ij'3in url,)o

copy
':Ut

p,35te
1~lt'ini:\ it

Figure 15.12a

010

,31: c ept ': ,3 ric el

Jnt~rta~~t6C Inter'f,3 ce-E:rO'.. . . 5 Irlt e t"f ,3 Ce - Irl 5p e c Inter'f,3 c e-Debuw Irl t e t"f3 ': e - F1 e r', . . , 0 I In t e r'f,3 c e - T r',:. rl5C Irlt erf,3 ': e - Projec m,.......,.,...""",

'''.P@

((Ibject) ((Ibject) ':. cll:JD epenl:J erll:: ((Ibj ec t)

A& alterna tiveOb ject

"E'. . 3. lu .3 t irllj con j u n c t i0 rl - - ,3 rl .:' '. . '. . e r'


,:.ltetTI.3ti,.. e l=,biect 51rlce t'ecei',.. er 15 tt'ue,"

me5':,,3 qe 5elec tor' ,3 rid ,3TI \1.,: 0 t' f 5P':. >: e en t 5t ':. t I rllj p u

Figure 15.12b

000

r
315
15.1 A Protocol Browser

If you try to use the yellow button menu, you will receive an error notification. Leave the ProtocolBrowser on the screen. Let's define two messages, textMenu and selectorListMenu. Each of these creates an instance of class ActionMenu, an object that represents a pop-up menu that can have lines between its items. An ActionMenu is created with the message labels:lines:selectors:. Here are the three arguments labels:
A String of the menu items, each item separated by a carriage return. The withers message to instances of String returns a String that substitutes a carriage return character in place of any \ characters. Thus you can use the \ to indicate the line change. An Array of numbers indicating after which item to draw a line. An Array of message selectors that will be invoked if the corresponding menu item is chosen.

lines: selectors:

The convention is that the object being viewed will be sent the message, although in several notable cases, such as editing text, the controller (paragraph editor) receives the messages.

The yellow button menu for the CodeView is for text editing, as in a browser text subview. Edit the method template to specify the message textMenu (Figure 15.13a).
Entin:. proto(ol of: TnJ'"

System 8rov/ser
In te rfa e e - Pro toe. In t e t'f.", (e - E: ro . . . . . 5~I;I;mtli1D.~.'I.~nWlii:Jjiil l;.tTl.l#iJl.III'~'~.all.II'.I.1I n t e t- f.", ( e - Irl pee - - - - - - - - - - - 1i t .", ( ( e

..

55

1", (( e p t T e t: fro m:
t eo t

I r, t e r f.", c e - Deb IJ q" Irlted.", c e-File r...l0 Irl ted.", c e - T t'.", rl 5 c Irlted.", ': e-r:'n:,j"'c

p n \...", t e

II'illI1i,liliml5ril'u

t-i. I

(1,"'55

textMenu
" .L rl

".. ,'.,' e r .'" rl m e rllJ for t' e q IJ e 5 t irl1j e eJ i t 5 0 f the t eo t 0 f .", met h 0 eJ ."

r ."-. ': t i':' rl r..., e rllJ

I.", (, e I Ii rl e 5

5: '", 'j .", irl ". IJ rl eJ 0 ... cop y.. . ': IJ t . . P'''' 5t e .....", ( ( e p t . . c .", n ( e I'

'*' 12

'.. . . . i t

r, CFi 5

5e Ie,: t ':' t- 5'

'*'

-:':1
r: .", ,}",

irl

IJ n d ':'

(0 p y ::' e lee t i0 rl CIJ t p.", 5t e .", ( ( e p t (.", rl ( e I;:."

Figure 15.13a

000

316 EXaInples of Creating or Changing Browsers

Since the messages are the standard ones used in all views in which paragraphs are edited (TextViews as well as CodeViews), you do not need to do anything further in order to use the yellow button menu. Return to the protocol browser you made earlier, and try using the menu (Figure 15.13b).

'......1'#
Irl t e r-f,:. c e - E:ro,.. .. 5 In t e t- f ':. c e -I n 5 pee I r, t e rf ':. c e - D e t, u q ,Irlterf,:.,= e-File f" ...10 In t e r f ':. c e - T r ':. r, 5 c Interf,:. c e-Proiec .1o:o-...................f
==

(C'bject) ( ,=, b j e c t ) .:. d d D e pen den t : ((, b j e c t )

& alterna tiveOb ject


" E',.. ':. !u ':. tin 'j con j 1j net i ,=, n - - .:. n :. \,',,.. e t-

.:.lterTI.:' tj... eC'bject :.ince recei,.. er- i5 uue,"

textMenu

alterna tiveObject

.:. 'j,:.in undo

T ."-. C t i 0

rl r" ..., e r,u

I,:" t,el.:.: ',:.'}:. irl "und,=,',.,=

line5: #(:2 -5) 3el8ctor3:

Figure 15.13b

010
The yellow button menu for the SelectionlnListView is for asking questions about the messages, similar to the queries available in the list menu of a message-set browser. It is defined in response to the message selectorListMenu (Figure 15.14). If the response to selectorListMenu is nil, then the subview will flash to indicate that no menu is appropriate. The three messages, browseSenders, browselmplementors, and browseMessages, will be sent to the ProtocolBrowser. Figures 15.15, 15.16, and 15.17 show their definitions, categorized under list functions.

317 15.1 A Protocol Browser

Entit-8 pi-otocol of: Tru8

Ir, t 8 t-f,j c 8 - E: r-o "i'i Ir,t8d,j c8-lr,Sp8( Ir, t 8 r't,j I: 8 - D 8 b U q 1In 1: 8 t' fj ( 8 - Fi18 f"/10 I r, t 8 d ,j I: 8 - T t- ,j r, s( Ir, t 8d,j C8 - Pt-o.! 8(

s~I~~~~~~~mlll~t~8~:'I:,e3 -Ci8gSIS I.~~'1:::!~-1~8~(~:t~,(~'t~':~~r.J!!I_1J t~_~,j~'I: 1 llu. ~ s818ctorList


Pri "i ,j t 8

r-.am'...I 1:"",

selec torListMenu

.:' 818 ( t 8 cJ ::' 8 18 ( t 0 t- ==r, i I itTt-U8: ifF,j 1':8:


[ T ,.:C.,

[T r,il]
I: t i 0 r, r',i' 8 n U
I,j b 8 I:0: ':0 8 r, ,] 8 t'':, . . imp 18 m8 r, t lin8:O: .#(:' :0818 ( t or:o: .# (b tOO
'i'i:o
(I

r s . . m 8 :0 Sa 9 8 :0'

"i'i i t

r, C Fi s
(I

8 ::'8n 1)8 t':o l)r,:, "i'i:o 81mpl8m8n t

t-S

Figure 15.14

000
Ir, t 8 r-fa C8 - E: t'O "i'i s~IDmmmll:DD.rmllt 801: ,j CC8 Ss Int8d,jl: 8-ln5p8( li5t ':'CC85':, Ir, t 8 d,j C8 - D 8 b U q ,IlIMuiillil.h Int8r-f,jC8-FiI8 r"ilo pr-i"iat8 Int8d,j (8 - T rj.ns( In t 8rf,j C8 - F'roj8( In t 8 r'f,j C8 - Ch,j nq class

1035*@#,J1I#_

"Ct-8,j t8 ,j m8:os,j98-:08t brO"i'i:08t- for- HI8 r'-18tho,]:o H"jt ir,clul)8 th8 :0 8 I8 I: t 8 I) m8 :0 :0 ,j I~ 8 "

Figure 15.15

000

318
Examples of Creating or Changing Browsers

Figure 15.16

000
Ent:ire prot:ocol of: TnJe

':': '<" ">:"1 - - - - - - - - - - -Int:erface-E:n:",/,/s~llIlImrm~aEmDllt:e .... t: ,:.ccess


In t: e rf.j c e -I n spee - - - - - - - - - - - ".Int:erf.:.ce-Debuq,Int:er-f,jce-File r,.. 10 Int: erf.:. c e - T r.:. rise .",.. " "'","1 Int:erf,jce-F'rojee Int: erf.:. ': e - Cr, ,00 nq

.<,<

I~Iils~t:m'j!eiel:em~U'~I' III~n~i~"!.T"'~~~~.!IW!!'~i5i~111 ImMilliWitn, bro//se::;enders


pri\"at:e

l,ro.. .,/selmplement:'

t, ro '././ ser/1e ssa ge s


"Cre.:. t:e ':. mer,u of t:he meS5a'je5 in t:he 5elect:e(j met:r,od .jn(j tr,en,

if the user selects .j mer,u it:em, creat:e .:. rIIec,c,,:'ge-set: bro'.. .. c.er for
HI e

rII e t: h ellj 5

HI ,00

t: imp Ie me r, t: it:."

::' rII ,00 II t: ,j If 5r, 0 ',/.... r'. .' e nuT r, e n E: n:, '. . '.. se : (5ele ct: edC',1 ':< c c. c orllpiledf'.."1et: r,od,"-, t:: selec t: e(j::;elec t:or) me 55,00 ge 5
,00

S::' on edC olle c t: ior~

Figure 15.17

000

r
319
15.1 A Protocol Browser

Now return to the protocol browser you created (or open a new one), and tryout the menus for the top view (Figure 15.18). Close the browser when you are done experimenting.

fWj'P'#I
.' """ ,.Interface-E:ro',,...... s In ter-f,jce -Insp ec Irl t erf,j c e - DeblJ q'In t e r-f,j c e - Fi Ie r',/io Int erf,j ce- T r,j n5c
==

(C'bject) (('bject) ,jddDependent: & alterna tiveOb ject "E \.. ,j IIJ ,j tin'j conjlJnc tion - - ,jn5',/,/er

In t erf.j ce -Projec 'io-.............,.,.,_---1 ,j I tern,j t;/el)[ljec t 5ince rec ei',/er- i 5 tr"lJe," cl

browseSenders
"Cre,jte ,j mes5.jlje-5et br 5e Ie c te,:J me 5;. ,j Ij e ," ::::' m,j II t ,j If bro',/,,1 5e ,"',II C ,j 115('

,j

It e rn a, t j',/e (1[' .Ie c t...

Figure 15.18

010
Notice that the yellow button menus for the Protocol Browser seem to work differently than the ones you have been using in the system in that they do not remember the last item you chose. This is because the menu is recreated each time you press the yellow button, rather than remembered as a class variable. The use of class variables to store the menu is described in the next section.

An interesting modification of this example is to be able to specify that protocol from one or more superclasses should not be included in the protocol browser. In particular, a user will probably not want to see the protocol of class Object included. Suppose we wish to create a protocol browser for only some of the protocol of a class.
ProtocolBrowser openForClass: aClass without: aCollection

The second argument would be an Array of classes whose protocol should be excluded. Add the message openForClass:without: to the class protocol of class ProtocolBrowser (Figure 15.19), The only difference between this method and that of openForClass: is the ProtocolBrowser creation message (on:without:) which must be implemented, and the label, which says Some of the protocol.., rather than Entire protocol.... When

320 Examples of Creating or Changing Browsers

you add this new method and choose the yellow button command accept, another menu will probably appear stating that the message on:without: is new. Choose the command proceed as is, since your intention is to specify the missing message next (Figure 15.20).

I"::::::::, ,:::'1 In t erf.3 c e - E: ro . . . . . 5~1'#llmll.I!.I'-I!.!Jli!l:.,D;II'lmlJl.llllmiBrma.=BlililliiEJi!Il*'!Jj, 1:'::<:::::::::llnterface-ln5pec -----------1< :::: ::::<llnterface-[)ebuq."""""''"lnterf.3ce-File r.. .i o 1< <><1 Int er-f.3 ce - T r.3. n5C 1< :::: <::::.lnterf.", ce-Projec Interf.3c e-Crlanq instance

liRilmIIIEII 111

openFor-C/.:'55: aCla55 ,,/.. itt"iout: aC::ollection "C:re.:. te ,:.ncJ 5checJuie ,'" bro"/'/5er for p.",rt cla.55,"
3 Ij.3

in undo cut

cop~~"

top . . /ie'.. .. ,:.F'E:ro""".. 5er I':'llel I ,,,,F'E:rO',.. .. 5er ... super ne'/,.. on: .:.CI,:'55 . . ... ithout: ,:.Collection). t':'llet - '::,ome of tr,e pr-otocol of: " 031:::1,:'55 name, top\/ie',,,,,/ ...

::, t.:. nd ':. r-cJ :::y 5 t em . . . . ie '. . . .

Figure 15.19

o I0

model: .3F'Eny,//:::er ),3bel: la.bel minirrPJrJJ::;ize: 2DDI~2DD, top \/ ie',.. ,.. ':. d cJ ::; u l' \/ ie '. . . . : '081;;::;m:;:;;:;(;::;' ;l;e;c:;t;i e 5e c~'r:;d: :n~L:;i":::'t~\;'"i:::e:;'..;.. ;':;)r:::,:m'3:::F~'E?:rm0""'m7 7r j''''S~T'~m-''"'S:'T:;t:0#;"7'ejl7e7cmtsoTrW00WJ >1 c,"' 7

.', ..... < .' "I In t e rf .:.. c 12 - E: ro . . . . . 5~1l.1IB!m;D1.IIIIII1i1I1E1ilmElllmll,rilliimi.!IlI#!Jj,ljil!o!JliiIlEE.EI In t er-fa ce -ln5pec Int err,:, ce -[Jf'buq.Interf.:.ce-File r.. .i o In t er-f,:. ce - T ra n5C Interf,,,, C e-Projec In tf'rf.3 ce-Ch.3 nq

11

1-:----.,

openForCI.:'55: .:.Cla55 ".. .. itr,out: "Cr-e,3te ,3ncJ 5crledule.3 t,ro""""'5er- for p,3rt c,f tr,e protocol of.:; cl,:.
55,"

on: aClass . . . . . ithout: aColiection

top ...... ie',.. ,.. ':. cJd::,ub . . . . ie""""':

Figure 15.20

100

(::,electionlnLi5t\"'ie',.. ,.. on: .:;F'E:ro"/''''5er ,:;5pect: #5elector

r
321
15.1 A Protocol Browser
You can create the new method openForClass:without: by copying the method for openForClass: and editing it, changing the first few lines. Similarly, you can create the new method on:without: by copying and editing the method for on:.

Now choose the browser menu item instance and the message category private, and then specify the method for on:without: (Figure 15.21). It differs from the method for on: only in checking the argument aCollection; if the defining class is in the collection, then the message is not added to the instance variable list.

1""<:""1

'nterface-E:t"o'/'/:::~IiEamm.m.Ie:t .;,cce:::::: t
Interf.3ce-ln5pec
lnt:erface-[)ebljq~-

on:

."",,',,

,"

li:::t 3cce55 list: functions

1iI.,4i'jM"

Interf.3Ce-File r/'o In t erf,3 c e - T t"a n:::c Inter'f,3 ce-F'r"ojec Irl t et-f.3 Co2 -C 1""1 ,;,nlj ::' y c. t em - ::' u 'I 'I 0 rt:

IIIIIIII'.'m'D 1

"Cre,3 te tl""le protocol bro,//:::er f,:,r tl""le CI.3::::::, ,3CI.3::::::, but e.:clude tl""le protocol for .3ny CI.3:::::: in the collection, .3.Collection."

I cJefCI,3'::::: I
li::t - '=lrljere,jCollectiorl ne""""" c 103 :::::: Dic t ion ,3 r'y - Dic t io rl.:t.ry rl e '. .\", ,3 C I.;, ::::: .;, 1 e I 02 Ctor'::: ,3::: ::; 0 r ted Colle c t ion do: I::' [ ::::elector( ,3

defCI,3.':,::: - ,3Cla:::::: /,,..hichCI.3::::::lnclude:::::,elector": :::elector", C,:,llec t ion include:::: defCI ,3. c.::) ifF,;, 1':.02: [Ii:::t .3dd: 5elector print::, tri rJlj , ' (', ,jefe::I,;,.::,:: n.3me,

'r.

Figure 15.21

000

c I 'Ct :::::: D i c t i 0 rl ,3. r:."

.3. Ij ,j:

(,i:.,':'50ci,3tion key', .:,elec tor '. . alue: defCla.5:::)Jl

Figure 15.22 shows an example for class True when class Object is omitted. It was obtained by evaluating the expression
ProtocolBrowser openForClass: True without: (Array with: Object)

Only messages implemented in Boolean and True are accessible from this protocol browser.
Another kind of protocol browser that you might try is to be able to switch between the messages to an instance of the class and the messages to the class itself, as is done in the system class browser. You can examine the implementation of class Browser for examples of how to create such a protocol browser. The implementation of file list provides another good example of how to create a simple browser. Examine the code for classes FileListView and FileListController.

322
Examples of Creating or Changing Browsers

'.' I'True'l Eiiti ' liu@ cJeepCopy (E:oole,jn) e q', , ' ( E: 0 0 I e .j n )

... nd: alterna tiveBlock a


" r'"j 0 r, e',.. ,j

lu ':. t i rll~ c 0 rl.! u net ion - - ,j r, 5'. . '.. 8 t'

the '. . ,jlue of ,jltern.j ti"ieE:locf 5ince tr,e recei',.. et- i5 l:t'ue," oper ,,,,.. ithout: (,"',tT,j Y ".,.. itrl: .

5) ifF,j 158: t'inq, . (', defCI,j 55 n.jme,

'r,

Figure 15.22

000

.............-------------_.....

ctor' ',,,,,:lIue: (JefCI.j 55)JJ

15.2
A Project Browser
The next example is a browser for creating and accessing projects. It could be used in place of the hierarchical access to projects available in the standard Smalltalk-80 system. We call this a Project Browser. It should have the following characteristics: The browser should have two subviews, one containing a list menu and the other editable text. The list menu should contain the titles of projects. The text should be a description of the project; the user should be able to edit the text and to cancel any changes. Selecting a project title should display the description in the text subview. The yellow button menu in the list menu should support adding new projects, removing existing projects, and entering a project. Adding a new project should prompt the user to specify a project title. Removing a project should require a confirmation if the project has open views or unsaved changes.

,
323
15.2 A Project Browser

Whenever a new project browser is created, it should provide access to every project in the system, regardless of the project in which each was created. A project browser can be created in a manner very similar to the protocol browser of the previous section. The list menu subview will be an instance of SelectionlnListView and the text subview will be a CodeView. However, the command accept in the CodeView will not mean compile; it will mean store the text as the description of the selected project. As in the ProtocolBrowser, commands do it and print it will not be supported in the example project browser. In a system browser, select the existing class category na.med Inter.. face-Projects and then edit the template in the text subview to define ProjectBrowser as a subclass of Object (Figure 15.23). It should have two instance variables as follows.
projects currentProject
A Set of all the instances of class Project that exist in the system.

Either nil, if no list menu item is selected, or the currently selected Project.

The class ProjectBrowser has no class variables.

'='t,jec t 5ubc 1.:< 55: #F't-ojec tE;ro .....'. . 5er

if! c t.,:, ric e . . . . '':' ri ':<. bler'"j ':< me5: 'projec t 5 currentF'rojec t'
cl,:< 55\"',':' t-i,:. bler",J.:< me5: .. pooIDiction,:<r-ie5: " c:. tel~ory: 'Intert,:. ce-F'roject5~

,:<I~.:<in

undo

copy
cut pa.5te do It pt-int it c,:<nlJP-l forma t 5p,:<.',.. ,.. n eopl,:<.in

Figure 15.23

OIOI~~~~~~~~n<1

324 Examples of Creating or Changing Browsers

After you have typed the class definition, choose the yellow button command accept. The new class is added to the class-names menu and is selected. In the class-names subview, choose the yellow button command comment and provide a comment on the role of the class (Figure 15.24). You can also provide an expression for creating an instance of the class. ProjectBrowser open. Choose the yellow button command accept to store the comment. The next step is to define the instance creation message open. Choose the browser menu item class so that you can define class protocol. Add the protocol name instance creation and then edit the method template to define the message open.

Inter"fa c 12 - E:n:,\"/::: - - - - - - - - - - -Irlter"f.:.ce-In:::pec F't'oject Irlterf,:. ce-DebIJ9'-'i"M-"'W. Irl t erf,:. c 12 - Fi Ie r/, 0 F't"ojec t Con t n:,ller I,n t erf,:.c e- T ran::: r: F'roj ec t \/ie',//

ClJt

-I,:t,s'te

elo

It

pt'int it c.:.n,_ 121 form,:.t :::p,:..'/,/n 12' ",I.:. in

Figure 15.24

010

r
325
15.2 A Project Browser

open
"Create and schedule a browser for all the projects in the system"

I topView aBrowser I aBrowser .- super new initialize. topView .StandardSystemView model: aBrowser label: ' Project Browser' minimumSize: 200 @ 200. topView addSubView: (SelectionlnListView on: aBrowser printltems: true oneltem: false aspect: #currentProject change: #currentProject: list: #projectList menu: #projectMenu initialSelection: nil) in: (O@O.O extent: 1@0.4) borderWidth: 1. topView addSubView: (CodeView on: aBrowser aspect: #text change: #acceptTextfrom: menu: #textMenu initialSelection: nil) in: (0@0.4 extent: 1@0.6) borderWidth: 1.
topView controller open

This method is the same as the one used in creating a Protocol Browser, with the exception of the proportions used for the subviews, and the message sent to SelectionlnListView to create an instance. The message used here contains two additional arguments associated with the keywords printltems: and oneltem:.
printltems:
A Boolean, either true or false. The argument of the keyword list: is a message to the browser. It returns an OrderedColiection, either of strings that can be printed in the list menu, or of objects that must be sent the message

326
Examples of Creating or Changing Browsers
printString in order to obtain the entry in the list menu. If the argument to printltems: is false, the response will be strings; if the argument is true, then the message printString should be sent. We plan to keep a list of Projects rather than string representations of Projects, so the argument must be true.

oneltem:

If it is known that a list menu contains only one item, then

it will be automatically selected if the argument to this keyword is true. There may be more than one Project, so the argument is false.

Once you have defined the instance creation message open, then choose the browser menu item instance so that you can specify the instance protocol. In the message-category subview, add the protocol names initialize-release, list access, list functions, and text access (Figure 15.25).

In ter-f,C1 ce-Debuqr~-I ~.m~EI. Irlted,:. r=e-File r,,/io In ter-f,:. ce- Tt-,:' n5C

In t e rf,:. c e - E;ro "/'/ 5 1 ted,:, c e-I rl5pec rl

init i.:.lize-relea 5e list access list functions

t e / t .:.. c c e 5 5

~:rtrjer: t

.:,ut,,: I,:, ':,5: #F'rojectE:ro"/'/5et-

irl.:,t ':. nr: e",:' ':. ri,C1tder'..J.:'rIJe.:,: 'project.:. currentF'roject ' r: I,:, 55 \/ .:. ri.:. trl e f'-.j ':. me 5: " po r=rI [r ir= t i0 rl ':. ri e 5: .. r= ':. terjr:rry: 'Irlterf.':1ce-F'roject5'

Figure 15.25

000
The message initialize is sent from the instance creation message open to initialize the instance variables. Only the instance variable projects is initialized; it is assigned an OrderedCollection of all the instances of class Project currently in the system (Figure 15.26). Under the category list access, define the method for projectList (Figure 15.27). This is the message sent to obtain the list of items for the list menu.

327
15.2 A Project Browser

initi.:l\i:e "::,et the in.5t.:1nce ....:.rj.:.tde.5."

Figure 15.26

000
Irlterfa ce-E:to.. ... .5 In tetf.:.ce -In.5pec F'rojec t Interf.:. ce-Debu9f'j0@Q.iWtmM Irl t e tf.:. c e- File r.. l o F'roiec tCont n:dlet Irl t e rf.:. c e - T ra n sc F't'ojec t . . ,..ie.. ,.

... W ..,

initi.:.li:e -t'elea se lis t func tions te." t .:. c ces s

ptoje,:tLi.5t " ..:::..rl.5 . . .. er the collection of items t,:, tie displ.:.yed irl H'le menu,"

Figure 15.27

000

328
Examples of Creating or Changing Browsers

Also define methods for currentProject (Figure 15.28) and currentProject: (Figure 15.29); these are the messages used to set and change the reference to the currently selected project.

_w.....22....lli...ililli.ill.ill.illiliJi.4.J...22....lli...ililli.ill.ill.illiliJi4J..ill...ill.. . . . . ili........w.......J4< Ir, t erf,:. c e------------ - - - - - - - - - -Inter'f,:.,: e-In:::peu F't'oject initia,liz'" r",le,:.:::e M"iiij"Ii m '#'_ projectLi::.t In t e t'f,:. c e - D ebu 9'- 'jNW"",'@.M "ee1334
E:n:,"/'/:::~

Ir,ter'f,:. ce-File r',/lo ProjectController li:::t function::: In ter'f,:.,: e - T t'a n :::c F't'ojee t . . /ie',/,/ te/t ,5Ieee::::::

': IJtTerltPr':lje.: t ","-,n::: ',/,/e r' the.: urrer,tly :::electe(! projecT:,"

Figure 15.28

000
Int erface-8ro',''/5 .,,::,::,Interface-In:::pec Project Intet'f,:<,ce-Debu9,-ljl.&4i"M .'<: ,,'c, Interface-File r',/lo ProjectControlier Interfa ce - Tr,5Insc Project\/ie',,-/

iM"ee,,'

-- --- -- -- --initialize-rele.:<,se

currentProject

list functions te>: t access

@1i,,"'jliiiA'
projectList

ela,5s curt'entF'roject: aProject "::;et the currently selected project to be aProject," cut-rentProject ... '5I,Project, self
ct'I,:<rll~ed:

#te:,t""

Figure 15.29

329
15.2 A Project Browser

The second statement of the method for currentProject is self changed: #text. The purpose of this message is to broadcast the fact that the list menu selection has changed and that, therefore, any objects dependent on the selection may wish to change. Subviews are dependent on one another and are notified when one another announces a change. The subview CodeView must change the text it displays whenever the menu selection changes. According to the arguments of the creation message for the CodeView, you must define methods for text (Figure 15.30) and acceptTextfrom: (Figure 15.31). The response from text is the current project's description, converted from a String to an instance of Text. The purpose of acceptTextfrom: is to store the String representation of the text that appears in the CodeView in order to update the description of the current project. These methods are defined under the category text access. Although we have not as yet specified the yellow button menus, you can now tryout the project browser. First use the System Menu command project to create two projects other than the one in which you are working (Figure 15.32). In each of them, type some text and choose the

Inter-face-8rov,/s ----------------------Interf,:<ce-Inspec Project initialize-r-elease Interface-Debu9,-'ii2ii#+"'ii- list ,jccess .', . , Inter-face-File [',/10 Pro iectConuoller- list functions Inter-face-Tr,:<n5c F'ro)ect\/ie',/,/ 1 . . .3 ., .

1111 1,1

" ,.!:.,

n s "/'/ e r the t e > t t 0 be ci i s PIaye din t rl e c 0 ci e "/ ie "/'/ ,"

currentProject isf"'Jil ifTnJe: [t" asTe't] if False: [tcurTentProject contents ,:<sTe:o:tl

Figure 15.30

330 Examples of Creating or Changing Browsers

Interta. ce- E;rO"i'i::.E - -- - -- - - - - - ..!Interf,:.ce-Inspect F'roject initi.:'.lize-rele,:.se I ) /iinterfa.ce-Debuiji IjWMii1'W9- list ,:'.ccess Inter-fa.ce-Tr,:'.nsc Pr-oject\iie',,"'i

1ttrue...

te>::t

:.:.::.,:.<:.::, In terf,:..c e -File r"i10 Projec tCont roller 1,.littlS.tljt.-u=ra"a::tli.ilc.,rl'::.' ,- - -- - - -- - - --

1'.*15-$

class a. c cep t T eo: t: ':.. Te >:: t fr-orn: '",'",'r,oC a.res ":::=;tot-e tr,e te:<t to tie displayed in Hie coeJe "iie',,"'i," c UtTent F'rojec t content s: ':. Teo: t 5trir,,}

Figure 15.31

000
In t er-fa. c e - E; ro "i'i s ~ In terf,:. c e -Insp ec t In t e t-f,:. c e - Deb u qi In t et-fa c e-File r"il0 Interfa ce - Tra n5 C initi ,3.li: e - rele,3 5e list ,:'.ccess list functions

~~~pft~*:t~~
teo:t

m,~rffl@f:~~j@~

tl'#*~~#~~$~

In t e rfa c e - C han Ij l!:o"""'!~~.,.,.---~ m:iitM~ cl,3.ss ,3.cceptTe>:t: a.Te>:.t ft-orn: "i'ihoC,:.res ":::;tot-e tr,e te,t to tie displ,3}"ed irl Hie code "iie"i'i," cutTer,tF't-oject contents: aTe:ot strinl} ttrue

F'roject

Figure 15.32

000

331
15.2 A Project Browser

yellow button command accept. This stores a description for each project so that you will be able to distinguish them in the browser. Evaluate the expression (Figure 15.33)
ProjectBrowser open

(Recall that this expression was included in the comment for the class
ProjectBrowserJ

'mME'Wi'. -----------In t '" t-f.3

Intet-face-E:t-o"i'i 5 -- - - - - - - - - -In t err.3 c e - In 5p e c F'roj ec t In t et-f.3 c e -DebUlj,-JI"'#ii!P.!qH@!!"-'!r..r.;;;JI!IIi~""'laB!l:J.1 Intet-f,3ce-File r"il0 F'rojectContr"olier Int erf.3. c e- T r.3. fi5C Projec t ""iie"/'/
C '" -,_:"" ,3. n Ij

irl it i .3Ii: e - re Ie ,35 e Ii 5t ,j CCe 55 li5t function5 teo t ,3 CC e55

,3 '}3irl ,undo ....-......- - - - - - t T 1""115 cia. 55 tOe p r~__5,.,.'-',~.:._filt,J5,:._. 'r3oI' rt,o,~_,tOO "i'/ 5e r to r cr-e a t Ir cop Y c c e 5 5 irl1j p n:,j e c t 5, Ct-e,3te one by ~ , , ., cut
0

cla55

I
Figure 15.33

p,3 5 t

ProjectBrowser open

-,t-in it .3.ccept C,3 nc el fon, I.3. t 5p,3 "i'ir, e, ,Iain


O

..

You are asked to designate a rectangular area in which the browser appears (Figure 15.34). In this new browser, you can select projects and the descriptions will be displayed. Since the project browser is constructed using a StandardSystemView, the blue button menu is immediately available. Notice, however, that each item in the projects menu simply refers to the words a Project, rather than to some unique label or title. Instances of class Project have no titles. To improve the projects menu, you will have to modify class Project to declare an instance variable for the title and to access the title. We will make this change to class Project in Section 15.3. We must now specify the yellow button menus. In this example, we will declare two class variables in which to maintain a reference to each menu so that they do not have to be recreated each time the yellow button is pressed (as was done in the protocol browser example), and so that the last selection is remembered.

332
ExaITlples of Creating or Changing Browsers

....
..
<

>I~: ili,.1,.IU51tleJrl"il ,il >El;tili.,:l,\,.1.'L;, e r1.., J.~~2ill:ill


\r, t e rf,'3 c e - E:ro ', 15 ~ (r,tert,j ce-Inspec t Inter'f,jce-Debuw Inr:erf,:.ce-File r" ...10 Interf""ce-Tr,:. rl5e F't'o lec

,.,......
..

l i l ~ .... IlnmlQilli:an~m!JII ~D11 I ,'3 F'rojeet '\ ...


._____
'llilw'lliU'wllillilli.w. u il l i il 1l .
,'3 F'rojecr:

.. ,

~)~
F'rojee F'rojee

.................. In ted,:' e e - C h ':. n q~

'.

mt~rm@ m~j@~

loj'="".nn.,.. ... .,....~.,... oooooi ...,..M.,.. ..,.

<
.......

Thi5 el,:'55 repre;,enr:5 ':. br-o',.. ,. .

'::: r e ,'3 tee, neb >" e ', . . ':. !u ,'3 r: i r"j

.....

....

Figure 15.34

000

_.. . . . .
Irl t,:. r-f,:. e,:. - Ch ':. rl'j

. LF:.'t:-e.:'j~e:.:e~:

.............
t:...:.E::t.:"C.:":.:""":.:"

;:"e..t.......--......,.... .. .- -

-.------"".111

In ten"" ce-E:ro","'i s.; - - - - - - - - - - -In tet-f,:. ce -In spec t Pt'ojec t init i,:'.lize-rele,:. 5e Ir, t e r f ,'3 e e - Deb u 'j I-Jllliii'l'!il'!.J1Il[l!!I#I'!.I!'r;.;'JlJi!!.!lII'TII#......'!I'.~.. Ii 5t .:. c c e s 5 1I!3 In t e tf.3 c e - Fil e "'il0 Proj e c t '::: e, n t tOO II ~ r Ii s t fu n c tio n s I r, t e rf,'3 e e - T r'3 r,;, e Proie e t ",i ie'",'..

"dfllti"M"'. -----------,=, bj e,: t


5ubc I ,:';,5: # Proj ee t E:ro"""i 5e r.';,}:.in undo
COpy'

in s t ':. nce \1 ,j ri,,; bler'"J,j me5: 'pt'oiec t s curren tF'to.i ec t c I,j 55\",'; t'i ,j lile r-..J,,; me 5: 'T e ,tr,.. len Ij Pt'ojec t r""lenl-i po olDie t i on ,j ri e;,: "
C ,j t e Ij 0 r' y: 'I n ted ,j
'

':

e - Pr- 01 e e t 5'

..

cut p,'3;,te do It pr-intit


I

c-3r~el form.'3t 5p.:... , in e'.pl.,;in

Figure 15.35

010"",. .,

- 'I'"""-,----------r...,...........,......,... , l

JI----------~I~.~

333
15.2 A Project Browser

In the class-names subview of the system browser, choose the yellow button command definition. Edit the definition of the ProjectBrowser to add class variables TextMenu and ProjectMenu. Choose the yellow button command accept (Figure 15.35). The class ProjectBrowser is recompiled. (Note that this change can be made even though a ProjectBrowser may be open.) Under the instance protocol name text access, specify the method for textMenu (Figure 15.36).

In t et-f.3 c e - E: r'o ..,...;. 5 Irlter'f.3ce-ln5pec

Projel:t

irliti.~li=e-rele.~.'",e

'~I:ceptTe'

..........

., Irl t 12 r-f.j c e - (: h ,j rl1j t e i t r',:,! 12 rlu

""(#Ji"'W*i''. ---'---------

1 t e rf,j C 12 - Fi I 12 f',:,10 Proi e c t (: orl tt"olle r-I~I'~' ~fu~r~,~t~il:~'~'5_ _ I~If~*~'~f~I~N~d~i~~.1 n i t C r Ir,ter-face- T r',jrl5C Pr-o iect\:'ie':,,,'

Intet-f,~ce-DebIj91'iijiUt--tii:ii-lWW'M Ii.:: t ,~c I: 12'::.'"

te't

100*'9114'

- -- -- -- - ----

",":",rl 5":",1 er' ,j menu for- editirl1j trle te, t in trle ,:,:,,je ',lie',.. " l:urrerltProjel:t i,,[",Jil if True [rrril] Te,tr",..lerlu i5r",lil ifTr-ue: [ T e , t r,,.., e rlu - Act i':' rl r,,:,l e rlu la bel,,: . ,j I}j i rl ' u rll:J 0
\, ': 0

p). "': u t \, P,j .'"' t e . . ,j Cc e p t \, ':

,~

rl Ce I' ,,',,' i t r,1 =: F; .::

Ii rl e,: # I: 2 5)
.::elector5

# ( ,j I}j i rl

Ij

rll:J ':' I: 0 p y ::' e e c t i0 r, cut p ,j .:: t e


1

,j

CI: e p t C,j r, I: e

:1 ]

Figure 15.36

000
The menu is an instance of ActionMenu that is only created if the class variable TextMenu is nil; otherwise the menu is accessible as the class variable TextMenu. If there is no selection, then no text editor for a project description is needed. The method returns the value nil to indicate this. According to the implementation of ActionMenu, you try to obtain the menu when no project is selected, the subview will flash. If you now return to the project browser, you will notice that you can press the yellow button and obtain the menu. Modify one of the project descriptions to try the editor (Figure 15.37). (Notice that the commands do it and print it were not included in the menu.) Under the instance protocol name list access, specify the method for projectMenu (Figure 15.38).

334
ExaITlples of Creating or Changing Browsers

,:to F'r'oject Inter'f.:tce-Debuq'-~j~:4#~~li.:t. F'roject .< <,>"Interface-File 1\..10 F'rojectCon Int erf.:t ce- T r,:t nsc F'rojec t \/ie''o' 1>n,~rm@+:pt9j~~ < < ,lnterfa.ce-Crla.nlj1o:o""""!""""!,.... ."-. .:...:= r e en ',/./ i t r, piC t u t,-' _~_,--,----" e .' ioo@ ,:tIj.:tin te,tf',/lenu undo
<, Irlterf.:tce-lr,5pect F'roject
"d ./.

.,.,.,."",.Int~r'face E;ro"/,/~,~

Di'P'#'

copy
cutTerltF'roject Is['.Jil Ten f',/le r,u i ':,[\jil i fTn [T e< tf/1enu ...."-, c t ic
I

cut p.:t5te

at, e Is: ',:t Ij a r, \ u r'-_.....


1

..,..,. <I

lines: #(2 5) selec t 0 r's:


t

Figure 15.37

010
1< >

T e, t

r" ...,

#( alj.:t.in undo copy:::;election cut p.:tste .:t.ccept c.:tncel)], e nu

> > < > <>


Intert.:tce-E;ro/.. s~ In terface-Inspec In t e t'fa c e - Deb u 'j'Inter'f,:tce-Flle r" ...10 Ir,tet'f,:tce-Tt'.:t.nsc In terf,:t c.:.-(:rl ,:t.n'j projec t 1...1enu

_~w..............-_---.......----_---_-- _.....--_~I
'i ult4".Ji.i\iilj+ mi.'
--~-------------------F'r'ojec t -----------initi a li:e - relea se

> <>IF'r'oject E:ro',/.. . ser ...... < ,'.' ',

. , '> . >,', '


c utTer, tF'rojec t CurTe n tF't'ojec t: projectList

'QltJMi"gai'i'!Ii

F'rojectConuoller list functions F'roiect\.. ie',.. / te,t ,:tccess

------------

IW"'''ll#ij'

","-,ns/,.. er a menu for .:tcce.:,sinlj or' ch,:trlljlrllj projects," cIJrTentF'r'oject isf",Jil if True: [tnil]. F'r'o.iectl',...l enu )s['.Jil ;fTrue: [F'r'ojec tr'.. 1enu ... ,"-,C t i c,nf',/1en u I,:tbels; 'enter"".:t dd project '.rerfJo'/e projec t' ',//in,(:FiS line;.: #(:1 5elector5: #1:enterF'roject .:tddF'roject r'emc1',/eF'ro.iect)], t F'roje c tf'.. 1en '~

Figure 15.38

335
15.2 A Project Browser

The menu has three commands.


enter
Enter the selected project. Add a new project to the menu. Prompt the user for a project title. Initially the new project has no description. Remove the selected project, unless it is the one in which the user is currently running.

add project
remove project

The messages associated with each item must be specified in the instance protocol of class ProjectBrowser. Figures 15.39, 15.40, and 15.41, show the methods for enterProject, add Project, and removeProject; they are each categorized under the protocol for list functions,

'mM".i@.
Intet"f,3. c e Ch.3nl~

- - - - - - - - - - -initi.3.lize-rele,3.:.e Interf,3ce-Detlul~,.I#imtD'Ii1'.ftiil. li:.t ,3cce:::::: Inter~.3ce-File r',,..10 Pto.!ect:=;:)nttoller (ntert.:':I.ce- Tr.:':I.nsc Pro lee t ', . Ie'"',,.. te./.t ,:':I.C ce:::::: F't'oject

Interf.3 ce-E,ro . . . . :. Intetf.3ce-ln:::pec

I.Ma....wili #i'-=.U"iliM _.1 .... _

ngM''''''i["''

------------

entet"Project "r',,..1,3Je n-,e :::electecJ project the cun'ent one,"

Figure 15.39

OOOI..~----r~--~)1
The method for removeProject has several interesting aspects. First, if no project is selected, the command means nothing. Second, if the project selected is the project in which you are currently running, deleting that project is very dangerous. The message error: will cause an error notification (notifier view) to appear, warning you that you are trying to do something that should not be done. If you try to remove the project in which you are running and get the notifier, simply choose the blue button command close to erase the notifier from the screen.

336
Examples of Creating or Changing Browsers

_ i i W L L L L L J . F..._.c... c,..:t_E... "'.,'I... ,e t_.,.''...... '::" ........-........................_ ......__.. 't 'j_e.... ;t_.C... .. ';...... .. ::,::...... :" "

1 /

Ilntetf,jCe-E:ro',/",'% -----------Interf,j,ce-Inspeu F'roject initi,j,lize-relea,:::e '!USli.,'JI <>, Interf,jce-Debu 1 j,-liiillD';;Ji.W89- list ,jccess entetF't-oject In t e rf,j, c e - Fi Ie r/, 0 Pto je c teo n tro II e r IIQlIlgl1-IilIi!lI'i1MI1'ln~Jiill 1::::::::::::::::,:,lnterf.j,ce-Tra,nsc F'roiect\/ie"/'/ te::<t j,ccess

I------------

Ildt.lI"#8imrD! ---"--------Intet-f.jc,:,-( :rlan'j

cla,ss ,j(j(jProject ","-.dd .jnother project to Hie menu of projects,"

I
Figure 15.40

I ,jProject I
,j Project ... Project rle',/,/, pr-ojects ,jd(j: aF'roject. cutTer,tF't-oject ... ,jPr-oject. self c~"jnljed: #currentPt-ojec t...

000
Project Browser
I:'",,:,:,:::,:,:,,:' Interf.9, c e -BrowSE - - - - - - - - - - -I>/:::U)] Interfa,ce-Inspect Project initialize-t-elease addProiect IUU/] Intet-fa,ce-Debull li list a,ccess enterP~o iect 4 Il W In t e rfa, c e - Fi Ie rl,10 Pro ie c teo n t ro II e r U111-II!lIIMrliDilili IIII"lIil;;B.'.9~il;nllaFIi"I1ll I i 1 1::::::::::\.:.::1 Intet-fa,ce-Tra,nsc Pro:iect\/ie"/'/ te::<t a,ccess

'i'_dcla,ss

rernovePro ject

:l:
g
iii;:

"Fiemo/e t~,e currently selected project from trle menu." currentProject is[.Jil ifTnJe: [tselfJ. cUtTentF'roject == Project current ifTrue: ['lself etTOt-: '\'ou ca,n not remo/e t~le project in /.hic~1 you cutTently runnin'j.'], currentF't-oject release. pt-ojects t-emo/e: CUtTentProject if."-.bsent: [J. ~ cutTentProject ... nil. :::elf ch.j,n1jed: #currentProject...

if:

Figure 15.41

000 1~/'!8<~]rI---------"~,,!81::,~,,,-----------rLrlCnHHI

337 15.2 A Project Browser

The third statement is currentProject release. The message release is sent to a Project so that it can remove from the system any views that it knows about. The style of using the viewing and controlling components of the system includes sending the message release to a view whenever it is erased from the screen and should no longer be accessible.
You can improve on this method. For example, you might check to see if the project to be removed has any views or unsaved changes and, if so, you can inform the user and ask for confirmation. The system class Confirmer can be used for this purpose.

The last statement of the method broadcasts the fact that the menu changed again. Note that this time the argument is the Symbol #currentProject, whereas in the earlier example the argument was #text; these arguments help the CodeView decide what messages to send to the model to obtain updated information. Try the yellow button commands. Enter a project (Figure 15.42). Create some views in the new project, including a project browser (recall that to create a project browser you evaluate the expression ProjectBrowser open). Use the project browser to return to the original project. Try to remove a project, and to add a new one.

~>J: ;Jyl. 52t2:r.il (,l ~1;11:, .

r'0 ,.il ,..cJ, e.illr.l

~ -,.~il l i~ _ww.>.. w .>


,01 F'ro ieet

;...Y

> w . w>> >;... ..

.w.... ..

,YI

~~h:~rrn@P~(Jj@~ - - ~ - - '-Ili1ilJo""""j~---------------L Ir'tetf,jee-Cr"jr,q~~"""""''''''''''''..,....--4 ::,et'eer, "i,,..ith S,j mple bro',,..,/sets - m:rtM~1 '
.......... 1

Irl t e t'f,j e e -Eito',,..,,.. s': Ir, t erf,j e e -In spec t .F'n:,jec In t erf,j c e-D ebuq"P:roj~ Intet'f,jee-File 1',,..io F'roje,: In t erf,j c e - T t.:. rise F'n:, iee

nii.j'g'
I
,01,)'] pt'oj~t 1 It'emo ', . e p t'oJee tl

rernovePro ject
"Fiemo',,..e Hie eUtTently s': e UtTentF't'ojee t ic,f",Jil ifTt'u ':UtTer,tF'n:,jeet == F't'oje': [lself etTOt: "t'ou e,jf ,jt'e eUtTer,tly runr,ir,'j,'], e UtTerltF'rojee t rele,jse, pn:,jeets t"emo',,..e: cutTer,tF'roieet if,':::',t,ser,t: [],

eUtTer,tF't"ojeet - nil, self er"jnoje']: /teutTer,tF'roject


.

Figure 15.42

010

I. .

..

338
Examples of Creating or Changing Browsers

Notice that if no item is selected and you try to obtain the yellow button menu in the list menu subview of the project browser, the subview flashes. However, when no item is selected in the subview, it is appropriate to be able to invoke the command to add a new project. The method for projectMenu in class ProjectBrowser can be changed. One such change is shown in Figure 15.43. When the currentProject is nil, the menu is an ActionMenu of one item, add project; when currentProject is not nil, the menu is an ActionMenu of three items. (In fact, the class variable ProjectMenu is no longer used.) Figure 15.44 shows the yellow button menu that appears when no item is selected in the subview. We have fulfilled all but one specification for the ProjectBrowser. We still have to provide a prompter for the title of a new project. To do so, we must first modify class Project.

i_~~~~~~~~.~.W.LI~t_~:_~_~.,.~_~__E__ :t~_C~_"'~_/~_.e_r_: _ _.,.-___.._ _._ _ _


Intet"tace-E:ro'//s~ -----------Inter"f,jce-Inspect Project In t er f ,01 C e - Deb u I~ I" 'iiItM';iiWHYIr,terface-File f',/10 F'n:1ject(_:or,tt"oller Int e r"f,j c e - T ra.nsc Pro iec t \/ie',//

-----------initia.lize-relea.se

Melee.
list functions te>: t .01 c ces s

'DUmMi"#iiE'mDI
Ir, t erfa. c e - C::h.j nl~

--~---------

-----------crl,jrll~irll~

.QiU@+'I,,'ii_

curTentF'roject curreri tF'n:1jec t: pt"ojectList

pro jectMenu ","-.r,s',/,/er" a menu for

.jccessinl~

or

projects,"

c u rTe rlt Proje c t i ;'[",j[1 ifTr"ue: [Proje l:tr,,/1erlu

<'-

,"-,ctior,r',,..1enu

1,01 be Is: ',01 ,:J(J p r"oje ct' lirl e s: # () select ors: #( ,01 d dF'r"oje ct) ] ifF,jlse: [F'r"ojectr'./1erlu ...."-,ctionf',,..1er,u 1,01 bels: 'er,te('".j(Jd pr"oject\remo',/e project' ,,//itr,CF,s lines: #(:' ;,elector;,: #(erlter-Pr"oiect .jd,:JPr"oject r"emo',/ePr"oject)}

Figure 15.43

000

t Proi ec t r,,.., enl-i

r
339
15.3 Modify Class Project

.'=' F'roje,= r .':1 F't'oiec r

projectMenu

CUtTerlrF't"ojecr

i~r'.Jil

if True'. [F'rojec H,..1enu I.':1 l) el ~: '.':1 ,:j cJ Pt" c' .i e i fF.':I I ~ e: [F't'oj e c r r,.., en u L-~---------:,--:----:-~-=-----r> 1.':1 l) el ~: . e r, ret""" .':1 cJ cJ Pt' oi e cr. t" e mo'' e p t" C' j e ,= r' '.. 'i H, C Fi ~
line~: #()
~ el e c rOt' c:

# ( e r, ret" F' t" oi e c r .':1 cJ ,:j F' t',=, j e Crt" e m ,=, .' e F' t",=, j e ,= r, ]

Figure 15.44

010

t F'roj e c r r',..1 e r,u

15.3
Modify Class Project
Close any example project browsers and project views that you might have created by choosing the blue button command close in each view. In the system browser, choose the class name Project. The definition for Project displays in the text subview of the browser. Change the definition by adding the instance variable title (Figure 15.45). Choose the yellow button command accept. The class is recompiled. All existing instances of Project are updated to have one additional instance variable; in each case, the initial value of the variable is nil. Each of the existing projects must be given a title before you can change the way in which Projects print a description of themselves. One way to solve this problem is to create an inspector for all existing projects by evaluating the expression Project allinstances inspect (Figure 15.46a). There is at least one Project, the one in which you are currently running. Choose each project, one at a time, and open an inspector on it (Figure 15.46b). Choose the instance variable name title. In the text subview of the inspector, type a literal String that is the title for this project (Figure 15.46c). Choose the yellow button command accept to store the title. Do this for each existing Project. Close each inspector.

340
Examples of Creating or Changing Browsers

_'i.i<;<. .>. >. .> < <>.< >.> <. . . < > <>.<. >.>.<.>.> . . . . . <
) / ' ..

......

> />

> }<> . .>.


) .'.

Intet"t,:.ce-E:rO''''','5~ ----------------------Inter tOo c e -Incpec 1'~;~il!.!I"m#I-DJ 1initi,:.li:e-rele,0i5e In t e rf,:. c e - Dettu'j" F'roj ec t E;ro" . .'. . :::e r" co r, tr"ollinl~ I t f F'I r, F' ' t-' t II c-lependerlt::: ,:.cce = . .,:,ro e r" c m,:. n ,:'.Ijem ImMri'IiMiiiltD -----------lock ,:t.cceS5

I~: ~:;:f:::~: T'r~ r:"~:~' F';::~:::::~ ~ :,,~:::;,'

~,,:' nl~e

....I.. .~ ... . ..

_>.LI~n~t:o:.~r-~f,.:::c~e_-_'~:r~':a~n~qlllllI[~~~r~~"' r~.i~". .~,Oi~t~e~-i .. C/'0i:::5


::,tr'irll~Holder

:::uttcla::::::: #F'roject

i r, 5t ':. r, c e . . . . ':. r' i':. tt Ie ['"j ':. me:::: 'p r 0 j e c t \1,,1 ir, do, I"
Pr-oi e c t Tr,:. r,5 c r'lp t p r'o,! ec t Ho I(je r' . '
c I':. c, 5""'" ':. r-i ':. lllef'"j ':.. me 5: 'C u r'r-e rlt F'r"oj e c t pooIDiction,:.rie:::: " c':. tel~or'Y: 'Irlted,:.ce-F'roject5'

,:'Ipin ... un(Jo pr copy ,:..rll~e::;et cut p,Oi:::te (Jo It print it c,:.rl'\el form,:.t :::p,:'.',.. ,.. n eo:pla.in

......

'.'

Figure 15.45

010
ini ti,Oili:e -rele,:. 5e c or, t r'olli rll~ deperlderlt::: ,:.cce
c~I,:.nl~e m,:.n,:'I~em

locf ,:.cce5:::

~""'''''''''''''''"T-----t p ri ',. . ':. t e


cl,:.::::::

,:'Ipirl ur,do

t c,'

copy
cut pa:::te Irin. it ':. cc ept

OIO~~.....,.,.......=,:,:.rlc~.~el< "7"""'T~.~~ .................


Figure 15.46a

341 15.3 MQdify Class Project

1111::];:il ",~il :;till.eillrillnIE;illnill:,ill\l,.],,=ill,eillt~'I~J,~,~,~J,~;~,~'I"']-lli'iiliUlli411iillilillilli"Z'::':'W""::ili"'ill"""4:'] 11_ __ ___.;.


F'n:

1<,:1 In t erfa. c I - E:ro'","'" s .

Interf.:t.ce-ln:::pec~9j@~

Interf,:t.ce-Debucv F't'oject Intetf.:t.ce-File r'.,,'10 F't-oject 1,'.'0'-;',:',:',:',">::1 In terf.:t.ce- Tr.:t.n-:.c Project

self fir-:.tlnde>: I,;.::: tlnde::<


1

ect

2
:]

:,~:!~!~:.~~
::;trin,~Hoi(Jer

- lli~.~"!"":::"'!"'M""")~""":'

4 L

:::ubcl,:tss: #F

7
::: 9

".'V 0 t-k::: p a. c e

l ~c e~"'~'~,t-_i~. b.1 ~~\~'~ ~fl

F't'oject aillnst,;nce::: inspec

'\

Figure 15.46b

010
l)nJet''''~COII''ction:,
.' '' '.' '.' ' ' .; F'roject

,;q,;in urldo copy cut p,;ste cJo It print it

Figure 15.46c

010

342 Examples of Creating or Changing Browsers

Currently, when a Project prints a description of itself, it uses the de fault description, a Project, specified in the method for printOn: as de fined in class Object. We want a Project to print its title instead. Create the protocol printing for class Project, and specify a new method for printOn: (Figure 15.47). You must also provide a message for setting the value of title that can be used in creating a new Project. The value should be an instance of String. Add the message title: to the category initializerelease (Figure 15.48). Now open a new project browser. You can see that each existing project now displays its title in the list menu (Figure 15.49).

1//un:::?11 n t erf.:.. c e - Deb Ij (,1' Pro .Ie c t Eiro V'l ser Ir:Uiiii1IIiliIlliIllil~

lun/un Intet-f,:..ce-Inspec
lUi) :1

fnterfa.ce-E:ro . ., . . s

-- -- ----- --initia.lize-rele.:..se

1::::::::ULllntet-f,:.ce-File r.,,10 ProjectC:ontt-oller controllinq In t e rfa. c e - T r,:.. n sc Pt-oje c t""'" ie ".. .,,' d ep e nd en;: s a. c c e Interfa c e-F'roJec cla.ss printC1n: a::itrea.rn

II------------

;~~;,~,~:n,;~cr~:;,a.gern

Figure 15.47

000

343 15.3 Modify Class Project

I
Figure 15.48

title: ,j.::;uin9 ":::et nle title of nle project,"

000
I>

< <

1 r, t et-fa c e - E:ro',/,/:;; In t er-f,j c e -I r,:;;p e c I Irlterf,jce-Debuq,Interf,jce-File r,,/io In terfa c e - T r.j n:;;c

."""",1 m'(,~tffi@,..mqj@

- - - - - - - - - - --

In t e t- f.j c e - C 1'"1 ,j n1j ~......,......,......,......,_---l mrtM~ cl,j.: title: ,j:::,uirI1j \I'/od:;;p.jce _he title of tl'",e pr-oje l:

Figure 15.49

000

344
Examples of Creating or Changing Browsers

The next step is to change the method associated with addProject in class ProjectBrowser to prompt for a title. The new method is shown in Figure 15.50. It uses an instance of the system class FiIIlnTheBlank to request a title, then sends the newly created project the message title: in order to store the response. The two arguments in the creation of the FilllnTheBlank instance specify the noneditable text that appears in the upper subview, stating what kind of information is expected, and the editable text that appears in the lower subview. In this case, the ((default" title, a Project, will appear in the lower subview; it can then be edited by the user.
Project EirO\I,/ser- - - - - - - - - - -initi,jli:e-relea5e pmDP!Jl.'#illi'.)If'#~''' 1 Interf,:.ce-Debul~,.I#iim#";d"T.TA#. list ,:.ccess enter"Project '>::"':"":":::"'llnter-~,:.ce-File f',/10 Pro_!ect:=:::.ntroller 'g.lIi.kiIN. r-emo',/eProject Int er-t,:. ce- Tr-,:.. nsc Pr-o lec t "/ Ie ',,I,,.. te:<t a cceS5 Int er-fa ce- E:ro',/,/s -----------Pr"oject

1<> Iinterf,:.ce-inspec

II

Imm,eEii+fB
addProject

------------

I<'::'::<'>! Jnterface-Cr,an9

""'::',dd another project to n-,e menu of projects,"

,j::;trfnl~

,:.F'roject ,j::;trinl~1 ... FilllnTrleE:I,:.nf request: 'Title for Project?' initi,:.I,il.,ny,,..,/er-: ',:' Project',

Figure 15.50

000

,j::;tr-inl~ isEmpty ifTrue: [tself]. aProject ... Project ne",I,,.. title: ,j::;trirll} projects ,:.dd: ,jProject, currentPr"oject ... ,jPr-oject,

self

char,,~e(j:

#currentF'n:,ject

The user of this kind of prompter can abort the action of adding a project by typing nothing in the lower subview. The second statement in the method for addProject tests to see if the response is nothing (isEmpty) and, if so, terminates (1 self). Try it. Choose the yellow button command add project (as shown earlier). A prompter appears. The initial response is the default title a Project (Figure 15.5Ia). Edit the response and then choose the yellow button command accept (Figure I5.5Ib). The new project appears in the project browser menu (Figure I5.5Ic).

345
15.3 Modify Class Project

for Pt"oject:

1\..\)Yi'i~J

addProject ".':::'.dej .:'.notrlet" pt"oject to trl-

I .:.Projeet

.:.::;uirll~1

.:.:::tt"inlj ... Fi'"nTrleE:I.:.r,f t"eque:::t: 'Title for Project:?' initi.:.I."-.n::: ........ er: '.:.. Project' . .:.::;uinl~ i:::Empty ifTrue: [t:::elfJ. .:.Prc,ject ... Project ne,..,.. title: .:..::;uirll} pt"oject::: .:.ej,:J: ,:.F'roject. CUtTentProject ....:.F't"oject,
:5e/f cr,.:trll~e,:J: #currentF'roject

Figure 15.51a

000

Int erf.:.. c e-E:ro'o"""':5 In tet"f.:. c e-In :::pec ....... . Interf.:.ce-Debuq.Interf,:.(e-File 1\1;0


I .... ..,

Pt"O j e c t T ",. .,. c:..

~;t:~~:;t~j~:
(I.:.:

iA------I~----------t~~::J

1>< < 'Interf.:.ce-crl,:.n'j1o;o......,.................,.._--t


addProject ",':::',,:Jej ,:.notrll~r project to tr,-

I .:. Pr"ojeet

':. ::,uir"~1 ,:.::,trin'j - FilllnTr,eE:I.:.nf reque.:-t: "Title fOt" F't"oject:" initi.:'/ ..:!..n.:-,,..,,..er": ".:. F't'oject' .

.:. ::,tr'irll~ i.:-Empty ifTnJe: [t ::elfJ ,:.F'rc,ject - Project r,e',..,.. title: ,j::,uin,} pn:,jec t:: ,j ,j':J: .j F'roje ': t.

Figure 15.51b

0101>

> "'......,........

~c

c'J,'rentF'rojec t

:.F'rojec t.

..... !'"l.f.....'!'"r.'.:...r......... ':J....'!'"# c'!'"u... "e r 't"F'r.... ..... . t. e' c ... . ' rj e... : n................ c.

"C~'j.e

> <>"'> .... < < ...

,/

346 Examples of Creating or Changing Browsers

Top Pt'oject Project T',,I,,Io

.';';;"";;,'<<1

a.ddPro ject
","-,deJ ,:.notrler pto.iect to trl-

aF't'ojeet ,:.::;uir''jl request: 'Title for F'roject?' irliti,jl,"-,rls",I,,Ier: 'a F'roject',

a::, ui rl'j ..... Fi Illrl T rle E:I,:. n f

,j::;uir"j i.::Empty if True: [r.::elfJ. ,jF'roject ..... F't'oject rle',,I,,I title: ,j::;uirI1j. project.:: ,jdeJ: ,jF'n:lject, currentF'roject .... ,j F'roject, self ch,jn1jel:J: #CUtTerltF't'oject

Figure 15.51c

000

15.4
Change the System Menu
It would be more convenient to be able to create a project browser with the same ease that we can create a system browser, that is, by choosing an item from the System Menu. The creation of the System Menu is specified in the system class ScreenController. In the system browser, choose the class category Interface-Support and then choose the class name ScreenController. Choose the browser menu item class. The only message selector in the category class initialization is initialize. Choose it (Figure 15.52). The System Menu is a PopUpMenu. PopUpMenu is an alternative way to create menus that know about item labels and lines, similar to ActionMenu. A PopUpMenu does not store the messages associated with the menu items. Class ScreenController has two class variables in which the PopUpMenu and the corresponding array of messages are stored (ScreenYellowButtonMenu and ScreenYellowButtonMessages). To modify the System Menu, you must edit the method for ScreenController initialize. Delete the exit project and project items in the menu labels and insert project browser. The line numbers must change as well as the messages. Delete the messages exitProject and openProject, and insert the new message openProjectBrowser. Choose the yellow button command accept to recompile the method (Figure 15.53).

r
347
Change the System Menu

f<:et'nel-::;upPOtt Intetf.;ce-Fr.;me,., E.pl,;iner' IInG'E" r...lou:::er.. l enuContr ------------

.ii'dWli

AMmgrmnm .mgge.
------------

Intetfo3.ce-Li:::t::: In t et'f,; ce- Te. t ::;c n:dlController In t erfo3 ce - r.. l en u::: ::; t .;neJ.;t'd::;y::: tem' In terfo3C e -Prompt

"1''#9''''''"''

initia.lize
"Irlitialize trle ::;y:::tem
r" ...1er,u."

',:icreen',' ello'/,/E:ut t onr',/lenu popupr....' enu 1,;beI5: 're5tOt'e di5pl.;y e>:i1: pt'oject project file li5t bro,.. .. :::er '. ... Ork:::po3Ce

Figure 15.52

000
I: IU.....':....

1/ / /" f<:.et'nel-::iupp,:,tt

[ II I~.~'d~m~a~E~'e~.~~I'~i~WliIiDI
, Intet'fb.ce Li:::t::: llnterf,;ce-Te>:t llnterf,;.ce-f./1enU5

I> > /iinterf.;.ce-Frb.me.'

E:<pl.;.iner' r'/l 0 u::: e r,...l e n u Con t I' ::i c roll'::::: on troll er ::; t a. n eJ .;. t'eJ ::; y 5t em.:

I, I l[illlillillLI~r~,t~e~t~f~.;~.,:~:e~-~F_'t~'c~,r~n:p~tlTI~~~~III.L in5tance
'n~:::ton~

..J ';I~a.in ....


undo
COP),

-I,:>,~'.

di5pl,:o.y

pr'oject brO"/'i5et'

I
Figure 15.53

file li:::t bt'O'.. ... 5er ',...,... 0 rk::: p ':0 C e 5y:::tem tt',;.n:::cript
::: :.'5 t
5'~"'1"~

cut ".:O.5te do It pt'int it ce c.;.nl el fOtTna.t :::pa.,/,... n e::-:: I\.;.in

em

"",,/0 t'k::: p 03

quit' line5: #(1 7 ), ::; c t'e en\' ell 0 "/'''' E: u t t on r"," e 55,; 9 e::: ...

010

#( re::: tot'eDi:::pl.; y openF'rojectE:t'o,.'V5et'

348
Examples of Creating or Changing Browsers

You need to update the class variables and to inform existing instances of ScreenController that the menu has changed. This is done by evaluating the expressions
ScreenController initialize. ScreenController alllnstancesDo: [ :sc

I sc initializeYellowButtonMenu]

that appear at the end of the method initialize, as shown in Figure 15.54.

f<.ernel-::;upport In t e t-f.:<. c e - Fr.:<. m e "/ Eo pi ,j i r, e r r',/1ou5er',/1enuContt" - - --- -- -- --I:::::: Ilnterf.j.ce-Li5t5 In t et-f.:<. ce- Teo t ::;c t-oIIContr'olletInt er-f,j ce- r',/1enu5 ::; t ,j nd,jrd::; y 5tem l I:: :: >llntet-f,jce-F't"ompt in5t,j.nce

I> <I

"11I#1'i'.&"iibim

geMmprmpQ1i 1QllumH
-- - ---- -- ---

.i#"."WliD

line5: #(1 -; ), ::' c tOe en'," e II 0 "/'''' E: u t ton r',/1 e 55':< I~ e 5


+-

':<.I~,jin

undo # (t-e 5t 0 tOe D i 5 PI,j Y 0 pen F't-oj e c t E: tOO "/'/ 5e (: 0 p y cut p.:<.5 te n T r.:<.n5ct-ip t

openFileLi5t openE:t-O"""/5er open'o,,'o,lork:;'~ open::; y 5 t e m'o,I'/od5p ,j c e

I
Figure 15.54

5,j',/e quit),

010
The ScreenController must be able to response to the message openProjectBrowser. The method is shoiwn in Figure 15.55. Add this method to ScreenController. The System Menu is now changed so that you can try it out (Figure 15.56).
Now that you can create project browsers using the System Menu, you will find that adding projects and removing projects must be broadcast in some way to all existing project browsers. Moreover, unless you are careful, broadcasting a message to change a browser will cause it to redisplay. If project browsers from different projects redisplay on the single display screen, this will look very peculiar. Thus you might prefer to add a menu item to the yellow button menu of the project browser list menu subview, update projects. You can broadcast the addition and removal information without updating the display of the browser, and then select the new menu item update projects to obtain the proper display. This is the technique adopted by the system browser. Perhaps you can think of an improved approach. Also note that if you do change the menu for the project browser, you must reset all the class variables referring to the menu.

('t)

0)1 ;:l '<:t C


(l)

:E
....ffJ
(l)

;; +-'
"-

III

E (l)
>,

I.,, ()

'I'

:~

.:.
III 4-'

-E 6
1,'-' 1 ..-,

G...

'_I

....'
G.-

U)

-~. ~~ 0'
.~

::-

IJ,1

...c::

....-

~~~ +-'
III

I~~;" ~ ~~;
III

1.'-,

,ri

c--;-:-

=+-' 0...
-~

III

Q..

a...
CI

C)

c ~ ...c
~
~

III

c c C III III o...o..u


.:. 0 0
1)1

f-I}I
I_I

c ~
C

11::-

'I' 'I'
'-11
~

1,-.1.'-'
l],l,.,_,
1"-1

G.-

+-'

IT:i

IT)-,

~ ~i
III '.....

~~Q
C 1],1

c---::-

1t:1

--,
III

It:l

0...

III

I";:)
[-.J

Ii,)

'I' "0
L

................

,]1

'l:i ~
;:.

+-'
It:l _:_

'I'

C'

-:. 1 ..-,

'.-, ,.,",

iD
.......'

'_I
1]1

C
III

~-C
-

0...

on:
,..",
1.,-,
IT)

il'
~.:JM.:
!

gu
1,-.

".....

rn
C
C

C) ='
C
L
(11

.:.

.:::

~ ~~
~ ~~~;
f -,
....... tl) C?:1

C
~

11,"-

L:.st :. . '=, .~ ~

-tl
'.

-=;

III

="D o C
:......

It:i

'I' .;:c.
C/J
4)

U:;:2

,...,:, +-'

iti

'1)1

(0 (0

-f~f
1 I I I
III () III
()

1.'-'

-t:'

3:
(Q
'-

o --

,~.

-:i I~ :.!:, 2 ~

;, ~ <i~'~

~ :::.~:i ~ ~:S:

gI~~~I'
g~
~
I~;

..... 1,-,

'I'

in

rn

III ~
'I'
'-'

~o...n

rn

'1' '1'
fJ
ITI

1'-1

.-',
IT)

iD
I}l

C
4-'
1'-1

'I'
---

r-l
--,

..:::

f ;r}J:: I~~:

:....
iD

C'

...

(.)

.....
~

III (.,) '-I-

I}I ()

....

4)
~

o -0

1)1

'-'

't:' .t:; .t:. 't:'


'.....

'......

:......

'+L

Q.

c:
4)

u.

111 ......'

III 4-'

111 III 4-''''''

f .t: l 't 't:~: : .t:~: : 't~: : :~: :~:


~
1]1

di~]H
~
I

r--- G ;.=: IT) ..... ..... ..... 1,'-' --- -, ~ -i, :~: -~ c ~t: t:D ~:-LL~~
c
I}I
~

;::;

.:'

a...

4-'

c
'I'
III

,I'

:~: 2
C

III

.... '
C

..... --,
W

4-'

Qi 'It:
C

g-

'11

,_.

:~:
c

4-'

,-,
1_-1

C
III 111

cIII
1)1
rJ

'1' '1'
11-1

'I' .....
---",

C
1)1 1)1

C C C C

Q.

1 ~:S."~ ~ ~ ~

':~.: '::01<

'-'

1.0
C

II-j

1'-'

1]1

'II

III

,}I

,-,

G.-

'1'

.....
c

1"='

~ ~
I1':i I1':i

I: :
(.0

..0
.-1
Q)

I1':i

..0
.-1
Q)

b()

... ::l

b()

::l

...

.......

Spelling Correction

354 Spelling Correction

A major area of research in the development of programming environments has been to provide on-line assistance to the programmer. Some of the earliest work in this area was done in the context of the development of the Interlisp programming environment under the research title of ~~programmer's assistant." [\\1. Teitelman, ~(Automated Programmering- The Programmer's Assistant," Proceedings of the Fall Joint Computer Conference, Dec. 1972; W. Teitelman and L. Masinter, ~(The Interlisp Programming Environment," IEEE Computer Magazine, April 1981, pp. 25-33]. One of the results of this research was the introduction of the DWIM, or ~(do-what-I-mean" spelling correction, approach to interaction and error handling. Adapted from this research on spelling correction, the Smalltalk-80 system includes the ability to assist the programmer by correcting misspellings of variable names and message selectors. Spelling correction is done within the context in which you are working, that is, within the scope of the variables and message selectors of a class definition or of an interrupted context. This chapter describes the spelling correction mechanisms as you might encounter them when evaluating expressions in a workspace. Chapter 17 explores the way in which the Smalltalk-80 parser reports syntax errors in method definitions, and the way the system uses the spelling corrector to help you correct these errors. And Chapter 18 illustrates how you are notified of runtime errors that are associated with unrecognized message selectors, and how the spelling corrector can help you determine the correct message selectors. Figure 16.1a shows a workspace in which the text consists of a temporary variable declaration for bic, and an expression to assign an instance of class Pen to the variable spelled bik. This could either be an undeclared variable name, or a misspelling. If you select this text and then choose the yellow button command do it, the system guesses that bik is an undeclared variable. This variable is selected and a menu of optional next actions is displayed (Figure 16.1b). Four of these actions involve declaring the variable; one tries to fix its spelling.

,j c cept C,j.rlcel

Figure 16.1a

355
Spelling Correction

II
Figure 16.1b

.
..;-

I bic: I
Fieri ne'//

I (jecl.:'.t-e bik

.:1;0

000
temp class var

temp CI.:'.55 'o,".:'.r ,~lob.:t.1 ~ Ij n (j eel.:.. tOe d cot"t"ect It .:'.bort


:::::::::::::/
::::

:: :-:

::::

::::

::::

:::.

Declares the variable to be a temporary. The variable name will be inserted into the text, delimited by the vertical bars. If the vertical bars do not already exist in the text view, they are added. (See Figures 16.4a, 16.4b, and 16.4c in which this declaration is illustrated,) Declares this variable to be a class variable of the class of the method in which the error was found. If the error is found in the text subview of the inspector, then this declaration will make the variable a class variable of the inspector. At the level of a workspace, the class is assumed to be UndefinedObject, the class of the object nil. (All class variable names must start with a capital letter.) Declares this variable to be a global variable, which means that the variable is included in the system dictionary, Smalltalk. (All global variable names must start with a capital letter,) Leaves this variable undeclared, which means it is included in the system dictionary, Undeclared. A message that states that the variable is undeclared prints in the System Transcript, if it appears on the screen. Tries to determine the most likely correction. (This is done by searching the known symbols in the system for the closest match.) Forgets the attempted evaluation.

global

undeclared

correct it

abort

356
Spelling Correction

Choose the command correct it (Figure 16.1cL The system determines that the most likely correction for bik is bic. A confirmer is displayed indicating that the proposed correction is bic. Confirm the choice by choosing the command yes (Figure 16.1d). The correction replaces the erroneous variable in the text of the workspace (Figure 16.1e) and the expressions are successfully evaluated.

l'I'II..I:.il'~:i~I!..:m

I bie I

!III .,:.

F'e nne '",',,0'

I decl,:'.re

bik

,:'5

temp cl':'.55 '0,,0 ':..t qlob.:..1 Ij n Ij e c I':.. re d

Figure 16.1c

100
!III
I bie I
.,:..

:::

Pen neo,,o",o'

Confirm eorrec:tiorr to bie


~~ll

es

Figure 16.1d

100

f!
:::::::::.

(~ll
::::::::::

rio
:::::: ::::::::::,: ::::::

:::.

:::

:::

:::

:::

:::

::::::::::::::::,:,

In Figure 16.2a, a statement has been added to the text in the workspace, but the trailing colon for the keyword go was omitted. The attempt to evaluate the expressions fails. The erroneous message selector is selected, and a menu appears indicating that the problem is that the message go might be a new message (Figure 16.2bL

pe hng Carre Clan t'

I'

357

Figure 16.1e

Figure 16.2a

Figure 16.2b

358
Spelling Correction

The menu indicates three optional actions.


proceed as is
Proceeds on the assumption that this message will eventually be implemented. This is a likely occurrence if you take a top-down approach to programming. This option really only has meaning in the context of compiling a new method, not in the context of evaluating an expression in a workspace. Tries to determine the most likely correction. Forgets the attempted evaluation.

correct it abort

Choose the command abort. As shown in Figure 16.2c, the keyword go was corrected to be go:, and then a third statement was added. The attempt to evaluate these expressions fails (Figure 16.2d). A menu appears indicating that the problem is that the message trn: might be a new message. Choose the action correct it. The system guesses that turn: was intended (Figure 16.2e). Confirm that this is the correct message by choosing the confirmer menu item yes. The correction is made in the text of the workspace. The evaluation is restarted, and the new Pen draws a line on the display screen (Figure 16.2).

,3.CC~pt

ca.nc~1

Figure 16.2c

010

Spell' 359 Ing Correction

Figure 16.2d

I bie I
_ bie f- P.:.r, n.:.'",',,' bie qo: 1nl- - " _ _ J,

bieB!

yes ..~~
Figure 16.2e

rio

I bie I
td 1-: _
f-

PI:::!n

r,.:.',,',,'

bie qo: _

11-11- - " _ J.

bie_

Figure 16.2f

360
Spelling Correction

For the next example, edit the statements in the workspace so that there are four expressions; the second (and new one) changes the form source (the ((brush") of the Pen to be a new Form. Evaluate the statements (Figure 16.3a). The class name Form was misspelled as indicated by the menu that appears (Figure 16.3b). Choose the command correct it. The system guesses that an appropriate correction for Fom is Form (Figure 16.3c). Confirm by choosing the menu item yes. Evaluation is restarted, but another error is found (Figure 16.3d); a message is not known. Choose the abort command. Parentheses are needed. Notice also that the argument to extent: should be an instance of Point. Make both corrections (Figure 16.3e). Delete the declaration of bic as a temporary variable; evaluate the remaining expressions (Figure 16.4a). The system notices that bic is not declared (Figure 16.4b). Choose the item temp in the correction menu that appears. The declaration is inserted into the text (Figure 16.4c).

Figure 16.3a

010
I bie I
bie ~ Pen ne',//, bie 50ureeForm: bie !jo: '100. bie tUtTi:

III ne'",'",'

e>::tent: 20. d.:.el.:t.re Foro ,:'.5 temp


CI,:t.55
:11:::::::::::::11

e9

'/a.r

Figure 16.3b

100

'jlob.:t.1 Ij n (j e e l.:t. re (j ,\,3.bort

361
Spelling Correction

~ Pen ne.. .. sourceForm:


I~ 0 :

ne.., e::<tent: 20.

'1 [II] .

tUtTI: ::: 9

:
Figure 16.3c

r . ~~:~;,

(:::onfirm correction to Form


~q~l
=.~

no

Pen ne.. ....

sourceForm: Form nevv' I>:. tent: 20


~~o: 1C)O. turn: ::::9

Figure 16.3d

100
~ ~~o:

sourceForrn:e>::tent: is a. ne/.. rnessa.!~e proceed ~.S is correct it

Pen ne.. ....


2Ii:~ 1[~1.

sourceForm: (Form ne.,., e>::tent:


ll]C).

'\

turn: i:i9

Figure 16.3e

000

362
Spelling Correction

Figure 16.4a

010
:::::::::

:::::::::::

Fi:iii:iiiiiiii'iiiiiiiiH

II

f- F'e nne """"', bic sourceForm: (Form ne',/,/ e>::tent: 2CJ(~ '10),

I<~<:>::::<,>I bic Ijo: '1 C:re" I:~,~:><:':>I bic turn: ::;9

I clecla.re bic

as

Figure 16.4b

100
bic Ijo: '100,
~)ic tUtTI:

cia. s S \1 ,:to r1 9lob a.1 un (j e c I ,:to re d COtTect It :,:,::: ,:t.bort

bic 50urceForm: (Form ne'/,,' e::<tent: 20@ '1 C)), ::;9

Figure 16.4c

000

Syntax Errors

17.1 Variable Name or Message Selector Errors 17.2 Poorly-Formed Statements or Methods

364
Syntax Errors

A compiler is used in three places in the Smalltalk-80 system:


1. when you add a method to a class description by choosing the command accept in a system browser,

2. when you evaluate an expression by choosing either the command do it or print it, and 3. when you file in a class description from an external file. This chapter illustrates the kinds of syntax errors you can encounter in the first two cases; Section 22.2 describes the third case.

17.1
Variable Name or Message Selector Errors
The spelling corrector is a part of the syntax analysis available when you compile class methods. To illustrate the kind of syntax errors that you can encounter, follow an example implementation of the class FinancialHistory. We will continue to work on this FinancialHistory exam~ pIe for several consecutive chapters, so try to save your work between sessions. Add the class category Financial Tools and define the class FinancialHistory. The class definition is shown in Figure 17.1. (If you have forgotten how to add class categories and classes, review Chapter 9.) Choose the browser menu item class so that you can define a message understood by the class FinancialHistory. This message is an instance creation message. Add the class protocol instance creation. In protocol instance creation, type the method for initialBalance: shown in Figure 17.2a. Choose the yellow button command accept. The method for initialBalance: consists of sending the new instance of FinancialHistory the message setlnitialBalance: so that the instance variables can be initialized. This message is not implemented as yet, sO a correction menu, like the ones introduced in Chapter 16, appears. The menu states that setinitialBalance: is a new message (Figure 17.2b). The next thing you will do is define this message, so choose the action proceed as is to complete the compilation of the method initialBalance: (Figure 17.2c).

365
17.1 Variable N arne or Message Selector Errors

1>">::>:::1 ::;y::.tem-Chan1je::. 1::::1 ::;y::.tem-C:ompiler

1. . . . . . .IIiIIIIiIIMllIIiIII~~.1 - - - - - - - - - - - -

> 1 ~;ii'~=~t:~r~~_:i,~~~:::.in9

I>
I>

. File::'-.>:.ero:<

1 File::.-,':::',b::.tr-a.ct

QJ.i,it#'.m

,':::',Ito

i
ill!
lillil

~='bjec t ::.ubcl,:o::.::.: #Fin,~ r, ci,:oIHi::. t or-y


ir,::, t ,:0 n c e \i ,:0 t-i ,:0 til e r",J ,:0 me::.: ' c ,:0::' 1'"1 CI n H ,:0 n cJ e / perl cJ it u t"e::. . cl,:o::.::. \i ,3 t-i ,3 ble[",J,:o me::.: " po olDi c t io narie::.:" c,::.tQljory: 'Fin,3nci,31 Tool::'

Figure 17.1

000

ll(:r-ea.te ,:t rie'",'",' Fln,~,nc:ia.IHi5tory

"/I,I'itrl a.rnount 1~_5 the current c,:o::.r,


,:0 9,:0 i

r,

undo

coPy
cut p,:O.::' te
1]0 It

pt-int it
~"'M"'III

c,:onc~1

Figure 17.2a

010

form,3.t Sp':O"i'in e\plain

366
Syntax Errors

in i tia IE; a I.:. nc e: ':. mount "Cre.:.te ':. rle,I,,I on r,,:.nd," t5uper- ne'........ setlnitialBalance: amount
Financi,:'IHi5tOt-~

... ,I,,Iin-, am,:,unt

,~5

n-,e CIJtTent

C.~5rl

Figure 17.2b

100

init i alE:al ':. nc e: a moun t


1.11:

"Cr-eate ,~ ne,I,,I Financi,~IHi5tOt-"" orl r,,:.ncJ,"

',I,,Iin, ,~mOljrlt .~5 n,e CUtTerlt c,:'5r,

t5uper ne',,I,,I setlnitialBalance: amount

Figure 17.2c

000

367 17.1 Variable N arne or Message Selector Errors

Now choose the browser menu item instance and add instance protocols transactions, inquiries, and private. Under private, we will categorize all messages that should only be sent by an instance of FinancialHistory to itself (self). Define setlnitialBalance: under the protocol private (Figure 17.3a). Notice that for the example, you are to mistype the instance variable cashOnHand-the 0 should not be capitalized. A correction menu appears indicating that cashonHand is not declared (Figure 17.3b). Choose the command correct it. A confirmer appears indicating that the probable correction is cashOn Hand. Confirm by choosing the menu item yes (Figure 17.3c). As a result of your choosing yes, the corrected variable name is inserted into the method, the method is successfully compiled, and the message selector is added to the browser menu (Figure 17.3d).

1<)1 :~: :::: ~ ~: ~: : = :~:::~,~,'n:~


1.// /1 Files-,"-,bstt"act
,i!.,lto

gU;;,;;mmN.
------------

I> >1 ~;ii'~::~t:~f~~.:',~~~:sin'j


QI'il,I.I

tra.ns,:.ctions inquit'ies

me"

11 Files-.:<etO\
m

cla.ss 5I2tlrlltia,IE:ala,nce; .;t,rnount "Initialize Hie inst,3nce "i,3.riables of tr,e c,3.shonH.:.ne] - ,3mount,
ne"i'i

Fin,3rlci,3IHistory."
,3
Ij,:..in urJe]o

copy
cut

c,:'.n,_: -I fo t-rl"i a t

Figure 17.3a

~O~I!O~l1bJill~illl]1illJ]IIillJilllillIilll]IIillJill~illl]1illJ]illJillillJillilll]1illJ]~illJillilll]1illJ]=~E''1~: 5 ~ ;':~E"r~E'~IIillJillilll]~

368
Syntax Errors

1< ><1 :=: y::. tem-C:h':'.nge::. 1 >1 E: :,1::, t i;! m- C:ompi\i;!r


.':::'::''::':::::\

1. .1111.........IiIIMlliIl!..

~;i:(:::.t:~:f~~,:i.:~~;::.in'~
li'Ii'M"

lr'iw lIlli!!Il.II.. 1 t r.:t n::. :t.C t io n::. .... 1

11F.Dl!j:Ii"~kIUm~jli'tt!~I::. 1

."",'<:"'1 Fi Ie::. - ."-. b::. t t'':'. C t 1'::>''1 File::,-;":i;!t'O\ ."-.Ito

I ' < > ,I - - - - - - - - - - -5et Initi.:.IE:.:. I,:t nce: a mount

C/.3.::'::'

"lrdtialize tt'le in::.ta.nce /a1'iatl/e::. of the ne'// Fin.3nciaIHi::.tot'y."

.W*M'
i;!/pi;!nditure5

3ffJOunt, Diction,:rry ne',/..

declare cashonHand .:t5 temp cia::.::. /a.r


,~/obal

Figure 17.3b

100

undec/a.1'ed

1><">1 -----------::'12 tlni ti,3./E:a/a nce: ,3.moun t

"Initialize the in::.t,3nCf, '/,31'i.3ble5 of the ne',// Fin'3nci,3IHi::.tor'y,"

*MI
e.\ pen,jit ure::.

,3mour,t, Dic tion,3t'y ne',//

C:onfinfl correction to c,3::.rIC'nH.:t.nd


~.-

._l1.,

no

Figure 17.3c

369
17.2 Poorly-Formed Statements or Methods

I> >< >1 ~;ii'~~~t:~,r~~.:;,:~~: slnl~ 1><1 Files-,"-,t'Stt',3.ct 11 Files->':eto< ,"-.Ito


Q',,#I,8"

I........

I>:'):

I : ;:,. stern - Com p II: r

I :=;',,'stern-Cr-,anqes

------------

QiMiiim@"M
- - - - - - - - - - --

mu';

t r3.n S,3. c t ions inquit'ies

."mW'Wt#i,iW

set Ini ti,3.IE: ,3Ia.nce: amount "Initialize Hie instance \",:.r-i,3.bles of tr-Ie rle"i'i Firl'3rrci'3IHistoty."

'+'

e>penditut'es

,3mourrt. Diction,3r'y

n';"'i'i

17.2
Poorly-Formed Statements or Methods
Choose the protocol transactions and specify the method for spend: amount for: reason (Figure 17.4a). Notice that you are to omit an argument. When you choose the yellow button command accept, a syntactic error is found (Figure 17.4b). The error message, Argument expected- >, is inserted into the text, preceding the point of the error, so that an arrow points to the location of the error or to the location at which the error can be corrected. Type the correction so that the error message is replaced by the argument name reason, and choose the yellow button command accept again (Figure 17 Ac). This time the new message totalSpentOn: is noticed (Figure 17 Ad). We will define this message later so choose the action proceed as is. The method is compiled successfully and added to the class (Figure 17.4e).

370
Syntax Errors

I. >< ><1

I:':>: ::.<1 ::;ystem-Fiele.:<.sirlq

:~: :::: ~ ~: ~: : =:~:::~,~,'~:~ IlillDmBlllilEDDIm"IIIIDII- -- -- -- - --- -

1 < I Files-::,tre.:<.ms < I Files-,6,bstr-.:<ct


I:::>: <'.:::'1 Files-:<.ero. ,"-,Ito I

>

Qimlet_@
1 ------------

cla.ss

sperll:J: ':< mour, t for: roe ':<. SOri "::;penl:J amount for- n-,e re,:<son Iji.. en, decrementinlj U-,e .:<" . . ,:<iJ.:<ble c .:< sr, 0n r, ':<. rI d ," e.per,ditur-es ,:<t: put: (self tot,:<I::;perlt')n: r-e,:<sorl) c,:<.sr,I='r,H,:<.r,d ... c.:<sh l)r,H.:<r1d - ,:<.mour,t ':< I}:< i rI un,:Jo ,:<mOUrit. copy I: u t ",aste do It prirlt it ca.r 'el form,:<.t sp.:<.".. .'r1

,.

Figure 17.4a

OIOI~~~~~~~ =:>:,I.:<i~r1HI

1 < <>1 ::;ystem-Cr,a.rIljes 1 < 1 ::; y S t e m- Com p i Ie t1

<<

i;i i,~;~t:~'-~~_:i.: ~~: S ir19

IIilli1mBlllillDD1 m"IIIIDI I - - - - - - - - - - -

1>':',:'><1 Files-."-.bstr,:<ct I. <I Files-:<et-o>: ."-.Ito

Q'ii'M"
sperll:J: ,:<mOUrit for: reasorl "::,perll:J .:<.mourlt for the re:<.sorl Iji',,Ierl, decr-emerltirl1j tr,e .:<","ail.:<.(lle c.:<sr, Orl h.:<r,d," e.perll:Jitures ,:<t: r-e,:<sorl)

Argument expected -)

+ ,:<mOUrlt,

c,:<.sr,C'nH,:<.r1d ... c,:<.sr,C'rlH.:<.r,,:J - ,:<.mOUrit

Figure 17.4b

000

371 17.2 Poorly-Formed Statements or Methods

:::peneJ: ,3.rnount fot': t-ea.:::on "::,peneJ 03 mount for Hie re ,3::: on Iji\1 en, cJe crement irl1j ca:::t", on r,,3.neJ," e<peneJitlJt-e::: ,3.t: t-ea.:::on j,ut: (self total::'pentC1n: tOe C,3:::t",I)nH,3ncJ ... ca:::t",ClnH,3nd - ,3.mourlt

,3'j,3.in uncJo

copy
cut -',3:::te do It print it C,3 :el form,3t :::p,3",:,,:r, eo "ilain ,3mount,

Figure 17 Ac

010

:::pend: ,3mount foro: te,3.50n "::'pend ,3.mount for" tt",e t-e,3:::or, 'ji',,:en, deu"emerltir,1j Hie ,3"':,3il,3l,le C,3.:::t"1 on t"',3nd," eopenditut"e::: ,3. t: r"e,3.:::orl put: (self totalSpentOn: reason c,3.;,r,C'nH,3nd .,. C,3.:::t"il)nH,3nd - ,3.moun
l

;, +

,3.mour,t,

tot,31::,pent ='n: I::: ,3 ne',,:,,: me::::::,3'je

Figure 17Ad

100

372
Syntax Errors

sper,,): ,jmour,t fot-: "::,pen,) amour,t fOt- the t-e,j sor, 'ji . . er" C,j sh on h,jTI')," e,perl,)itur-es ,jt: t-e,jS'XI put: (self total5pentOn: reason c ,01 s 1"",'=' r, H ,j n ,) .... C,01 S1"",'=' r, H a r, ,:J - ,01 m 0 Un t ,)ect-emerltirllj Hie ,01'" ,jil,j[,le

Figure 17.4e

The syntax errors you might make when you try to evaluate an expresson or compile a class method fall into three categories: 1. something expected was missing 2. there was a bracketing error 3. you tried to do something you can not do Expected parts of a method that can be missing are the argument name, as illustrated by the previous example in Figure 17.2a; an expression after an assignment symbol (+-) or after a return symbol (f); a vertical bar; and a period or right bracket at the end of the method. Also nothing more might be expected if the compiler thinks the method has ended, although something more exists. Bracketing errors may exist for parentheses, comment quotes ("), square brackets, and string quotes ('). Another common mistake is omitting the period at the end of a statement (other than after the last statement of a method). Three things you can not do that will be noticed as syntactic errors are to store into a pseudo-variable (self, super, true, false, or an argument), to cascade to a constant or to super, and to cascade certain control messages (ifTrue:ifFalse:, ifFalse:ifTrue:, whileTrue:, and whileFalse:).

373 17.2 Poorly-Formed Statements or Methods

To illllstrate another syntactic error, add the method totalSpentFor: to class FinancialHistory; categorize it under inquiries as shown in Figure 17.5a. (For now, please ignore the fact that the message used in the method for spend:for: was totaISpentOn:, not totaISpentFor:. You are making this error so that we can illustrate another kind of error in Chapter 18,) Choose the yellow button command accept. A syntax error message is inserted into the text at the end of the method (Figure 17.5b) because, when you typed the method, you forgot the closing right bracket. Replace the error message with the right bracket and choose the command accept again. The method is added to the class (Figure 17.5c). Remember to save your work, either by making
1. a snapshot (see Sections 1.4 and 23.1) or

2. a file that describes the class.


In the system browser, choose FinancialHistory and then choose yellow button command file out. The file name will be FinanciaIHistory.st.

1~~lm~_I------------

tot ,;,1 ::,p en tFor": t"e.;, 50n ","-,rI5 .....,.. er Hie amount 5perlt fOt" t"e,;,50r,; e ,perlditur-e5," ( e ' pen cJit u r"e~, inclu l:Je 5 fe y: re;, 50n) i fT nJ e: ,;, I~pirl ur,,:Jo

Ci if re,;,~,orl r,e',.. er" u5ed fot"

[t e i p en,:Ji t ur"e 5 at: re.;, 5or, ]

copy
cut

ifF,;,15e: [tC~

Figure 17.5a

l1L!OI!illO

~B]EB]EB]EB]E~a..

374
Syntax Errors

I~~~II_

. . .I

-------------

CI03SS tot ,3.1::;pentFot-: re03 son ",':",nY'i",'er tt",e 03.rnount spent for re03.son;
e>:.penditur>~s, "

0 if re,3.son ne"ier use,] for

(e:<penditut-e s inclu']es V:ey: re,3.son) ifTrue: [te>:pen,:litures .3.t: re.3.son] ifF,3Ise: [to Period or t-ight bt-03c~et e)pecte,:l -)

Figure 17 .5b

000
tot 031:3 )en t For:

1// /

_
tot 03.I::;pentFot-: re03. son ",':",nY'i'ier tr,e ,3.rnount spent for re,3son; e >:: perll]it ut-es," (e,pene1;tut-es inclu,]es f<ey: re03.son) ifTrue: [te:<penditures ,3t: re,3.son] ifF03lse: [t0l. 0 if t-eason ne''1'er used fot-

Figure 17.5c

000

Notification of an Execution Interrupt

18.1 Incorrect Message Selector 18.2 Other Runtime Errors

376
Notification of an Execution Interrupt

A message-send is the activity of sending a message to an object. A notifier is a view that is displayed on an interruption of a message-send. Since responding to a message involves sending a message, a notifier is basically a view on a sequence of message-sends. Each of the messages displayed in the view has been sent, but has not yet received replies. There are a number of ways to interrupt a message-send, four of which are described in Chapter 20: the programmer sets a breakpoint, the user types the ((control" and ((c" keys at the same time, the system runs out of space, and recursion occurs in the system error handler. This chapter explores interrupts that occur whenever a runtime error is encountered. Most runtime errors occur because a message was sent to an object that does not understand the message, that is, the message selector was not specified in the class of the object or in any of its superclasses. The error could be that the message selector was incorrect, or that the receiver of the message was the wrong kind of object. The other kinds of interrupts are discussed in Chapter 20.

18.1
Incorrect Message Selector
The FinancialHistory example in Chapter 17 will be used to illustrate the way a notifier is used to locate a runtime error. If the class is not already in your system, we assume you created a file containing the class description, as discussed at the end of Chapter 17. Evaluate the expression, (FileStream oldFileNamed: ' FinanciaIHistory.st') fileln to retrieve the class. Open a workspace and type the instance creation message
FinancialHistory initialBalance: 450

This creates a new instance of FinancialHistory with 450 as the cash on hand. Inspect this new instance by sending it the message inspect. (Remember that the instance creation expression must be parenthesized as shown in Figure l8.la, otherwise the precedence rules cause the message inspect to be sent to the number 450.) Create the inspector and examine the values of its variables (Figure l8.lb). In the text subview of the inspector, type an expression to spend some of that cash.
self spend: 100 for: 'rent'

Evaluate the expression by choosing the yellow button command print it (Figure l8.lc). A notifier appears (Figure l8.ld). It consists of two parts: a title that states the reason for the execution interrupt, and a list of the last few interrupted message-sends.

377
18.1 Incorrect Message Selector

:::;ystem E:ro.lser

1:.:,..1 ~JI~E~~i~~~flg

;;~~~~!~~;;" ;~~;ij~J;"";" ;;~~~~~;~;~;~;'"


.....
cla.ss
:ij~~~ij{'

I:n:: /1 Files-,':",bstr,:'.ct 1::\\1 Files-.:'{eto::-:: ,':",Ito 1:/ :\]iffl~m~~iT~~~.~~~


1:1 ------------

If total:::;pentC'n: re,:'.son)
COP~!t"

+ .:l.mount.

mount

cut pa.ste ",rin'\ it a.ccept c.:'.nce)

:;:;::

Figure 18.la

010
1 \ \ / I :::;ystern-Compiler :OO~

I:.: \]
I:H/\

450
;:;ystem-Ct"I.:.nl~es

I:::: 1:::;ystern-Fiele.:.sinq
1< ~I Files-;::;tre,:'fn5 1 Files-,':".bstr.:'.ct Files-:":et'o, ,':".Ito

I:H : :1 ~M6~~"rt~~~: I: : \ ] -----------.~


spend: .:. moun t fOt": tOe rj a.mount fo 1_ ~ II
_ 0

"'_.,

1,II,II-,t ( .. ::.p.::'.l_.~

(Fin.:.nci.:.IHistory initi.:.. 450) inspect If tot.:.I:::;pentCm: re.:.sc,n) mount

a.mount,

Figure 18.lb

100 000

378
Notification of an Execution Interrupt

.01'j.01in un.:Jo
COP~!o"

1<><><1 -----------::.pend: .01mour,t foro: r-e.01::.on \1,,o'ot-k::.p.01.ce ~ a.n-:,ount for tl"",e (Fir, a nc i.01 IHi::.t ory init i.01 IE: a 1.01 450.) in::.pect
L..._ _.....,~iiiiiil. ......

cut pa::.te do It

If tot.01 1::::'pent'Jrl: re.01::.or,;, mour,t

amount.

Figure I8.Ie

010
I,
1

< <.1 ::::;y::.tem-CI""I.01nqe::.

~i;E:~;~::~:~f:g
::.pend: .01rflount for: t-ea::.on

Fi nan c i.01 IHi::. t 0 toy (('[' j e c t) >>.:J 0 e::. f'.j 0 tUn d e r::. t.01 r,.:J: Fi n01 r, c i.01 IHi::. tory::. pen d: fo r: Fin.01 r,ci.01 IHi::. tory" Dolt

1"',<""",''''1 Fi Ie::. - ."-. ['::' t t-.01 c t


1<

11 fiMncl~fto~s. Io:o""...,........,..'"'""i C omp iler-"e'/.01 lu.01 t e:irl: t ~rloti fy in'j:i fF.01il: I, >< I - - - - - - - - - - - 1< > 1---------.&;,;;,;....................."" CodeContt-oller-".:Jolt
',,o',,o'ork::.pace ~ .01_rr:,ount fOt- tl"",:, (Fina ncia IHi::. tory 450) ir,::.pect If tot.01I::::'pentCtn: r-e.01.::.on) mount

>".".

1 File::.-::et-o' ."-.Ito

.01rflount.

Figure I8.Id

000

379
18.1 Incorrect Message Selector

You might decide from this information that you have seen enough information, that everything is satisfactory, and that you want to proceed with the evaluation. You can do so by choosing the yellow button command proceed. Or you might want to stop the evaluation and do something else. You can do this by selecting the blue button command close. Of course, the view is non-preemptive; you can just leave it on the screen and do something else, returning to deal with the interrupted situation at a later time. The message shown in the Figure 18.1d says that the message totalSpentOn: was not understood. Of course, this happened because you specified the method for totaISpentFor:, not totaISpentOn:, when following the example in Chapter 17. The yellow button menu of the notifier includes the command correct. Choose it (Figure IS. Ie). The system determines that the message should probably have been totalSpentFor: (Figure 18.If). Choose the menu item yes in the confirmer to indicate your agreement. Evaluation proceeds, using the corrected message selector, so that the $100 is spent on rent. The method associated with spend:for: returns the FinancialHistory as its value (Figure 18.1g).

::; Ystem -(:r"j nqes

1/ )

)1

:F'~:i:I:_:,~._~t,~_: =_~;: t:"=t"~:~:,_"'. ,:~.'lr l~-~I"_:~ " ~f~-9~~M::: Fin,j nci,j.IHistoty(':)bject >doesf",]otUndersta. nd:
Files - ,"-,b st r,j. c t Files-.:<.et"o): ,"-,Ito

1/

1
>I

I> 1 ~Mij~~~rt~~$ I) )/1 -----------I>


" ' _ "l .. 1,11,lut

_ _........==~ CoeJeControllet"dolt
j ,jmount II

~~~~

Fina.ncia.IHistoty> >speneJ:fot": Fina.nci,jIHistoryDolt Compiler> >e',/a lu,j. t e:in: t o:not if proceed :


detlul~
'0

I ) )/1 spend: ,jmount for": re,j.50n


(::Ip,:tl_:~
_ . __

for

trlg&-r------~------------'1'q

(Fi n,j n cia IHis tory in it i,j IE: a.1 ,j. 450) ins pen ......--~- .... - - - - - - - - - - L I If tota.I::;pentC1n: reason) + amount, mount

Figure I8.Ie

010

380
Notification of an Execution Interrupt

self spend:l l- l C! for": 'r".:.nt'


I:>'>'::> ':I I::':::>::>' 1:<,':':0:' 1<':::'::> 1>< : :'. , I I

:_;ystem Cr,,:=t.n1jes ::; y stem - C ompil e r"


::; Yst e m- Fi e Ie ,:=to S irllj Files-::.tre,:=tms Files-,"-,t)stt",:=tct Files-:<et"o, ,"-,Ito

~~OO~ r',,I1ess,:=t 1 not understood: tot,:=t.I::;pentC1n:1 je


Financia IHis t 0 r'Y( C1bjec t)' 'doe sf",Jo tUnder"s t,:=t r, cJ: Fin ,:=t nc i,:=t IHi story>' spend: for:

; r.'.. .

1:

Fin,:=t.nc retr .... ',,1,,1 itt", selector": >1 f1Mncl~dt~OJ:5 Io:!oo......,."""""~ Compil tot,:=tI::.pentFor": yin1j:ifFail: ,'t----------':"---------------:~._~...$i;;,)_~:~ C: 0 cJ e 1=_::IIo----.....,r"-----1 ......)~1' .'.. spend: ,:=tmount for": re,:=tson ~" I:!", (~II no "'_ ".-" _. __.j ,:t.mount for" tt",J:l,.I----JIiiI;;;;;--,.;;ioioiI----....;L...-------JI ur r:,:;,p'::1 _:1:::! 1_ .
I,ll,' I II

(Fin,:=t r, cia IHi sto r'y init i ,:=t.IE: ,:=t I,:=t 4':; C!.:, i r,s n e c t
r-

L...--.....,--...L. 1::;pentC1n: - - - - - -,:=tmount, f I ------If tot,:=t r"e,:=tsor,) +


mount

Figure 18.If

100

"'" :: : ':':' ::'>:

,'> >:

:':':

: >

'il.",,I,
I> >1 -----------spen1j: amount for: re,:=tson ',,1.,1or"kspace ~ ,:=t"r'-:,ount for" t~,e (Finaneia IHis tor"y ini ti ,:=t IE: ,:=t.I,:=t 4':; CI.) ins n e c t
r-

self spend: 1C!C! for":

L...--.....,......IiiiiiiL...I..------_--------f I
If total::;pentl)n: t"eason)

,:=tmount,

mount

Figure 18.1g

000

381
18.1 Incorrect Message Selector

Unlike other uses of the spelling corrector, the correction was only temporary. You must use a system browser to find the method containing the error and to correct it (Figure 18.2). Once corrected, you can spend successfully $50 on food and $75 on a trip by evaluating the appropriate expressions in the inspector text subview (Figure 18.3). You can also choose cashOnHand and expenditures in the inspector to examine the instance variables (Figures 18.4 and 18.5). Keep the inspector for the FinancialHistory so that yoil can use it in Chapter 19.

1< >1 ::;ys tern-Fiele ,3 sinq 1><1 Files-::;ue,3ms 1< <I Files-."-,bstraet
1>1 Files-.:<eto/ ,"-,Ito

1< I ::;ystern-Cornpllet- UI,III.rm;

1,.,.'.'/"""''''1 ::;y stern - Cr,anqe s

-- -- - - - - ----

0..
inquiries pt-i"/,He ------------

IIM.18'

UiM"''
cla.ss spend: amount fot-: tea.son "::;pencJ ,:<mount fot- trle t-e,3son (:,3 sri on rl,3ncL"
I~i"/en, cject-ementinl~

trle -" - :1- . ,39 03in undo

copy

~ ,~~~~,'~,i~'~t:: : ~~. ,:-:~~,;~:~,:;~:: _( c:r:'~)~'~I:':< I ::;pen t FOt~

t-e,3 son

p:~I~~e
do It print it
(:,3.~el

Jnt,

Figure 18.2

010

fonn,3 t sp,:<.',/,/n exp\.:t.in

382 Notification of an Execution Interrupt

, <.>

II +~:=;~:,~;~.t~e~r~n;,~=:-Frl~.j~.r~1q7..=.~~~,f:~~~1s elf . I " :=;ystem-Compllerftij~~ij,.~.1I.1t~


1/ / ) I :=;ystem-F:ele.jsinq 1 )/1 Files-:=;tre.j.ms
e'pendi 1<

:_;ystem E:n:I.. .. sert

"""""'>"

... "
self spend: 1DO for": 'r"ent'

<<

I Files- . e..t)str.j.ct I

1)/ ./1 Files-::er"o/ ,.e..lto


1<

~M6~ijtrr~~$.
spend: jmount for": r"ea.son ":=;pend amount for" tr,e c.j.srl on rl.jnej,"

.jlja.in undo

c op~./
cut paste "Irirl'\ it .j.ccept

.....------'------~c.j.ncel e,penditur"es .jt: re,json put: (self tot,jl:=;pentFor: r"e"_ _'l""""' c.jsh()nHand ... ca.sh(lnH.jnd - amount

jmount,

---.....,V.

Figure 18.3

010
I) d :=;ystem E:ro... ser

I/\n /Hd

I / / / d :=;ystem-F:ele.jsirJlj

:~: ~:::;, ~ ~ ~: : =::~:~:~I~"~ ~ ~

self

F*e.;~
e:<pendit: es

I ) I Files-:=;tre.jms 1//nU/1 Files- . e.,bstr"act


I) / )1 Files->':er"o/ ."'.Ito

1//)/)I~Mij~~~T~~$. '.."

ij~~ spend: a.mount for": reo

":=; pen d a. m 0 un t fo ."<,>,."",,t"I ca. srl 0 n rl and, " e'peneJitures ,jt: re.j.son put: (self tot.j.I:=;pentFor: re,json) casrl(lnH.jneJ ... c,jsrl(lnHaneJ - ,j.mount

,jmount,

100
Figure 18.4

000

383 18.2 Other RuntiIne Errors

spend: ,3mount fot-: tOe,


I)()[,J

"::: pen d 03. m0 u n t fo

IH c,3sr, on r,ar,<:J,"
e'penditures a.t: t-e,3son put: (self total:::pentFor: reason) c,3.sr,C nHa.nd .... casrl()nH,3.nd - ,3mount '

a.mount,

Figure 18.5

100 000
A notifier appears (at the center of the display screen or at the center of the active view) whenever there is an execution interrupt due to an error in running a method. These runtime errors occur for a large number of reasons. As stated earlier, most often you will encounter an error because an object is sent a message to which it cannot respond. The label of the notifer is
Message not understood:

18.2
Other Runtime Errors

followed by the erroneous message selector. The notifier only displays the last few message-sends of the interrupted execution. You may determine that this is not enough information, either because the purpose of the interrupt was to explore further or because you do not know why the interrupt occurred. In this case, choose the yellow button command debug. The notifier is closed, and you are asked to designate a rectangular area in which a debugger will be created. The system debugger is described in Chapter 19.

384
Notification of an Execution Interrupt

Runtime errors caused by other than an incorrect message selector include: Trying to create an instance of Character or Boolean. All Characters are defined at the time the system is created, and are immutable. Boolean is an abstract class with two subclasses, True and False, each of which has only one instance (true and false, respectively). Trying to create instances with incorrect instance-creation messages (such as sending new to create a MappedCollection). Trying to evaluate a BlockContext with the incorrect number of arguments. For example, if the BlockContext is of the form [ :i :j Ii> then the message needed to evaluate it is of the form value: i value: j. A message to this BlockContext with any other number of value: keywords would be an error. In numeric computation, attempting to divide by zero, creating a Fraction with denominator of zero, or taking the square root of a negative number. In Collections, mismatched collection sizes for mapping operations, attempting to remove an element not in the collection, attempting to access elements of nonindexable collections using atput, attempting to store into an Interval or to remove elements from an Interval or an Array, using an object that is not an Integer as an index, attempting to store an object that is not a Character into a String, attempting to do a Dictionary lookup with a key or value that is not in the Dictionary, or using an index that is out of the bounds of the indexable collection. Sending an object an inappropriate message (one to which instances of the superclass respond, but of which the subclass blocks the use), or sending an object a message that its class should have implemented but did not (the superclass implementation is probably self subclassResponsibility). Sending control messages to objects that are not Booleans (ifTrue:ifFalse:, ifFalse:ifTrue:, ifTrue:, ifFalse:) nor BlockContexts
(whileTrue:, whileFalse:).

n,

1
Examining and Debugging Execution State
19.1 The Activation Stack 19.2 The Structure of a Debugger 19.3 The Context of a Message Receiver 19.4 The Context of an Interrupted Method 19.5 Evaluation Within the Context of an Interrupt

386
Examining and Debugging Execution State

I I I
I:
!

To illustrate the use of the debugger, we will add another method to the class FinancialHistory which was used as an example in Chapters 17 and 18. The method will have an error in it that we can explore using a debugger.

I:

19.1
The Activation Stack
Add the method for report, categorized under the instance protocol inquiries, as shown in Figure 19.1. Try it. Type the text self report in the text subview of the inspector for the FinancialHistory created as described in Chapter 18. Select the text and then choose the yellow button command print it (Figure 19.2). A notifier appears indicating that the message do: was not understood (Figure 19.3). The text displayed in the notifier indicates the last few messages sent before the interrupt occurred. The methods associated with these messages have not as yet returned their values. In conventional programming language parlance, this sequence of messages represents the activation stack that you wish to explore to understand the source of the error.

n~port

::,uin'j H"jl: cJe.:,er-ibe5 l:he CIJtTenl: b,jl,jr,ce ,jr,cJ ,j'j,jin un,:Jo !_:UPy I ,j::,ue,jm I cul: ,j::;ue,jm - \,"ir-il:e::,Ue,jm or,: ::,uirl'j r,e"i'i, p,j5l:e cJo Il: ,j::,q-e,jm r,e'l:F'Ul:.':",II: 'Fir"jr,ci,jl Hi5l:0r-y'; erprinl: il: a::; l:re ,jm r,ei l: F'u l: ,':",11: 'b ,01 1,01 r, c e: "
.1,~,r1:'::'I,IIII'~r
,j

,j::;l:r-e,jm r,eil:F'ul:,':",II: c,j.:,rl'='rIH,jr,,:J; e'perlcJil:Ur-e5 pr-inl:'='rl: ,j::,l:r-eam, r ,01 I:; l: r-e ,jm c or,l: er,l: 5

cr-,

Illlcllc".UI

c,jn~el

Figure 19.1

010

...

fon,-"jl: .:,p,j"i'ir, ei,pl,jin

387 19.1 The Activation Stack

a.1j,jin unljo
COP~,/

1<

cut -"j:::te (Jo It

1-----------report ","-,n:::',/,/er ,j e/penditur-e:::," ,j::;trea.rn ,j ::' tre ,j rn .;- \1,/ t-i t e ::' tre ,3 rn 0 r,: ::; t t-i rllj n e "/'/, ,3.::,tre,jrn ne:<tF'ut,"-,II: 'Fina.ncia.1 Hi:::tot-y'; cr, ,3.::.tt-e,jrn ne<tF'ut,"-,II: 'b,jla.nce: " a::,tt-e,jrn ne<tF'ut,"-,II: c,j:::r")nHand; cr, e/ pen d i t u re::: p ri n t (I n: ,j ::' t re ,j rn, ta::,tre,3rn content::: ,3.cce t c,3.ncel

Figure 19.2

010
::. y::: tern Ei r-o '".',..'::: e r

I)? ?I File:::- .:<.ero>:: ,"-.Ito I: I J1M~~~~r:~~~"".~""""""~


J6~~~M
t r, a. report " ,"-, n::: ","'/ e r-

1<: < <I File:::-::.tr-e,3.rn::: 1 <I File:::-,"-,tl:::tra.ct

1:\ .1 ::;y::: tern-Fielea. :::irllj

IHHH??1 ::;~~'::: tern - Cornplier-

::..,,::: tern - C r, an qe:::

::. rn a.llin te Ije r'(':) bje c t) >>(Joe::: r'"J 0 t Un de r-::: t ,3. n d: ',.,'",'ri t e ::. t r-e ,3. rn (::. t r-ea. rn) >>n e >:: t F'u t ,"-, II: Fi n.3. n c i a.1 Hi::: t or-y >>re p 0 tot

~::: ~'~"~I ~~_I~,i~ ~.'~t~::',:~~':'~';,~ to: ~:I t i fy in Ij: i fF,3. iI:

a::. t r-i n Ij

e>:penditure:::,"

I a::.tre,j.rn I
,j::;tre,3.rn ... \,\,'r-ite::;tre,3rn on: ::.tr-in1j ne',/,/, a ::,tn~,j.rn ne>:t F'u tAil: 'Fin ,3. nc i,3.1 Hi:::tot'Y'; cr, a. ::. t re ,j rn n e >: t F'u t ,"-, II: ' b a 1,3. n c e: " a. ::; t re,3. rn ne >:: t F'u t ."-, II: c ,3.::: rl ,) n H a. n d; c r-, e>:penditur-e::: pr-in t()n: a.::.trea.rn, ta::.trea.rn content:::

Figure 19.3

000

388
Examining and Debugging Execution State

The first message-send in the example notifier indicates that the receiver of the message was a Small Integer. There is a class name delimited by parentheses after the class name of the receiver. It denotes the class in which the message definition is specified. The example shows that the definition of the message doesNotUnderstand: is specified in Object. The second message-send indicates that the error came from sending the message nextPutAII: to an instance of WriteStream. The method associated with nextPutAII: was actually found in the description of the class Stream (a superclass of WriteStream). And the third message-send indicates that the message nextPutAII: was sent from the method associated with report that was sent to a FinancialHistory. The remaining message-sends have to do with the compilation and evaluation process, and can be ignored.

19.2
The Structure of a Debugger
Choose the yellow button command debug in the notifier (Figure 19.4). The notifier disappears and you designate a rectangular area for the debugger. The debugger is shown in Figure 19.5.

1,<;:,<] ::;ystem

E:t-o',/,/ser

11 ::;ystem-Compiler
1//
1/ ) /1 /1 Files-,'"-,bstra.ct
Files->:et-o:< ,'"-,Ito

.,',',',,,,,,,,,',,,,'. ::; y s t e m- C h a. n 9 e s

~;ii,~c~t:~r~~_::,:~~:sin,~

::;m,~ III n t e ,~e t-( () bj ec t) >>do e s r",J 0 t Un de t-S t ,':t n ej:

',/,/t-i t e ::; t tOe a. m (::; t tOe a. m) >:> ne::- t F'u t ,'"-, II: Flna.nc i,':t.IHis tOt-yO :>report Fina.nci,':t IHis t o t- .., >:>Dolt -,roceee! ct .il:

1 ) / / 1 ------------

1<'<A'~MQ.~~~'t~~$.."'.:.'~~~
tOe p 0 tot ",'"-, n s "/'/ e r- ,':t ::; t t-i n 9 trl a e::<penditures,"

1<":"1 F)<tt

compilet-e',/al~a.te:in:to:not(~or ..

,':t::;tt-e,':tm
+-

I
\,\,'t-ite::,tre,':tm on: ::,trin,~ ne',/,/,

,':t::;tre,':tm

a:::tre,':tm ne:<tF'utA,II: 'Financ!,':t.1 Histot-y'; Ct-, a::,tre,':trrJ ne,tF'ut,'"-,II:'bal,':tnce: " a.::;tt-ea.m ne:<tF'ut,'"-,II: c,':tsr,C'nHand; cr, e::-penejitut-es pr-intC1n: a.::,tr-e,':tm, ta:::tt-ea.m contents

Figure 19.4

010

389 19.2 The Structure of a Debugger

n 03. nc i,:'.1 His t 0 r-'"" ::; rn 03.111 n t e q e r-( 0 [, j e c t);';' doe s ['"j 0 tUn d e t-S t " n d: "l'l t-i t e ::; t t-e-" rn (::; t roe ,9 rn);';' n e > t F'u t ,11, II: Fin"nci"IHistory >>t-epot-t Fin03. nc I"~ IHis tory> >Dol t

Figure 19.5

010
The debugger presents some or all of the sequence of message-sends that occurred prior to the interrupt. It allows you to select each one in order to see the method and to determine at which point in the method the interrupt occurred. You can choose any message-send on the stack and cause evaluation to proceed from this selected point. You can also single-step through message-sends, checking the state of the variables in order to determine the source of the error. You can change the value of variables and proceed. If you evaluate expressions within the debugger view, evaluation will be carried out in the context of the currently selected message. You can also edit and recompile (accept) a method. A debugger view is made up of six subviews. You are already familiar with each of these subviews. The top two subviews are similar to the two subviews of a message-set browser; one is a menu of classes and messages, and the other is a text view in which the method associated with a selected message is displayed. The items in the class/message menu are the message-sends of the interrupted execution, identical in format to the message-sends displayed in a notifier. Each message-send displays the class of the receiver and the message selector of the message sent to the receiver. It also shows, in parentheses, the class in which the interpreter found the method for this message selector, if the implementation class is different from the class of the receiver. Selections in the first subview cause the corresponding methods to be

390
Examining and Debugging Execution State

displayed in the second subview. The methods can be edited, compiled, and installed (accepted), just as you are able to do in a browser. The bottom four subviews provide two inspectors. Information appears in these inspectors only if a class/message is selected in the top view. The first inspector allows you to explore the object that was sent the interrupted message; the second inspector allows you to explore the context of the selected message-send, that is, the temporary variables of the interrupted method. The debugger shown in Figure 19.5 illustrates the yellow button menu available when no class/message item is selected in the top subview. You can choose to ignore the problem and proceed, just as you could have done from the notifier. Or you can expand the number of class/message items in the menu.
full stack
When a debugger is first created, at most only the top nine message-sends appear. This command displays the complete stack of all the message-sends of the interrupted message-sending activity.

proceed

The debugger closes and evaluation continues just after the point of interruption. The point of interruption is a message-send that is completed with a reply that is assumed to be the value of the last expression evaluated in the method subview, or nil if no expression has been evaluated.

In order to follow the example in this chapter, do not choose a command from this menu. Instead, choose the second message-send in the top subview of the debugger (Figure 19.6a). Three things of interest happen. First, the method associated with the selected message is displayed. In the display of this method, the message that was last sent is selected in order to focus your attention at the point at which the interrupt occurred. Second, information is displayed in the menu parts of the two inspectors at the bottom of the debugger. And third, the yellow button menu in the top subview is changed. It now contains eight commands (Figure 19.6b).

391
19.2 The Structure of a Debugger

n a. n c i03.1 His t 0 t"\'

. . . . . .i,twi,in:mUIIIE 1 I I
Fin a. n c I03.1 HIS t 0 t"y.>.> tOe p 0 Fi n a. n c i,01 IHis t 0 toy >>Dol t

::; m03.111 n t e q et"( () ~)j e c t) >>(j 0 e s [",J 0 tUn (j e t"S t a. n d:

rt'\
0

nextPutAII: aCollection
",':::',pp end t rle element s a.Co Ilee tion," ,jCollec t ion do: [:v
t ,01 C ollec tion

f ,01 Collec tiorl orl t 0 trl e roe e ei "/ e r",

,.:::., rI.o ',/,/e r"

self ne) tPut: v]

Figure 19.6a

1001 000

~---------r-----~
A'"~,'

~_
A-

- - - - - I

,jCollectio

n a. n c ia.IH is t 0 r\1 ::; m,01.111 n t e 9 er( () bj e c t):>:> (j oe S['"j 0 tUn (j ers t a. n d: Fina.ncialHi story> :>report Fina.ncia.IHistot"y:> >Dolt full st,jcf proceed

tOe s t ,01 I"t se riders II~~+-------....;--------------~i mpie men t 0 t"St-...IIIIi-------I nextPutAII: aCollection me ss,01 q e s ",':::'.ppend Hie elements of .jCollection ontl step send aCollection," aCollection do: [:v
t

self ne x. tPut: v]

,01 Collec tion

...

...... ?? jself
collection position tOe a. d Li mit

A-

a.Collectio
\.'

A-

Figure 19.6b

010

392
Examining and Debugging Execution State

senders

As in a class browser, creates a message-set browser on all methods that include an expression in which the currently selected message is sent. If no such methods exist, prints Nobody in the System Transcript (if the System Transcript is open on the screen J. As in a class browser, creates a message-set browser on all methods that implement the currently selected message. If no such methods exist, prints Nobody in the System Transcript (if the System Transcript is open on the screen). As in a class browser, creates a menu of all messages sent in the method associated with the currently selected message. Choosing one of these menu items creates a messageset browser on all of its implementors. Evaluates the next message to be sent in the selected method (see the full explanation of step in Chapter 21). This command is a refinement of the command step. If the next message to be sent were evaluated, it would consist of a sequence of messages. The command send is a request to enter that next message at the top of the activation stack and be ready to evaluate the next message in its method (see the full explanation of send in Chapter 21). When a debugger is first created, at most only the top nine message-sends appear. This command displays the complete stack of all the message-sends of the interrupted message-sending activity. The debugger closes and evaluation starts from the beginning of the currently selected method. The debugger closes and evaluation continues just after the point of interruption, assuming that the value of the expression forced to completion is the value of the last expression evaluated in the method text subview, or nil if no expression has been evaluated.

implementors

messages

step send

full stack

restart proceed

As described, when you make a choice in the debugger top subview, the corresponding method displays in the adjacent subview. A part of the method text is selected. This is the place at which evaluation will proceed next. Because some implementations of the Smalltalk-80 system might be too slow to allow for this selection determination, you can consider removing this selection capability from your system.

Viewing and Editing Methods You can edit and recompile (accept) a method that is displayed in the debugger. You do this in the same way as you edit and recompile in a class browser or in a message-set browser. All the functonality accessible from the text view of these

393
19.2 The Structure of a Debugger

kinds of browsers is available from the text view of the debugger, including the ability to explain tokens. The yellow button menu of the debugger text view, identical to that of the browser text view, is shown in Figure 19.7. If you recompile a method, that method becomes the top of the stack of message-sends. It is not necessary to return to the class browser, retrieve the method, and make the change. In the Smalltalk-80 system, wherever you can access a method (in any of the class browsers, message-set browsers, or the debugger), you can edit and recompile it.
Note: suppose that the method you edit is inside a block, that is, the message-send item in the top view begins with [ ]. When you recompile, then the method containing the block becomes the top of the stack of message-sends.
If the stack of message-sends contains multiple instances of a message-send, that is, a recursion exists, then you ought to make any edits to the method reference that is closest to the bottom of the stack. Suppose instead that you edit a method higher in the stack. All instances of that method lower in the stack will still refer to the old version of the method. The items in the top view change to reflect this fact; specifically, the message name changes to Dolt.

no3.nc io3.IHi sto t"\'

.n,:.. n c HIS tory> /t"epo tot "..ii'Wlifi",'WMI FI


1,:'.1

::; m,:'.llln t e q et"{ oJ to iec t'!> >cJ oe:.=: f".J 0 t Un cJer:.=: to3. n d;

Fino3ncio3.IHistot"y:> :>Dol t

nextPut All : aCollection ",I:.,F'F,encJ the elements of o3.C:ollection onto Hie


o3C:ollection," o3.Collection do: [: Y raCollection

':"~F,in undo
C 0P~':/

1',

,1:.,ns',,I,,Ier"

self n e ....t Pu t:

YJ

cut p,:.ste ,:Jo It Ipt-int it ,:.ccept co3.ncel form,o.t Spo3.',,I,,In e::-pl,o..in

Figure 19.7

010

o3.Collectio
"",

It.

394
Exall1ining and Debugging Execution State

19.3
The Context of a Message Receiver
The left inspector of the debugger (bottom left pair of subviews) gives you access to the message receiver of the message selected in the top view of the debugger. The context of this message receiver is its state at the time the message was sent. In Figure 19.8a, WriteStream(Stream) > > nextPutAII: is selected; in the inspector, self refers to the instance of WriteStream. A WriteStream has four instance variables; collection refers to the String in which the description of the FinancialHistory is being collected. As shown in Figure 19.8b, collection was
, FinancialHistory Balance: '

at the point of interruption. This indicates that the next information, the cash on hand, failed to enter the WriteStream. Inspecting the variables can give you information about the state of information in the system at the moment the method was run. You can change the values of the variables, either by
1. evaluating expressions in the text part of the inspector that consist of messages to the object self;

n a. ne i,,,IH i s t 0 t-""
.':'",<",1 ::;ma II In teqe r(C1bjee t >does [",JotUn det-s t ':'. n eJ:

.'."i;i,w"mi".ww:mpn Finane IHIS tOt-y'> >t-epot-t


103

Fin.:. nei,3IHi::; tory> >Dolt

nextPutAII: aCollection
","-,ppeneJ trle elements of aColleetion onto trle r-eeei\'et-, aCollection,"
,j

,"-,ns',/,/er-

C: ollec tion do: [: . . .


,j

I self

nex tPut: ..... J

Colle c t ion

Figure 19.8a

000

100 i~.:_~+--r----~..,...__----11 ~
..,.: , -------a
~,1Vr(te:::itrea.rn

::,1

--------aCollectio

position reaejLimit

395
19.4 The Context of an Interrupted Method

nanci,:'.IHistor\'

_.".oo,i+M''
::; ma.111 n t e qe n: Fin.:'.nci.:.IHi story:-:- t-eport Fj n ':.. n c j,:'.1 Hjst 0 toy> >Dol t ,:'.Collection do: [:v t a(:o Ilec ti on

(:, t,j ec t) >>(joe sr'"j 0 tUn cl ers t ':.. n (j:

nextPutAII: aCollection ",,,-,ppencj the elements of a.Collection onto tl'",e r-ecej',/er, aCollection,"

,"-,ns"/,/et-

self ne) tPut: vJ

Figure 19.8b

100 I~~:;~~-------------000
m .,~
self
:W

---'-F-j n-c-j n-a-. ,:.-I-H-j-st-_ r _-y---"T"""-----------_-_-_"T"""-----------t I c-, t,,:,./,:'.nce: ' ,:'.Colleetio


'",'
A-

".': m'@lI.
posit.i'~lr\~
t-e,:'.dLlmlt

2. evaluating assignments to the instance variables; or 3. selecting a variable, typing a new value in the text part, and then choosing the yellow button command accept. Then you can continue evaluation from the point of the selected message, having changed these values.

19.4
The Context of an Interrupted Method
The right inspector of the debugger gives you access to the state of the method associated with the selected message, when that method was first invoked. The currently selected method shown in Figure 19.9 has one message argument, aCollection, and a block argument, v. These two names are shown in the inspector. Choose one to see its current value. Notice that aCollection is 225, which is a Smalllnteger, not a Collection; hence the error.

396
Examining and Debugging Execution State

n ':.. nc ia.IHi s t 0 t-",'.

mm.'@,,'H,,......'

::; m,:'.111 ri t e q e r( () bje c t):>:> doe s r'"j 0 tUn ej ers t a.n d:

nextPutAII: aCollection ","-,ppenej Hie elements of aCollection onto Hie recei'..ler, aCollection,"

,"-,ns","'ier-

,:.Collection do: [:v t ':. C: o11ec ti on

self ne, tF'ut: vJ

n00l7[j11
Figure 19.9

100< ...

-----------------'F-i-rl,-:.r-,I:-j-,:.I-H-i-s-tc-,t--y-......... ba.lance: '

IlmE,e~II@..'lIrmlrill
position t-eadLimit

~-n--r----------------_.....-~-'~-'E-, --------1.'.
!13\I

il
;

BiJlmtllBi

:~.:;.I: ~.:

---------

19.5
Evaluation Within the Context of an Interrupt
Choose the next message-send, the message report to a FinancialHistory. The method text selected indicates that the error occurred when cashOn Hand was to be appended to the WriteStream, aStream (Figure 19.10a). Select the text cashOn Hand in the method, and choose the yellow button command print it (Figure 19.10b). The value is 225, as we expected given the result in Figure 19.9 (Figure 19.10c). When you evaluate an expression that appears in the debugger method text, the evaluation takes place in the context of the interrupt, i.e., using the values of the receiver and the method at the time the selected method was interrupted. If you choose to proceed at this point by choosing the yellow button command proceed in the debugger top view, execution would proceed as though the value of the interrupted message send in the current method were the value of the last expression you evaluated, in this case, 225 (rather than the contents of the WriteStream as desired). If you proceed from a method without evaluating expressions, the assumed value of the method is nil. A String representation for cashOn Hand should be the argument to nextPutAII:. This representation is obtained by sending cashOn Hand the message printString. (Note that the result of sending the message printString to any object is a String that describes the object.)

397
19.5 Evaluation Within the Context of an Interrupt

no01.ncio01lHis t oro,'

report
","-,ns',/,/er 001 e:< pen d it u tOe S."
::;trin,~

trlo01.t desct-it)es tr,e CUtTent b,jl,jnce ,jncJ

o01::;ue,jm

o01::;ue,jrn .- ',/,/rite::;ue,jrn on: ::;tt-inq ne',/,/, o01::;Ueo01rn ne:<tF'ut,"-,II: 'Fino01rlci,jl Histot-y'; cr, ,j::;tt-eo01.m ne:<tF'ut,"-,II: 'b,j.lo01.nce: " ne,
tF'ut/~.II:

co01sh()nHo01 nd

e>:penditut-es pt"int()n: ,j::;tre,jrn, to01::;tt"eo01.rn contents

Figure 19.10a

000
n 001. n c io01.IH i st Ot-"" ::; m001111 n t e q et"( () bj e c t):>:> c.J 0 e s f",J 0 tUn d e t-S t ,j n d:
'"i,," t"i t e ::; t t-e-,j rn( ::i t tOe 001. m):>:>n e:< t F'u t ,"-, II:

Qiii..ME!IjI@m_mM'
Fi no01. n c io01.IH ist 0 t"y:>:>D 01 t

report
11,6,

e:< pen d it u tOe s,"

n 5 '".'./ ~ r- a. ::,trirll~ trlo01t desCt-ibes the current t"j I,j.nce ,j rid o01qa.in urldo

a::;ue.:.rn

copy
cut pa::.te do It
,j.cc~,t

a::'ue,j.m .- "/'/rite::;ue,j.rn on: ::;tt-inq ne',/,/, a::;tt-earn ne:<tF'ut,"-,II: 'Financi,jl Histor-y'; cr, a::;ueam ne:<tF'ut,"-,II: 'ba.la.nce: " a.::,tt-ea.m ne:<tF'ut,"-,II: e>: pe n di ture s p t-in t () n: ,j.::; t t"e,j.m, ta.::;tt-e,jrn contents

'MI;

Ct-,

c,jncel forrnat

::.p ,j. ".,',/n


e:<~II,j.in

Figure 19.10b

010

398
Examining and Debugging Execution State

n" nc ialHi stor",' ::,malll r, t eqer( '='bjec t) "(J oes r",J 0 tUn(Jers ta.n(J: \1'irite::,tre-,'rfIl' ::,tre"rfI 'I , 'ne.tF'ut,"-,II:

ui,t#',i'm;m'~I'Hdi#iui
report

" ,"-, r,s '/'/ er " ::; t t"i rl1j tr", t (J e scr"i b e s e.' p en(JitlJt"e s,"

n"1 e

c u tTe n t b "I a r, c e " n d

I " ::; Ue "

rfI ,,::,trearfl .... \1'it"ite::,tr"e,'rf1 or,: ::;tr"in1j ne"i'i, a::,tre,;'rf1 ne,tF'ut,"-,II: 'Fin,'.ncial Histot"y'; cr, "::;tre,,rf1 ne'tF'ut,"-,II: 'bal"r,ce: " ,,::,tre,'rf1 r,e'tF'ut,"-,II: c', srIClr,H" rl(JIIiIi; Ct", e'per'l:Jitures printC1n: ,,::,trearfl, t,,::;tre,'rf1 contents

Figure 19.10c

000
na.nci ,;'.IHis tOt""1

report

I
Figure 19.11

e'pen(Jitures,"

","-,r'S\,',/et" " ::,tt"irllj tr,at (Jescrit,es trle CIJtTent t",I"nce a a.1j,;.in un(Jo
COP~!I"

,,::,tt-eam

,;.::,tt"ea.rf1 .... \,"irite::,tre,'rf1 or,: ::;tr"in1j ne "i'i, ,;.::;ue"m r,e,tF'ut,Il.,II: 'Fir,,;'Tlci,;.! Histot"y'; cr, ,,::;tt-e,;'rf1 ne.,tF'utA,II: 't";.I,,nce: " ,,::,tre,;'rf1 ne,tF'ut,Il.,II: c,;.srIC'r,H"nd e,penditures pt-intC1rl: ,,::,tt"e,'rfI, t,,::,tream contents
print::,trinl~

cut pa.ste do It pt-int it Ct",


car~el

fom"la. t sp,;'.',/,/n e:,pl,;.in

010

self c ,;. sr,')nH,;. e,penditlJt

399
19.5 Evaluation Within the Context of an Interrupt

Make the correction and choose the yellow button command accept (Figure 19.11), Notice that the method is now changed. It is placed at the top of the stack and selected in the debugger top view (Figure 19.12). Messages that had been initiated from the original form of this method have been terminated on the assumption that the change in the method may have changed the desired sequence of message sends. Choose the yellow button command restart in the top view. The FinancialHistory is re-sent the message report, and the successful result appears in the workspace (Figure 19.13). The result could be prettier in that the Dictionary expenditures needs better formatting. We will return to this problem in Chapter 20. (Note that your browser probably had report selected at the time you were using the debugger to change the method. The updated version of the method for report is obtained by reselecting report in the browser message-selector subviewJ

na.nci,:'./Histor Fina ncia IHist 0 r"y" >Dolt

:~: :~: ~'tl,~:~,r~'~;~"';'I'::~~,.~,~~: ~': to: not ify in 9: ifFa i/:


Cod e Con t t'O II e t"> >Pt"i n tit

sen(Jet-s implementors mess,:'.qes report step ",i>,ns".''ier- ." ::;tt-inq H'I,"t describes the I send e ar,(J e:-:penditur-es." "'-----.-

I ,:.:::tr"e,:.rt"I I
':. ::: tr"e ':. rt"I ....
'",',,0'

r-i t e ::' tr"e ':. m

IXI: ::' ui n Ij

III.

,,,:::tream ne'.tF'lJt,i>,\I: 'Fin.".nci,:.1 History'; cr, .:.::,tre."rIi rle,tF'lJt.i>.II: '\:t,:. I,,, nee: " ,:.::;tr-e.:.m ne'tF'lJt,i>,II: c,:.shCinH.:.nd pr-ir,t::;trir'lj; cr-, e'penditlJt-es pt"ir,tClrl: a::;tr-e,:.m, t,:.::,tream conter,ts

Figure 19.12

010

400 Examining and Debugging Execution State

Figure 19.13

000

.. .. .. .. .. .. .. .. ...... .. .. .. .. .. .. .. .. ~~ .. .. .. .. .. ~: .. .. .. .. .. .. .. .. .. ~~ .. .. .. .. .. .. ~: .. .. .. .. .. .. .. .. .. .. .. ~~ .. ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ .. .. .. .. .. ~: .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ .. .. .. .. .. ~: .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ .. .. .. .. ~: .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ .. ~: .. .. .. .. .. .. .. ... .. .. .. .. .. .. ~~ .. .. .. .. .. .. .. ~: .. .. .. .. .. .. .. .. .. ~~ ~: .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. ~~ ~: ~u4 ~: .. .. .. .. .. .. .. .. ~~ A ,


~:
..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6. ..6.

Kinds of Execution Interrupts

20.1 Breakpoints 20.2 User Interrupts 20.3 Running Out of Space 20.4 Recursion in the System Error Handler

..6. ..6. ..6.

..6. ..6. ..6.

402
Kinds of Execution Interrupts

In Chapters 18 and 19, you have seen that execution interrupts can occur because of unanticipated runtime errors. It is possible to interrupt the execution of a message-send in order to examine the state of an object at the time it receives a message. There are three ways in which an interrupt can occur.
1. You set a breakpoint in a method.

2. You type the ttcontrol" and tt c " keys (ctrl c) at the same time. 3. An anticipated error condition occurs while a method is running. In the third case, the method includes a test for a possible error condition and, if found, evaluates an expression of the form
self error: messageString

A notifier appears whose label is messageString. The label should be sufficient information to explain to the user why the error occurred.
You can evaluate the expression Smalltalk browseAIICallsOn: #error: to see examples in the system where these tests occur.

20.1
Breakpoints
A breakpoint is set in a method by including an expression that creates a notifier. The two possible messages you can use are
self halt

and
self halt: messageString

In each case, a notifier appears so that you can choose to proceed or choose to create a debugger. In the first case, the label of the notifier is
Halt encountered

In the second case, the label is the argument messageString. An example of inserting a breakpoint is presented next. The example uses the description of class FinancialHistory presented in previous chapters. In the method associated with report in the class FinancialHistory, insert the expression self halt just before the point at which the Dictionary expenditures is added to the WriteStream (Figure 20.1). Choose the yellow button command accept.

403 20.1 Breakpoints

Fi n,=:t n c ia.1 His t 0 toy

class

report
",':::',nS"i'iet- a ::;uin1j trla.t eJescr-i[,es trle CIJrTent [I,=:tl,=:tnc e>::penditures,"

I ,=:t::itr-e,=:tm I
a. ::i ue am .;- \1./ t-i t e ::; ue a. m 0n: ::i ui rllj n e "i'l', a::iue,=:t.m ne:<tF'ut,':::',II: 'Fina.ncial Histot-y'; cr, ,=:t. ::itream ne:,: tF'ut ,':::',11: 'ba.lance: " ,=:t::;tt-e,=:t.m ne:<tF'ut ,':::',11: ca sr,()nHa.nd pt-in t::i t r-inlj; cr, self rlalt;.. e:<penditures pt-int()n: a.::;tream, ta.::itre,=:t.m contents
c,=:tr~el

fonn,=:tt sp,=:t. "i'irl e:<p\,=:t.in

Figure 20.1

010
Iii

In the inspector for the FinancialHistory, type and select the expression self report (Figure 20.2). Choose the yellow button command print it.

l l.l.l.lh:~ ; S: : 7.~ ~ :~ r~r: :~=7: ~ : ~:~ n~ ~,'~ :;~ ~ r.~.ftO~.~a~)~.lC.'~:~.'as '"'11:.fill. .


::i y stem -Fielea sin!j Fi Ie s- ::i t re am s File s- ,':::',bs tra.c t Files-.><.et-o::< ,':::',Ito ~~Mij~~I,.;T~~~ :;.:.~_~ ,=:t'j,=:tin uneJo

::i y st em Eo ro '",'",' set-

copy
cut -,a.ste eJo It ,=:t.cce t ca.ncel

J'~$~~M

report
",':::', n s'",'",' era ::i t t-i n Ij t r, a e >: penditure S,"

a::iue,=:tm I ,=:t. ::i t tOe ,=:t. m .;- "/'/ t-i t e ::i tt-e am 0 n: ::i ui n Ij n e "i'i,

,=:t::i tt-e,=:t m ne:< tF'ut ,':::',11: 'Fin,=:tnc i,=:t I His tor-y'; c r", ,=:t.::itr-e,=:tm ne>:tF'ut,':::',II: 'ba.la.nce: " ,=:t::itt-e,=:tm ne>:tF'ut,':::',II: c,=:tsr,(lnHand pt-int::;tr-inlj; cr-, self ria It, e>: pendi tut-es pt-in t (In: ,=:t ::;ue,=:t m, t,,=:t.::itt-e,=:tm contents

Figure 20.2

010

404
Kinds of Execution Interrupts

A notifier appears (Figure 20.3). Choose the yellow button command


debug. Designate the rectangular area for the debugger and then choose the second message-send (FinancialHistory > > report) (Figure 20.4). The message halt is selected in the method text in the debugger.

In the inspector for the message receiver, select the instance variable name expenditures and choose the yellow button command inspect (Figure 20.5).

","-, n 5"/'/12 t-

a ::i trin,~ t r, ,;

.:::::::::':'':'::::'' 12:< pen cJ it u re 5," \ ,3.:::;tre,3.m a:::itre,3m


<'-

',/'/t-ite:::itre,;m on: :::itrin,~ ne',/'I',

,; :::i ueam ne:< tF'ut ,"-,II: 'Fina.nci,3.1 Hi::. tory'; cr, ,3:::itream ne>tF'ut,l!.,II: '[,,;I,;nce: " ,3::itrea.m ne:<tF'ut,l!.,II: ca5r,C'nH,;ncJ pt-int::itrin'j; cr,

::.elf r,,;lt,
e>pencJiture::: printC1n: a::itre,3m,

Figure 20.3

000

ta.::::trea.m content5
.::::::::::::::::::::::::::::.:::::

405 20.1 Breakpoints

I.U~,~"IZ"i1il'.,mmW"lIiDlI-ImR@m' r11 .
I.

Fin ,j nc ia.IH ist ory( () bje c t) >>rla.1 t FlnEl.nc I,j IHI stOt-y) )Dolt

'\

report
","-,ns',/,/er a ::Ht-in'j trl,jt (Jescrit,es r:!"-Ie CUtTent t"jl,jrlce ,jn(J e;. penelit ut-es,"

,j::;ne,jm

a::;ne,jm ... ',,o',,o't-ite::;neam on: ::;nirllj ne'",',/, ,j::;neam ne,tF'ut."-,II: 'Fin,jnci,jl Hi::,tory'; Ct-, ,j:::tnO!am ne<tF'utAII: 'b,j.la.nce: " ,j::;ne,jm nei.tPut,::",II: C,jsf,i.)nH,j.nd print::,nin'j; cr, self e,peneJitut-es pt-int()n: a:::tt-eam,

lID,

Figure 20.4

100 000

t,j::;tt"e,jm contents

report
","-,ns',/,/er .j ::,tt"irllj tr,.jt describes the current b,j\.j.nce ,jnd e>:penditures, "

a.:::tt-eam , ,j.::;tre,jm ... ',,o',,o'rite:::tre,jrn on: ::;trin'j ne',/,/,

,j ::; tt-e,jm ne, tF'u t ,"-,II: 'Fina. ncia.1 Histot"y'; Ct-, a::;tr-e,jm ne'tF'ut,"-,II: 't'a.lance: " a.:::tt"e,jm ne'tF'ut,"-,II: C,jsrl()nHand print::;tt-in'j; Ct-, self., e'pen,jitures printi.)n: .j:::tre.j.rn, t,j::;tre,jm contents

Figure 20.5

010

....

----IIi-a-I-I-I-II~)ictiona.ry ('t-ent'->1 00 self III 'foo(J'->50 'tt-ip'-)75 ) CaSrl()n =0.

406
Kinds of Execution Interrupts

Designate the rectangular area for the inspector for the Dictionary expenditures. You can use this inspector to explore ways in which to print the keys and values of the Dictionary. In the text subview of the inspector, type, select, and evaluate the expression self keys (do the evaluation by choosing the yellow button command print it). The result is a Set of three elements, each of which is a String (Figure 20.6).
Ha.lt encounter-eel,

report
e>:peneJitur-es, "

a::;tr-eam neo:tF'ut,"-,II: 'rent' 03. ::; t re 03 m n e:< t F'u t ,"-, II: ' fo 0 el' ,:'.::;ne,':!.m ne>tF'ut,"-,II: 'tr-ip' self
~Ia.lt,

e .. peneliture:: printl) t,':!::;treo3m content:: Dictionary ( 'fooel'->5Ci '

Figure 20.6

000
You can then try different methods for printing. An example method is shown in the inspector text subview in Figure 20.7a. The expressions format the keys and values in two columns using messages cr and tab; the text is printed in the System Transcript (Transcript) as shown in Figure 20.7b. (For this example to work, you should make certain that the System Transcript is visible on the display screen.) Close the inspector for expenditures. In the method for report, replace the printing expression for expenditures with a version of the ~~practice" print expressions. Make the change shown in Figure 20.8, and choose the yellow button command accept. If you then retry evaluating self report in the inspector for the FinancialHistory, a better formatted result is displayed (remember to choose the yellow button command print it so that you can see the result) (Figure 20.9). Close the debugger.

407
20.1 Breakpoints

a::;tt-e.:'.m ne>:tF'ut.i!.,II: 'rent' a.::;tt-e,:.m ne>:tF'ut,i!..II: 'food' ':.. ::; t t-e.:. rn ne< t F'u t.i!..II: self rla.lt, e:- pen d it u tOe s p t-i n t (, ta.::;tre.:.m contents Dictionat-y (. 'food'->50

'uip'

Figure 20.7a

010
Halt encountered. ::;ystem Tt-,:'.nscript .'_. 't-eM' 'food' 'tt"ip' 100 50 75

a.::;tre.:.m a. ::; t t"e.:.. m ne:- tF'u t .i!..II: 't"ent' a::;tt-e,:.m ne:-tF'ut,i!.,II: 'fooej' a::;Ue,:.m ne>:tF'ut.i!..II: 'trip' self ri,:'.lt, e:<penditut-es pt-int() t.:'.::;tream contents Dictionar-y 'fooej'->50

Figure 20.7b

000

408
Kinds of Execution Interrupts

Fina.nc i a.IHis tory( ()t,jec t >r,a I t

U'il<.inc ia.1 Hi st Ot"y >>Dol t "' '" @iii.,. Fi n ':


",'::',ns',//et- a ::;tt-irllj tr,at elescribes tr-,e CUtTent ba.la.nce a.nel e:< peneJitut"es,"

a::; t tOe a. rn
a::;ne,:<rn ... '1,1',,It-ite::;tre,:<.rn on: ::;trinq ne',/,/, a::;tt"e,:<rn ne::<tF'ut,'::',II: 'Fin,:<.nci,:<.1 History'; cr, a. ::; t re a. rn ne>: tF'u t ,'::',11: ' t, ,:<.1 a. n c e: " ,:<.::;tt-e,:<.rn ne::<tF'ut,'::',II: c,:<.sr,o:)nHa.neJ pt"int::;tt-inq; Ct", e>::penelitut"es keys eJo: [ :eachf<.ey

a. ::; t tOea. rn ne::< t F'u t ,t:., II: ea. chf<.e y; t a. b, a. ::; t t"ea.rn ne>: t F'u t ,.::., II: (e >: pe no:J it ut"es a. t: ea.c rtf<.e y) p t-int ::; t t"in q; c r]A t-a.::;tt"o",a.rn contents I)ictiona.ry ('t"ent'-> 100 'fooel'- >50 'tt-ip' - >75 )

Figure 20.8

010
'ft--------------t 't ".'::',ns',,"'/er a
e>:pen,:Jitures,"

a.::;tt"earn

I
1 \"',1 ri t

.:t. :::i t

re .:t. rn .;-

e :=i t re .:t. n

a::;tre,:<.rn ne::<tF'ut,'::',II: 'Fi a. ::; t tOe a. rn n e >:: tF'u t ,'::',11: 'b, ,:<.::;tt"ea.rn ne>:tF'ut,'::',II: ca.
&.00 .... ...

e::<pen,:Jitut"es keys ':Jo: [ :ea.crtf<.ey

a. ::; t re a. rn n e:< t F'u t ,'::',11: ea c r, V:e y; t ':<. b. a ::;nearn ne:<tF'utAII: (e:<peneJitures a. t: eacr.f<.ey) print::;nirllj; cr],
t

a. ::; t tOe a. rn con ten t s Dictionat-y ('rent'->l 00 'foc,,:J'->50 'tt-ip'->75 )

Figure 20.9

000

a.::.trea.rn e,:<.cr,V:ey

r
409
20.3 Running Out of Space Be careful in inserting breakpoints in the system classes. Unless you understand the flow of message-sends, you might find yourself recursively creating notifiers if the code that creates the notifier, or that creates any of the views on the screen that you might select, uses the method you are interrupting.

20.2
User Interrupts
You can press the ~~control" key and the ~~c" key (ctrl c) at the same time in order to interrupt immediately the execution of any code. A notifier appears whose label is
User Interrupt

Choose the yellow button command proceed to continue the process. Typing ctrl c is a way to interrupt a successfully running process that you wish to explore, to find out about and to possibly change the part of the system that supports the running process. Try an example. Open a workspace as the active view. With the cursor inside the workspace, type ctrl c (Figure 20.10a). A notifier appears (Figure 20.10b). (The sequence you see in your notifier might be different than the one in the example figures due to the somewhat arbitrary timing of your typing ctrl c.) The sequence of message-sends indicates that a SharedQueue was interrupted in its evaluation of peek. This message was sent from the method keyboard Peek to an InputState, which in turn was sent from primKbdPeek to an InputSensor. The message keyboardPressed tests to see if the user is pressing a key on the keyboard. It was sent from a StringHolderController; a StringHolderController provides the user interface to a StringHolder which is the implementation class for a workspace. Hence this is a way for you to find out which classes are involved in the implementation of the user interface. If you now open a debugger you can explore the StringHolderController and examine its instance variables and methods to learn more about the user interface objects.

20.3
Running Out of Space
A notifier appears on the screen if the system starts running out of memory space, either because you have created more objects than the system can handle, or because the objects you have created take up more space than is available. The label of this notifier is
Space is Low

You should close the low space notification (it might be hanging onto a very large activation stack if the cause of the low space was infinite re-

410 Kinds of Execution Interrupts

:::y5tem E:t-0"/'/5er:: :::Y5tem-Crla.rl 1 je5 re

..'1 FIrI,:trlClaIHI5tory [ /
'I -I
.--1':

'><> > , '......."


- ..

-- - -

'C":

-.~,-'-

.J'.- .. -

-',

." .,' 1

:::Y5tem-Compilet'~~~~Hm,~w tra. rl5a Ct iOrl5 ~Mijri~$ ~;ij,~c~t:~r~~_~,,:'~~:5irllj - - - - - - - - - - -pri',/a.te

tot ,:t I::; perl t Fo r-:

~Mrt

, ui File 5- ,6,b 5ua.C t Fi I I 5- .>': I t'O;' ,6, Ito

~iji#~~~.1~ij~

rl1j rl e',,I,,I , Hi5tory'; cr',

Figure 20.10a

000
:_:y 5t em - C ria. rlqe5 ::: y 5tem -Compiletr'e :::Y5tem-F,ele,:t5irlq 'fol File5-:::ue,:tm5 'tri Fi Fi User Irlterrupt .~.,. ::: rl are (j()u I u I >>pee f t ra rl5a.C t iOrl5

~OO~ri~$
pr-i ',,I ,:t te

tot ,:tl:::perlt Fo r-:

~P9ct

re Irlput:::ta.tekeybo,:tr-dPeef

I/mm
V',I Ot

Irlput:::erl50r> >pr'imf<t,dPeef ::; t r-i n Ij Hoi (j 12 rC 0 rI t ro II 12 r'( F',:t r,:t Ij r,:t p 1'-1 EI:J ito r-)' 'p ro Ce 5s f<e y tl 0 ,:t rl:J

1.i'....!Ii'"'"l~-f Inpu t :::12 n50r> >f'.e y t\ O,:t t-dF're 5512 (j

rl\j rle',,1'" i5tor-y'; cr,

Figure 20.10b

000

411
20.3 Running Out of Space

cursion). The low space might be due to an error in your code, such as infinite recursion, gobbling up space. Otherwise, the problem might be harder to trace, such as cyclic pointers; or the problem could be that your application needs more than the available space. In any case, protect yourself by filing out your work (as explained in Chapters 22 or 23) so that your work can be filed back into a new system image. Making a snapshot will not help you since you will simply be saving a system image that has insufficient space. If your application needs more than the space available in the initial system image, you might consider deleting other applications (sets of classes) that you do not require. You can use the system tracer to create a ~~clean image" (as described in Section 23.4). At the time that the low storage notification appears, you ought to have enough time (space) in which to save your work before the system crashes. A second warning will appear if you ignore the first and continue to use the system. At this point, you will probably not have time to save your work before the system crashes. If you want to monitor your space utilization, the System Workspace includes three expressions that you can evaluate to check on the actual space used, and to check on the number of object pointers used.
Smalltalk oopsLeft Smalltalk coreLeft Smalltalk core
Amount of remaining space for object. Number of words of memory remaining. Number of words of memory currently being used. (This computation typically takes a long time.)

The result of Smalltalk core plus the result of Smalltalk coreLeft is less than the total amount of memory available to the system. The difference is the amount of space taken up by the Smalltalk-80 interpreter and resident tables of data for the interpreter.

20.4
Recursion in the System Error Handler
When the system error handling mechanism results in a recursion calling on the messages error: or halt or halt:, then the system is not able to handle the usual user interface control. Instead, a message appears in the System Transcript (if it is open on the screen):
**System Error Handling Failed**

followed by the error message followed by the last three message-sends indicating the recursive call that caused the failure, and then followed by
* *type < s > for more stack; anything else restarts the scheduler* *

412
Kinds of Execution Interrupts

You have two choices. You can type the letter s on the keyboard to see some more of the activation stack (typically more indication of the recursive call), or you can type anything else in order to try to return to the usual user interface, notably to a browser to correct the problem. An example showing the appearance of the System Transcript is given in Figure 20.11.
You can test this facility by evaluating the expression
ErrorRecursion
0-

true

and then creating an error. ErrorRecursion is a class variable of Object and is therefore globally accessible. It 'is used to test for recursive calls on the primitive routines for the error handler. For example, evaluate
nil+3

If you type any key, other than s, to get the system to respond again (reschedule the ControlManagerl, the value of ErrorRecursion is automatically set to false. If the System Transcript is not open on the screen, the problem still exists but you can not see the comment about the failure. Your system will appear to be "dead." In such cases, type any key other than s and see if you can get the system to respond agf),in. Whenever the System Transcript is not open, you take a chance on losing feedback about an error.

::;Y5t,:.m Tt-03.n5cript

r',/le5503.tje not under5tood: Ilnd,:.fin,:.dC'bj,:.ct:-:-Dolt

(_: 0 m p i I,:. (>:-,:. '.,.' a lu ate: in: to: not i fy in 9: i fF,3. i : ;t t-i n 'j H olej e r(_: 0 n t t'oll e (>:- dol t +'*typ,:. <5'> for mot-e 5t,3.ck; o3.nytt-dn'j e 15':' re 5t a. rt 5 5 C 1"1 e ej u Ie (+' *

11-

Errot'F,ecUt'5ion ~ tnJe,

Figure 20.11

000

413 20.4 Recursion in the System Error Handler

It is most likely that the reason the error handler failed is that you have modified incorrectly some critical part of the user interface. Your system is probably dead. One last resort that you can try is to type ctrl shift c (all three keys at the same time, but you should press the ctrl and shift keys first and then, while holding them down, press c). This puts you into a preemptive, teletypewriter-like interface in which you can type one expression and then evaluate it by typing the uescape" key. An image of this interface is shown in Figure 20.12. Editing in this interface is done using the ((backspace" key. Only two lines are available, so if you type an expression on the second line, then the result will appear on the first line. If your user interface changes were conditional on some global flag, you can reset the flag and hope for the best. (If you are knowledgeable enough about the system, you can try to redefine the method causing the problem by evaluating the appropriate compile message to the class.) If ctrl shift c does not work, then most likely the input/output handler is locked up. There is nothing you can do except start over with a new image, and turn to Chapter 23's section on crash recovery.

r',/1ess,3ge not undet"stood:

UndefinedC1bjec t >>Dolt Corn p iI12 (> >12 ' ,' ,31u a. t 12: in: to: no t i fy in Ij: i fF,3. i
::~ t

FI.I I I.I 1 F

ri n Ij Hoi d 12 rC 0n t tOO II 12 r>' do It

..
Figure 20.12

**type <s> fOt" rnOt"e sta.ck; ,3nytt-tin 1 j else resta.rts schedule(++'

EtTOt"F;ecursion ... true,

000

J!iIiil~J!iIiilJ!iliilJ!iliilJ!iliilJ!iliil uuuuuuu J!iIiilJ!iliilJ!iliilJ!iliilJ!iliilJ!iliil~ uuuuuuu

111111111111111111111 111111111111111111 11111111111111111111 111111111111111111111

1Illlllllllllllllla

_11111111111111111

SingI e-steppI T an Exe t ng hrough eu Ion

lIlalllllllllllla alllllla IIlllllllllllllalll allllll allllll 1Illllllllll 111111111111111111111 IIllllalllaalll IIlIlllaallla lIlaaalllla allllllalllaa IIllllaalllllllll alllaalllaa 1111111111111111 IIllllalllllllllll

111111111111111111111

416 Single-stepping Through an Execution

Two commands in the yellow button menu of the debugger top view, step and send, make it possible to step through the execution of a method, one message-send at a time, and observe the behavior of the message receivers. The method associated with the example for the system class Pen provides a sequence of messages that create graphical feedback so that you can observe the results as you step through the execution. In a system browser, find the method for example in the class protocol of Pen. Insert a breakpoint, self halt, at the beginning of the method, after the temporary variable declaration. Choose the yellow button command accept. The browser selections and the change to the method are shown in Figure 21.1.

lI::i::

1/ 1</ I/U

1>

Collec tions-:::trea. - -- --- -- ---e t iI.) Point 1 1 (;;t",:.pt"lics-Display ')ua.dranl~le ':Ot',:' pt"dc s- Pa HI s Fi ec tan 1~le // I Gra.phies-\/ie'",'./s -----------/HH Gr,:'.pt"lics-E(Jitors 1 - - - Gt"a.phic s- :::uppor"t instance

'I!H:1ti(0:

0l"i'~::l r~,s~-i::;iju~iI"~i"eI lll~#I~;!i ,

e II~iln~I:;tga'minllci.e.: a.t~"'.:1llliBiiii.mn,I" 11 _4'4 r i n -----------p .:

-- - -- -- -- -- -

----- -------

example
!IIII

"Dr",:.',,,,,,,,s ':. spiral in qray ".. ,.. ith ':.. pen tt",,:tt is 4 a I}:' in //ide," undo copy I llie I cut self h,:.lt, p,:.ste Abie .... Pen ne',I',I, do It pt'int it bie m,:.sk: Form I~r,:.y, bie def,:.ultf",Jib: 4. bie comllin.:.tionFiule: Forni under,
1 to: 50 do: [:i
I'Pen
e:".:,~.rflp\et'

bie I~O: i+4, bie tUtTI: :::9J

ca.rji)el form,:'.t sp,:'.',,I,In e:<pi,:'.in

Figure 21.1

010
Now select the text Pen example at the end of the method and choose the yellow button command do it. A notifier appears. In it, select the yellow button command debug (Figure 21.2). Designate a fairly large rectangular area for the debugger. Then choose the second messagesend; the first one is just an indicator for the message halt (Figure 21.3). Notice that the message halt is shown as the text selection in the second subview of the debugger. This selection is the next message that will be completed if you proceed (choose the yellow button command proceed), or if you choose the yellow button command step in the debugger top view.

417
Single-stepping Through an Execution

1/ //:1 C:olleetion:::-::;tnO!a -----------t.-.-,, .

1<>
I

i.'.,.:.' . .:-."',.: .. F" ", I:. : .1 .,'~~.~~"":.~".:,~.I.~,~'::., '...:.. . . . ,. ...., ....,..,.:.,r_.. '. ,'.',~.c.'. :...,.F',~.~ ,.~.',',:.,:P.ili~ " " ' " in::: t a. nee e t-e:. t ion ::~i1i~ml.~if/':"" n:.""J~;'II!~~*,~ij~~)' - - - - - - - - - - -.

------------

------------

> I Cka.prcic:::-Di:::pl.:..y <> I Gra.phic:::-F'a.tr,:::


('r-a.pr,ie::: ::;uppo

':).u.:'dr-.:.rl,~le Fieetan,~le

------------

I: : : I (:.:ir-a. phie::: - . . . . ie'."'''' ::: - - - - - - -- - --I I Gt-a. p rlie:::-Editor lI _

10;";1.'

--------...,~-------J.]
. . . 'ide, "

exa.mple
"Dr,:..""""'::: a

F'en ela.::::::(C'bjeet),>rl.:..lt F'en ela:::::::>e>:a.mple Un,) 12 fi n e ,) () bj ee to 0 Dolt

tcic I :::elf r,,:.lt,

C ompil e t->" 12 "i ':. lu .:.. t e:in: t 0: no lpr-oceedf':'. il: Co (jeCon tt-oller-> >dol t

bic .... F'er, n Lbic ma:::k: For-m Ijt-ay, tdc ,)ef,:.ultf\jit,: 4, bic combin,:.tionFiule: Form undet-,

'\

---I

1 to: 5C1 ')0: [:i


"F'en e:O::.:'.mple"

t,ie ,~o: 1+4, tde tUtTI: :::9J

Figure 21.2

010
Ml,II' 1111I#mii.-,,III'iII!d.II'id U lm:1
UndefinedC)bjee t> >Dolt '\ F'e n cia.:::::: (()b ie e t "1 >>rl a.1 t

exa.mple
"Dt-a'//::: .:. :::pit-a.1 in Ijt-ay '/,/itr, a. pen trl.:'.t I::: 4 pi:<el::: "/'/1')12."

I bic I
:::elf . bic "- F'en ne'/.... tdc m,:.:::k: For-m Ijt-.:.y, tlic ,)efaultf".Jit,: 4, bic combin.:'.tionFiule: FOtTn under-.

1 to: 5C1

')0:

[:i

I bie

Ijo: i+4. bic tUtTI: :::9J

1----.. :: :<1
I:
Figure 21.3

100 000

"F'en e>:a.mple"

~~,~----:::upen:la::::::

tdc

mmpetrw,o'IT)DmiC

ITWTI'T'T"IT'TITIITWITmmTtm--E--rn--E--mwmmErnErnErn~I:l

418 Single-stepping Through an Execution

If you choose the yellow button command send, nothing will happen. Generally, when you have not selected the method at the top of the ac tivation stack, then the first thing to do is to choose the yellow button command step. This will complete all the message-sends above the Current selection. Choose the yellow button command step (Figure 21.4).

UneJefi neeJ()bjec t >>D olt

example

5end

"[ir,:,\0',,15 ':. 5pir,:.1 in 9r,:.:'," ',,1',1 i n', a pen tr,at i5 4 pi,el5 ""',Iide,"

bie

5elfll, bic .... Pen ne \0'.,.' , bie rn,:'.5k: For-rn I~r-,:..y, tlic def,:.ultf",Jit,: 4, bic cornt,ir,ationFiule: For-rn under-,

I to: 50 do: [:i


"Perl ey,:'.rnple"

I cdc

'jo: ;+4, cdc tum: :::9]

....- - - 1 ) / )15uper-cl,:..55

Figure 21.4

o I0
I

5elf

m z eyJD '
""y:'

rn

tr 0

mit:

"""""""""""""""""'T"'"T"""'T"'"T"""""'"'Tb--7--7--7--mm..,..,.......,..,....."'7'77~TI"'TI" I

The selected message-send goes to the top of the stack and the text selection is now new (Figure 21.5). That is, the message halt was completed and execution advanced to the next message. The text selection visually shows you what send or step will do if one of them is chosen.
1. The command step does a complete message-send. If you now choose step, new will be sent to Pen and the entire method associated with new to Pen will be evaluated. Assignments are quickly

passed over, so in this case, the assignment to the temporary variable bic will also take place. 2. The command send will invoke the method for the message selected, in this case, new. The message-send new to Pen will become the first message-send in the top subview of the debugger. The text selection should indicate the next message-send, the first message that is not an assignment. All assignments of the form variable <- variable or variable <- constant, up to the point indicated by the text selection, will be carried out immediately.

419
Single-stepping Through an Execution

Un de fi n e dObj ec t u n b 0 u ndM e t h od Compile r) >ev ,3.lua t e: in: t o:not ifying:i fF.;I.II: CodeController> >dolt

example "Dr',3.V'lS a. spira.1 in gr'a.y v.. . ith .3. pen that is 4 pixels vI'ide."

I bie I
self rlalt, bie .... Pen., (de m,;I.sk: ForTn
l~r,;I.Y,

bie eJefa.ultl",Jib: 4, bic combin,;I.tionFiule: Fonn under', '1 to: 50 do: [:i

I bic

J~o: i*4, bic turn:

:::9J

....- -.....1;);1 superTla.ss


methodDic

100 000

"F'en e::< a. mple"

~~,~-----

(de

Figure 21.5

Assuming your situation is as shown in Figure 21.5, choose the yellow button command send. The message-send Pen class> > new is entered at the top of the activation stack and displayed in the debugger (Figure 21.6).

F'e n cia. ss>>e ):: a. mp Ie UneJefin ed C'bj ee t >>un boun eJr"lle trio eJ C: ompiler> >e',/.:' lua t e:in: t ,j: no t i fying:; fFa. 1/:

new

I quill I
quill quill quill quill quill quill quill quill .... super'., destFor'm: Display, frame: Displa.y (louneJinl~E;o>, soun:eCwigin: O(lO, m,:'.sk: Form bla.eh.. defaultl".Jib:1, combinationFiule: For'm pa.int, dO'o,,'.. 'n,

quill r,ome,

Figure 21.6

100 000

quill

420 Single-stepping Through an Execution

The first message-send, new to super, is selected. The method that is displayed is a sequence of initialization messages to the variable quill. The right inspector of the debugger shows the temporary variable name quill in its menu; choose quill (Figure 21. 7). You can now observe the initial change in the value of quill from nil to a Pen. In the top view, choose the yellow button command step and notice that the value of quill is now an ihstance of Pen (Figure 21.8). If you wish to see subsequent changes in the instance variables of quill, you will have to inspect quill and rechoose each variable as you step through the method. If you just use the command step several times, you will eventually reach a point where the return expression, f quill, is selected (Figure 21.9). If you choose send now, nothing will happen. This last message is an action that completes the method; you must choose step in order to complete a method.

Pen cl,:t. s S >>e >:: ,:to rnp Ie Un de fine d () b ie c t >:>u n bou n drvle t 0 d Co rnp ilet">:> e ".,:,:t lua t e:i n: to: not i fy in 9: ifFa i I:

r,

new

I quill I
quill'" super-., quill destForrn: Displ,3Y. quill fr,3.rne: Displa.y boundin'jE;o>:., quill sourceC1ri'jin: [I (! [I , quill mask: For-rn black. quill eJefault[.Jit,:l, qu ill corn td n .3. t ion Fi u Ie: Fo tOrn p 3. int, quill do",/n, quill rlorne.

.....- - - t//)!supercl,:tss
methodDic

100 000

~~,~-----

~(
':~~

1!11~

--------

nil

Figure

21.7

421
Single-stepping Through an Execution

Pe n el,:. s i,:>:> e/ a rnp Ie Un d e fi ned C)bj e e t:>:> u n b u n (] r',,11 e trio d Corn p il e t">:> e ",1 ,:.Iu ':! t e: i n: t 0: r, t i fy i n 9:i fF,:. il:

new

quill I quill .... super ne'",',,I,

quill de5tForm: Display


quill fr,:!rne: Displ,:!y boun(]in1jE:oi, quill soureeC)ri'jin: I]I!I], quill m,:.sk.: FonfJ bl,:..ef, quill def,:!ultf\Jib:l, quill combin,:!tionFiule: Form pair,t. quill do""",.n, quill r,orne,

...- - -...:':;;> I superel,:..ss


motr,odDic

100 000

;~,~-----

rmnlll'

---------

,,:.

Pen

Figure 21.8

Pen cl.OIss:>:>e::<':'.rnple Undefine(]C)b lee t:> :>unt'oundr',/1e thod Cornpilere\,:alua te:in:to:noti fyin'j:ifFa.iI: quill .... super nev,,I, quill destForm: Displ,:;'.y, quill fra.me: Display bouneJinqE:o:<. quill $our-ce()ri'jin: [I(2!Cl quill m.:..sf', Form bl,Clef. quill defaultr\jib:1. quill combin,:!.tionFiule: For-m p,:;.int. quill eJo",.,,.r,, quill r,orne, quill notth.

1'1
.....- - - - - - - -..L',I

III
self . .- - -... ) ( 1 supercl.:..ss

010

.n'-.-.-.-.-.,,,:;.

F'en

mo,hOdDic

Figure 21.9

422
Single-stepping Through an Execution

Choose the yellow button command step. The method is completed and is removed from the activation stack. The action is reflected in the debugger (Figure 21.10). The message new has now been sent SUCcessfully to Pen. The assignment to bic is carried out immediately, and the next message selected is gray to Form. This is precisely the state the debugger would have reached if, at the point shown in Figure 21.5 when new to Pen was the text selection, you had chosen yellow button command step instead of send. In the inspector for temporary variables, choose the name bic in the menu; bic is an instance of Pen. In the menu of the inspector, choose the yellow button command inspect and create an inspector for bic (Figure 21.11). In the text subview of the inspector for bic, type
halftoneForm displayAt: Sensor waitButton

Select the text and choose the yellow button command do it (Figure 21.12a), Click any button somewhere on the screen where the area is clear and you will be able to see the result. A black, 16 x 16 square is displayed; this is the default mask for a Pen (Figure 21.12bL

I (,ic I
:::e If t""f,j It,

('I': .- Pen rle . . .'i,


bic m,j :::k: Form

!D,
I
bie qo: i+4, (,ic tum: :::9J

b Ie,) e f ,j u I t f",J Ib: 4, b ICC ,:,m(' Irl ,j t ionFiule: Form urlder-, 1 to: 5Ci do: [:i "Perl e:, ,jmple"

Figure 21.10

100 000

423
Single-stepping Through an Execution

example
"Dt-a "/'/ s a spit-,j.1 i rI 'jt-,j Y ',/,/i tl"", ,j perl trl,H is 4 pi, els
"i'i

ide,"

I bic I
self I"""jlt, bic ... Perl r1e',/,/, bic m,j.sk: forom

mII!l,
I
bic 'jo: i t 4, tdc tUtTI: :::9J

bic (jefaultr'"jib: 4, t, ic com bin at ion F,u Ie: fo nn Uri (j e to, 1 to: 5Ci do: [:i "Perl e>::,j.mple"

~~I~n_n
...- - - 4 \ \/1

ft
...

C1 :,nnn
1

Figure 21.11

010 I:::

superclass

'mmemtt"imOdCm)!cm'

TT'1Tmm'TTITT'Trrm~ilmwWTImm""T""TIT"WTI"""""""'""T""TIT"7T"'1

(:: om pil er:>:> e''I' ,j lu ,j t e: in: to: no t i fy in sout-ce Cod e C: 0 n t tOO II e r.>:> I) 01 t I"""jlfto 1><:' > I - - - - - - - - - - - - - - - - t comtlirl example dest:< "D t-,j "/'/ S asp it-,j lin Ij t-,j Y "/'/ it,) est','

~:~~f-::~~~o~~~~'~'OUrll)r',/'el""" t

,jljairl undo

copy
cut paste -,r-ir,'\ it ,jccept C,jr,cel

bic I self I"""jlt,

bic ... Perl ne',/,/, bic m,jsk: form 'jt-,jy, tdc def,jult[\Jib: 4,

',/,/idtl"", heiqht source sout-ce clip>': clip\'

b!c corntdnationFilJle: f,xm IJn,)et-, 1 to: 5Ci do: [:i "F'e rI e:\ ample"

bic 'jo: i t 4, bic tUtTI.: :::9J

, . . - - -.../ /

Figure 21.12a

010

self Isuperclass

I.

jrsnetsohosdD0iC

IT'"'""TI'T~~%%""'"'"TITI0IT'"'""TI'TT"'J0"""""""'%%"""""""'IT'"'""TI'T00<1

424
Single-stepping Through an Execution

H a.1 ten c 0 u n t e t-e d,

Com pile t-> >e\1 ,3.lu ,3. t e: in: to: no t i fy in :::ourceForm C:ocleC:ont roller> >dolt r',3.lftoneFor ..-----------~ combin,3.tion example cl e::: t:< "D t-,3. '",',,..::: a. ::: pit-,3.1 in Ij t-,3. Y ', . , . i t de::: t\'

~:~~~~~~~~~.~~~'~'I:,:,~:~,:,~r'",',:~~~,,:::elf de:::tForm

I bic I
:::elf ria It, bic .... Pen ne'",',,.., bic ma:::k: Fot-rn 'jray, bic def,3ult[",Jit,: 4,

'",',,..ieJtr, rlei1jrlt :::ource.:< :::out-ce ',. clip}:; clip'"

bic combina.tionFiule: Form undet-,

1 to: 5C1 1]0: [:i

tdc 90: i+4, bic tUtTI: :::9J

"'----1'>1
Figure 21.12b

100 000

"Pen e::< ,3.mple"

~~,~----:::upet-cI,3.::::::

,3 Pen

mQthodDic

Now return to the debugger and choose the yellow button command
step in the top subview. The message gray is sent to Form. The next message is mask: to bic. Choose the command step again. Return to the inspector for bic and reevaluate the expression halftoneForm displayAt: Sensor waitButton

Click any button somewhere on the screen where the area is clear and you will be able to see the result. A gray, 16 x 16 square is displayed; this is the new mask for bic (Figure 21.13). Returning to the debugger, keep stepping through the method (choosing the command step); examine the variables of the Pen, bic, by choosing variable names in the inspector menu or evaluating expressions as already illustrated. You will change the size of the nib, the source Form, and the combination rule for bic.
These evaluations will go very slowly since a simulator for the Smalltalk-80 interpreter is used. Sending defaultNib: will be especially slow, perhaps one-half minute on some machines.

Eventually, the text selection will be the message to: 50 do: [ :i I bic go: i*4. bic turn: 89] (Figure 21.14). If you were now to choose the command step, you would watch the Pen draw the 50 lines that make up the spiral design; the drawing would be carried out in an excrutiatingly slow manner. Rather than choosing the command step at this point,

425
Single-stepping Through an Execution

Ha.lt encountered,

k',','
r,,:. Ift on eFo rrn di spia. y ,"', t: ::; e n sor
"i'i ':.. it r"i'

1< >

Cornpiler> >e'.,,:a.lua t e:in: to:notifyin sourceForm CoeJeCon troller> >dolt rla.lftoneFon < 1 - - - - - - - - - - - - - - - 1 cornbina tion example cJ est:: "D to,:' "i'i S ':.. sp it-a lin ,~r,:. y "i'i i t eJ e s to.,' "i'iidtr,

:~.~I4..~~~*M~':'......".":.:".',, self Un d e fi ned C' b iec t >>u nbo u nd e t r" . destForrn

E:u t ton

III

I bic I
self rla.lt, bit: ... F'en ne'i'i. bic rn,:'.sk: For-rn 9t-,:'y, bit: default[",Jib: 4,

r,ei,~r't

source.:'''; source 'y' clip>: clip'o.,'

bit: cornt,in,:'.tionFiule: Fot-m undet-, 1 to: 5C1 do: [:i "Pen e>:,:'.rnple"

I bit:

'~o: i+4. bic tUtTi: :::9J

Figure 21.13

4 pi>:els v'iide,"

I bic I
self r',:'.lt, bic ... Pen ne',.,"i. bit: m,:.sk: FOtTn '~ray, ttic defaultf",Jib: 4, bit: combina.tionFiule: Fot-m uneJer,

1 to: 5C1 do: [:i

I bit:

go: i of 4, bic tUtTi: 89J

."Pen e>::arnple"
self

...---4//HUI supen::I,:'.ss
mQthQdDic

010

Figure 21.14

426
Single-stepping Through an Execution

choose the command send so that you can see, more quickly, the Pen design. Assuming you choose the yellow button command send in the top subview of the debugger (Figure 21.14), the message to:do: to a Small Integer is placed at the top of the activation stack (Figure 21.15). The first expression in the method associated with to:do: is an assignment, and it is carried out immediately. The text selection is at the second expression, a comparison of the temporary variable nextValue with the argument stop. In the right inspector of the debugger, choose the temporary variable name nextValue so that you can watch the value change as the iteration proceeds; nextValue is initially 1 (Figure 21.16). Choose the yellow button command step to evaluate the test for the iteration; the next message is value:. Choose step again. A small line is drawn, and the selection goes to +. Choose step again. The value of nextValue is now 2; the display of the change in value for nextValue is automatically updated (Figure 21.17). Continue to choose step for awhile, say until the value of nextValue is 4, and you can see the drawing of 3 lines of the spiral design (Figure 21.18). You can now complete the example by choosing the yellow button command proceed in the top subview (Figure 21.19). Or you can close the debugger by choosing the blue button command close, and thereby abort the execution of the example.

to: stop do: aBlock


"C:t-eate an Inter',,,,,:, I ft-om the t-ecei'" et- up to the .:.njument, stop, incrementin1j by block, .:.E:locf'."

1.

For e.:.crl elemert1: of the irlter-" ....:.I, e\".:.lu.:.te Hie

I ne,t"""'.:.lue I
[ne't"""'alue

net\/alue .... self. ....... hileTr-ue:

_J
+ 1J
-r-------tl
stop .:.E:lod

[.:.E:lock '....:.Iue: ne,t"""'.:.lue.

....- -.... \\/1 --------

100 ' . .- - - - - -~A


self

rl e . t \ . . a lu e .... n e t""'" .:.Iu e

- - - , . --

Figure 21.15

OOOI 7IT~~~rle:.~.:t:.lu~e~~/I ..

427
Single-stepping Through an Execution

Pen

Pen cla.ss:>:>e::o::a.mple Unde fi nedC) bj ec t:>:> untlo un elr"ilet rio d Compiler:>:>e "i a.lua. t e :in: t o:n 0 ti fy ir,,~: i fFa. iI:

to: stop do: aBlock


"Cr"e.:tte .9n Inter..91 from Hie r"eceh"er up to Hie an~ument, stop,
incr"ementir,,~ by

'1.

For ea.crl element of trle inter"'.i.91, e","a.lua.te trle

block, .9.E:lock."

I ne:<t\i.9.lue I

ne::o::t\ia.lue ... self. [ne<t\i.:t.lue """irlile True:

_J
+
'1J stop a.E:lock Pen

[.9.E:lock ... a.lue: ne::o::t\"'a.lue.

Figure 21.16

100 000

ne>:t\i.9.lue ... ne::o::t\ia.lue

self

Pen CI.9. Ss:>:>e )::.9.mple Un define eletb ie c t:>:> Dol t Corn pile (>:>e . :.9Iua. t e: in: t o:n 0 t i fy i nl~: ifF.9. il:

to: stop do: aBlock


"Cr"ea.te 9.n Interia.1 from trle recei""'er up to Hie an~ument, stop, incr-ementin9 by '1. For- ea.crl element of Hie interi.9.1, ei,9Iu.9te tr,,;, block, aE:lock."

I ne>:t\ia.lue I

ne>::t\i.9Iue ... self. [ne>:t\i.9Iue


"i'i rl ileT ru e:

_J
+

[a.Eilock ... a.lue: ne;.t'/.9Iue. ne>:t\i.9.lue ... ne:o::t\i.9Iue

...- -...:n:>1 -------Figure 21.17

self

000

'

...
stop a.E:loc!::

'1 J

428
Single-stepping Through an Execution

to: stop do: aBlock


"Cr-e,j te ,jn Inter"i,jl fr-om Hie recei"ier- up to tt-,e ,jTljUment, :::top, ir,cremerltin1j by 1, bloc!, ,jE:!oc!," For e,jO-, element of Hie ir,ter"i,jl, e"i,:;,lu,jte the

I ne,t\i,jlue I r,e,t\i,jlue .... :::elf,


[ r, e ,t \i ,j !u e ,= ::: top J
"i'i

r, ile T nJ e:
[aE:locf value: nextValue rle.\t\ialue .... r,e>t\i,jlue

+ 1J
:::top a.E:lock 4

:::elf

. - - -... <\1 --------

Figure 21.18

000

i"ti'@lIA

Figure 21.19

The File System

22.1 Writing Code onto a File File Formats 22.2 Accessing the Contents of a File File List Browser 22.3 Retrieving the Contents of a File Syntax Error View 22.4 Getting Started Revisited Sources and Changes Files Decompilation

432
The File System

The purpose of this chapter is to describe the mechanisms available in the Smalltalk-80 system for filing code in and out. In using the programming system, you should be aware of how access to the source code is handled, and how the system supports you in remembering changes you make to the system. Source code and changes are stored in files that exist on either your local disk or on a network-based file server. If the file of source code is not available to you, you can still browse the system methods by using a decompiler. The end of this chapter reviews the use of the sources and changes files and the decompiler; further details about sources and changes are given in Chapter 23.
At Xerox PARC, work in progress on an application is typically stored in personally managed snapshots. The purpose of maintaining snapshots is that they represent a collection of objects, whereas files are needed because we do not understand, as yet, how to transfer external objects, and we do understand how to transfer descriptions of objects. Files, therefore, are our primary communication medium. Periodically, files containing class descriptions and changes to system classes are made, especially when the programmer wishes to work in a new release of the system. The programmer accesses a new release and then files in the new class definitions and methods. To share additions to the system, either bug fixes or new functionality, files (rather than snapshots) are made and then stored on a shared network-based file server; an announcement of the availability of the files is made using a form of electronic mail. Throughout this chapter's discussion, it should be understood that the system makes no distinction between local disks for storing files and remote files stored on network-based file servers, other than in naming the file. (The name of a remote file includes the name of the file server and directory, and the system must request any log in identification. Smalltalk-80 systems that provide access to file servers must implement the network protocols and provide prompters for obtaining log in identification.) Because most of the computers used by the Smalltalk-80 developers are shared, files are rarely stored on local disks, with the exception of the latest system release image and changes files. All users are expected to back up their work, snapshots, or files of class descriptions, on a file server.

22.1
Writing Code onto a File
There are two ways to write code onto a file. The usual way is to select the yellow button commands in the system browsers that provide general access to class descriptions. Four layers of information can be selected for filing out from the various subviews of a system browser. The code that describes all the classes within a class category. Choose the yellow button command file out in the class-categories subview of the browser. The file name is the class category followed by an extension. The code that describes an individual class. Choose the yellow button command file out in the class-names subview of the browser. The file name is the class name followed by an extension.

433 22.1 Writing Code onto a File

The code that describes the methods associated with a category of messages in an individual class. Choose the yellow button command file out in the message-category subview of the browser. The file name is the class name or metaclass name followed by a hyphen followed by the category name followed by an extension. The code associated with one method of an individual class. Choose the yellow button command file out in the message-selectors subview of the browser. The file name is the class name or metaclass name followed by a hyphen followed by the message selector followed by an extension. In each case, the Hextension" for the file name is a period followed by the characters 51. The class name is inserted in front of the messagecategory and message-selector when creating the file name for the third and fourth subview. Any invalid file character in the selection is replaced by hyphens; invalid file characters include space, <, >, =, > =, and < =. Examples of file names associated with various selections is given in Figures 22.1a, 22.1b, 22.1c, and 22.1d, in which the command file out is chosen in each of the four menu subviews of a system browser. The information written onto the files using the command file out is in the form of expressions that can be evaluated to reconstruct the class descriptions.

...._ _ cla.ss
1',.!J.

l'Al

~--t

asCharacter a 51nteqer copying asLov... ercase printing as5ymbol u i liiIWm5iiiilli'II" 1as U ppe rc a se -----------testinJ~

a.ccessing

't"'I~_t_er....,.n~o ".,-i e_-I

upd,:t te edit 09.11

Collections - Text .st

Figure 22.1a

010

.,,-

434 The File System

1:<0:0:

pt"in" 5p a. '","i n 5 ",,:,"i'in r,ierarcr,y rllet"a.rcrIY ::<:1 ",aslnteger definition " ,"-, n 5"i'i e r trl e "i ,:'.Iu comment ",rotocol5 t"i,3.lue 1rl5t ',/at" t"ef5 cla.55 "iat" ref5 cl.:'.55 ref5 rena.me t"emo'...' e

.mom

a. 5 Lo ......... e rc a. 5 e a.5::;ymbol 1 ':. 5U Ppen: ':. 5e

-"

a 5Cr,,:,.ra. c ter

Chara.cter .st

Figure 22.1b

I:>:::>1 ",asciiValue
","-,nY'/'iet" trle ",,'a.lue of trle recei\,'er," t',/,:.Iue

t"emO"ie

Chara.cter -accessing .st

Figure 22.1c

435
22.1 Writing Code onto a File

Te/t

testirllj copyin1j pr-intin1j co n"/ ert i n1j

pt-in _ out

s -"j "/'/ r,

1:::::1 ,fsciiValue
","',ns',/,/et- Hie ',/alue of trle t''1'alue
n~cei',/er,"

sen(Jers implementor-s mess,jqes


mO"ie

remo',/e

010 ,' ,. ., ',. " , ''


Figure 22.1d

Character -asciiValue .st

??" (.?.' ', . ',???)"(?.'.( '

" , ', ''

Alternatively, choose the yellow button command print out in each of the subviews of the browser in order to obtain a npretty printed" version of the descriptions. The file name extension is a period followed by some sequence of characters indicating the format of the contents (at Xerox PARC, the characters are press). Typically, the contents of a file created using the command print out cannot be evaluated as Smalltalk-80 expressions. The command print out is reserved as a system dependent message for creating the best possible pretty-printed version. Because printing formats differ among hardware systems, the pretty-printed version defaults to being the same as file out in the basic version of the Smalltalk-80 system. The format for a file created using the command file out is described in the paper by Glenn Krasner entitled ~~The Smalltalk-80 File Code Format" in the book he edited, Smalltalk-BO: Bits of History, Words of Advice. A summary of that paper is given here. The file format contains exclamation marks as special delimiters. Text up to, but not including an exclamation mark, is treated as an expression that can be evaluated. If an exclamation mark is the first character in the next chunk of text to be read, then all but this first character are treated as an expression and evaluated. The result of the evaluation is an object. This object then takes over the task of reading

File Fori?1ats

436
The File System

the file, stopping when the object determines that its task is completed. In this way, a class can read and install new methods. Figure 22.2 shows a file out of part of the class description for Collection. The file starts with a String that indicates the date and time at which the file was created, and the version number of the system from which it was made. The exclamation mark delimits the String from the next chunk of text, which is a message to Object to create a new subclass, Collection, with no variable declarations and categorized under Collections-Abstract. The exclamation mark delimits this message from the next, which is a message to the new class Collection to store a comment about itself. The next exclamation mark is followed immediately by another. The chunk of text is a message to Collection to create a new category, accessing, and to start reading the methods for that category. The class Collection, then, becomes the file ~~reader." It installs a method for size. The exclam~tion mark after the method is followed immediately by an exclamation mark, indicating the Collection can stop reading the file. The next text chunk creates the message category testing for Co!lection, and the methods follow. The ~~pretty printed" version for printing part of the class Collection is shown in Figure 22.3. This format can not be read by the system, but is somewhat easier for a human being to read.

22.2
Accessing the Contents of a File
Instances of external files can be the form
cre~ted

by evaluating an expression of

FileStream fileNamed: ' fileName'

The response to this expression is an instance of FileStream that can be sent messages for reading and writing information onto the file it accesses. Note that FileStream also responds to messages with selectors oldFileNamed: and newFileNamed: in order to open access to external files that already exist (oldFileNamed:) or do not already exist
(newFileNamed:).

437
22.2 Accessing the Contents of a File

'From Smalltalk-80 of March 9, 1983 [v29] on 15 March 1983 at 9:35:22 pm ' ! Object subclass: #Collection instanceVariableNames: " classVariableNames: " poolDictionaries: " category: 'Collections-Abstract'! Collection comment: '1 am the abstract class of all collection classes. ' ! !Collection methodsFor: 'accessing'! size "Answer how many elements the receiver contains. "

I tally I tally +- O. self do: [ :each I tally Hally! !

+-

tally

1].

!Collection methodsFor: 'testing'! includes: anObject "Answer whether anObject is one of the receiver's elements. " self do: [ :each I anObject ffalse!

= each ifTrue: [ttrue]].

isEmpty "Answer whether the receiver contains any elements. "


i self size = O!

occurrencesOf: anObject "Answer how many of the receiver's elements are equal to anObject. "

Figure 22.2

I tally I tally +- O. self do: [ :each I anObject Hally! !

= each ifTrue: [tally

+-

tally

1]].

438 The File System

From Smalltalk-80 of March 9, 1983 [v29] on 15 March 1983 at 9:35:22 pm Object subclass: #Collection instanceVariableNames: classVariableNames: " poolDictionaries: category: Collections-Abstract
I I II
I

Collection comment:

I am the abstract class of all collection classes.


I I

Collection methodsFor: accessing size Answer how many elements the receiver contains.
I I

I I

I tally I tally +- O. self do: [ :each I tally Hally

+-

tally

+
I

1].

Collection methodsFor: testing includes: anObject " Answer whether anObject is one of the receiver's elements. "
I

self do: [ :each I anObject = each ifTrue: [Hrue]]. ifalse isEmpty "Answer whether the receiver contains any elements. "
f self size = 0 occurrencesOf: anObject Answer how many of the receiver s elements are equal to anObject. "
I I I

Figure 22.3

I tally I tally +- O. self do: [ :each I anObject Hally

= each ifTrue: [tally

+-

tally

1]].

439 22.2 Accessing the Contents of a File

For example, create the file whose name is testFile, and practice writing text into it, by evaluating the following sequence of expressions.

I aFile I aFile - FileStream fileNamed: ' testFile ' . aFile nextPutAII: ' The beginning of the file. ' . aFile cr. 1 to: 50 by: 10 do: [ :each I aFile nextPutAII: each printString. aFile cr]. aFile nextPutAII: ' The end of the file. ' . aFile close
FileStream is a subclass of ReadWriteStream; the messages for writing into the file are like those of any ReadWriteStream. Using a system browser, you can explore the messages available for writing text into a file.
Note that instead of using the expression
aFire nextPutAII: each printString

in the statements for writing on the file, you could have used
each printOn: aFile

and the result would have been the same.

File List Browser

The simplest way to open a file and access its contents is to choose the System Menu command file list. You are asked to designate a rectangular area in which the file list view is displayed. This standard system view consists of three subviews. You type text in the top subview to specify file names or patterns for file names (of either existing or new files). A pattern is a sequence of characters that can contain the special characters * or #; * matches any sequence of no, one, or more characters, and # matches anyone character. When you choose the yellow button command accept in the top subview, the next subview, the filenames subview, displays a list menu containing all the names of the files in the local disk that match the names you specified in the pattern subview. When you choose a file name from the menu, the contents of the selected file is displayed in the bottom text subview.
If the file system you are using allows the characters * and # in a file name, then you will want to choose other characters for pattern matching purposes, and it will be necessary to change the String matching routines. The method to be changed is
String match:.

440
The File System

The form of the pattern subview is a sequence of file names delimited by ((carriage returns," that is, each file name or pattern is placed on a separate line. Suppose you type
story

and then choose the yellow button command accept in the top view (Figure 22.4a). Weare assuming that the file story did not exist before. The file-names menu displays one item (Figure 22.4b).
story

Choose it. The item is selected. Nothing else happens. The yellow button menu offers five commands (Figure 22.4c).
get contents file in
Retrieve the contents of the selected file, and display the contents in the text subview. Retrieve the entire contents of the selected file, reading and evaluating the text according to the file format for class descriptions and expressions. Copy the text of the file name into the text editor buffer so that it can be "pasted" into other text views.

copy name

:;::::::::
:::::::::::

a.,~,:t.in

:::::::::::::::

undo

storx...
.:::::::::::::::::::1 - - - - - - - - -.;",;::;;:,,;:,,::;:1 _

coPY
cut pa.ste
ca.n~1

010.:::::::::::::::::::
Figure 22.4a

441
22.2 Accessing the Contents of a File

:,:::::::,:

::::

story

Figure 22.4b

000

.I
.,>

1------------

II_m_l_g_I_._I_I_I_I_I_.__~j e t ;~:I,~ni~~ n t 5_
1

L.t. ~:.:. .

copy na.me ren.:t.me remo''1'e

010:::::::::::::::;:::1
Figure 22.4c

442
The File System

rename

Change the name of the selected file. A prompter appears, with the name of the selected file. Edit it with the new file name. Type the "carriage return" key or choose the yellow button command accept to indicate that you have completed the file name. The menu of file names will be updated. If you type an improper file name, or no file name at all, a confirmer will appear to determine whether you want to try again to specify a file name. Examples of this command are given later in this chapter. Delete the selected file from the file directory. A confirmer appears to determine whether you really want to remove the selected file. Choose yes if you do, no if you do not.

remove

Whenever you retrieve the contents of a file, information is presented in the System Transcript (if it is visible on the display screen). This information tells you which class and which method is currently being read and compiled. In this way, you can monitor the progress of the file retrieval. Choose the yellow button command get contents (Figure 22.5a). The file contents is empty. The text subview displays
- new file -

story

copy na.me rena.me


remo'... e

Figure 22.5a

010

443
22.2 Accessing the Contents of a File

to indicate that a new file will be created if you edit and store the contents of the text subview. Keep in mind that the new file will be created only if the contents are saved onto the file. Edit the text subview as though you were working in a regular workspace. The yellow button menu contains the text editing commands plus three additional commands, file it in, put, and get (Figure 22.5b).
file it in
Read and evaluate the text selection. This selection should
be in the file-out format, which includes the exclamation

mark.

put

Save the edited information onto the file. One level of back up on the file is maintained. The original version is renamed to the given file name with a trailing $ appended; the new version is stored as the currently selected file name. Retrieve all the information currently in the file.

get

story
story

It. ~..-,.

,,0: ....

I'

,+-,;'., .. _,--

undo copy cut '03.ste cJo It print it file it in put


!~et

03.9~in

Figure 22.5b

010

444
The File System

story 5tory

Once upon trle time".:..

.:t!~.:t.in

undo coPY cut

Figure 22.5c

010
Edit the contents and then choose the yellow button command put (Figure 22.5c).
The cursor changes to a writing pen when a file is being written; it looks like eyeglasses when a file is being read. During the time it takes for the system to access the file, the cursor looks like an hourglass, meaning "wait" because it may take noticeable time to find the file you requested.

The commands put and get are the external file counterparts to accept and cancel. Although the contents of the file are retrieved when you select a file name, you might make changes that you later wish to throwaway. In a workspace, you would choose the command cancel; in the file browser text subview, you choose the command get. In the top subview, replace story by storage and choose the yellow button command accept. The file-names subview changes again (Figure 22.6a). Choose the single item, storage. Choose the yellow button command get contents (Figure 22.6b). Again, we are assuming that you requested a new file. Edit the text subview and then choose the yellow button command put (Figure 22.6c).

445 22.2 Accessing the Contents of a File

~ Cmce

:::==~-----------I

upon HIe time".:..

mtl:

.. '.:

Figure 22.6a

010
~.

lilili

;:~
::..::

------------

coPY n,:t.me rena.me remo'.,.'e

Figure 22.6b

446
The File System

stora e
.::::::::::::::::::1 - - - - - - - - - - --

T rl e folio -'i'iin!~ is (joe umen t ,:to t ion a. bout t r,e memory


,:t.!~,:t.in

undo copy cut

Figure 22.6c

010
Now in the top subview, replace all the text with the pattern
stor*

As stated earlier, the top part of the file list view can contain explicit file names or patterns for the names. String-matching provides two special notations for matching an arbitrary substring. * match any number of characters, including none # match exactly one character Note that s*y matches story, as does #t*y and story*. If you type stor* in the pattern subview and then choose the yellow button command accept, then the list menu will contain (at least)
storage story

Choosing each item and then choosing get opens the previously created file. Rename story to be tale. Choose the yellow button command rename (Figure 22.7a). A prompter appears (Figure 22.7b).

447
22.2 Accessing the Contents of a File

l)iA~4-':":'':'':''.....------~q e t co n ten t 5.....- - - - - - - - - - 1 : : : : : : 1

'-

file in

Figure 22.7a

5tor:+-.:...

1IIIIIillllllllllllll._ _~==~~cC~lp~~-1I' --lliiiWI cut I t.=tlp . _. -...


----------~

5tora.~je

I
I

r',jp'-,-'-,-' na.rfIp for file

a.!ja.in undo

pa.5te

cJo

It

print it

.-.-5II.U
c.~.nl:5"t!1

010.:::::::::::::::::::
Figure 22.7b

448
The File System

Replace the text in the prompter with the file name tale, and then choose the yellow button command accept. The file name tale is select ed automatically (Figure 22.8). If you created the file testFile suggested earlier in this section, you might use the file list view now to see its contents. Since any number of file names or patterns, separated by a ((carriage return," can be typed in the top view, you can simply add this file name to the pattern already in the view. In addition to creating a file list view as just described, instances of external files can be accessed for editing by evaluating an expression of the form
(FileStream file Named: 'fileName') edit

1
I I

The text subview part of the file list view, only, is created. The label of the view is the name of the file. In Figure 22.9a, the expression (FileStream fileNamed: 'tale') edit is typed, selected, and evaluated in a workspace. In Figure 22.9b, a simple view of the contents of the file is shown. The yellow button menu is like that available in the file list view.

I
000:,:::::::,:,:,:,:,:1
Figure 22.8

tale

449
22.2 Accessing the Contents of a File

coPy
cut pa.ste . .a.. _
Iprinl. it a.ccept
c,~.ncel

Figure 22.9a

,~.'j,~.in

undo coPY
cut
p,~.5te

do

It

pt-int it file it in put qet

Figure 22.9b

450 The File System

22.3
Retrieving the Contents of a File
Class descriptions that were stored on a file whose name is fileName, using the browser command file out, can be retrieved by evaluating an expression of the form
(FileStream oldFileNamed: 'fileName') fileln

This expression is provided in the System Workspace for your convenience. Whenever you read class descriptions from a file that create a new class category, any open system browsers will have to be informed of the new category. In the class-categories subview of the system browser, choose the yellow button command update.

Syntax Error View

Since files are created by choosing the file out command in a browser subview, there are three reasons why an error can exist in a file you try to read.
1. Variables or messages that had been a part of your image at the

time you created the file are not in the version into which you are now filing. 2. You used a file list view and edited the text directly, creating a syntax error (which is why you should not edit class descriptions this way!). 3. You selected the text of a file and chose the yellow button command file it in, but did not select the correct sequence of characters. As you are filing in information from a file, a status report is printed in the System Transcript (if it is open on the display screen). If, when filing in, undeclared variables are encountered, a statement showing the variable name and the fact that it is undeclared prints in the System Transcript. The system will store the method anyway, as though compilation had been successful, and you will have to use the browser to find and correct the error. Similarly, if an unknown message selector is encountered in a method, the process of filing in will be interrupted. A notifier will appear on the screen. You can ask the spelling corrector to determine a possible new selector. If the determination is acceptable, you choose the menu item yes. This will store the right information in the system and continue reading the file. Or you can use the debugger, find and correct the error, and then proceed (choose the yellow button command

451 22.3 Retrieving the Contents of a File

proceed) to continue reading the file. Or you can simply proceed to con-

tinue reading the file, without correcting the error and, therefore, without storing the information in the system. In each case, the text in the file will not be changed. If a syntax error exists in the expressions that are filed in from an external file, a special view will be created on the screen. It is the Syntax Error View. Its purpose is to report the error and give you an opportunity to edit the expression. A syntax error view consists of one text view that displays the expression to be evaluated, or the method to be compiled and stored in a class description. To create an example of a syntax error, file out the class FinancialHistory that you had created as an example in Part Four. You do this by choosing the class name FinancialHistory in a system browser, and then choosing the yellow button command file out in the class-names subview. Use the file list view to retrieve the contents of the file you created; the file name is FinancialHistory.st (Figure 22.10).

liiililijliijiliil
I:!

I<"':<,UI

::;y::.tem Fiele,3.::in,~ FF!III :_- -_:; ,:_'.",-_:: t. File::- .:'<.ero::< ,':::',Ito

=,; ~,t o"r_:ro'3t~

;~;
-

.;:,.

I>'::::::<t:jr~~~~~~~~~~!~:

r'.L~..:,..:.
~

p'MiiI!!lilU'UM

Eiiiiiiiiliiiiliiiillilir3bj~~;;:M;7;"~h~"$~' ~~:a~'~~:""-F-n:-'n--::-ir,-,.:;-.II-t-.:;-Ik---::;-O-,-'./-et-'5-ic-,r-,-2-,-o-f-,.:::.-,p-r-I!-,-,---4<1
o ,

()bjec t ::ubcfa.::::: #Fin,3.r in::: t a. nce \/ ,3 ria. bler",J.3. cl,:; 5::\/ ,:;ri,:;ble!\)a me::: pooIDiction.:;rie:::.', " ca. te,~otoy: 'Fin,:; nCI,:;1

19:::::: on 25 r""'1,3 y19i:::3 a. t1 0:17:12 .3m'!

(:'bject ::ubcl.:;.::::: #Fin.:;nci,:;IHi::tory in:: t ,3 nc e \/ ,3 ri,:;. ~)ler",1,3 me:::: ' c.:;;; h ()n Han o:J e:o::perll:HtlJre:: ' cl,:; ::::\/ ,:;ri,:;ble[\j.:;me::: " pooIDictiona.rie::: " c,:; teljory: ' Fin,;:. ncia.1 Tool::'!

!Fin,:;nci.:;.IHi::t ory method:::For: 'tr,3 n;;,;:. c t;on:::'!

Figure 22.10

000

:;t

o -,nfl' ,=tmount f,-,t


,:,,"::

O ,

r".=t ':;,-,n
:;:;: ':;, ":

452
The File SysteIll

Next, create some syntax errors in this file. Find the first occurrence of an assignment expression and insert an extra left arrow, or find a keyword in a message pattern and add an extra colon. Choose the yellow button command put to store the syntax error into the file (Figure 22.11). While the text is being written on the file, the cursor changes to the shape of a pen.

fin 03 nCI ,:tlrlis tor:.', s t...

1<><>1 Files-::;tre,:'.rfIs ttlJM"" lJitii,wl!lMl'''M ~.~.~.~.~., 1< <I Files-,'::',r'suact 1< > <I Files- .:<'ero> ,'::',Ito 1< <I r..o~@Wl100.~ 1">:',><:, _ 11
('bject subcla.ss: # e>pendituf'e::: ,Ct.t: tea.sor ,Ct 9,Ct.in un(10

.: ").':::::1

::~:,,'stem-Fiele,:.sin

If
.Ct.mount! !

;~'o~~';o't;:;r~~~:~
c,:.te'jory: 'Fin,:

ins t ':. nee \/ ':. ri ':. t

tot

'Ct,~::~~~,t~~~J,~:n:~e : s~~~I ,Ct: rl'~' ~~lt:h:

do It !Fin,Ct.nciaIHistory metrloeJsFo print it file it in tOe p

o,~~:_ n s
I

"i-i

e r ,Ct. ',:, t ri n 9 HI -Ct. t

~~; t,:-__' HI e

current b.:tI.Ctnce ,:tnd e>:penditures."

Figure 22.11

o I , / 10

...

,Ct::;ueam

I
tIT
t

/ , ............................I; TIs:0 '=,TI<:=IT~tIT ,IT~.~:,=,.rW(',d.~ '.,~IT.'IT P't ,u~t:~ ',.I T,I>2'F~:in~<~=, ,ft~'~I:-:i~,=,TI ,~.~l~.I',.~m' T"t7~' ,"m'.TI.:.: >TI: : ~"I
S

,Ct.::,tr-eam .,. \,',,irite::,tre,Ct.m on: ::;tr'irI1j r,e ''1\1 ,

n:

In the menu subview of the file list view, choose the yellow button command file in (Figure 22.12a). A syntax error view appears indicating that an expression is expected after the first left arrow (Figure 22.12b). Text describing the syntax error is inserted into the method at the point of the error; the text is selected. You edit the method to correct it, just as you would in a browser text subview. Choose the yellow button command accept to recompile the method (Figure 22.12c). Now choose yellow button command proceed (Figure 22.12d). The correction you made is known to the system, but no change has been made to the text on the file itself. You either have to file out again to create a corrected file, or you have to use the file list view to access the contents of the file and make the correction. During filing in, expressions can be evaluated. For example, an expression that creates a new class description might appear in the text in the file. If evaluating the expression generates a runtime error during the file in, then a syntax error view will appear. The poorly-formed expression will be displayed in the view. For example, suppose you

1
I . H><jf'~'>~<~<l<~'~'::ili~"'j .

453
22.3 Retrieving the Contents of a File

.1Bili: . '., ",.


I
COp:.,1

.
Iqot content,
n,;.~e

ren,3.me

Clt>jec t sutl cl ,3 ss: #Fin'3. r in s 1:'3 nee \" ,3rl,3. ble(\!,3 !Fin'3. n ci ,;.IHi::, tory metr,od sFor: 'tr,;.ns actions'! c I ,3. S S ....... ,3. r'j ,3. tl I e f\J am e s pooIDietion,;.rie s:" ca te1jory: 'Fin,3.nci,3.1 spend: 3.mount for: re,;.son "::,pencJ amount for ttle t'e,3son >ji'..len, deerementinlj tr\e ,:,>\I,:'>il,:'>ble c,:'>.:,rl on r,,:'>.n>:J," e,pencJitures at: re,3son put: pelf to t.:<ISpen tFor': r'e a. son)
A

amount,

ca. srll)nH,3.neJ '"' '"' c ,3. shC'nH,3nd - ar(toun t!

Figure 22.12a

File Li::,t
;=; y stem Br'o """... ::er

fin,;'.ncia.lrlist Dry ,:: t

1< / 1 File::-;:;tn~,:<m5 1/ ) \ ( ) Files-,i:.,t'5tra.ct I)U) <)1 File::-)<ero>: Alto

::;:,,':stem Fiele,3:sin

IUUHU HI.'r~~~~ r"~~

.
n~,;'50n

:spend: ,;.mount for:

":::pend .:<.mount f<:<t' !t'le rea.:son

91\' en,

.ra.ns,;. ct ions'!

dec rementin>j trle ,;. ..... a il,;. tile c';. sr, on r,and," e'peneJiture5 ,;.t: re,3.50n put: (5elf tot,3.1::;pentFor: re,;'50n) ca.5hCJ nHa.nd - ,:<mount
5Clrt

'ji ',... en ,

,;.mount,

=,1"1 on r',3.n,),"

c,:'>.:,r,C.lnH,3nd ... E> pre:ssion e)

pee ted -)
t: (::elf
nt,

nel - amount!

rnroo~Oi ..l...i . .... . brr~~~~~nquiries!


Figure 22.12b

454
The File System

Fil>=> Li5t I :=:Y5tem E:rO,.. . . 5er ::;',15tem Fielea5in _

1/ ///1 File 5- ,':::'.t'5t ra.c t I ) ) ) / 1 File5-.>:.eto/ .':::'.Ito

1<>< >,>1 Fiie5-::;tre,;.m5

.~6an~".~.~ll~~~n,~j~~.i.:#~ijlrY,,$~j'.j'."/" . '\'.".j"/.'.' "j".j'.j "j\j .< >,11 . . .


____________ ....

I:T?:

?1.~~M~.11~~

I(;c",",: :."~_a........ ,;:


.:.:.:
:::.;:

------------

-.....,
.'.,-

5pend: .;..mount for': t-ea50n "::; pen ej .;t m0 u n t fo t- t r, e tOe a 50

...

_r.;'.n5.;' c t ion 5'!

decrementinq tr,e .;... ail.;.ble C.;'5r, e:openeJitUt'e5 ,;.t: te.;'50n put: tot.;./::;pentFor: re.;'.50n)

';'I~a.in

l.ln,jo

copy
cut p.;'5te ,jo It print it
ca.nc~

.;.mount

50n ,~i'. . en, ::r, on r,.;.n,j." t: (5elf nt.


~nej

ca5r,OnH.;.nd ;,- c.;. 5r,C'nHand "

',roceed

- amount! !

Figure 22.12c

010
Fil>=> Li5t ::;y5tem E:ro"/'/5e r l<

'~-'

nquiri>=>5'!

>>

I fin.;. n c i.;.Ir, i5tory. 5t

. t-.;'.n5 ,;. c tion5'!

COp:,:",

I
Figure 22.12d

tot

.;.~:~, ~: : ~:~~~=:~_~-erc~.::,~,~-~ .:5 ,~ r~,.,::: ~E~ ~

:
--"~-'

50n ,~i\len, ::r, on r,.;.n,j." t: (5elf nt,


~ncJ

c;. 5r,C'nHa nd ;,- ).=.;. 5r,C'nHa. pt'int it unt a.ccept c.;..ncel

- .;..mount!

010

- .

nquit-j>=>5'!

455
22.3 Retrieving the Contents of a File

modify the file FinancialHistory.st so that instead of trying to create FinancialHistory as a subclass of Object, the expression contains the name Oject (i.e., there is a typo) (Figure 22.13a). Choose the yellow button command put to store the change. Now choose the yellow button command file in in the menu subview of the file list. A notifier will appear (Figure 22.13b). Open a debugger and select the message-send Dolt to see the erroneous expression. You can edit the expression and then select the yellow button command accept (Figure 22.13c). The expression is stored so that the information is now known to the debugger; the file is not corrected. To continue the process of filing in, you must choose the yellow button command proceed in the top subview (Figure 22.13d). If, instead of correcting the error in the syntax error view, the notifier, or the debugger, you close the view by choosing the blue button command close, the process of filing in is discontinued and the file is closed.

:::

::; '/ 5t em Eiro '",',. . 5e t"

fina.ncia.lt"d5 tory,s t...

1 / ( / (HI ------------

I::!: !!:::!:I~~:;:-~:7:=1!i,"~" .1':UUHHd 1/


cia. 55""'" a.t"ia.bler',,] poolDietionat"ie c.:'.te9ory: 'Fin,:

(object 5Ijbcla.55: in5tanee"""'ariat

'Ft"om ::;ma.llt,:t.If::.-:::O, \"E!t"5ion 2, of ,b..pt"it '1,

19::::3 on 25 1,. .1':.. y 19:3:3 ,:'.t10:17:12 ,:'.rn'!

C, C 5 i

~, :~I~t~:~:1 : '~o'~~ :,i Ir~'~:,]~~:r:"::1 ~ i ~ ~.'~t~:;1 C' n Ha. nd

r:

e \penditljt"e5 ' e I 0355""'" a. t"i ':.. ble r"J a. me 5: " p 00 IDie t ion ,3. t"i e 5: " ca.te,;)ory: 'Fin,3.nci.:'.1 Too\:.'\

!Fin,3. neia.IHi5 t Ot"y me tt",Od5F,x: 'tt"a n5ae tion5'!

Figure 22.13a

000

':;n -,nd' .=t roo -,lint t,-,t", n:',=t:; -,n


::::,:,,::

::::

456
The File Systell1

1
,
File List :3 y st e m E:ro '........ ser
fin,~nciall'",istory ,s t

Unde finedC) bjec t (C1t,jec t) >>(Joe s[",)0 tU nders t a nd: Und e fin e d':)bj ec t >>Dol t Compile (>: >e '",' a.lu 09. t e: in: t o:n 0 t ify in9: ifFa.i1: Ik-::;:D, version 2, of ,A,pt-i1 '1, \1,:'.y19:3:3 .:'.t1D:17:12 .:'.m'! .s: #Fina.ncia.IHistory

:~: :~: ~:::~::::;: :~:::: :::: :::::::::~:~::~:~: ;:: ~~:~~~~:~~i:n 'j: I0 'j 'j e d:
IT"

IGmGn--i=~;('c)l',[J.li(,c::'l: 00nna.,:..'FniEe!5s:::-T-iinn5s~t,a:. nnZc~e\/ 09. ri ':.. bIe r,.) 09. me s: ' c 09. S1'",.:) n H':.. n d c ;(,
c.:.te'jory: 'Fin,:.ncia.1 e>::penditures ' cia. s S ....... 09. t'j 09. ble [',,) ':.. me s: " pooIDictiona.ries: " ca.te'jory: 'Fina.ncial Tools'!

!Fin 09. nc ia.IHis tOt'y me thodsFo t': 'tt',:. ns ':.. c tions'!

Figure 22.13b

000
:::

Un de finedObjec t( Object) >>doesf'oJot Unders t and: Compiler> >e',.. a lu 09 t e:in:t 0:notifyin9:ifFail: Compiler class> >e'.,'alua te:for:notifying:lo9ged:

Dolt
tC't~ect

subcla.ss: #Fina.ncia.IHistory ins t 09. nee""'" ,9. t'i.9.b Ie[',)a. me s: ' e:.. 5 l'",f)nH .:'.n d e::<p e nd it u tOe s '

e I':. s S....... 09. t'i 09. ble[",) ':.. me s: "


pooIDict;onaries: " e.9.te'jOt'y: 'Finaneia.1 Tools'

a. 'j ,9 in undo copy cut pa.ste do It print it


canllel forma t spa. \vn e::<pla.in

Ii!

...---4::nU/d self

Figure 22.13c

010

457
22.4 Getting Started Revisited

full stack Compiler Clo.55.>.>e.. o.luo.te:tor:notltYln'3:1 il. Compiler cla.55> >ev.:'.lu.:.. te:for-:1099ed: i~~ Compiler cia. 55> >eva.lua. te:lo9,~elj: .....- - - - - - -......1 Dolt :::

Comp!lerev.:..lu.:..te:in:to:n~tifyin:~.:i~F.:t.il:

Undetlned'='bJec t ['olt

IU>If-_-_-_-___

-_-_-_r----------...-_-_-_-_-_-_-_-"'T""'----------I:ll _
i==

\11

...---In:\\H s e l f ' "

Figure 22.13d

010

--------- ...

22.4
Getting Started Revisited
Recall that in Section 1.3 you were introduced to the names of the external files needed to run the Smalltalk-80 system-the image, sources, and changes files. The sources and changes files contain text for methods stored in the format shown in Figure 22.2. When you use a browser to access a method, the system has to retrieve the source code for that method. Initially all the source code is found in the file we refer to as the sources file. This file might be stored on your local disk or it might be on a network-based file server, shared among several Smalltalk-80 system users. As you are evaluating expressions or making changes to class descriptions, your actions are logged onto an external file that we refer to as the changes file. If you change a method, the new source code is stored on the changes file, not back into the sources file. Thus the sources file is treated as shared and immutable; a private changes file must exist for each user. The executable form of methods is compiled code (an instance of class CompiledMethod). The location of the source code corresponding to the compiled code is stored as part of the representation of a compiled method.

Sources and Changes Files

458
The File System
The sources, changes, and image files must be used in a coordinated way because of this retrieval reference in the image to one of the the two external files.

The two external files for sources and changes are referenced as elements of a global variable, the array named SourceFiles. The first element of the array is the sources file, the second is the changes file. The System Workspace contains the following expressions for changing the reference to the sources file.
SourceFiles at: 1 put: (FileStream oldFileNamed: ' filename.sources'). (SourceFiles at: 1) readOnly.

If you rename the sources files, you can inform the system by evaluat-

ing this expression. You can change the reference to the changes file
(SourceFiles at: 2) in a similar way. Extensive access to the changes file,

either to merge the work represented on two or more such files or to create a new one, is available in the Smalltalk-80 system. This access, the change manager, is presented in Chapter 23. When you do not have access to the sources file, because it is not available on your local disk (perhaps there was not enough space) or you do not have access to a remote file server where it is stored, then it is not possible to browse methods in the way described in Chapter 9. Your system, however, contains the compiled version of the methods, and the system includes a decompiler. If you use the decompiler, you can obtain the text for methods, even though you can not obtain comments or the names of arguments and temporary variables. There are two ways to inform the system to decompile, rather than to try to access the sources file. 1. Hold down the left ttshift" key on the keyboard at the same time that you choose a message selector in the message-selector subview of a system browser. 2. In the System Workspace, evaluate the expression
SourceFiles
<-

Decompilation

nil

The system will notice that the global variable SourceFiles is not an array referencing two files, as expected, and will decompile methods when you try to access them in a browser. In addition, the changes file will not be maintained.

::::",.".", \.

System Backup, Crash Recovery, and Cleanup

23.1 Saving Your System State 23.2 The System Change Set Change-Set Browser 23.3 The System Audit Trail Crash Recovery Change-Management Browser Conflict Resolution 23.4 Creating a Clean" System Creating a New System Image Static Checks Condensing Sources and Changes 23.5 Version Management

':':":'~':~'" :'::;'" \. ":;'" \. "':;'" \. "':;'" .... "':;"

460
Systelll Backup, Crash Recovery, and Cleanup

This chapter covers four aspects of the system that fall in the category of housecleaning support. Once again, we review the use of a snapshot as a way to save your work. We discuss the availability of the change set for monitoring the changes you make to classes and for supporting your ability to create files for sharing your work. While you are using the system, each addition or change to the system and each evaluation that you make is stored on an external file. This "audit trail" can be used by you to recover from a system crash and to merge the work of several programmers. After you work for awhile in a system image, housecleaning is needed to create new versions of the system image, changes, and sources files. This chapter includes an explanation of how to create "clean" system files. Version management is a general problem that is not directly supported by the standard system views. Research h~s been conducted in this area, and an experimental form of version management is used by the Smalltalk research team at Xerox PARC. A brief review of this research is provided in the last section of this chapter.

23.1
Saving Your System State
Periodically you might wish to save the current state of your work in the form of a system image. This is especially appropriate if you are going to make changes whose behavior you are not clear about, and which might, therefore, crash the system. Creating a snapshot is also appropriate if you feel that the amount of space for object storage is very low and you do not want to take a chance on losing your work. And it is important to save your work periodically if you feel that your hardware is not sufficiently reliable. The System Menu contains the command save. Choose this command (Figure 23.1a). When you choose the command save, a prompter appears. It contains the name of the image file currently being used (Figure 23.1b). Note that the extension for the file name is not included. (Note also that this is the first part of the name found as the first element of the global array, SourceFiJes.) If you want to use this same file name, then choose the yellow button command accept, or simply type the "carriage return" key (Figure 23.1c).
For some systems, to gain performance, part of the display screen turns white while the snapshot is being created on the file. It restores as soon as the file is completely written.

461 23.1 Saving Your System State


::"

::::
restore display ~.;.;.it project pr0.lec t file list b r 0 '",'",' s ~ r

IIII!III!I!!!!'I!!I!I'!!III!!!I!!III!!!I!!!I!I!II!II!I!!IIIIII
Figure 23.1a

'",',. '0 rk .:: p.:t. c. e system tt".:trrscript s y stem ',/",' 0 rksp.:t. c ~


I"

010
:.:.:::.,:

uit

Ii

'",:

'::'

Figure 23.1b

...: :><

:: :.:::.. :..

:::':':'(:'::: > ':'.:"


:'\i :,:

::::::::::::::::::::::::::::::::::'::': ::::::)<ii/"\ ;': : : : : : : :":':':.::::::::::::::::::::::::::,:,:::,:

Figure 23.1c

010

462
System Backup, Crash Recovery, and Cleanup

If you want to use a different name than the one that appears in the prompter, then edit the text in the prompter. To terminate, choose the yellow button command accept, or type the ((carriage return" key. A new file for the image is created; the name is the name you gave in the prompter followed by a period followed by the characters im (an abbreviation for ((image"). The image file must be coordinated with the file containing the changes made in this image of the system. Thus another new file is created; the name is the name you gave in the prompter followed by a period followed by the characters changes. If you request a snapshot and then change your mind while the prompter is visible, delete all the text from the prompter. Choose the yellow button command accept, or type the ((carriage return" key. When you back up your work on another personal disk or on a network-based file server, you should save both the image file and the changes file. When you want to use these files again, you should use them with the same interpreter you used when the files were created. Access to snapshot is also available when you choose System Menu quit. You are given the choice, then, to save, then quit.

23.2
The System Change Set
Within each project, a set of changes you make to class descriptions is maintained. (Projects are described in Chapter 4.) Using a browser view of this set of changes, you can find out what you have been doing. Also, you can use the set of changes to create an external file containing descriptions of the modifications you have made to the system so that you can share your work with other users. Sharing work, such as an application, involves sharing files of new class descriptions and sharing files of any changes you have to make to existing system classes. Information is added to the set of changes whenever you change an existing method add a new method remove a method change the category of a message change an existing class definition change a class comment add a new class rename an existing class

463 23.2 The System Change Set

remove a class change the category of a class These changes occur either by your system interactions (expression evaluations or method compilations), or by your retrieving information from a file (filing in). That is, the file contains class definitions or method definitions, and these are modifications to the system noted in the change set. If you change a method several times, there will be only one entry for that method in the change set. Keep in mind that an independent set of changes is maintained by each project. If you want to maintain a set of changes for each activity in which you participate, you can create a project for each. The changes you make to class descriptions, and the addition of classes to the system, however, are shared among all the projects that you create.

Accessing the Set of Changes The set of changes can be accessed in the system by sending the single instance of SystemDictionary, Smalltalk, the message
Smalltalk changes
Smalltalk is a global variable that is a dictionary whose keys are the names of all the other global variables in the system, notably the names of existing classes. The set of changes is an instance oj class ChangeSet and is bound to a class variable oj System Dictionary named SystemChanges.

The expression
Smalltalk changes asSortedCollection

may be found in the System Workspace. If you evaluate this expression by selecting the text and then choosing the yellow button command print it, you see a description of the changes you have made so far. Try this when you first start using the system, and try it again after you have compiled some methods and/or have defined some classes. An example result of evaluating the expression is shown in Figure 23.2. The changes displayed are the ones that existed in the system after the class FinancialHistory was added to the system (as described in Chapter 13) an instance of FinancialHistory was created and inspected several messages were sent to the instance a new method was added to class Dictionary to modify printOn: the method for report was changed to use printOn:

464
System Backup, Crash Recovery, and Cleanup

files
(File::itt-e,jm oldFiler",Jo3med: 'Fin,j ncio3.IHis tory,s t') fileln,

(File::;treo3 m filer\Jo3 me(J: ' filer\Jo3me,s t') fileC'JjtCho3r,,~es, (File::itreo3.m filer",J,jme(J: 'filer\Jo3me,st') edit,

Changes
::im,j.llt ,01 If noCr"j file(1 u t
n,~e

s,
::; t r-eo3m,
n,~es,

(FileS t re,:t m fileT'"j.:. med: ' fileT'"j,:t. me. S t',i


Ch,jnl~e sF,x:

::i tt-eo3 m r-emo"ieFromCr"j ::; m ,01 II t ,01 If b ro "i'i seC r, ,01


rl'~

e d r"i' e ss ,01

I~ e

:::mo3.11 to3./k ch,:t nges ,51 s::iorte(JC:ollec tion

Inquiry
::imo3.llt ,01 If bro"'i'i se,"-, III mplement orsC' f: #mes s,j,~e::ielect or ::i mo3 lit ,01 If b ro "i'i s e ,"-, II C ,01 Ils'=' n: # me ss ,01
,~e::;

e lec t 0 t-

Figure

23.2

000

C ollec tion ('t-O"i'i s e,"-, IIC,j lis (In: # timesFiepeo3 t: ::imo3llt,jlk bro"i'ise,"-,IICo3llsC'n: #o3.t: ,jnd: #o3t: -,ut:

The changes show only that class FinancialHistory was added, and that a method in class Dictionary was added. The fact that expression evaluations were carried out is not stored in the set of changes.

D Removing Entries From the Set of Changes There are three ways to remove entries from the set of changes for the current project.
1. Remove all the entries from the set of changes by evaluating the expression Smalltalk noChanges.

2. Remove all the entries that have already been saved on a file. This is automatically done whenever you file out from a system browser. For example, if you file out a class description, all entries about the class are removed from the set of changes; if you file out a particular method, any reference to the method is removed. 3. Remove all entries that refer to a particular class, ClassName, by evaluating an expression of the form
ClassName removeFromChanges

Whenever you start with a new system image and you want to make certain that the change set contains only subsequent changes, you

465
23.2 The System Change Set

should evaluate the expression Smalltalk noChanges; the expression appears in the System Workspace. If you create a new class definition, the set of changes indicates that the class was added to the system. Henceforth, any changes to this class are not entered into the change set. This is because it is understood that the class is new and, therefore, everything about the class is new. If you file in a new class definition and then wish to maintain information about subsequent changes to the class, you should remove the class from changes using the message removeFromChanges or, if appropriate, sending Smalltalk the message noChanges. A typical way in which several people can work together on a project is to maintain independent changes files. A file created by one person is filed into the system, the change set is emptied, and then all new changes logged. Then a file of the changes is created. The next person retrieves the original file and then retrieves the file of changes.

Storing the Set of Changes on a File Changes to class descriptions (class definitions, comments, and methods) can be saved on an external file by evaluating an expression of the form
(FileStream fileNamed: ' fileName' ) fileOutChanges

Alternatively, changes pertaining only to a specific class, ClassName, can be filed out by evaluating an expression of the form
(FileStream fileNamed: ' fileName' ) fileOutChangesFor: ClassName

The process of filing out the changes does not modify the set of changes, so that the changes can be filed out again, especially if additional changes are made later in the working session. Rather than keeping a snapshot of your work, you might prefer to back up periodically by creating files of changes. As noted earlier, the process of filing out a class by choosing the yellow button command file out in a system browser causes references to that class to be removed from the set of changes. One strategy to use in creating external files for sharing your work is, first, to file out any classes that you added to the system, and second, to file out the remaining contents of the set of changes. The set of changes should then contain only changes to system classes.

Change-Set Browser

You can create a view of the set of changes that is like a message-set browser. This is done by evaluating the expression
Smalltalk browseChangedMessages

that appears in the System Workspace. Try it (Figure 23.3).

466
System Backup, Crash Recovery, and Cleanup

(File::, tr'e,:; m 0 1,:JFile['"j,:;me ,:J: 'Fi r,,:; ric i,:;1 Hi 5t c, r- y, 5t') ril eln

(File::, tre.:; m file r'.J.:; me d: 'filer",J,:; me, 5 t') file I)U tCrl':; rll~e 5, (File::, t r'e ,:; m filer'"j ,:; m e':J: 'filer'.,] ,:; me,: t') e,:Jit,

Changes
::,ma II t ,:; If noCr,,:; n'je 5, (File::; t rea m rilef'o,J,3 med: 'rilef'o,J,:; me,:' t') rileC'1j t C r\.:; rl1j e 5Fo to: ::' t re ,:; m, ::' t re ,:; rJ"1 t'e mo '.... eFro m C r, ,:; rl'je 5,
lll,I'I'E" 1,,1,"
th'~' C'l~'tr~ri"(

':;'j.3in UrllJO

copy
cut p.:;:.te
I~,rirl,\

c'i'i',:5:ti',ge"sl

..

it

5malltalk browseChangedMessages

,:;ccept

::;m,:;llt,:;lk crl.:;n'je5 ,:;:.::;or'te,:JCollectior, ::,or't - c,:;ncel ,ior, CDictionar'y printCm: - cr,arllje' 'Fin.:;rlci,:;IHi:.tor'y - ,:;,),)'

Inquiry
::; m ,:;11 t ,:;1 f t, r' 0 ', , 5e ,"-, III m pie men tor' 5,=, r: # m e 55 ':;'~ e ::' e Ie c tor' ::' m ,:;11 t ,:;1 f br'o ' 5e,,,-,IIC ,:;115C'r,: # me 55a
,~e ::,e Iec

tor'

Figure 23.3

010

C ollec t io n t,ro', ,.. 5e ,"-, II C ,:;115'=' r,: # t ime5 Fiep e,:; t: ::,mallt,:;lk t,t'o"""/5e,"-,IIC.:;115C'n: #.:; t: and: #.:; t: ',ut:

If there are no changes, then no browser is created and the word Nobody appears in the System Transcript (if it is visible on the display screen). The change-set browser shown in Figure 23.4 is a view of the same information that was printed in the workspace of Figure 23.2. The two parts of the change-set browser are identical to a message-selector browser as described in Chapter 10. The top subview is a list menu; the yellow button menu associated with it is the same as the yellow button menu associated with a message-selector subview of a browser. If you choose one of the class/message pairs, the method associated with the message appears in the text subview of the change-set browser. You can file out or print out the method, and spawn a message-selector browser for the currently selected message. You can inquire about senders, implementors, and messages in the method. And you can move the message to a new message category, or you can remove the method from the system. You can not modify the change set using commands in the change-set browser. Notice that the fact that a new class was added to the system does not appear in the change-set browser; only changed methods are accessed using this browser.

467
23.3 The System Audit Trail

1><> >1

files
- 'File['"j,Cirlie(J: 'Fin,Cinci,CiIHistory,st') fileln, : r",Ja. me d: ' file r'"j a. me, s t') file C1U t C:I"", a. n qe s,

p,.intOn: aStrearn

tc,of"il,:.ny

I
+
self r1i,Ci./F'rint,

toor"il,Ci.ny ... ,Ci::;tt'e,Cim position ,Ci.::,tream cr, 5el f ,Ci55 oci,.; t ion 5Do: [:element

,Ci::;ue,Cim ne'tF'ut,"-,II: self CI,CiSS n,Cime, , (',

I
toor",il,Cin:,' ifTnJe: [,,,::;ue.".m ne::<tF'ut."-.II:

,.;::;uearli p05ition

100
Figure 23.4

'", etc."

r , t 5eIfJ.
element prirlt(ln', ,Ci:::tre.:.m. ,Ci::;tt'ea.m crJ.

000

.Ci.::;tre.Ci.rIi ne<tF'ut: $)

23.3
The System Audit Trail
The storage of changes in the Smalltalk-80 system takes two forms: an internal form as a set of changes (actually a set of objects describing changes), and an external form as a file on which your actions are logged while you are working (in the form of executable expressions or expressions that can be filed into a system). The previous section described a browser to access the internal form; this section describes a browser to access the external one. All the information stored in the internal change set is also written onto the changes file. In addition, when you make a snapshot, the changes file is marked with the notation
II

----SNAPSHOT----

II

so that you can use a change-management browser (described later) to request a view only of the information stored in the changes file since your last snapshot. You can also look at the file and see what changes occurred between snapshots. The changes file serves two important uses: to provide information for recovery from a crash, and to support a way of sharing code

468
System Backup, Crash Recovery, and Cleanup

implemented by a group of programmers, including finding and resolving conflicting changes. Because the changes file maintains a log of each of your actions, you can use it to recover from a system crash, that is, any situation in which you find that you can no longer communicate with the system and therefore can not safely save your work. Recovery can be done in two ways. After a crash, start up a previous system image that you can run (presumably the last snapshot that you successfully made and saved). Evaluate a message such as
Smalltalk recover: 5000

Crash Recovery

The argument, 5000, represents the number of characters from the end of the changes file that you wish to copy. The characters are copied onto a file named staO.recent. A view of this new file will be created on the screen. Explore it. Find the last place in the file containing the text " ----SNAPSHOT----". This is the point at which you wrote the last snapshot. If you can not. find this text on the file, you will have to reevaluate the message recover: again, this time with a larger number. Now that you found the point at which you had previously saved your work, you can use the yellow button command file it in in the view of the file staO.recent to selectively evaluate and file in the changes you had made up to the time of the crash.

ChangeManagement Browser

Alternatively, you can use a browser that we refer to as the Changemanagement Browser. This browser lets you access your do it or print it evaluations, as well as method definitions, whereas the change-set browser described in Section 23.2 does not. Moreover, the order in which you made changes is retained in the changes file and presented in the change-management browser. The order of changes is not retained in the internal change set. You can use this ordering information to back up to a previous version of a method. The change-management browser lets you examine the contents of one or more changes files examine the method changes stored in the change set configure a new changes file redo any of the changes or evaluations determine whether there is any conflicting implementations of a method in two or more changes files To open a change-management browser that has no initial change content, evaluate the expression

469
23.3 The System Audit Trail

ChangeListView open

To open a change-management browser that initially displays all the actions stored in the current changes file since your last snapshot, evaluate the expression
ChangeListView recover

Or you can specify a changes file (fileName) whose content should be displayed initially in the change-management browser. Evaluate the expression
ChangeListView openOn: (ChangeList new recoverFile: (FileStream oldFileNamed: 'fileName'))

All of these expressions are provided in the System Workspace. Select and evaluate the first one (Figure 23.5).

&EWillill..ill.....ill...ww.. . . .-U
Time milli:::econd:::ToFiun: [:::y::: tem i )r-93 niz,;. tion print ::; trin'j ] 1',..112::: :::.3912 T.3 II Y :::p yC1n: [E:et-,,;, ''I'lor compile ,;"IIJ, (File::;tre,3m oldFile[",J.3mee]: ':3py,r-e:3ult:3') eeJit

3 'j .3. i n

copy
cut

undo

pa.:3 te orr-in it .3.ccept ca.ncel

Change Management and Crash recovery


ChangeListView open.

Ch.:.. ngeLi::: t \/ie ',/./ open(ln: (Ch,jn1jeLi::: t ne'/,/ reco"'/ erFile: ': File::;tr-e,jm ol(jFiler'.j,j med: ' filer",],j me,:3 t ')),
",.ii, ft~t.:;

(:'1'"-05: ~71~':o Ct-~'6 (~. .:;

1"'I'~I\.I.,'

t(i'

bt,31.. 1,I'S~' Ch,5: {j',q~'S S(;ti'C~ t~h~

Il,s:st sr(6:,t.fSI~fCi't:'

::.m,31Italk reco\'er: 5000,

Figure 23.5

The empty change-management browser is shown in Figure 23.6. It consists of three major parts: the top part containing a list menu, the middle part containing several browser menu items that control the kind of information that will display in the menu, and the bottom part in which text is displayed and can be edited. With the cursor in the top subview, press the yellow button to observe the menu (Figure 23.7). The

470
System Backup, Crash Recovery, and Cleanup

file

type

Figure 23.6

000

r"emO"ie it r"estore it s ", ':. "i'in it crle ck conflict s check "i'iith system

Figure 23.7

010

l
471
23.3 The System Audit Trail

menu commands allow you to specify changes files to read or to write, and allow you to operate on a single item or on a group of items in the list menu. Two commands invoke conflict analysis on the items in the list menu.

Commands that specify changes files


A prompter appears in which you type the name of a changes file. When you choose the yellow button command accept, references to the contents of this file are added to the browser menu. If you change your mind and want to abort this command, type nothing in the prompter and choose the yellow button command accept or type the "carriage return" key. A prompter appears in which you type the name ofa changes file. When you choose the yellow button command accept, the items in the browser menu that are not marked for removal are stored in the file. If you change your mind and want to abort this command, type nothing in the prompter and choose the yellow button command accept or type the "carriage return" key. Adds to the browser menu references to the contents of the current changes file since the last snapshot. Adds to the browser menu references to the methods in the internal change set.

file in

file out

recover last changes display system changes

o Commands that operate on a group of items


do all remove all restore all spawn all forget
Evaluates each expression or new definition that is referenced in the browser menu and is not marked for removal. Marks every item in the browser menu for removal. Unmarks every item in the browser menu that is currently marked for removal. Creates another change-management browser whose menu is identical to the currently displayed menu. Deletes every item in the browser menu that is currently marked for removal.

Commands that operate on a single item


Evaluates the item that is currently selected, whether or not it is marked for removal. The item is either an expression, or a class or method definition.

do it

472
System Backup, Crash Recovery, and Cleanup

remove it restore it spawn it

Marks the item that is currently selected for removal. Unmarks the item that is currently selected and that is marked for removal. Creates a message-selector browser for the current definition in the system of the item that is selected. You can then visually compare to see if the changes file specifies a different definition, and then you can decide which one you prefer to use.

o Commands that check for conflicts


check conflicts
A prompter appears in which you type the name of a changes file. When you choose the yellow button command accept, an analysis is done of all the items in the changemanagement browser menu to see if any of them refer to the same message selector, but specify different definitions. Any conflicts found are written on the file. A prompter appears in which you type the name of a changes file. When you choose the yellow button command accept, an analysis is done of all the items in the changemanagement browser menu to see if any of them refer to the same message selector, but specify different definitions. Also checks to see if any item specifies a different definition than is currently in the system. Any conflicts found are written on the file.

check with system

If you start with an empty change-management browser, and choose the yellow button command display system changes, you access the same information that is shown in the change-set browser. If you start

with an empty change-management browser, and choose the yellow button command recover last changes, you access the same information that is shown if you evaluate the expression ChangeListView recover. Assume that the internal change set is the one displayed in Figure 23.2, and that you have not made a snapshot since you made these changes. Choose the yellow button command recover last changes in the top subview of the change-management browser. The information shown exceeds that available from the change-set browser (Figures 23.8a and 23.8b). In addition to method definitions (such as FinancialHistory spend:for:), the change-management menu contains class defines (for example, define FinancialHistory) expression executions (for example, dolt self spend: 100 for: ' rent' ) category changes

r
::;m.:..lltalk eO.cha. n'jes.", (Jolt 'From ::,m.:..iit.:..il.-:::Ci, /er-sion 2, of ... (Jefine Fin.:..nciaIHistor-y

473 23.3 The System Audit Trail

~:~::~~::~::~:~: ~ ~ :~: ;:~: : ~~';',~I;~~ for:


sho./ file file

~:~::~~::~::~:~:~ ~ :~: ;: : : ~~~ ;~I'i~ f.~ ~::~:~r~: c e:


I
type

cla.ss

ca.te'jory

selector-

s.:..me

Figure 23.8a

000

1 / / 1

:=;mallta.lk ;_:u.crl.:.r"j'::'s.!

>'."'."'..

Diction.:..ry print.:)n: (Jolt self spend: 100 for: 'r-ent' (Jolt self spend: 75 for-: 'food' (Jolt self spend: 50 for-: 'trips' (Jolt self r-epor-t l:Jolt ::;m.:.llt .:.Ik cr,.:. nqe::: .:..;. ::;ortedCollec t ;. rl 0 ',/./ fi Ie file

type

OOOYUHU)]
Figure 23.8b

474
System Backup, Crash Recovery, and Cleanup

These ((special" changes are shown indented from the left margin of the list menu.

Display Options and Filters The menu items in the second part of the change-management browser let you obtain more information. Click the red button while the cursor is in the rectangle labeled show file (Figure 23.9). This ((turns on" the option to see which changes file the list items came from, useful if you have accessed multiple files. Click again to ((turn off" this option.

,:Jolt , Ft-Orl-I ::;m.jllt.:lIf-;:;[I, "iet-:::iorJ 2, of . defirJe FirJ.jrJcialHistory FirJ.jrJci.j.IHi tory :::perJd:for: FirJ.jrJci.j.IHi tory report F!r,.jrJc!.jIH! tor-y tot.jl.::;perJtFor-: FlrJa. rJC 1.01 IHI tory ::: e tlrJltla.IE: ala rl c e:

100-;;;;;;;';;";';";';,;1
Figure 23.9

000
Now click the red button while the cursor is in the rectangle labeled show category (Figure 23.10). This ((turns on" the option to see the category of the methods referenced in the list menu. The remaining menu items provide a filter on what information should be shown in the list menu. Choosing one of the items ((turns on" the filter indicated. The filters only have meaning if an item in the top subview is selected. The basic idea is to remove any items from the menu that do not match exactly the filtered part of the selected item. An item is made up of at most five parts: file name, type (dolt, define, method, and so on), class, message category, and message selector. Thus the possible attributes for filtering items are

475
23.3 The System Audit Trail

,jolt 'From ::;m,:<IIt,:.lf-:::O, ',,len/on 2, of ,,, define FirlanciaIHi:::tot'Y


0

~~";'~'i~~;:'~~ i '~~~~,~ r~~ ~::1 ~'~; ~I~'~~,~ tr:~t~;':~, r~:' end: f


::: 1"', 0 ',,I,,"

t':

inquirie:::) Fin,:<.nc i,:<.IHi::: t 0 t'Y to t ,:<.1::, pen t For: pr'i',,1a te) FinancialHi::: tory :::etlniti,:<.IE:,:<.I,:<.nce:

ti Ie

tile

Figure 23.10

100 000

1/ . / ....1

file type class category selector same

The changes file for all items should be the same as that of the selected item, The type (evaluation, class definition, method definition) of all items should be the same as that of the selected item. The class to which the items refer should be the same as that of the selected item. The class category for each item should be the same as that of the selected item. The message selector of each item should be the same as that of the selected item. All items should be precisely the same (this makes it possible to see multiple entries that are possibly conflicting definitions).

Suppose the menu item selected is a method definition and you choose the filter labeled type (Figute 23.11). Then the only items displayed in the menu are method definitions. Choose the filter type again, that is, ttturn off" this filter. Suppose the menu item class is FinancialHistory and you choose the filter labeled class (Figure 23.12). Then the only items displayed in the menu are method definitions for FinancialHistory. You can explore the change-management browser further by marking and unmarking items for removal, and spawning related browsers using the appropriate commands in the yellow button menu.

476
SysteIll Backup, Crash Recovery, and Cleanup

.,">,

>II''i,.*t,,n,J.Wi'.i",mLiil"*'u#;uH"'i

file 3pend: "::,perld ,jmount for- the r-e,j.30rl c ,01 3 h 0 n 1", ,01 n cJ, " e,perlditurec, ,011:: re,j30rl put: (5elf tot,jl::,perltFor-: re,j.30n) ,:;mount, c ,01 31"1'=' r, H ,01 n ,] ... c ,01 3h C' rl H,01 n ,] - ,01 m0 u r, t
,~i',/erl, ,]ecr-emer,tin,~

tr,e ,j',/,jil,jr,le

100,,,,,,,1
Figure 23.11

000

"::,per,d ,jmour,t for t1",e re,:; 30n 'ji',/en, decremerttirt'j t1",e ,01 ',/,:;ij,jl:tle c ,01 31"1 0 rl h ,01 rl d ,"

Figure 23.12

100 000

477
23.4 Creating a "Clean" System

Conflict Resolution

Detecting conflicts between method definitions is described in the paper Managing the Evolution of a Smalltalk-80 System" by Steve Putz in the Smalltalk-80 implementation considerations book, Sma llta lk-BO: Bits of History, Words of Advice. The main reason conflict checking is needed is that work done by different people can affect the same methods. When work is done in parallel by several programmers, each programmer submits a changes file. It is not possible to file-in each changes file, one at a time, since one file may undo (redo improperly) the definition provided in another file. A conflict analysis routine is available in the system to examine code files and report the ways in which they conflict. Whenever two or more submissions define the same method, all conflicting definitions are appended to a ~~conflict report" file. It is then up to the programmers. involved to determine how to resolve the conflicts, often by writing a new method that merges the needed functionalities. Conflict checking is requested by choosing one of two commands in the yellow button menu of the top subview of the change-management browser, conflicts among the menu items (check conflicts) or conflicts among the menu items and the system methods (check with system). For each command, you must type a file name in a prompter and choose the yellow button command accept. The file is then created. When the analysis is completed, you can use the file list view to examine the file.
Missing from the audit trail (changes file) is date stamping on each entry, back linking to alternative definitions, and "person" stamping (that is, associating the name of the person who made the change), all of which can be useful when multiple persons participate in a project and share the use of an image and its changes file.

23.4
Creating a uClean" System
If you use an image long enough, modifying system methods and adding

new methods, you will eventually create a very large audit trail on your changes file. Most methods will be referenced in this changes file rather than in the sources file. When you then want to create a new system release, you will want to clean up your system so that it has the following characteristics. 1. All up-to-date definitions and methods are on the sources file. 2. The changes file is empty (except for the date and version comment). 3. You are assured that there are no unreferenced objects in the system image.

478
System Backup, Crash Recovery, and Cleanup

Even when you are not releasing a new system, you may want to keep your changes file as short as possible. The changes file grows to include definitions for methods that override one another. That is, in the process of programming, you might try several versions of a method before settling on a definition. Each version will appear in the changes file, even though the system compiled method only refers to the last one. The most common ((clean up" needed, then, is to condense your personal copy of the changes file, leaving the shared sources file untouched. A new system image is created by a process we call ((doing a VMemwrite," that is, writing a new file that contains an image of the virtual system. The idea of a VMem-write is to trace every accessible object, and write a copy of each object onto a disk image. This determines which objects are actually being used and which are occupying space unnecessarily. The end result is to release any possible free space. Moreover, the resulting clone can pe started up and run, just like a snapshot.
Some care is taken so that objects appear in the same order in the data space as they do in the system object table. This aspect of the implementation is covered in Part Four of the book Smalltalk-BO: The Language and its Implementation.

Creating a New System Image

The second purpose of a VMem-write is to allow any transformation of the system, such as changing the bytecode set or the structure of a class of objects (for example, the representation of floating-point numbers), which can not be done while you are interacting with the system. To initiate the VMem-write, evaluate the expression
SystemTracer writeClone

In this case, no special transformations will be carried out. The result is a new image written on a file named
clone.im

which you rename according to whatever system version naming conventions you have. One of the common transformations done with the VMem-write is to clamp out (remove) classes. You might want to do this because your system includes some applications that you wish to remove in order to have a version of the system that takes up less space. Or you might want to do this because you have developed an alternative implementation of an application and had been using both versions until the new one was stable; now you are ready to eliminate the original version. For the most part, you do not need a VMem-write to eliminate classes from

r
j

479
23.4 Creating a "Clean" System

your system since you can use the command remove in the class-names subview of a system browser. To clamp out classes, use a different message to SystemTracer.
SystemTracer writeCloneWithout: aSetOfClasses

where the argument is an instance of Set whose elements are the classes that you do want to clamp out. The method associated with SystemTracer writeCloneWithout: will do two things.
1. Remove the class references from the system dictionary, Smalltalk.

2. Remove any class categories that become empty as a result of re-

moving the classes. This means that the running image (the image from which you create the VMem-write) will be irreparably modified, so make sure that you have backed up your system image appropriately. Before doing any VMem-write, you might want to clamp out some message protocols for various classes. You do this directly by using the system browser to remove the protocols from the class. Again, this means that you are irreparably modifying the source image, so make sure that you have backed up your system image.
Included in the description of class SystemTracer is a clamping mechanism called winnowing. Its purpose is to cull out all unreferenced messages, with the exception of ones you specifically name. Then, based on these deletions, cull out more, and so on. This is basically a first attempt to understand how to drop out major parts of the system. You can explore this feature by examining the comment and the method associated with the message winnow: in class SystemTracer.

Static Checks

Before creating a new image, you will want to check for things that might be wrong with the current image. The system includes class Checker that contains many messages that support your doing static checks of the system. You can check for messages implemented but not sent by any method (this situation might be acceptable if the message is there for semantic completeness of a protocoD, and messages sent but not implemented (this suggests a possible runtime error). An important thing to check for is the existence of obsolete classes. Send Checker the message obsoleteClasses. The response is an OrderedCollection of the classes in the system that have been made obsolete. A class becomes obsolete when it is removed from the system, but one or more instances exist. To remove the obsolete class, all instances must be deleted. You remove the instances by finding all references to them and setting the references to nil.

480
System Backup, Crash Recovery, and Cleanup

Condensing Sources and Changes

The purpose of condensing changes is to remove all redundancies from the changes file. Condensing also removes all logged information other than one copy of the changed method definitions. To condense your changes file, evaluate the expression
Smalltalk condenseChanges

In the System Transcript, you can observe the name of each class and message category as the source code for each is written onto the new changes file. The final name of the changes file is the name of the current one. If you want to merge your changes file into a sources file, evaluate an expression of the form
Smalltalk newSourceFile: prefixName without: aCollectionOfClasses

where prefixName is a String representing the file name. Evaluating this expression creates two files whose names are
prefixName. sources

and
prefixName.changes

The second file is empty except for the date and version comment. Besides writing the method definitions, all class definitions are written and everything is alphabetically ordered, by class name, on the sources file. An example of using this expression is
Smalltalk newSourceFile: Smalltalk versionName without: Array new

in which the prefix file name is the current system version name and no classes are omitted.

23.5
Version Management
In his paper, Steve Putz also describes a special application he developed for managing the evolution of the Smalltalk-80 system. The system he describes supports users in reporting bugs and bug fixes, and in

481 23.5 Version Management

suggesting or announcing new applications (we call these ((goodies"). The central feature of this development support system is a networkbased database containing information about the past and proposed changes to the system, as well as bug reports and application announcements. The database also contains documentation about system changes and released system versions. This version management system is considered experimental and was not provided as a part of the standard Smalltalk-80 system. A summary of the version handler is provided here; if you are interested in more details about this area you should examine the Putz paper. The interface to the system version handler is done using a special browser. There are actually three different browsers that filter information from the database of system changes and system release documentation: a version browser, a new feature browser, and a bug report browser. The version browser supports you in examining the changes introduced in the currently selected version of the system, the changes submitted that were not included in the version release, remaining known bugs, and the known bugs for which fixes can be retrieved but are not as yet incorporated into the system. Figure 23.13a shows an example of a version browser. It consists of two subviews, one is a list menu and the other displays text. Each of the four kinds of information that you

\/2::: ::ima.llta.lk-:::O Ima.l~e \/ersion: \/29 tima.llt,3Ik-eO Irn,3.'~e \/ersion: \/:30 ::;ma.llt,3Ik-:::O Irn,3.qe \/et"sion:
W.

nM".'.....",,;.'..

::iT:::O\/2::: ::iTeO\/29 ::iT:::0\/:30

@.wMJ{IEW::1

Figure 23.13a

482
System Backup, Crash Recovery, and Cleanup

can access is presented in a menu associated with the top subview of the version browser (Figure 23.13b). Choosing a menu item creates a browser that presents the requested information.

::,m,jllt ,j Ik-:::O 1m ,j qe """'er"5ion: """'29 ::,m,jllt,j If-:::O Im,jl~e er5ion: . . . . :~:O ::' m ,j II t ,j I k- :::0 Ima 'je er5 i on:

::' T ::: 0""'" 2::: ::,T:::O . . . . r=-2-=-,9 ----" ::' T ::: 0""'" bro',.. ,.. 5 8 C h ,j n'j8 5

' lEJmllllmll-a-!l'lliilm mDlEW=I!'.


........" """'""1--------------------1 D ,j t e: 1:::"-, p r" ::::~: 15: 5 7:26 p::, T
Fr"o m - . . . . er"5 i on: ....... :~:O

t, tOO """"'5 e b u q:. bnY''''''''5e t'lJ'j ti,e5 t'r"0""""'5e r,e',.. ,.. qooeJie5
r",:._ t. t"I'':'_ ',... ,:._ "," ,:._r"., '1'-.' r,

t---I._-,

c h a r"j e 5:
::' IJ b j

,= 4 O'~,

C 4 10, C 41 1, C 4 1:2, C 41 4, C 41 5, C 4 16, C 41 7


::' T ::: 0 . . . . :~:1

e c t: ::' m ,j II t ,j I f - ::: 0 Im ,j 'j e ....... e r c, i 0 r, :

From: Put::
i rn ,j

'j e - til e::' T ::: 0 . . . . :~;1

c, 0 u n: e c, - tile: ::' T ::;1]""'" :~:I]


', ... i n IJ ,j

I- rn ,j c i n e: EE:

rJ

0 ', . . ,... rJ -tliJ 'j 5: E:', E: , 6, E: 2 7, E: 5


:~:

'2, E: 5 6, E: 5 ';I, E: Co 2, E: 7 '2, E:W 0, E:ll -:' ,


1'~

E:l 2';1, E:1

7, E:l 66, E: 169, E: 170, E:l 72, E:l 7 Co, E:l ::: 2, E:l ::: :~:, E: 1::: 4 ,

E: 1::: :::, E:l ';I :~:, E: 1';I 5, E: 1';I Co, E: 1';I 7, E:

:::, E:l 99, E: 2 0 CI, E: 2 1=1 1, E: 2 0 2 ,

E: 2 CI :~:, E: 204, E: 2 0 5, E: 2 0 6, E: 2 0 7, E: 2 0 :::

Figure 23.13b

010
Figure 23.14 shows a browser that was created by asking to see all the known bugs in the currently selected version of the system. It was obtained by choosing yellow button command browse bugs in the top view of the version browser. The numbers in the menu subview of the Ubugs" browser correspond to those cross-referenced in the version handler. Browsers are available that are used for submitting bug reports or fixes or goodies, and for composing a new system version. The bug report and bug fix browser is a modification of an electronic mail retrieval browser. The user can browse for a reported bug and then fill out a form that documents the proposed fix (Figure 23.15). The bug fix is then added to the database when the user selects the command accept in the yellow button menu of the browser. If a bug fix is selected in the report browser, a cross reference from the bug fix to the bug report is stored so that someone browsing bug reports will be told about the proposed bug fix.

483 23.5 Version Management

lID}

'itMMM!u.i.liM"#".'Mu,MMilt@J."#'

E:59 E:u'j FiepOn: Defininlj ne'// c/.:.ss ca. uses se.:'.rcr, of system

E:72 E;u'j Fiepor't: scn:d/inq due to output into system t:r,:.nscript E: HKI E:u'j Fiepon: Te>t ::;election EiU'j. ,bnY,/,/se fi, .:., E:'1 '15 E:u'j FiepOr"t: ejepenejents may conta.ln dupllc.:. t E; '129 E:uq Fie "'Ot"t: ero",I'iser DIS ',Ia.y (,lltcl"",es
1:):)I~F'.:..te;16 july

\,

I//UU//I I/<//U/I

19:::2 9:09:07 ,:'.m Fr"om-"/er"sion: \/19 ::iu(,ject: E:uq Fieport: Inspector"s on lanje object:.

1 / ) / \ 1 Fr"om: rl.:'.ljm':'.nrl

Innn::nnnnni

I inspecteej .:. fa.irly I.:.rlje object, It "i'i,:'':, ':.. sequence l] collection of .:'.bout120 entr"ies. ,~,round 60 of trle enuies in the collectiorl '''',,o'er'e

1/// ::1 not select.:.ble fr"om Hie irlspector', Trrls is \Ier"y (I,:.cj since it is rl,:.tljt',:.1 to ,:'.ssume tr'.:'.t ,//r,.:.t you see in ,:'T, inspector is ,:.11 Hler'e is to ,:'.n object, ::im.:'lltalk is ',/er'y 'joocj about not rl,:,',/inq speci,:.1 nJles for' 1::::::1 (Jifferent cases (also c.:'.lled "ye,:.rl, but "," irl most systems), I trtinf tr,,:'.t trti.:, 'fe,:.ture' sr,ould be crl,:.n'jecJ to either', (1',1 cJo tr,e ri1jr't Htin'j,

I > :I (2) put ::; eJots in Hie left p,:.ne (",) or (:T) rl.:.',/e a yello',// buttorl select ~~~-::~i!!!n)ii!!!!1 to qet to see trle full Object, I Htink HI,:'.t (1) is Hie corTect solution

010

.n,j is in 'oo.in' with H,e r,,,t of H,o '''''0m

Figure 23.14

.'

::ioun: e-File: [Filene J' ::im.:'.llt ,:..lk:::O::iUp p or't' filer',j,:.. me,s t bUljs-fi>ed: E;1 Descrip tion C'fFi,

'.

.
'

.'

Figure 23.15

484
System Backup, Crash Recovery, and Cleanup

Figure 23.16 is a browser for ((goodies" that was obtained by choosing the yellow button command browse new goodies in the top view of the version browser. ((Goodies" are new ideas for the system, new applications or user interface changes or performance improvements, that have been contributed by any user who has access to the network-based database for the Smalltalk-80 system. If you are interested in using a goodie, you choose a command from the yellow button menu of the goodie browser so that class descriptions for the goodie are filed into your system. Each goodie description is associated with a file of class descriptions that implement the goodie.

'.''''0.=&1.,'',1 '''.1.,.
1":1 d,3 te:16
Febru.3ry19::;:~;

6:04:4::; pm

.,,,::,,,,,:,:,,,'::'1 frorn-',/er5ion:

"""'2::;

13:"".":::":::"'':1 5U[,ject: Cioodie: E'/en E;etter r',/10'',''e .3nd Collap:::e

11

fr"om: F'ut: file: {::,m ':. lit.:.. If.eO::'uppot"t'E ,. . enE:e t terr.. . l0.. e-:::p.::: t

.'::::"":''':',: 'I ::: OutTe -

-":"":',""'.1 In ,:<r,.:,',.. ,.. er" to rCilerln'5 1,35t t'....'. . o ,~oodie5, "',ere i5 ,;. ',/er":::ion '//,..,ic"', make:::

.".,.,."". a Form out of the ,/,.. incJo',/,/ ,3ncJ leU tr,e u:::er" draq ,:<.roun(J n,e . ... ir,,:Jo'/..
1":">.:::"'1 "...,/it"', the mOU5e,

.',"., '"",. ....r"Jote nl,:<t nil': 15 ".. .. r,,:<t L.:<ur.:< (Joe::: in n,e Fier,e,:<r5.:<I ',,1,,1 or\l:J , ,"-.150 note

-":"'''.'.,.,1 H,,:<t on r(lernory-poor rnacr,ine::: I,e,q. Dolprlin) trli5 may e,cerci:::e tr,e

rO~~I~O~
Figure 23.16

corllp,:<ctOt" Ot" t"un trle.:,:,.. :::tem out of mernor"y,

I :::uppose ,3 test could

\\1

be put in '/,/,..dc"'l check::: coreLeft fir5t, but '',''irtu.31 rn ern or:'," \"',"oulcJ be a much nicer 50lution.

New system versions are created by choosing items from a menu of submitted bug fixes and goodies in order to compose a list of changes that should be checked for conflicts and then incorporated into a running system. Bug fixes might conflict with one another in the se;nse that they change the same methods. The system conflict analyzer can be used to check for any such conflicts, leaving it up to you to resolve the differences. This approach to version management was successfully used in managing the refinement of the Smalltalk-80 system.

Appendix 1 Financial History Views and Controllers

This appendix contains a complete listing of three class descriptions: FinancialHistory, FinancialHistoryView, and FinancialHistoryController. These three classes implement a simple model for monitoring income and expenditures (FinancialHistory), viewing that model as two bar charts (BarChartView and FinanciaIHistoryView), and interacting with that model in order to increase income or expenditures. A sample screen image of the bar charts is shown in Figure A.l in which the yellow button menu is showing. The menu has two items: spend and receive. Choosing either one of these brings up a prompter in which the user specifies the reason why money is being spent or received (Figure A.2). Once a reason is specified, a prompter appears in which to specify the amount of money (Figure A.3). The appropriate bar chart is then updated (Figure A.4). If the reason given is new (Figures A.5, A.6, and A.7), the bar chart is reorganized to display the new bar. The view is created as a standard system view so that the blue button menu is available (Figure A.8). This example is given to you as another sample of how to use the classes View and Controller that are provided in the Smalltalk-80 system as basic building blocks with which to construct interactive graphical interfaces. It is unlike the examples in Chapter 15 in that a different approach to creating the yellow button menu is used. The format for presentation is that of a class implementation description as introduced in the book Smalltalk-80: The Language and its Implementation. The example makes use of prompters (instances of the class FilllnTheBlank). The first class, FinancialHistory, was described in Chapters 17, 18, and 19. This version of the class adds access to the instance variable incomes as well as expenditures. Note the addition of the changed mes485

486
Financial History Views and Controllers

=-in,~ ne

ia I Hi.:;tor:,1

eoo
60CJ 60CJ

400 200
[I

400 200

o
food utilities

p.:t.y

Figure A.I

010
=-in.~ ne

ia I Hi.:; tory'

e[reJ

eoo
.:t.ga.in
undo
cop~..,,

6[10

400
2CJ[1

cut
-.3.ste do It print it

Figure A.2

010

r~nt foodutiliti~s

ca

!i!;i!!!!!!!;;;;!!;!!!!!

pay

inm~st

~;~;;~~~~~~~~~;i~~~;~~~~~i;~~~;;~;~;;;~;~~;~;~~~~;;;~; ~;~;;;~;~;~;~;~;~;~;~;~;~;~;~;~;~;~~J~I~J~~~~~J~~~I~I~ ~~~~~;~;~;~~~;~;~;~i~~~~~~~~~~~;~~~~~~~f~~~~~~~~~~~1~~~~~~~;~i~~~~~~;~~~;~~~~~~~;i~~;~~;~~~~I

487
Financial History Views and Controllers

eoo
600

400
2C)0

o
n:!nt fooc1 utilities

20C~

P':'y

IrI

,eres .

Figure A.3

000
:::00

6C)C!

61][1

400

41]0

200

200

o
r'ent food utilities

o
p.:t.y

Figure A.4

000

i nterest

488
Fina nCla} H" . lstory V' ews and C ontrollers l

:=:C.,C.,
6C)0

40i]
200

I]

p.3.',1

interest

Figure A.5

e(]c)

60C)

400
2C)0

(]

in terest
Figure A.6

r
489
Financial History Views and Controllers

=ina nc ia I Histor~. .

::;00 600 400


200

'121]C)

9[1(]

600
:300

C)

o
rent food utilities

interest ~3ift

.1

Figure A.7

000
=in.:tncial History

n.:t.\' r- .'

::;00

'1201]

6C)0
4[11]

under mo'.. e

91]1]

600 :300

200

o
rent food ut\lit\es

interest 9ift

.1

p.:t.y

Figure A.8

001

490
Financial History Views and Controllers

sages to receive:from: and spend:for: to notify any objects dependent on these variables that there was a change.
class name superclass instance variable names category class methods

Financial History Object , cashOn Hand incomes expenditures' , Financial Tools'

instance creation

initialBalance: amount
" Create a FinancialHistory with amount as the initial balance. "

isuper new setlnitialBalance: amount new " Create a FinancialHistory with 0 as the initial balance. " i super new setlnitialBalance: 0
instance methods

transactions

receive: amount from: source " Receive amount of money from source, and increment cash on hand by this amount. "
incomes at: source put: (self totalReceivedFrom: source) cashOnHand -- cashOnHand + amount. incomes changed

amount.

spend: arnountfor: reason


" Spend amount of money for reason and decrement cash on hand by this amount. " expenditures at: reason put: (self totalSpentFor: reason) cashOnHand -- cashOnHand - amount. expenditures changed
inquiries

amount.

cashOnHand
" Answer the current balance? " i cashOnHand expenditures " Answer the Dictionary of expenditures. " i expenditures

491
Financial History Views and Controllers

incomes " Answer the Dictionary of incomes. "


lincomes totalReceivedFrom: source " Answer the total amount of money received from source. " (incomes includesKey: source) ifTrue: [rincomes at: source] ifFalse: [rO]

totalSpentFor: reason " Answer the total amount of money spent for reason. "
(expenditures includesKey: reason) ifTrue: [rexpenditures at: reason] ifFalse: [TO]

private

setlnitialBalance: amount " Initialize the instance variables. "


cashOnHand ...... amount. incomes ...... Dictionary new. expenditures ...... Dictionary new

You can create an instance of FinancialHistory, and spend and receive money, by evaluating the following expressions.
Smalltalk at: # HouseholdFinances put: nil. HouseholdFinances <- FinancialHistory initialBalance: 1560. HouseholdFinances spend: 700 for: ' rent' . HouseholdFinances spenQ: 78.53 for: ' food' . HouseholdFinances receive: 820 from: ' pay' . HouseholdFinances receive: 22.15 from: ' interest' . HouseholdFinances spend: 135.65 for: ' utilities' . HouseholdFinances spend: 146.14 for: ' food' .

In the above expressions, HouseholdFinances is created as a global variable. Then the instance of the class FinancialHistory is created and several messages are sent to it. At this point, if we were to view the incomes and expenditures of HouseholdFinances as two bar charts, we would see the image shown in Figure A.1. The next step is to create a special bar-chart viewing mechanism for a Dictionary. Class BarChartView has no variables declared.

492
Financial History Views and Controllers
class name superclass category instance methods

BarChartView View , Financial Tools'

accessing

barFrame
" Answer the area available for the bars. The response to insetDisplayBox is implemented in the superclass View. " tself insetDisplayBox insetBy: (50 @ 10 corner: 10 @ 50)

labelCount
" Answer the number of labels needed. Although this is specified as a constant, it should probably be an instance variable. "

t5 maximumValue
" Answer the maximum value on the y-axis. The message model, whose response must be a kind of Dictionary, is implemented in the superclass View. "

I total I tot;3.1 self model values inject: 0 into: [ :sum :value I sum + value]. t (total/self labelCount roundTo: self units) * self labelCount
numberOfColumns
" Answer the number of bars needed in the chart. " tself model size

positionFor: value
" Answer the relative position within the chart for value. " tself barFrame height * value / self maximumValue

units
" Answer the unit increment of values used to compute the ticks on the y-axis. Although this is a constant, it probably should be an instance variable. "

t100
displaying

displayView
" Display the x- and y-axis labels and then the bars. This message is

493
Financial History Views and Controllers

sent from View's implementation of the message display, in which the View requests display of each of its subparts. " self displayXLabels. self displayYLabels. self displayBars

displilyXLabels

I corner I corner ~ self barFrame bottom Left. self model keys do: [ :key I key displayAt: corner + (self barFrame width - 20 / (self numberOfColumns * 2) @20) - (key asDisplayText bounding Box extent / 2). corner ~ corner + ((self barFrame width / self numberOfColumns)
displayVLabels

0)]

I count label increment I count ~ self labelCount. increment ~ self maximumValue / count. label ~ O. count timesRepeat: [label printString displayAt: (self barFrame bottomLeft - (35 @ ((self position For: label) + 7))). label ~ label + increment]
displayBars

I height bar corner I corner ~ self barFrame bottomLeft. self model keys do: [ :key I height ~ self position For: (self model at: key). bar ~ corner - (0 @ height) extent: (self barFrame width / self numberOfColumns - 10) @ height. Display black: bar. Display fill: (bar insetBy: 2@2) mask: Form darkGray. corner ~ corner + ((self barFrame width / self numberOfColumns)
update: aParameter
" Some values have changed, so update the view. " self display

0)]

494
Financial History Views and Controllers

You can tryout the bar chart viewing mechanism on any Dictionary with numeric values whose keys are instances of String or Text. In particular, try the following expressions in order to see the bar chart for the HouseholdFinances expenditures.

I aBarChartView I aBarChartView ~ BarChartView new. aBarChartView model: HouseholdFinances expenditures. aBarChartView window: Rectangle from User. aBarChartView insideColor: Form white. aBarChartView borderWidth: 2. aBarChartView display
The third statement asks you to specify the screen area in which the bar chart will be displayed. The expression Rectangle fromUser means that you are to designate a rectangular area. Make it large enough to accommodate the text for all the keys in the Dictionary, HouseHoldFinances expenditures. The definition of a BarChart is faulty in several ways. First, the units are designated as 100. If all the values of the Dictionary are less than 100, then an error (division by zero) will occur when you try to display the bar chart. Second, the number of labels (IabelCount) is specified as 5,

true in our example, but probably not all the time. You can improve the class description by parameterizing these values. To see the problem, try the following expressions.

I aDict aBarChartView I aDict +-- Dictionary new. aDict at: ' 1 ' put: 10. aDict at: ' 2' put: 20. aDict at: ' 3 ' put: 30. aDict at: ' 4 ' put: 40. aDict at: ' 5 ' put: 50. aDict at: ' 6' put: 60. aBarChartView +-- BarChartView new. aBarChartView model: aDict. aBarChartView window: Rectangle fromUser. aBarChartView insideColor: Form white. aBarChartView borderWidth: 2. aBarChartView display
The next step is to create a viewing mechanism for FinancialHistory that groups together the bar charts for incomes and expenditures within a single view. Class FinancialHistoryView specifies a view that consists of

495
Financial History Views and Controllers

two views, the bar charts. It is a subclass of View, and adds no new variables.
class name superclass category class methods

FinancialHistoryView View , Financial Tools'

instance creation

open: aFHModel
" Create a standard system view of the FinancialHistory, aFHModel, that consists of two bar charts, one for expenditures and one for income. "

I aFHView aBCView topView I


" First create the top view that is a standard system view and provides the blue button menu for moving, framing, collapsing, and closing the view." topView +- StandardSystemView new. topView model: aFHModel. topView borderWidth: 2. topView insideColor: Form lightGray. topView label: ' Financial History' . " Create the FinancialHistoryView and make it fill the top view. " aFHView +- self new model: aFHModel. topView addSubView: aFHView. "Create the bar chart of expenditures and place it inside the FinancialHistoryView. Its interior should be white, its border 2 pixels wide, and it should have no user interaction independent of the one provided for FinancialHistoryView. " aBCView +- BarChartView new model: aFHModel expenditures. aBCView window: (10@10 extent: 35@35). aBCView insideColor: Form white. aBCView borderWidth: 2. aBCView controller: NoController new. aFHView addSubView: aBCView. " Create the bar chart of incomes similar to that of the one for expenditures. " aBCView +- BarChartView new model: aFHModel incomes. aBCView window: (55 @10 extent: 35 @35). aBCView insideColor: Form white. aBCView borderWidth: 2. aBCView controller: NoController new. aFHView addSubView: aBCView.

496
Financial History Views and Controllers

" Standard system views have standard system controllers that respond to the message open by asking the user to designate the rectangular area in which the view will be displayed. " topView controller open
instance methods

controller access

defaultControllerClass " Answer the name of the class that provides the usual user interaction for this class. " i FinancialHistoryController

Note that the last method, defaultControllerClass, specifies that the user interaction for a FinancialHistoryView is handled by a FinancialHistoryController. You will not be able to add this method to the system until you declare the class FinancialHistoryController, as follows. A MouseMenuController is a system controller that provides the mechanisms for storing and retrieving pop-up menus. FinancialHistoryController is like this class except it provides a particular yellow button menu for items spend and receive. When these items are chosen, the corresponding messages, spend and receive, will be sent to the FinancialHistoryController.
class name superclass class variable names category class methods

FinancialHistoryController MouseMenuController , FHYellowButtonMenu FHYellowButtonMessages' , Financial Tools'

class initialization

initialize " Specify the yellow button menu items and actions. "

FHYellowButtonMessages ..... #(spend receive). FHYellowButtonMenu ..... PopUpMenu labels: 'spend receive'

497
Financial History Views and Controllers
instance methods

initialize-release

initialize " Make certain that the instance knows about the menu items. " super initialize. self initializeYeliowButtonMenu

menu messages

receive " Ask what amount is being received for what reason, and then update the FinancialHistory accordingly. Use the prompter, a FillinTheBlank, to obtain the needed information. (Note that comma is the String concatenation operator. Also note that no special care is being taken to make sure that the number is a positive one-perhaps you might want to add this condition.) "

I spendOn amount I spendOn ..- FilllnTheBlank request: ' Receive from what?' . spendOn isEmpty ifTrue: [tself]. amount ..- FiIIlnTheBlank request: ' How much from' , spendOn,' ?' . amount isEmpty ifTrue: [1self]. amount +- Number readFrom: (ReadStream on: amount). model receive: amount from: spendOn
spend " Ask what amount is being spent for what reason, and then update the FinancialHistory accordingly. Use the prompter, a FillinTheBlank, to obtain the needed information. (Note that comma is the String concatenation operator. Also note that no special care is being taken to make sure that the number is a positive one-perhaps you might want to add this condition.). "

I spendOn amount I spendOn ..- FilllnTheBlank request: ' Spend for what?' . spendOn isEmpty ifTrue: [1self]. amount ...... FiIIlnTheBlank request: ' How much for' , spendOn,'?' . amount isEmpty ifTrue: [tself]. amount +-- Number readFrom: (ReadStream on: amount). model spend: amount for: spendOn

498 Financial History Views and Controllers

control defaults isControlActive " sensor, declared as an instance variable in the superclass Controller, is an instance of InputSensor. It can determine the cursor location, and whether mouse buttons or keys on the keyboard are pressed. "
1super isControlActive & sensor blueButtonPressed not

private initializeYeliowButtonMenu " yellowButtonMenu:yellowButtonMessages: is specified in the superclass MouseMenuController; the response is to create the correct menu image and corresponding messages. " self yellowButtonMenu: FHYellowButtonMenu
yellowButtonMessages: FHYellowButtonMessages

After defining the class FinancialHistoryController, remember to define the message defaultControllerClass in FinancialHistoryView. To initialize the menus before trying to use the class, you evaluate the expression
FinancialHistoryController initialize

You can then evaluate


FinancialHistoryView open: HouseholdFinances

in order to tryout the user interface as shown in the figures. These classes are offered as initial ideas with which you can play. There are several modifications to try. Make certain that only the part of the view that needs to redisplay does whenever there is a change. Try to change the user interface to the bar chart so that you can point to a bar and ((drag" it up in order to change the value in the Dictionary (that is, instead of providing NoController as the user interface to a BarChartView, create a new controller that handles the user red button actions). Be careful that the scale on the axis of the chart is appropriate for such action. Try to create viewing mechanisms that display pie charts or graphs instead of bar charts. Make a view in which the expenditures or incomes are shown as both graphs and bar charts, and make certain that both views update correctly when the Dictionary changes.

Appendix 2 Smalltalk-80 Software Development Do's and Don'ts

As a software engineer at Xerox Special Information Systems (XSIS), I am responsible for the ongoing support of the Xerox 1100 Scientific Information Processor Smalltalk-80 System. I participate in the development of Smalltalk-80 virtual machine implementations and virtual image releases. In the past, as a member of the Publishing Systems Department, I developed an experimental interactive page make-up editor with the Smalltalk-76 programming environment (precursor to the Smalltalk-80 system). I also observed and supported the development of two major applications with the Smalltalk-80 system at XSIS. As a result of these experiences, I would like to share with you several important udo's and don'ts" for Smalltalk-80 software development.

First and foremost: Do read the documentation. Perhaps this statement should be printed on the cover, or even emblazoned on your machine, rather than located at the end of a book that you have probably just finished reading! Early Smalltalk-76 and Smalltalk-80 development projects at XSIS began with seasoned software engineers who had no prior experience with Smalltalk programming, nor did they have offline documentation. Their success in the beginning should be credited to their programming background, but also to the user support provided in the Smalltalk-80 environment. However, several system features and techniques that would have simplified their development efforts were not discovered until well into the projects, when early versions of this book became available. Change management, system tracing, and performance analysis were several useful tools that they had not discovered on their own.
499

500
Appendix 2

Before embarking on your first Smalltalk-80 development project: Do understand the basic language concepts. The basic language concepts are outlined in Chapter 5 of this book and summarized in Section 5.5. This recommendation may seem obvious, but it is so easy to develop software by copying and editing existing system code. Often the new programmer, anxious to use the system, starts programming before learning about the object and message-sending metaphor of the Smalltalk-80 language. Whether your development team consists of one person, or many: Do understand and use the change manager. The change manager is one of the most important tools for software development in the Smalltalk-80 environment. It is described in Section 23.2 ((The System Change Set" and Section 23.3 ((The System Audit Trail." This facility tracks and helps you to maintain all changes you have made to the system. It allows you to selectively browse them, remove them, incorporate them into another version of the system, check for conflicts, and prepare the changes for release to other members of the development team or to end users. Should a system crash occur, the change manager can recover all changes since the system's state was last saved.

D At the outset of a project involving two or more programmers: Do assign a member of the team to be the version manager. Refer to Section 23.5 uVersion Management" to learn about the kinds of tools the version manager might create. The responsibilities of the version manager consist of collecting and cataloging code files submitted by all members of the team, periodically building a new system image incorporating all submitted code files, and releasing the image for use by the team. The version manager stores the current release and all code files for that release in a central place, allowing team members read access, and disallowing write access for anyone except the version manager. Much of this process can be automated.
In the course of software development: Do not modify system classes when subclassing is possible. It is more desirable to subclass an existing system class, using multiple inheritance when appropriate, rather than to modify system class definitions and behavior. There are two reasons for this. The first relates to managing changes. It is more difficult to track changes to system classes than it is to track changes that are concentrated in a single, user-defined subclass of a system class. The second reason involves compatibility with new system releases. It is more difficult to incorporate your software into a new version of the Smalltalk-80 image if your system changes conflict with changes in the new version, that are needed to improve the basic system rather than a specific application. There are indeed cases when it

501
Appendix 2

is appropriate to change system classes, but it is important to understand the potential impact before doing so.

that can be exploited in your applications. Refer to Part Two of this book ((How to Find Information in the System." Unlike traditional programming, about 90% of Smalltalk-80 programming typically consists of making relatively small modifications and enhancements to existing code. The programmer searches the system for classes and methods that demonstrate behavior similar to the desired functionality of the new application, and then extends the behavior through the mechanism of subclassing or copying and editing. Graphical interactive applications are created by extending the existing hierarchy of classes that support viewing and controlling behaviors.

o Do browse the system to find existing features

D Do not be at the mercy of the system; if you do not like something, change it. Several XSIS customers comment about various details of the system that they would prefer to have changed. Examples are the size of the system font or the functionality of a particular system view or the way a particular method is written. My response to these comments is to remind the customer that the system is designed so that they can easily and freely change it. This concept is a new one to many people because traditional programming environments carefully protect system code from modification. The Smalltalk-80 environment treats system code and user code alike. Mold the system into an environment that suits your needs. The researchers designed the system so that they could experiment with creating new systems; the changeability of all of the system parts is a necessary attribute of this research. The easy changeability of system code, of course, means that you can make changes that crash the system. Therefore, make certain you have saved your work before trying something that changes system code that you might not fully understand. For creating applications that can not be changed by the end user, you might want to try mechanisms for protecting the code-for example, hiding the existence of certain classes from your users. D Do share your creative ~goodies" with a friend. Your creativity will inevitably result in novel yet natural extensions to the environment. Michael Malcolm, an XSIS software engineer, did not like the way text selection was handled originally, so he cleverly enhanced the old technique and Shared it with other Xerox Smalltalk-80 programmers. It was such a useful extension to the system that it was incorporated into all subsequent releases. This ((goodie" became part of the system because he packaged it so that other programmers could easily file it into their images for experimentation, and because he announced its existence over the Xerox electronic network to ensure its broad availability.

502
Appendix 2

The Smalltalk-80 environment provides such a rich set of interactive software development tools that the programmer's time shifts from finding the path of least resistance through a complex web of system utilities to actually writing code. With this system, my belief that programming is an art is at last fulfilled.

o And finally: Do have fun!


Prepared by Evelyn Van Orden Xerox Special Information Systems

System Workspace Index

Expression in System Workspace


Create File System

Explanation and Reference


This is the code needed to initialize a file system when the Smalltalk-80 system is first installed. The example is for the Xerox Alto file system. The global variable Disk references the file directory. The global variable SourceFiles references the sources and changes files. See Section 22.4. The first element of SourceFiles is a FileStream on the sources file. See Sections 1.2 and 22.4. The second element of SourceFiles is a FileStream on the changes file. See Sections 1.2 and 22.4. The sources file should be read-only. The system VM-writer is used to update the sources file. See Section 23.4.

Disk .-- AltoFileDirectory new

SourceFiles -- Array new: 2

SourceFiles at: 1 put: (FileStream oldFileNamed: 'Smalltalk-80.sources')

SourceFiles at: 2 put: (FileStream oldFileNamed: 'Smalltalk-80.changes')

(SourceFiles at: 1) readOnly

503

504 System Workspace Index

SourceFiles

+-

Disk

+-

nil

When these variables are nil, it is assumed that no sources can be accessed so that the decompiler should be used when browsing class descriptions. In addition, no changes file (audit trail) will be maintained. See Section 22.4. Information about external files is found in Chapters 22 and 23. Read the class descriptions and expressions stored on a file. See Section 22.3. The information maintained in the system change set can be stored on a file. See Section 23.2. A view of the contents of a file can be created. See Section 22.2. While you are working in a project (Chapter 4), a set of class and method changes is maintained. See Section 23.2. Initialize the set of changes. See Section 23.2. Changed definitions for a particular class can be filed out. See Section 23.2. References in the set of changes to a particular class can be removed. See Section 23.2. View the current changes in a browser. See Section 23.2. View the current changes as a
SortedCollection. See Section 23.2.

Files

(FileStream oldFileNamed: 'fileName.st' ) fileln

(FileStream fileNamed: 'fileName.st') fileOutChanges

(FileStream fileNamed: 'fileName.st') edit

Changes

Smalltalk noChanges

(FileStream fileNamed: 'fileName.st') fileOutChangesFor: Stream

Stream removeFromChanges

Smalltalk browseChangedMessages

Smalltalk changes asSortedCollection

505
System Workspace Index

Inquiry

The system supports your making many inquiries about the relationships among the objects. See Chapters 8, 9, and 10. Like the menu item implementors in the message-selector subview of a browser. See Section lOA. Like the menu item senders in the message-selector subview of a browser. See Sections lOA and 12.2. Like the menu item senders in the message-selector subview of a browser, except constrained to the methods of a particular class. See Section lOA. Like the menu item senders in the message-selector subview of a browser, except accesses information about two message selectors rather than just one. See Section lOA. Obtain a message-set browser that provides access to all methods in the system that reference a particular literal found in Smalltalk. See Section lOA. Obtain a message-set browser that provides access to all methods in the system that reference a particular literal found in the pool dictionary TextConstants. See Section lOA. Obtain a message-set browser that provides access to all methods in the system that reference a particular literal found in one of Object's pool dictionaries. See Section lOA. Obtain a message-set browser on all methods such that, when the block is

Smalltalk browseAlllmplementorsOf: # messageSelector

Smalltalk browseAIICallsOn: # messageSelector

Collection browseAIICallsOn: #timesRepeat:

Smalltalk browseAIICallsOn: #at: and: #at:put:

Smalltalk browseAIICallsOn: (Smalltalk associationAt: # Transcript)

Smalltalk browseAIICallsOn: (TextConstants associationAt: #Centered)

Smalltalk browseAIICallsOn: (Object classPool associationAt: # DependentsFields)

Smalltalk browseAIISelect: [:meth I meth numLiterals > 40]

506
System Workspace Index

evaluated with the method as its argument, the result is true. See Section 10.4.
FileStream instanceCount

Answer the number of instances of the class that exist in the system. Create an inspector on the collection of all the instances of the class that exist in the system. Inspectors are presented in Chapter 8. Create an inspector on the pool of variables that the user tried to reference but that were found to be undeclared. See Section 6.1. Access objects that have been declared as dependents of one another (for example, a particular view is dependent on the object it views).
DependentsFields is a Dictionary, a class variable of Object in which knowledge about object dependencies is stored. It is sometimes referred to as a "soft field." Its keys are the objects that have other objects dependent on them.

FormView allinstances inspect

Undeclared inspect

Dependents

(Object classPool at: # DependentsFields) keys

(Object classPool at: #DependentsFields) keysDo: [:each I (each isKindOf: TextCollector) ifTrue: [each release]]

This is a useful expression for searching for a particular kind of object, here instances of TextCollector, that may have dependents. If there are dependents, they are sent the message release, that is, break the dependency. This is needed to make certain that undesired cyclic pointers are destroyed. Names in Smalltalk other than classes and pools.

Globals

507
System Workspace Index

Disk Sensor

A FileDirectory.

An InputSensor. See example uses in Section 6.4 and Chapter 21. A DisplayScreen. See example uses in Sections 6.4 and 11.3. A ControlManager. See Section 2.5. A TextCollector. See Section 3.4. This single instance of ProcessorScheduler coordinates the use of the physical processor by all processes requiring service.
Array of FileStreams. See Section 22.4.

Display

ScheduledControllers Transcript Processor

SourceFiles SystemOrganization

A SystemOrganizer, the basis of the hierarchical indexing for the system browser. See Chapter 9.

Pool Dictionaries
Smalltalk

A SystemDictionary in which reference to all global variables, especially classes, is maintained. See Sections 6.1 and 10.4. A pool dictionary known to AltoFile, AltoFileDirectory, and AltoFilePage. A pool dictionary known to
ExternalStream, File, FileDirectory,

AltoFilePool

FilePool

and FilePage.
TextConstants

A pool dictionary known to


ArrayedCollection, CharacterBlock, CharacterBlockScanner, CharacterScanner, CompositionScanner, DisplayScanner, DisplayText, Paragraph, ParagraphEditor, StrikeFont, TextLinelnterval, and TextStyle.

508 Systell1 Workspace Index

Undeclared

A global dictionary in which to store the names of variables the user improperly tries to reference. See Section 6.1. Remove a particular entry from the
Dictionary Smalltalk.

Smalltalk remove Key: #GlobalName

Smalltalk declare: #GlobalName from: Undeclared

Add a particular entry from


Undeclared to Smalltalk, effectively

declaring the variable. See Section 6.1.


Transcript show: (3+ 4) printString; cr

Display the result of evaluating 3 + 4 in the System Transcript, Transcript. See Section 3.4. For slow machines, some of the automatic selection that happens in the debugger and browsers can be turned off by evaluating this expression. Evaluate expressions to Display or to DisplayScreen to change the display area used by the system. Make the screen 1024 dots wide by 808 dots high. See Section 6.4. Make the screen 640 dots wide by 480 dots high. See Section 6.4. Take some measurements of the amount of space being used in the system. Evaluating these expressions typically takes a long time. Amount of memory - number of objects, number of words of data. See Section 20.3. Number of objects that can still be created. See Section 20.3. Amount of memory left for your programming. See Section 20.3.

Smalltalk frills: false

Display

DisplayScreen displayExtent: 1024 @808 DisplayScreen displayExtent: 640@480


Measurements

Smalltalk core

Smalltalk oopsLeft

Smalltalk coreLeft

509 System Workspace Index MethodContext instanceCount

Instances of MethodContext hold all the dynamic state associated with the execution of a CompiledMethod. In addition to their inherited state, this includes the receiver, a method, and temporary space in the variable part of the context. This expression is a way to determine the number of interrupted executions of a method that are known to the system. Amount of space left on your disk for files. Length of time in milliseconds it takes to evaluate the expression(s) in the block. Do an analysis of the performance of the expression(s) in the block. See Chapter 14. Examine the file on which a performance analysis has been stored. Recovering from system crashes is discussed in Chapter 23. Create a blank view for change recovery. See Section 23.3. Create a view for change recovery from a given file. See Section 23.3.

Disk freePages

Time millisecondsToRun: [SystemOrganization printString]

MessageTally spyOn: [Behavior compileAII]

(FileStream oldFileNamed: 'spy.results' ) edit

Change Management and Crash Recovery


ChangeListView open

ChangeListView openOn: (ChangeList new recoverFile: (FileStream oldFileNamed: ' fileName.st' )) ChangeListView recover

After a crash, create a view to browse changes since the last snapshot. See Section 23.3. Copy the most recent 5000 characters to the file named STBO.recent and open an edit window on it. See Section 23.3.

Smalltalk recover: 5000

Menu Command Index

abort accept

238,355,358

to compile 24, 26, 100-101, 164, 166, 174, 179,200,221,238,242,244,252,256,280, 284,303,308,310,320,324,333,346,364, 369,373,389,392,399,402,406,416,452 to store 37, 48, 134, 147, 156, 173-175, 180, 225-227, 233, 249, 254, 265, 268, 272, 278, 284, 303, 331, 339, 395, 439-440, 444, 448, 455, 460, 462, 471, 477 add category 173, 272 add field 156 add protocol 178,225-227,278, 284, 308 again 57, 58-59, 61, 179 browser 42, 43, 162, 218 cancel 37,131,134,180,282,444 category 475 check conflicts 472,477 check with system 472, 477 class 163, 168, 218, 278, 364, 475 class refs 175, 213, 303, 324 class var 355 class var refs 175, 211 close 20,40,48,72,132,146,238,261,379,426, 455 collapse 48 comment 174,249,303,324 continue 23 copy 58,60-61, 179 copy name 440 correct 379 correct it 355, 356, 358, 367 cut 58, 60-62, 179
510

debug 160,383,388,416 definition 174,252,333 display system changes 471,472 do all 471 do it 106, 107-110, 170, 179, 182,220,238,258,

260,282,288,354,364,416,422,471
edit all 173, 272 enter 42,68 exit project 42, 68 explain 180, 182 file 475 file in 440, 452, 455, 471 file it in 443, 450, 468 file list 42, 439 file out 172, 173, 177, 178, 292, 373, 432-433,

451, 471
forget 471 format 179, 244 frame 47,48 full stack 390, 392 get 443,444 get contents 440, 442, 444 global 355 hierarchy 174,200, 203-204 implementors 179, 199, 200, 204, 392 inpect 146,152,284,404,422 instance 163, 168, 224, 284, 321 inst var refs 174, 211 messages 179, 201, 203, 392 move 47, 179,264 no 20,36,40,48,126 paste 58, 61, 179 put 443,444,452,455

511 Menu Command Index

print it 106, 110, 154, 167, 179, 244, 364, 376, 386,396,403,406 print out 172, 174, 177, 178, 435 proceed 159, 379, 390, 392, 396, 409, 416, 451, 453,455 320, 358, 364, 369 proceed as is project 42, 68, 329 protocols 174, 225, 230 quit 22, 40, 43 Quit, without saving 23 references 157 recover last changes 471, 472 remove 156, 173, 175, 178, 179, 201, 227, 230, 272,442,479 remove all 471 remove it 472 rename 173, 175, 178, 227, 254, 272, 442, 446 restart 392, 399 restore all 471 restore display 42, 138, 170, 238 restore it 472 same 475

save 24, 43, 460 Save, then quit 23, 24, 462 selector 475 send 392, 416, 417, 426 senders 178, 196, 200, 204, 392 show category 474 show file 474 spawn 172, 174, 178, 180, 187-191 spawn all 471 spawn hierarchy 174, 192-193 spawn it 472 step 392,416-428 43, 65, 68, 204 system transcript system workspace 43, 44 temp 355, 362 type 475 undeclared 355 under 47 undo 58,62,175,179 update 173, 270 workspace 16, 35, 43, 68, 244 yes 20, 36, 40, 48, 72, 126, 173, 360, 367, 379

Subject Index

t 92, 104 Abelson, Hal

13B

ActionMenu 301, 315, 333, 83B, 346 activation stack 386 argument name 102 array B4, 103, 14B-150, 21B, 224-233, 237, 243, 274 assignment B9, 91, 103 audit trail 467-468, 477 binary message expression see message, binary Bit Editor 31,49 123, 131-139 block B7, 90, 91-92, 103, 208 argument 90-91, 103 BlockContext 384 see also block Boolean 91, 192, 313, 321, 325, 3B4

boot button 14 breakpoints 402-40B,416 brovvser 32,35,42,49,52,99-101,161-193, 218-244, 249,252, 274,3B1 see also Menu Command spawn; message-set brovvser; Project Brovvser; Protocol Brovvser Browser 167 button 11, 12 see also standard system view blue 20,26,47 red 16,20,23,26,34,52,122-124,133,474 yellow 16,lB,22,24,26,40 caret 52,66 see also text, selection
512

cascaded message expression see message, cascaded categories 100-101, 162-169, 173 class 268-272, 274 message 174, 178, 179, 225-233, 278-280 ChangeListView 158,409,472 changes 68, 101-102 see also file, changes change set 462-463, 467 classes 98 Change-Management Browser 467-477 Change-Set Brovvser 465-467, 472 character 80-84, 14B-150, 384 Checker 479 class 77-79, 102 see also browser; categories, class; class editing; variable, class abstract 203-204 definition 252 description 93-95, 100 hierarchy 162, 164, 174, 176 name 173-175,254-260 obsolete 479 references 175 template 100, 274-27B class brovvser 188 see also brovvser class editing adding new methods 233-24B adding protocol 224-232 categories 268-272 creating nevv class 274-27B modifying comments 249-250

513 Subject Index

class editing (cont.) 218-223 modifying existing methods renaming see renaming variable declarations 260-268 192-193 class hierarchy browser see also browser; hierarchy click 12, 13, 26, 258, 261 see also button; text, selection 12, 26, 53-56 double single 52 CodeView 301, 306-310, 315, 316, 323, 325, 329, 337 192, 203, 384 Collection 279-293 Commander commands see menu comments 85, 162, 166, 174, 196, 203, 249-250 31 compactor compilation 98-101, 116, 221, 393 see also Menu Command accept complimenting 32 see also highlighting confirmer 20, 27, 31, 36, 37, 40, 48, 49, 72, 173, 175,178,230,356,360,367,379 conflict analysis 471-472, 477 control keys see text editor 7, 27, 46-47, 413 control manager 91-92, 372 control structures conditional selection 61, 91 conditional repetition 91 Controller 98 cursor 4, 23, 27, 30-31, 34, 39, 40,49, 108 crossHair 133 eyeglasses 134, 444 26, 108, 261 execute hourglass 26, 108,444 writing pen 444,452 Cursor 31,32,134,137,221,267 data structures 95-96 debugger 160, 383, 386-400, 416, 450-451, 455 debugging 65, 107, 147, 385-400 see also debugger; inspector; notifier decompilation 98, 458 delimiters see text editor Dictionary 156-157 138 diSessa, Andrea' Display 114-116, 237-240, 261 display screen 2, 4, 7-10, 15, 122-126 see also graphics Display Object 136,261 DisplayScreen 114-115

documentation 111, 141-142, 162, 168, 481 see also browser; categories; comments; examples; explanations; menu; spelling correction; System Workspace; templates draw through 52, 66 see also text, selection editing class descriptions see class editing pictures see Bit Editor; Form Editor programs see class editing text see text editor error handler 411-414 see also debugger; notifier escape key 110 see also text, selection examples in the book see Commander;
FinancialHistory;

Project Browser; Protocol Browser in the system 168-171, 218-220 101-102, 116, 159-160, execution interrupt 401-414 evaluation within context of 396-400 notification of 375-384 explanations 180, 182-186 expression 80, 103 see also block; variable; message evaluation 18, 105-117, 452 see also Menu Command do it and print it file 4, 14-15, 96, 102, 126, 172, 431-458 changes 14, 24, 26, 27, 100, 457-458, 467-468 see also changes command 24 480 condensing sources and changes formats 435-436 see also retrieving information; saving information 14,24,26, 27, 464, 477-478 image see also snapshot remove 442 rename 442, 446-448 run 14,24 sources 14, 27, 100, 256, 457-458 see also SourceFiles file list browser 42, 49, 321, 439-449, 451

514 Subject Index

FileStream 293, 436, 439, 448, 450, 465 FilllnTheBlank 344

filters

474-475

364-388, 402, 406, 451, 463-464, 472 flashing 20, 26, 30, 34, 37, 49 font 61-63 see also text Form 31, 120-123, 126-127, 131-135, 139, 220-223, 237, 240, 261, 422-424 opaque 135, 139 Form Editor 31, 49, 120-131 formatting 179, 244 global variables see variable, global graphics see Bit Editor; Form; Form Editor; user interface; view gridding 124-130 see also Form Editor hardware systems 4-6, 100 hierarchy see class, hierarchy; Class Hierarchy Browser; Protocol Browser; Menu Command hierarchy and
FinancialHistory spawn hierarchy

highlighting 12, 30 text 32, 52, 57 see also text, selection identifier see selector; variable, name image file see file, image inspector 107-108, 144-158, 261-266, 282, 284-288, 355, 376, 386, 390, 403 see also debugger for dictionaries 156-157, 406 instance 77-79, 102 variable see variable, instance interface 76-77, 102-103 see also user interface interrupt system control-c 62, 159-160 keyboard 4, 7, 122-123, 134-135 keys 7 6, 103 keyword message expression see also message, keyword Krasner, Glenn 435 literal 80, 87, 103, 208 Masinter, L. 354

menu 2, 13, 18, 27, 49 cascaded 64 commands 104 fixed 35, 36, 163 iconic 120-123, 139 list 36, 37, 163 locked 37 pop-up 35, 36, 40, 201 selection 12, 36, 122 system see System Menu message 1, 27, 76, 102, 162 argument 103 binary 86-88, 103 cascaded 89, 103 expression 85-89 implementors see Menu Command implementors keyword 86-88,103 pattern 102 protocol see interface receiver see receiver selector see selector senders see Menu Command senders unary 86-88, 104 Message Browser 190-191 see also browser Message Category Browser 189-190 see also browser message-send 107, 116,376, 388-390, 409, 418-420 message-set browser 157,175,178-179,196-213, 256,260,392,465 MessageTally 296 metaclass 94-95 method 1, 27, 76, 92-93, 101, 102, 196 see also message-set browsr literals 208 primitive 103 template 101, 233, 280 value of 92 mouse 4,11,27,52 see also buttons images 12, 13 nil 109, 116, 301, 355, 396, 479 notifier 159-160,238, 252, 261, 376, 383, 386-388, 402, 404, 409, 411, 416 number 81 object 1, 27, 76-80, 103

515
Subject Index

Object 95, 156, 192, 301, 310, 319, 321, 323, 388, 436 object-oriented programming 1 OrderedCollection 203,204,240-241,310, 326,479 Papert, Seymour 138 paragraph see text; text editor parsing 88 pattern match 439,446 Pen 136-139, 164, 175-176, 180, 218-223, 354, 360, 416-424 see also Commander performance 296-297 Point 144, 146, 360 pointing device see mouse pool variable see variable, pool PopUpMenu 346 see also menu, pop-up 12,26 press see also button printing 172, 406, 436 see also Menu Command print out program editor see browser programming environment 76,99-102,354 project 2, 32, 42, 49, 67-73, 463 Project 337-344 Project Browser 73, 322-339, 342-346 prompter 24-27, 41, 49, 126, 173, 175, 178, 179, 225-227,254, 265, 278, 344, 446-448, 460-462, 471, 477 see also FilllnTheBlank 41 scheduled unscheduled 41 protocol see categories, message; interface Protocol Browser 189,300-322 pseudo-variable 95 see also self; super Putz, Steve 477, 480 quitting see stopping procedures receiver 85-86, 103 context of 394-395 recovery 175,468 see also changes; Change Management browser; snapshot Rectangle 109-110,114,144-145,151-155,237,249 rectangle de8ignation 16, 34, 123-124, 133, 146, 180

release 12, 26 see also buttons renaming see also Menu Command rename 174-175, 254-260 class name message selector 200-201 retrieving information see also recovery pictures 126 programs 376, 442, 450-457, 465 text 442,443 run file see file, run running out of space 409-411 runtime errors 375-384 24, 43, 373, 411 saving information see also snapshot pictures 126, 132 programs 172-174, 177-178, 292-293, 432-435 system changes 462-465 system state see snapshot ScreenController 346, 348 scroll bar 11, 27, 37-40, 46, 108 scrolling 38-40 see also scroll bar for selection 56 selection see menu, selection; text, selection; view, selection SelectionlnListView 301, 306-310, 316, 323, 325 selector 85-86, 103, 201 self 95, 104, 116, 145, 147, 282, 367, 394 Sensor 115-117, 261, 422 SequenceableCollection 204,218,240-244 Set 203 4 side comments single-step execution 392, 415-428 see also debugging Smalltalk 94, 108-110, 117, 136, 156, 206-208, 260,296-297,355,411,463-465,480 snapshot 23,26, 411, 460-462, 467-468 SourceFiles 458, 460 sources see file, sources spawning 180 see also Menu Command spawn spelling correction 107, 353-362, 367, 381 spy 296-297 standard system view 7, 28, 32,37, 46, 127, 133,439 47-48 blue button menu StandardSystemController 307

516
Subject Index

301, 306-309, 337 StandardSystemView 13,457-458 start up procedures static checks 479 stopping procedures 22, 43 StrikeFont 62 see also font String 83, 241, 244, 310, 329, 339, 396 subclass 78, 95, 103, 256 see also class 7, 27 subview super 95, 104, 156 superclass 95, 103 see also class specifying name of 252-254 83, 104 symbol syntax errors 101, 106-107,238,363-374, 450-457 syntax error view 451-457 system classes 95-99, 103 image 478-479 see also file, image sources 142 System Browser see browser System Category Browser 187 see also browser System Menu 37, 40-43, 65, 346-349 System Transcript 32,43, 49, 65, 196, 199, 204, 252, 256, 266, 355, 392, 406, 412-414, 450, 466, 480 System Workspace 32,43,45,49, 111-112, 117, 206, 260, 411, 450 SystemDictionary see Smalltalk SystemTracer 99,478-479 Teitelman, W. 354 templates 100-101, 106, 111, 162-166, 233, 279 see also System Workspace temporary variable see variable, temporary testing 244, 282, 292 see also debugger; inspector text buffer 60 copy 52, 57-58, 60-61 delete 52,57-59 font 52 insert 57-58 move 60-61 paste 58 replace 52, 57-58 search 59,61 selection 18, 30, 52-58, 63, 66, 159-160 Text 329

text collector 65 see also System Transcript text editor 6, 51-66, 163, 179 see also text buffer 58 commands 57-64, 179-180 control keys 61 delimiters 54, 63-64 TextStyle 62-63 see also font; text editor, control keys TextView 316 transcript see System Transcript Transcript 65, 112, 117, 406 typing 46 see also keyboard; keys; text editor unary message expression see message, unary Undeclared 110, 355 UndefinedObject 355 user interface 1, 76, 158, 300-301 classes 98, 158 components 15 user interrupts 409-410 variable see also class definition; inspector class 94, 102, 175, 266-267, 355 global 65,68,93-94, 102, 109, 111, 355 instance 94, 102, 174, 260-266 name 85,104 pooled 94, 103, 267-268 pseudo-variable 104, 372 references 211 temporary 92-94, 103, 220, 354, 355, 426 undeclared 107, 110, 252 version management 480-483 view 2, 7, 11, 37, 48, 68, 337 see also browser; inspector active 11, 28, 45 close 20 collapsed 7, 28 deselection 45 inactive 32, 45 overlapping 47 selection 30, 32, 45 View 98, 136, 158, 307 visual cues 2, 37 window see view workspace 16, 18-21, 32, 34, 36, 43, 45, 46, 52, 106,261,292,354,376,409 see also System Transcript; System Workspace Xerox 14,23-24,154, 172-174, 177,432

Hit NotltlerVlew(StandardSystemV/ew. contaIns


UH\~ NotifierController(Controller)viewHasCursor

ni~~~ NotitierView(Sta.ndardSystemView)labeIDispla [H[~ d'ISP I a ve d t ex, t" :.:.:.: . .. . ')) . P


0

lUi! NotitierController(MouseMenuControllerp>contrc
align: aPoint 1 with: aPoint 2
Answer a new Quadrangle translated b)/ aPoint2 - aPoint 1,
II II

Hn

\\jH

iii!!!

I newSelector I
newSelector ~

nHn

(\(U(\ .:.:.:.: tH j)j)i)n

See Section 22.3


1"'

Quadrangle region: (super transla te8y: aPoint2 -

aPoint 1) border'.. . . . idth: borderWidth borderColor: borderColor insideColor: insideColor

See Chapters 19 and 21


O@O corner: 92@20

~~~Mrn~
"aj:)'~Tn't'

O@20

See Chapter 8

"aController may contain changes that ha. ven't a.lrea.d)... been accepted" topView textView \ (topVie\.v ~ self model: aBro . . v ser label: 'System Bro\vser' minimumSize: 200@ '150)

;.;.;.;.;

..

See Section 22.2

See Section 22.2 and 23.3

example "Draws a spiral in gra)l with a pen tha t is 4 pixels wide."

class

I bic I
bic ~ Pen new. bic mask: Form IightGray. bic defaultNib: 4. bic combina tionRule: Form under.

See Section 23.2

See Section 23.3

Srnalltalk-SQ The Interactive PrQgramming Environment provides an introduction to the user interface to the Smalltalk-SO system - a persona~ integrated, interactive programming environment.

The book is divided into five parts. Part One introduces the user interface to the Srnalltalk-80 system. Part Two is an explanation of the support provided for finding information about objects that exist In the Smalltalk-80 system Part Three provides an lustrated description of how to explore the class descriptions available in the system, and of how to use the editors for implementing new class descriptions. Part Four presents the support available for finding and correcting errors, while Part Five introduces access to external flies and such system housekeeping support as crash recovery and change management. The book is written to encourage specific practice and exploration. A brief introduction 'to the Smalltalk-80 language is also provided in order to explain the ways in which the user interface components prOVide access to the language components. For a more In-depth understanding of the lang4,age, readers may use this book in conjunction with Smalltalk-SQ The Lang~ and its Implementation by Adele Goldberg and David Robson (Addison-Wesley, 1983~ which includes reference material for the system classes.
Adele Goldberg is Manager of the Software Concepts Group at the Xerox Palo Alto Research Center (PARC~ the team responsible for the development of the Smalltalk-80 system. This is one of a series of four books documenting the history, development, nature, and implementation of this revolutionary programming environment. Other books in the Addison-Wesley Smalltalk-SO series Smalltalk-80: The Language and its Implementation (11371-6) Smal)talk-80: Bits of History, Words of Advice (11669-3) Smalltalk-80: Creating a User Interface and Graphical Applications (11370-8)
I

.,

t
I

II

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy