perm filename BAIL.DOC[DOC,AIL]11 blob sn#186793 filedate 1975-11-15 generic text, type C, neo UTF8
COMMENT ⊗   VALID 00031 PAGES
C REC  PAGE   DESCRIPTION
C00001 00001
C00005 00002
C00007 00003	BAIL -- A debugger for SAIL                         TABLE OF CONTENTS
C00011 00004	BAIL -- A debugger for SAIL                              INTRODUCTION
C00016 00005	BAIL -- A debugger for SAIL                              INTRODUCTION
C00021 00006	BAIL -- A debugger for SAIL                              INTRODUCTION
C00024 00007	BAIL -- A debugger for SAIL                                  EXAMPLES
C00026 00008	BAIL -- A debugger for SAIL                                  EXAMPLES
C00027 00009	BAIL -- A debugger for SAIL                                  EXAMPLES
C00030 00010	BAIL -- A debugger for SAIL                                  EXAMPLES
C00032 00011	BAIL -- A debugger for SAIL                                  EXAMPLES
C00035 00012	BAIL -- A debugger for SAIL                                  EXAMPLES
C00037 00013	BAIL -- A debugger for SAIL                                  EXAMPLES
C00040 00014	BAIL -- A debugger for SAIL                                  EXAMPLES
C00041 00015	BAIL -- A debugger for SAIL                                  EXAMPLES
C00043 00016	BAIL -- A debugger for SAIL                                  EXAMPLES
C00045 00017	BAIL -- A debugger for SAIL                                  EXAMPLES
C00047 00018	BAIL -- A debugger for SAIL                       COMPILE-TIME ACTION
C00051 00019	BAIL -- A debugger for SAIL                       COMPILE-TIME ACTION
C00055 00020	BAIL -- A debugger for SAIL                           RUN-TIME ACTION
C00059 00021	BAIL -- A debugger for SAIL                           RUN-TIME ACTION
C00063 00022	BAIL -- A debugger for SAIL                           RUN-TIME ACTION
C00065 00023	BAIL -- A debugger for SAIL                           RUN-TIME ACTION
C00068 00024	BAIL -- A debugger for SAIL                           RUN-TIME ACTION
C00070 00025	BAIL -- A debugger for SAIL                           RUN-TIME ACTION
C00073 00026	BAIL -- A debugger for SAIL                           RUN-TIME ACTION
C00076 00027	BAIL -- A debugger for SAIL                            RESOURCES USED
C00079 00028	BAIL -- A debugger for SAIL                            CURRENT STATUS
C00082 00029	BAIL -- A debugger for SAIL                            CURRENT STATUS
C00084 00030	BAIL -- A debugger for SAIL                            CURRENT STATUS
C00086 00031	
C00087 ENDMK
C⊗;



                     BAIL -- A debugger for SAIL



                           John F. Reiser
                     Computer Science Department
                         Stanford University


                            November 1975










                              ABSTRACT

BAIL is a debugging aid for SAIL programs, where SAIL is  an extended
dialect of ALGOL60 which runs on the PDP-10 computer.   BAIL consists
of a breakpoint package and an expression interpreter which allow the
user to stop his program  at selected points, examine and  change the
values  of  variables,  and evaluate  general  SAIL  expressions.  In
addition, BAIL can display text from the source file corresponding to
the current location  in the program.  In  may respects BAIL  is like
DDT or  RAID, except  that BAIL  is oriented  towards SAIL  and knows
about   SAIL  data   types,  primitive   operations,   and  procedure
implementation.







This  work was  supported in  part by  a National  Science Foundation
graduate  fellowship.   Computer  facilities  provided   by  Stanford
Artificial Intelligence Laboratory and by Institute  for Mathematical
Studies in the Social Sciences, Stanford.
BAIL -- A debugger for SAIL                         TABLE OF CONTENTS


  
                  T A B L E   O F   C O N T E N T S
                  _ _ _ _ _   _ _   _ _ _ _ _ _ _ _



SECTION                                                          PAGE


1    INTRODUCTION                                                   1


2    EXAMPLES                                                       4


3    COMPILE-TIME ACTION                                           15


4    RUN-TIME ACTION                                               17

     1    Debugging Requests                                       17
     2    ARGS                                                     18
     3    BREAK                                                    18
     4    COORD                                                    19
     5    DDT                                                      19
     6    HELP                                                     19
     7    SETLEX                                                   19
     8    SHOW                                                     20
     9    TEXT                                                     20
     10   TRACE                                                    20
     11   TRAPS                                                    21
     12   UNBREAK                                                  21
     13   UNTRACE                                                  21
     14   !!GO                                                     21
     15   !!GSTEP                                                  21
     16   !!STEP                                                   22
     17   STRING TYPEOUT                                           22
     18   BAIL and DDT                                             22
     19   WARNINGS                                                 23

5    RESOURCES USED                                                24


6    CURRENT STATUS                                                25
BAIL -- A debugger for SAIL                              INTRODUCTION


                             SECTION  1
                             _______  _

                            INTRODUCTION
                            ____________




The ideal way to debug a computer program is to write it correctly in
the  first place  and not  debug it  at all.   Experience  has shown,
however, that most programs of moderate size contain errors, and that
debugging is  a significant part of  software production.  BAIL  is a
tool  which is  designed to  be useful  for interactive  debugging of
programs written in SAIL  [4], a high-level ALGOL-based  language for
Digital Equipment Corporation (DEC) PDP-10 computers.

In  the very  early days  of  computing, debugging  was  done at  the
console  of  the  computer.    The  programmer manipulated  switches,
observed lights, and had complete control of the whole machine.   The
programmer could examine and change  any location in memory and could
start,  stop, and single-step the processor.   Console debugging soon
became uneconomical on medium and large-scale machines.   It is still
used on  minicomputers.   This type of  debugging is at  the machine-
language level; the lights and switches are direct representations of
bits inside the machine.

Debugging moved to  the assembly language level with  the development
of  interactive  time-sharing  systems  in  the  early 1960's.    The
programmer typed commands at a terminal, and a collection  of special
subroutines interpreted the  commands so that the  effect was similar
to  working at the console of the  machine.  Instead of communicating
in bits, the programmer and subroutines used character strings in the
format  of  octal   and  decimal  integers,  text,  symbolic  machine
instructions, and  symbolic addresses.   One  of the  most  important
features of  the debugging routines  was the  ability to suspend  the
execution  of   the  program  being  debugged,  enter  the  debugging
routines, communicate with the programmer, resume execution, and make
the  whole process  invisible to  the program  being debugged.   This
process  became known as  breakpointing; the location  where the main
program was stopped is  a breakpoint, and the debugging  routines are
called  a breakpoint  package.   The  premier example  of  a symbolic
debugging package is DDT [1], developed for use on the DEC PDP-1  and
subsequently extended for use  on the PDP-6 and PDP-10.   DDT and its
derivatives  are still  among the most  powerful tools  for debugging
assembly language programs.

BAIL is a high-level breakpoint package for  use with  SAIL programs.
(Swinehart  [3] and Satterthwaite  [2] contain  descriptions of other


                                  1
BAIL -- A debugger for SAIL                              INTRODUCTION


high-level debugging systems.)  Communication between the  programmer
and BAIL  is in character strings  which are the names  and values of
SAIL  objects.   BAIL  reads general  SAIL  expressions typed  by the
programmer, evaluates them in the context of the place in the program
where execution  was suspended, and prints the  resulting value in an
appropriate format.  The  evaluation and printing are  performed just
as  if the  programmer  had  inserted  an extra  statement  into  the
original  program at the point  where execution was  suspended.  BAIL
also provides  a  way  to  talk  about the  program,  to  answer  the
questions  "Where  was  execution  suspended?",  "By  what  chain  of
procedure  calls did execution proceed to  that point?", and "What is
the text of the program?"

In order to perform these functions, BAIL  must have some information
about  the program being  debugged.   The SAIL compiler  will produce
this information if the program is compiled with an appropriate value
supplied for the /B switch.  (See the technical portion of the manual
for  the  exact  meaning  of the  various  switch  values.)  In these
examples the compiler produces two files.  File PROG.REL contains the
relocatable code and  loader instructions, and file PROG.SM1 contains
the information for BAIL.   The PROG.SM1 information consists of  the
name,  type,  and   accessing  information  for  each   variable  and
procedure, the  location of the beginning and  end of each statement,
and a description of the block structure.

The code for BAIL itself is loaded  automatically when the program is
loaded.   In  order  for the  added  information and  code  to  be of
any  use,  it  must be  possible  to   give control  to  BAIL  at the
appropriate  time.    An  explicit  call   to  BAIL   is  possible by
declaring EXTERNAL  PROCEDURE  BAIL;  in the   program and  using the
procedure call  BAIL;.  This  works well  if it  can be  predicted in
advance  where BAILing  might be  helpful.  Runtime  errors,  such as
subscript overflow or CASE index errors, are not as  predictable; but
responding  "B"  to  the SAIL   error  handler  will   activate BAIL.
Interrupting  the  program  while it   is running  (to  investigate a
possible infinite loop, for example) can be achieved under  the TENEX
operating system  by typing control-B.    On a DEC  TOPS-10 operating
system, first  return to monitor mode by typing one or  more control-
C's, then activate BAIL by typing DD<cr>.

BAIL performs some initialization the first time  it is entered.  The
information  in the .SM1  file(s) is  collected and processed  into a
file PROG.BAI.  This  new file reflects  all of the information  from
the  .SM1   files  of  any  separately-compiled   programs,  and  the
relocation  performed by the loader.  If  the core image was SAVEd or
SSAVEd then in subsequent runs BAIL will use the .BAI file and bypass
much of the initialization.


                                  2
BAIL -- A debugger for SAIL                              INTRODUCTION


BAIL prompts the programmer for input by typing a number and a colon.
The number indicates how many times BAIL has been entered but not yet
exited, and thus is the recursion  depth inside BAIL.  Input to  BAIL
can be  edited using the  standard SAIL input-editing  characters for
the  particular operating system under which  the program is running.
[BAIL requests input via INCHWL on DEC TOPS-10 systems  and via INTTY
on TENEX systems.] Input is terminated whenever the editor activates,
string  quotation  marks  balance,  and  the  last  character  is   a
semicolon; otherwise  input lines  are concatenated  into one  string
before being processed further.

The  programmer may  ask  BAIL to  evaluate  any SAIL  expression  or
procedure call whose  evaluation would be legal at the point at which
execution of the  program being debugged  was suspended (except  that
expressions  involving  AND,  OR,  IF-THEN-ELSE,  and  CASE  are  not
allowed.)  BAIL evaluates the expression,  prints the resulting value
in an appropriate format, and requests further input.

Declared inside  BAIL  are several  procedures whose  values or  side
effects are useful in the debugging process.  These procedures handle
the insertion  and deletion of  breakpoints, display  the static  and
dynamic scope of the  current breakpoint, display selected statements
from  the  source  program, allow  escape  to  an  assembly- language
debugging  program,  and  cause  resumption  of  the  suspended  main
program.  These procedures are described in the technical  portion of
the manual.

The following examples illustrate  many of the features  available in
BAIL.  Text was recorded from an actual session on the computer.




















                                  3
BAIL -- A debugger for SAIL                                  EXAMPLES


                             SECTION  2
                             _______  _

                              EXAMPLES
                              ________




                                 This  is  a  test  program,  run  on
                                 TENEX.
@TYPE TEST1.SAI

;  <REISER>TEST1.SAI;1   SAT 10-MAY-75 2:37PM         PAGE 1


BEGIN "TEST"
EXTERNAL PROCEDURE BAIL;

INTEGER I,J,K;
STRING A,B,C;
REAL X,Y,Z;
INTEGER ARRAY FOO[0:15]; STRING ARRAY STRARR[1:5,2:6];
INTEGER ITEMVAR DAY; ITEMVAR QQ;

INTEGER PROCEDURE ADD(INTEGER I,J); BEGIN "ADD"
OUTSTR("
HI. GLAD YOU STOPPED BY."); RETURN(I+J) END "ADD";

RECURSIVE INTEGER PROCEDURE FACT(INTEGER N); BEGIN "FACT"
RETURN(IF N LEQ 1 THEN 1 ELSE N*FACT(N-1)) END "FACT";

SIMPLE PROCEDURE SIMPROC(REFERENCE INTEGER M); BEGIN "SBEG"
ADD(M,M←32) END "SBEG";

FOR I←0 STEP 1 UNTIL 15 DO FOO[I]←I*I;
FOR I←1 STEP 1 UNTIL 5 DO
    FOR J←2 STEP 1 UNTIL 6 DO
        STRARR[I,J]←64+8*I+J;
I←4; J←6; K←112;
A←"BIG DEAL"; B←"QED"; C←"THE LAST PICASSO";

X←3.14159265; Y←0; Z←23.;

BAIL;

ADD(7,45);
SIMPROC(J);

USERERR(0,1,"THIS IS A TEST");

                                  4
BAIL -- A debugger for SAIL                                  EXAMPLES


END "TEST";
↑L















































                                  5
BAIL -- A debugger for SAIL                                  EXAMPLES


                                 Compile and load with BAIL.
@SAIL.SAV;10
 TENEX SAIL 8.1 4-4-75  (? FOR HELP)
*TEST1,←
**/27B
**
TEST1.SAI;1 1
END OF COMPILATION.
LOADING

LOADER 6+9K CORE
EXECUTION

↑C

                                 Save the core image for later use.
@SSAVE (PAGES FROM) 0 (TO) 577 (ON) TEST1 [NEW FILE]
 [CONFIRM]

                                 Start the program.
@START

                                 BAIL identifies itself and the files
                                 involved.
BAIL VER. 10-MAY-75
TEST1.SM1;2
  TEST1.SAI;1
End of BAIL initialization.

1:45;

                                 The  "1:"  is  BAIL's   prompt.   It
                                 indicates  the  level  of  recursive
                                 invocations  of  BAIL  and  the fact
                                 that BAIL is awaiting input.

                                 See  how constants  are  entered and
                                 printed.  The "45;<cr>" is  typed by
                                 the user, and the next line  "45" is
                                 BAIL's reply.
   45
1:7.089;
    7.089000
1:"SOME RANDOM STRING";
   "SOME RANDOM STRING"

                                 An octal  constant; all  printout is
                                 decimal.

                                  6
BAIL -- A debugger for SAIL                                  EXAMPLES


1:'275;
   189

                                 Symbolic  constants  More  than  one
                                 expression requested
1:TRUE,FALSE,NULL;
   -1   0   ""

                                 Variables, assignment
1:I;
   4
1:J,X;
   6    3.141593
1:I←46;
   46
1:I;
   46

                                 Relational operators; remember  0 is
                                 FALSE.
1:I<J;
   0
1:I GEQ J;
   -1
1:98 LAND '17;
   2

                                 An undeclared identifier
1:XYZ;

UNKNOWN ID:  XYZ
                ;

                                 Usable as a desk calculator
1:45*(89.4-53.06);
    1635.300
1:X+J;
    9.141593

                                 Procedure call
1:ADD(3,4);

HI. GLAD YOU STOPPED BY.   7

                                 Argument list checking
1:ADD(3);

ADD TAKES 2 ARGUMENTS.:  ADD(3)

                                  7
BAIL -- A debugger for SAIL                                  EXAMPLES


                               ;

                                 Arrays.    Array  name   only  gives
                                 dimension   and   subscript   bounds
                                 information.
1:FOO;
   <ARRAY>[ 0:15]
1:FOO[4];
   16

                                 Substring notation has been extended
                                 to cover array elements.
1:FOO[5 FOR 3];
   25   36   49
1:STRARR;
   <ARRAY>[ 1:5 2:6]
1:STRARR[1 FOR 2, 4 TO 6];
   "L"   "M"   "N"   "T"   "U"   "V"

                                 Array accesses are interpreted
1:FOO[35];

SUBSCRIPTING ERROR.   INDEX    VALUE    MIN    MAX
                        1       35      0       15      :  FOO[35]
                                                                  ;

                                 LENGTH, LOCATION, and MEMORY
1:A;
   "BIG DEAL"
1:LENGTH(A);
   8
1:I;
   46
1:LOCATION(I);
   718
1:MEMORY[718]←64;
   64
1:I;
   64

                                 Substringing
1:A[2 TO INF];
   "IG DEAL"
1:B[3 TO 4];
   "D"

                                 Type-in  must  be  terminated  by  a
                                 semicolon

                                  8
BAIL -- A debugger for SAIL                                  EXAMPLES


1:B
;
   "QED"

                                 Tracing of procedure entry and exit
1:TRACE("FACT");

1:FACT(4);

 ENTERING FACT   4
  ENTERING FACT   3
   ENTERING FACT   2
    ENTERING FACT   1
    EXITING FACT=   1

   EXITING FACT=   2

  EXITING FACT=   6

 EXITING FACT=   24
   24
1:UNTRACE("FACT");

1:FACT(5);
   120

                                 Breakpointing
1:BREAK("ADD");

1:ADD(3,4);

                                 Now   one  level   deeper   in  BAIL
                                 recursion.     ARGS    prints    the
                                 arguments list.
2:ARGS;
   3   4

                                 Parameter  names evaluate  just like
                                 variables.
2:I;
   3
2:J;
   4
2:K;
   112

                                 To exit from one level of BAIL
2:!!GO;

                                  9
BAIL -- A debugger for SAIL                                  EXAMPLES


HI. GLAD YOU STOPPED BY.   7

                                 The message is from ADD  itself; the
                                 value 7 is from BAIL.

                                 Leave another level of BAIL.
1:!!GO;

                                 And come back again.  Where are we?
1:TEXT;

                                 Static block structure
LEXICAL SCOPE, TOP DOWN:
$RUN$
TEST
ADD

                                 Dynamic procedure  invocations.  The
                                 #4 means coordinate number 4.
DYNAMIC SCOPE, MOST RECENT FIRST:
ROUTINE         TEXT
ADD     #4      INTEGER PROCEDURE ADD(INTEGER I,J); BEGI
TEST    #24     ADD(7,45);
SIMPROC(J);

USERERR(0,1,"

1:ARGS;
   7   45

                                 Remove the breakpoint.
1:UNBREAK("ADD");

1:!!GO;

                                 Output  from  other  calls   in  the
                                 program
HI. GLAD YOU STOPPED BY.
HI. GLAD YOU STOPPED BY.
THIS IS A TEST
CALLED FROM 642124  LAST SAIL CALL AT 400303
↑B

                                 Entry to BAIL from the error handler
1:TEXT;

LEXICAL SCOPE, TOP DOWN:
$RUN$

                                 10
BAIL -- A debugger for SAIL                                  EXAMPLES


DYNAMIC SCOPE, MOST RECENT FIRST:
ROUTINE         TEXT
.SIMPLE.        '642124 %%% FILE NOT VIEWABLE
TEST    #26     USERERR(0,1,"THIS IS A TEST");

END "T

1:I;

UNKNOWN ID:  I
              ;

                                 The  static  scope needs  to  be set
                                 back one on the dynamic chain.
1:SETLEX(1);

LEXICAL SCOPE, TOP DOWN:
$RUN$
TEST

1:I;
   64
1:C;
   "THE LAST PICASSO"
1:!!GO;

END OF SAIL EXECUTION.






















                                 11
BAIL -- A debugger for SAIL                                  EXAMPLES


                                 Leap   and   records,   DEC  TOPS-10
                                 system.

.TYPE TEST2.SAI

BEGIN "TEST"
EXTERNAL PROCEDURE BAIL;
REQUIRE 500 SYSTEM!PDL, 10 PNAMES;

LIST L; SET S,S1,S2,S3,S4,S5;
INTEGER ITEM SUNDAY; ITEM MONDAY,TUESDAY,WEDNESDAY,THURSDAY,FRIDAY,
        SATURDAY;
INTEGER ITEMVAR DAY; ITEMVAR QQ;
ITEMVAR ARRAY P[1:10];

RECORD!CLASS CELL (RECORD!POINTER(CELL) CAR,CDR);
RECORD!POINTER(CELL) CX,CY;

CX←NEW!RECORD(CELL);
CY←NEW!RECORD(CELL);
CELL:CAR[CX]←NULL!RECORD; CELL:CDR[CX]←NULL!RECORD;
CELL:CAR[CY]←CX; CELL:CDR[CY]←NULL!RECORD;

P[1]←SUNDAY; P[2]←MONDAY;
L←{{SUNDAY}}; DATUM(SUNDAY)←0; DAY←SUNDAY;  QQ←MONDAY; S←{QQ};
S1←{SUNDAY,MONDAY,TUESDAY,WEDNESDAY,THURSDAY,FRIDAY,SATURDAY};
S2←{MONDAY,TUESDAY,WEDNESDAY,THURSDAY,FRIDAY};
S3←{MONDAY,WEDNESDAY,FRIDAY}; S4←{SATURDAY,SUNDAY};
S5←{SUNDAY,FRIDAY};

FOREACH DAY SUCH THAT DAY IN S1 DO MAKE DAY XOR SUNDAY EQV SATURDAY;

BAIL;

USERERR(0,1,"THIS IS A TEST");

END "TEST";


EXIT
↑C
.EXECUTE TEST2.SAI(27B,)
SAIL: TEST2  1
LOADING
LOADER 15K CORE
25K MAX 153 WORDS FREE
EXECUTION


                                 12
BAIL -- A debugger for SAIL                                  EXAMPLES


BAIL VER. 10-MAY-75
TEST2.SM1
  TEST2.SAI
END OF BAIL INITIALIZATION.

1:L;
   {{SUNDAY}}
1:S4;
   {SUNDAY, SATURDAY}
1:S5;
   {SUNDAY, FRIDAY}
1:S4 UNION S5;
   {SUNDAY, FRIDAY, SATURDAY}
1:FRIDAY IN S4;
   0
1:S2 LEQ S2;
   -1
1:DAY;
   SATURDAY
1:DATUM(DAY);
   0
1:CX;
   CELL.9231
1:CELL:CAR[CX];
   NULL!RECORD
1:CELL:CAR[CY];
   CELL.9231
1:SUNDAY ASSOC SATURDAY;
   {SUNDAY}
1:SUNDAY EQV SATURDAY;
   {SUNDAY, MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY}
1:SUNDAY XOR SATURDAY;
   PHI
1:SUNDAY EQV SUNDAY;
   PHI
1:↑C













                                 13
BAIL -- A debugger for SAIL                                  EXAMPLES


                                 Go back to the earlier example
@TEST1.SAV;1

                                 Initialization  uses   file  created
                                 last time.
BAIL ver. 10-May-75 using TEST1.BAI
End of BAIL initialization.

                                 Switch  /27B  at  compile-time makes
                                 SAIL  predeclared  runtime  routines
                                 known to BAIL.
1:OPENFILE(NULL,"W");
TODAY.TMP
   4
1:OUT(4,"THIS IS A TEMPORARY FILE CREATED WHILE IN BAIL.");

1:CFILE(4);
   -1
1:OPENFILE("","RC");
TODAY.TMP [OLD VERSION]
   4
1:SINI(4,200,"Z");
   "THIS IS A TEMPORARY FILE CREATED WHILE IN BAIL."
1:ODTIM(-1,-1);
   "SATURDAY, MAY 10, 1975 17:19:29"

                                 Quickie review of BAIL capabilities
1:?

EXPRESSION;
PROCEDURE!CALL;
TRACE("PROCEDURE");
UNTRACE("PROCEDURE");
BREAK("PROCEDURE, BLOCK, OR LABEL");
UNBREAK("PROCEDURE, BLOCK, OR LABEL");
!!GO;
SETLEX(LEVEL);
TEXT;
ARGS;
HELP;
DDT;
?

1:↑C

                                 End of the examples.



                                 14
BAIL -- A debugger for SAIL                       COMPILE-TIME ACTION


                             SECTION  3
                             _______  _

                         COMPILE-TIME ACTION
                         ____________ ______




The  principal  result  of activating  BAIL  at  compile-time  is the
generation of a file of information about the source program  for use
by the run-time interpreter.  This file has the same name as the .REL
file produced by the compilation, except that the extension  is .SM1.
If requested, BAIL will also generate some additional code for SIMPLE
procedures to make them more palatable to the run-time interpreter.

The action of BAIL at compile time is governed by the value of the /B
switch passed to the compiler.   If the value of this switch  is zero
(the  default  if no  value  is specified)  then  BAIL  is completely
inactive.  Otherwise, the low-order bits determine the  actions which
BAIL performs.  [The value of the /B switch is interpreted as octal.]

bit  action

1    If this bit is on,  then the .SM1 file will contain  the program
     counter to source/listing text directory.

2    If  this bit  is  on, then  the  .SM1 file  will  contain symbol
     information for all SAIL symbols encountered in the  source.  If
     this bit is off,  then information is kept only  for procedures,
     parameters,  blocks, and  internals; i.e.,  non-  internal local
     variables are not recorded.

4    If this  bit is  on, then SIMPLE  procedures will  get procedure
     descriptors, and one additional instruction (a JFCL 0,  which is
     the  fastest  machine  no-op  instruction)  is  inserted  at the
     beginning of SIMPLE  procedures.  Except for these  two changes,
     all properties of SIMPLE  procedures remain the same  as before.
     The procedure descriptor is necessary if the procedure is  to be
     called interpretively or if the procedure is to be TRACEd.

'10  If this bit  is on, then BAIL  will not be  automatically loaded
     and  initialized,  although  all  other  actions  requested  are
     performed.   This is  primarily intended  to make  it  easier to
     debug   new   versions   of   BAIL   without   interfering  with
     SYS:BAIL.REL.  By using this switch the decision to load BAIL is
     delayed until load time.

'20  If this  bit is  on, then  a request  to load  SYS:BAIPDn.REL is


                                 15
BAIL -- A debugger for SAIL                       COMPILE-TIME ACTION


     generated.  This file contains procedure descriptors for most of
     the  SAIL predeclared  runtime routines,  making it  possible to
     call  them  from  BAIL.   The  procedure  descriptors  and their
     symbols occupy about 6K.

The B switch must occur on the binary term, not the listing or source
term.  Thus:
        .R SAIL                 or      .COM PROG(27B,)
        *PROG/27B←PROG

The  program counter  to  source/listing index  is kept  in  terms of
coordinates.  The  coordinate counter is  zeroed at the  beginning of
the compilation and is incremented  by one for each BEGIN,  ELSE, and
semicolon seen by the parser, provided at least one word of  code has
been compiled since the  previous coordinate was defined.   Note that
COMMENTs  are seen  only by  the scanner,  not the  parser,  and that
DEFINEs and many declarations merely define symbols and do  not cause
instructions  to be  generated.   For each  coordinate  the directory
contains the coordinate number, the value of the program counter, and
a file pointer  to the appropriate  place.  The appropriate  place is
the source file unless a listing file is being produced and  the CREF
switch is off,  in which case it  is the listing file.   [The listing
file produced for CREF is nearly unreadable.] On a  non-CREF listing,
the program counter is replaced by the coordinate number if bit  1 of
the /B switch is on.

The symbol table information consists of the block structure  and the
name, access information, and type for each symbol.

If a BEGIN-END pair has  declarations (i.e., is a true block  and not
just a compound statement) but  does not have a name, then  BAIL will
invent one.  The name is of the form Bnnnn where nnnn is  the decimal
value of the current coordinate.
















                                 16
BAIL -- A debugger for SAIL                           RUN-TIME ACTION


                             SECTION  4
                             _______  _

                           RUN-TIME ACTION
                           ________ ______




The BAIL run-time interpreter is itself a SAIL program  which resides
on  the   system  disk   area.   This   program  is   usually  loaded
automatically,  and does  some  initialization when  entered  for the
first time. The initialization  generates a .BAI file  of information
collected from the .SM1  files produced by separate  compilations (if
any).  The  .SM1 files correspond  to .REL files,  and the  .BAI file
corresponds to the .DMP or .SAV file.  Like RPG or CCL, BAIL will try
to bypass much of the initialization and use an existing .BAI file if
appropriate.  During  initialization BAIL displays  the names  of the
.SM1  files it  is  processing.  For  each .SM1  file  which contains
program counter/text  index information, BAIL  displays the  names of
the text files and determines whether the text files are accessible.

The interpreter  is activated by  explicit call,  previously inserted
breakpoints, or the  SAIL error handler.   For an explicit  call, say
EXTERNAL PROCEDURE BAIL; ... BAIL;.  From the error  handler, respond
B.  Breakpoints will be described later in this section.



4.1 - Debugging Requests
      _________ ________


When entered, BAIL prints the debugging recursion level followed by a
colon, and awaits a  debugging request.  BAIL accepts ALGOL  and LEAP
expressions of the SAIL language.  A complete description is given in
[4] and in the addenda  describing the syntax of records  and record-
pointers.  The  following exceptions  should  be  noted.  Expressions
involving  control structure  are not  allowed, hence  BAIL  will not
recognize AND, OR, IF-THEN-ELSE, or CASE.  Bracketed triple items are
not allowed.   The TO  and FOR substring  and sublist  operators have
been extended  to operate  as array  subscript ranges,  FOR PRINT-OUT
ONLY.  If FOO is  an array, then FOO[3  TO 7]; will act  like FOO[3],
FOO[4],  FOO[5],  FOO[6],  FOO[7];  but  is  easier  to  type.   This
extension is for print-out  only; no general APL syntax  or semantics
are provided.

BAIL evaluates symbolic names according to the scope rules  of ALGOL,
extended to always recognize names which are globally unique and have


                                 17
BAIL -- A debugger for SAIL                           RUN-TIME ACTION


a fixed memory  location (everything except parameters  and recursive
locals).  For any activation of BAIL, the initial scope is  the ALGOL
scope of the statement from which BAIL was activated.   The procedure
SETLEX (see below) may be used to change the scope to that of any one
of the links in the dynamic activation chain.

Several procedures are predeclared  in the outermost block  to handle
breakpoints   and   display   information.    These   are   described
individually below.



4.2 - ARGS
      ____

STRING PROCEDURE ARGS;

The arguments to the procedure which was most recently called.



4.3 - BREAK
      _____

PROCEDURE BREAK("location","condition"(NULL),"action"(NULL),count(0))

BREAK inserts a breakpoint.  The syntax for the first argument is
        <location>::=<label>|<procedure>|<block name>|#<nnnn>
                        |<block name><delim><location>
        <delim>::=<any character not legal in an identifier>
        <nnnn>::=<decimal coordinate number>

If  the location  is specified  by the  <block name><delim><location>
construct then the blocks of the core image are searched in ascending
order of address of BEGINs  until the first <block name>  is matched.
The search continues until  the second <block name> is  matched, etc.
The breakpoint  is inserted  at the  label, procedure,  or coordinate
declared within the  scope of the  last <block name>.   This detailed
specification is  not usually  necessary, as  shown in  the examples.
The last three parameters are defaultable and need not  be specified,
again as in the examples.  The action taken at a breakpoint is

    IF LENGTH(condition) AND EVAL(condition) AND (count←count-1)<0 AN
        LENGTH(action) THEN EVAL(action);
    EVAL(TTY);

Here  EVAL is  a procedure  which evaluates  its string  argument and


                                 18
BAIL -- A debugger for SAIL                           RUN-TIME ACTION


returns the value of the last expression evaluated (similar  to PROGN
in LISP).



4.4 - COORD
      _____

INTEGER PROCEDURE COORD(STRING LOCATION);

Returns the coordinate number of the location given as  its argument.
LOCATION has the same syntax as in BREAK.



4.5 - DDT
      ___

PROCEDURE DDT;

This procedure  transfers control to  an assembly  language debugging
program (if one was loaded).



4.6 - HELP
      ____

PROCEDURE HELP;

A list  of options,  including short  descriptions of  the procedures
described in this section, is printed.  A question mark followed by a
carriage return is interpreted as a call to HELP.



4.7 - SETLEX
      ______

PROCEDURE SETLEX(level);

Evaluating SETLEX(n) changes the static (lexical) scope to  the scope
of the n-th entry in the dynamic scope list.  SETLEX(0) is  the scope
of  the  breakpoint;  SETLEX(1)  is  the  scope  of  the  most recent
procedure call in the dynamic scope, etc.



                                 19
BAIL -- A debugger for SAIL                           RUN-TIME ACTION


4.8 - SHOW
      ____

STRING PROCEDURE SHOW(first, last(0));

The text of the program from the source or listing file.  If  last is
less  than first  then set  last to  last+first.   Return coordinates
first  through last.   SHOW(5,3) gives  coordinates 5,  6, 7,  and 8;
SHOW(5,7) gives coordinates 5,  6, and 7; SHOW(5) gives  coordinate 5
only.

A plus sign ("+") following the coordinate number indicates  that the
values of some variables have been carried over in  accumulators from
the previous coordinate.  Changing  the value of variables  might not
be  successful in  such  a case,  because  BAIL will  not  change any
accumulator  value directly.   The MEMORY  construct can  be  used to
modify any location in a core image, including the accumulators.



4.9 - TEXT
      ____

STRING PROCEDURE TEXT;

The current static and dynamic  scopes, with text from the  source or
listing file.



4.10 - TRACE
       _____

PROCEDURE TRACE("procedure");

Special  breakpoints are  inserted at  the beginning  and end  of the
procedure  named.  On  entry, the  procedure name  and  arguments are
typed.  On exit, the name and value returned (if any) are typed.











                                 20
BAIL -- A debugger for SAIL                           RUN-TIME ACTION


4.11 - TRAPS
       _____

STRING PROCEDURE TRAPS;

A list of the current breakpoints and traces.



4.12 - UNBREAK
       _______

PROCEDURE UNBREAK("location");

The breakpoint at the location specified is removed.



4.13 - UNTRACE
       _______

PROCEDURE UNTRACE("procedure");

The breakpoints inserted by TRACE are removed.



4.14 - !!GO
       ____

pseudoPROCEDURE !!GO;

An immediate exit from the current instantiation of BAIL is taken and
execution of the  program is resumed.  !!GO  is a reserved  word (the
only one) in BAIL.



4.15 - !!GSTEP
       _______

pseudoPROCEDURE !!GSTEP;

Temporary breakpoints are inserted at all of the logical exits of the
current statement, and execution of the program is  resumed.  Logical
exits  are the  next  statement and  locations to  which  the current
statement  can  jump,  excluding any  procedure  calls.   All  of the
breakpoints which are inserted will be removed as soon as one of them
is encountered.
                                 21
BAIL -- A debugger for SAIL                           RUN-TIME ACTION


4.22 - !!STEP
       ______

pseudoPROCEDURE !!STEP;

Temporary  breakpoints are  inserted at  all locations  to  which the
current statement can jump, including procedure calls,  and execution
of the program is resumed.



4.17 - STRING TYPEOUT
       ______ _______


Strings are usually  typed so that the  output looks the same  as the
input, i.e., a string  is typed with surrounding quotation  marks and
doubled  internal quotation  marks.  For  SHOW, ARGS,  and  TEXT this
would  ordinarily create  confusion, so  they are  handled specially.
When these procedures  are evaluated they  set a flag  which inhibits
quotation mark  fiddling, provided that  no further  evaluation takes
place before the next typeout.  Thus SHOW(5,3); will be  typed plain,
but STR←SHOW(5,3); will have quotation marks massaged.



4.18 - BAIL and DDT
       ____ ___ ___


If BAIL is  initialized in a  core image which  does not have  DDT or
RAID, then things will be set up so that the monitor command DDT gets
you into BAIL in the right way.  That is, BAIL will be your  DDT.  To
enter BAIL from DDT  (provided that the SAIL  initialization sequence
has already been performed), use
    pushi P,<program counter>$X
    JRST BAIL$X
For example, if .JBOPC contains the program counter,
    PUSH P,.JBOPC$X
    JRST BAIL$X

The entry B. provides a path from DDT to BAIL which works  whether or
not the core image has been initialized.  One use of this  feature is
to  BREAK  a  procedure in  an  existing  production  program without
recompiling.  For example,
    @;  PROG originally compiled, loaded with BAIL and DDT, and SAVEd
    @GET PROG
    @DD
     B.$G

                                 22
BAIL -- A debugger for SAIL                           RUN-TIME ACTION


    BAIL initialization
            :
            :
    1:BREAK("procedure");
    1:!!GO;

    $G

To enter DDT from BAIL, simply say DDT;.  For operation  under TENEX,
control-B is a pseudo-interrupt character which gets you into BAIL.



4.19 - WARNINGS
       ________


Since BAIL is itself a  SAIL procedure, entering BAIL from  the error
handler  or  DDT  after  a push-down  overflow  or  a  string garbage
collection error will get you into trouble.

SIMPLE procedures cause headaches for BAIL because they do not keep a
display pointer.   [Indeed, the compiler  gets lost in  the following
example, and does not complain:
        BEGIN "LOST"
        PROCEDURE A(INTEGER I); BEGIN "A"
          SIMPLE PROCEDURE B; OUTSTR("THE VALUE OF I IS " & CVS(I));
          PROCEDURE C(INTEGER J); B;
        C(2);
        END "A";

        A(1);
        END "LOST";                                     ]

BAIL tries valiantly to do the right thing, but occasionally  it also
gets lost.  BAIL will try to warn you if it can.  In general, looking
at value string parameters of SIMPLE procedures does not work.












                                 23
BAIL -- A debugger for SAIL                            RESOURCES USED


                             SECTION  5
                             _______  _

                           RESOURCES USED
                           _________ ____




I.  Compile-time

    A.  One channel.  This means that REQUIREd source files  may only
        be nested to a depth of about 9.

    B.  Memory.  Up to 11*(maximum lexical nesting depth)  more words
        of   memory   may   be   required   compared   with  previous
        compilations.

    C.  CPU time.  Approximately 0.3 seconds per page of dense text.

II.  Run-time

    A.   Channels.   Three  during  initialization,  two  thereafter.
        Channels are obtained via GETCHAN.

    B.  BAIL uses 7 of the privileged breaktables, obtaining them via
        GETBREAK.

    C.  REQUIRE 64 STRING!PDL.  Necessary if the  debugging recursion
        level will exceed 3 or 4.

    D.  Memory.  (9.5K +((# of  coordinates+127) DIV 128) + (2*  # of
        blocks) + (5* # of symbols)) words.

    E.  CPU time.

        1.   Initialization.   Typically  4  seconds  for  a  30 page
            program.

        2.   Debugging requests.   0.07 seconds  per  simple request.
            DDT response time.

III.  Disk space

    A.  The .SM1 file  for a /7B compilation is  typically one-fourth
        the size of the corresponding .REL file.

    B.  The .BAI  file for a group  of /7B compilations  is typically
        one-third the total size of the corresponding .REL files.


                                 24
BAIL -- A debugger for SAIL                            CURRENT STATUS


                             SECTION  6
                             _______  _

                           CURRENT STATUS
                           _______ ______




The  state  of  the  world  is  determined  by  the  values   of  the
accumulators and the value of the SAIL variable !SKIP!.

The run-time interpreter recognizes  only the first 15  characters of
identifier  names;  the  rest  are  discarded  without  comment.  The
characters which are legal in identifiers are

        ABCDEFGHIJKLMNOPQRSTUVWXYZ
        abcdefghijklmnopqrstuvwxyz
        0123456789!_αβπλ⊂⊃∀∃→~#$\|


Notable for its absence: period.

LOCATION of a procedure does not work.

PROPS is read-only.

Bracketed triple items are not allowed.

A  procedure  call  containing the  name  of  a  parametric procedure
(functional argument) is not handled properly.

Contexts are not recognized.

The run-time interpreter will not recognize macros.

External linkage: If an identifier is never referenced by code (i.e.,
has  an empty  fixup chain  at the  time fixups  are put  out  to the
loader) then that identifier is not defined by SAIL.   Thus variables
which are  never used  do not  take up  space, and  a request  to the
loader  is not  made for  EXTERNALS which  are not  referenced.  This
feature of SAIL is  cast in concrete and  will not be changed.   As a
result, the  following DOES NOT  WORK unless special  precautions are
taken:
        BEGIN
        EXTERNAL PROCEDURE BAIL;
        EXTERNAL PROCEDURE PLOT(REAL X0,Y0,X1,Y1);
        REQUIRE "CALCOM" LIBRARY;

        BAIL END

                                 25
BAIL -- A debugger for SAIL                            CURRENT STATUS


PLOT will not be defined by SAIL, hence BAIL will not know  about it.
However if there are any  references to PLOT (real or  "dummy" calls)
then BAIL will know.  The following trick can also be  used, assuming
that CALCOM is a  SAIL-compiled procedure: Compile CALCOM  with /10B,
which  says  "make  the  .SM1  file  but  don't   automatically  load
SYS:BAIL.REL".   Then the  above will  win (due  to  BAIL recognizing
things which are globally unique) and programs which do not  use BAIL
will not have it loaded just beacuse the library was used.  This same
problem occurs with  EXTERNAL RECORD!CLASS declarations.  Use  of the
subfield index information  does not cause  a reference to  the class
name but NEW!RECORD does.  Thus  the same /10B trick must be  used if
there are no NEW!RECORD calls.





































                                 26
BAIL -- A debugger for SAIL                            CURRENT STATUS


REFERENCES

[1]   _____,  DECsystem10 Assembly  Language  Handbook DEC-10-NRZC-D,
      Digital Equipment Corporation, Maynard, Massachusetts, 1973.

[2]   Edwin H. Satterthwaite  Jr., "Source Language  Debugging Tools"
      (Ph.D.   thesis),   Computer   Science   Department,   Stanford
      University, May 1975.

[3]   Daniel C. Swinehart,  "COPILOT: A Multiple Process  Approach to
      Interactive  Programming  Systems"  (Ph.D.   thesis),  Computer
      Science Department, Stanford University, August 1974.

[4]   Kurt  VanLehn  (ed.),  SAIL  USER  MANUAL,  Stanford Artificial
      Intelligence   Laboratory   memo   AIM-204   (Computer  Science
      Department report STAN-CS-73-373), July 1973.

































                                 27