Trailing-Edge
-
PDP-10 Archives
-
decuslib20-03
-
decus/20-0078/sys/libsim.hlp
There is 1 other file named libsim.hlp in the archive. Click here to see a list.
LIBSIM
======
The files LIBSIM.REL and LIBSIM.ATR contain a large number of useful
external procedures and classes for the SIMULA programmer.
Library procedures will be available to your program if you declare them
as external at the beginning of your program, e.g:
EXTERNAL CLASS safeio;
EXTERNAL INTEGER PROCEDURE hash;
You need not mention any explicit filename if you are using LIBSIM on
the SYS area or on your own area. An external declaration in a
separately compiled segment (module) must be repeated in all dependent
modules including the main program. Please note that when you use
modules in LIBSIM that are coded in SIMULA you will sometimes have to
explicitly declare other LIBSIM routines. The compiler will duly tell
the user which declarations are missing.
If you want to use other libraries, see the DECsystem-10 SIMULA Language
Handbook part II chapter 7.1.1.
Normally, when you load your programs with the LOAD, EXECUTE or DEBUG
commands of DECsystem-10, you need not mention the names of any
separately compiled classes or procedures. Just write:
.EXECUTE myprog
if your program has the name myprog. Any external classes or procedures
declared as such inside myprog will automatically be loaded.
At installations using the MIC system for command language macros, there
may be a macro LIBSIM.MIC available for maintenance of LIBSIM libraries.
Type "DO LIBSIM" without parameters for information about this.
If you cannot find the necessary .SIM, .REL, .ATR, .HLP, .MAN or .DOC
files on the SYS:, HLP: or DOC: areas on your computer, contact the
computer center or the SIMULA development group.
In addition to the utilities listed below, a SIMULA programmer has
access to a number of built-in standard procedures. These are described
in appendix B to the DECsystem-10 SIMULA Language Handbook part I.
The procedures, classes and main programs listed below are described in
DECsystem-10 SIMULA Language Handbook part III.
The first column for each program indicates type of result for function
procedures, K for separately compiled classes. The following letters
indicate parameter types.
Letter codes in this list:
..=repetition of parameter, R=REAL, L=LONG REAL, I=INTEGER, C=CHARACTER,
T=TEXT, X=REF, B=BOOLEAN, G=LABEL, a=ARRAY, P=PROCEDURE, K=CLASS.
An asterisk (*) indicates efficient, MACRO-10 coded procedure.
1. UTILITY PACKAGES
1.1 APPLICATION PACKAGES
K T,T SAFEIO Safe conversational terminal I/O. See
SAFEIO.HLP and SAFEIO.MAN
K T SAFEI SAFEIO without file handling facilities
K SAFMIN Small, simplified version of SAFEI
K T,T SIMEIO Same as SAFEIO but prefixed with SIMULATION
K T SIMEI Same as SAFEI but prefixed with SIMULATION
K SIMMIN Same as SAFMIN but prefixed with SIMULATION
K SIMDBM CODASYL DBTG type DBMS system. Consists of
the external classes SIMDBM (DBMMIN), DBMSET
and the main programs DBDUMP, DBLOAD,
DBSORT, FETCH, HMAKE, TRANSF, LOAD, DIRED,
SPEC, PREP and PREP2
K I,I STORE Simple text-oriented DBMS
K SELECT Boolean condition searching TEXT or FILE
K I,I,I GPSSS GPSS-like queue simulation package
K I,I,I,C,I GPSSST GPSSS with more automatic trace facilities
K FIGURE Plot package for Tektronix plotter. GRAPHI,
COSYS, COSYSF and RUBOUT are also part of
this package. See FIGURE.HLP
K CALSIM Curve plotting on Calcomp 835 plotter. See
CALSIM.HLP
K I,I,X,B,I VISTA Full control of alphanumeric display screen,
e.g. to produce moving pictures
K I,I,X,B,I FORM Form fill in data entry, subclass of VISTA
P I,I,I,T GETVIS Terminal type input for VISTA
K T DAHELP Gives user help message when running SIMULA
program. Uses direct-access file to store
help messages. See DAHELP.HLP
B T,T,I,I SQHELP Gives user help message when running SIMULA
program. Uses sequential file to store help
messages
2. SIMULA SOURCE CODE CONVERSION PROGRAMS
[These are main programs, and thus not
placed in LIBSIM]
M SIMED Prettyprinting, cleaner layout, indentation
of BEGIN-END, no semantic change of program
M SIMEXP Combines separately compiled modules into
one module
M SIMIBM Conversion to IBM Simula
M IBMSIM Conversion from IBM Simula
M CDCSIM Conversion from CDC Simula
M FQCRED Adds frequency count statements to a SIMULA
program
M FQCLST Edits SIMULA source program with frequency
measurements
3. DIRECTFILE HANDLING PROGRAMS
M DIRED Edits a directfile
M MAKEDF Converts sequential files to directfiles and
vice versa
M FETCH General-purpose SIMDBM Data Base Manipulator
M MAKHLP Creates help file for use with DAHELP
4. PROCEDURES NOT WRITEABLE IN SIMULA
4.1 TIME AND DATE
T TODAY(*) Gives TEXT with date: yyyy-mm-dd
I DAYNO Number of this day in current year
T DAYTIME(*) Gives TEXT with hh:mm:ss
R CLOCKTIME(*) Gives REAL with time of day in seconds
R CPTIME(*) Gives LONG REAL with CPU time in seconds
4.2 REAL TIME
B X INPUTCHECK(*) Anything to read on file X?
P R SLEEP(*) Delays execution for R real seconds
I Xa,R INPUTWAIT(*) Sleeps until anything to read
K REALTIME Scheduler for terminal processes
4.3 INPUT/OUTPUT
I X LINECOUNT(*) Returns LINESPERPAGE setting
I X FILENAME(*) Gives TEXT with FILE object generation
parameter
C GETCH(*) Inputs character, will not wait for carriage
return (input from controlling terminal
only)
B R TTYCHECK(*) Checks if a character has been typed in at
the controlling terminal
P X,C,I OUTCHR(*) Outputs character bypassing image
P X FORCEOUT(*) Terminal output buffer to terminal
C X INSINGLECHAR(*) Inputs character, does not wait for carriage
return (Input from disk or controlling TTY)
C X INSNGL(*) As INSINGLECHAR, but line mode (waits for
break character)
P ILRCPa.. READ(*) Reads many values in standard format
P ILRCTPa.. WRITE(*) Writes many values in standard format
I X,RLICBTXa.. OUTPUT(*) Binary output
I X,RLICBTXa.. INPUT(*) Binary input
I RLICBTXa.. PUTSIZE(*) How much will OUTPUT write?
B T SCRATCHFILE(*) Deletes file on secondary storage
X T FINDINFILE(*) NEW INFILE, but no error if file is not
available
X T,B FINDDIRECTFILE(*) NEW DIRECTFILE, NONE if not available for
requested access
X T FINDOUTFILE(*) NEW OUTFILE, NONE if write protected
X T FINDPRINTFILE(*) NEW PRINTFILE, NONE if write protected
I X LASTLOC(*) Highest written line in a DIRECTFILE
B X DOTYPEOUT(*) Resets CTRL-O bit to resume terminal output.
TRUE if file is a terminal and the operation
was successful.
4.4 CONTROLLED ERROR HANDLING
P B ENTERDEBUG(*) Transfers to SIMULA debugging system
P T ABORT(*) User program generated error interrupt
P I FORSIM(*) Traps I/O calls from FORTRAN external
procedures
4.5 SCHEDULING AND JOB CONTROL
P T,I RUN(*) Runs a new program under current job
I T,B SAVE(*) Saves current main memory on a file
P T RESTORE(*) Resumes execution from save file
P I FREEZE(*) Exits to monitor, ready for SAVE
P I EXIT(*) Exits directly to monitor (I=0), after
closing files (I=1), to SIMDDT (I=2).
4.7 ENVIRONMENT ENQUIRY
I MAXINT(*) Returns largest positive INTEGER
R MAXREAL(*) Returns largest positive REAL
4.8 PACKING INTO PARTS OF WORDS(*)
B IRLa,I,IRLCBTa,I,.. PACK Packs many variables of varying type
B IRLa,I,IRLCBTa,I,.. UNPACK Reverse of pack
4.9 MIN AND MAX
I I1,I2 IMAX(*) Max(I1,I2)
I I1,I2 IMIN(*) Min(I1,I2)
R R1,R2 RMAX(*) Max(R1,R2)
R R1,R2 RMIN(*) Min(R1,R2)
L L1,L2 LMAX(*) Max(L1,L2)
L L1,L2 LMIN(*) Min(L1,L2)
5. PROCEDURES WRITEABLE IN SIMULA
5.1 PARTITIONING OF TEXTS
T T REST(*) Subtext after POS
T T FRONT(*) Subtext before POS
T T,I FROM(*) Subtext after pos=I in T
T T,I UPTO(*) Subtext before pos=I in T
T T FRONTSTRIP(*) Subtext without leading blanks
T T GETITEM(*) Subtext = next identifier, number or
delimiter after POS
T X INITEM(*) GETITEM on INFILE
C T,I FETCHAR(*) Returns T.Sub(I,1).Getchar, null if I out of
range
P T,I,C DEPCHAR(*) T.Sub(I,1).Putchar(C), no action if out of
range.
T T,I1,I2 TSUB(*) T.Sub(I1,I2), NOTEXT where Sub gives error
5.2 SEARCHING AND TESTING OF TEXTS
T T,C SCANTO(*) Next occurrence of C in T
T C SKIP(*) Skips string of characters = C from T.Pos
B T1,T2 FRONTCOMPARE(*) Does rest of T1 begin with subtext = T2?
B T1,T2 UPCOMPARE(*) Same as FRONTCOMPARE, but upper and lower
case letters are regarded as equal
I T1,T2 SEARCH(*) Finds first subtext = T2 from T1.Pos
I T CHECKREAL(*) Checks if GETREAL can be performed
I T CHECKINT(*) Checks if GETINT can be performed
I T CHECKFRAC(*) Checks if GETFRAC can be performed
I T,I HASH Computes hash value from text in interval
[0:I-1]
C T1,T2 FINDTRIGGER(*) Next occurrence of any character of T2 in T1
B T,I,Ta,I MENU Searches for unambiguous text in a text
array
B T,Ta,I,I,I LOOKUP Performs binary search in sorted text array
5.3 OPERATIONS ON TEXTS
T T,T CONC2(*) Concatenation of TEXTs, two parms
T T.. CONC(*) Concatenation of variable no. of TEXTs
B T1,T2 PUTTEXT(*) Copies value of T2 starting at T1.Pos
T T UPCASE(*) Converts to upper case
T T LOWCASE(*) Converts to lower case
T C,I MAKETEXT(*) NEW text, all I characters equal to C
T T,C COMPRESS(*) Removes given character from text
I T STARTPOS(*) Returns starting position for a (sub)text
B T1,T2,T3 CHANGE Replaces first substring of T1 = T2, if any,
with T3. Search starts at T1.Pos
L T SCANREAL(*) GETREAL, safe from bad data, starts at T.Pos
I T SCANINT(*) GETINT, safe from bad data, starts at T.Pos
I T SCANFRAC(*) GETFRAC, safe from bad data, starts at T.Pos
T T,R,C,I PUTTIME Edits a number in TIME format
T T,R PUTFLOAT Edits a number using minimum no. of
characters
T I,I RADIX Edits 2nd parm to an item in 1st parm base.
I I,T GETRADIX Deedits an item(T) in base I to an integer
value.
P T,T,T,T SPLIT Splits a text at given delimiter string
I T,T,Ta,I SPLITA Splits a text and stores the parts in a text
array
I T,C,Ta,I SPLITC Same as SPLITA but with character delimiter
I T,I,Ta,Ta SCAN Identifies keywords in a command string.
I T,I,Ta,Ta SSCAN Version of SCAN used by GETVIS.
K I DECOM (Subclass to SAFMIN) Interprets input
command of the format
outfil.ext/switch1/switch2...
=infil.ext/switch3/switch4...
I Ta ARRLGD(*) Total length of texts in Ta + number of elements.
Used in SIMDBM.
P Ta,T,C ARRTXT(*) Put all texts of Ta in T, with delimiter = C. Used
in SIMDBM.
5.4 INPUT/OUTPUT
C X LOOKAHEAD(*) Next non-blank character readable by INCHAR
T T,X INLINE Types out a prompting question and copies an
infile image (stripped)
T T,T,T,B,T,T REQUEST Sophisticated INLINE with input check, help
etc.
P X,R,C,I OUTTIME Prints simulated time in hh:mm:ss.cc format
P .. HISTP Prints histogram of Ia on file X
5.5 SORTING AND SUMMATION ETC.
I R ILOG Returns integer part of 10LOG(Abs(R))+1; if
R = 0 return 0. I.e. Number of integer
digits if Abs(R) >= 1 else number of leading
zeros after decimal point
I Ia,I ISUM Returns sum of an integer array
L La,I LSUM Returns sum of long real array (almost)
preserving precision
R Ra,I RSUM Returns sum of real array
R R,R,Ra,I SIGMA2 Returns variance, mean value of a real array
P R,R,I,R SIGMEAN Returns current variance and mean value
including new observation
P "x"a,I SORTxy Sorts a given array in ascending or
descending order.
x = T(ext), R(eal), I(nteger) or L(ong real)
y = A(scending), D(escending) order
P Ia,I1,I2,I3 SORTDN Sorts slice Ia[1:2,I1:I1-1+N] with respect
to either or both integers in each row.
R R,R,I SCALESTEP Adjusts approx. max and min for diagram
design
B Ia,I,I,I,B IASHIFT(*) Moves part of an integer array leftward.
5.6 RANDOM NUMBER GENERATION ETC.
P Ia,I,I,I SCRAMBLE Random permutation of array
C Ia,N PERGEN Systematic generation of permutations
R R,R RANDOM(*) Random generator of random number series
start numbers
I UNIQUE Unique number to be used e.g. as start
random number (seed)
I I1,I2 NEXTRANDOM(*) Returns the I1:th successor to random seed
I2
5.7 SIMULA VERSIONS OF SYSTEM CLASSES
K ZIMSET SIMULA tracing version of SIMSET
K ZIMULATION SIMULA tracing version of SIMULATION
6. SWEDISH LANGUAGE TEXT PROCESSING AND INPUT/OUTPUT
B C BOKSTAV(*) Swedish version of Letter
T X INORD(*) Swedish version of INITEM
T T LITENBOKSTAV(*) Swedish version of LOWCASE
B T,I,Ta,I MENY Swedish version of MENU
T T STORBOKSTAV(*) Swedish version of UPCASE
T T TAGORD(*) Swedish version of GETITEM
7. UTILITIES SPECIFIC TO DECSYSTEM-10
I I1,I2 ADJPTR(*) Byte pointer I1 adjusted by I2 bytes
I I1,I2 ANDINT(*) Bitwise AND function
I I1,I2,I3 BITFIELD(*) Returns a bit field within I1 starting at
bit I2 (0-35) with length Abs(I3) (1-36) (I3
negative gives sign extension)
B I1,I2 BITGET(*) BITGET:=I1.bit(36-I2)=1
P I1,I2,B BITPUT(*) I1.bit(36-I2):=IF B THEN 1 ELSE 0
I I1,I2,I3 BOOLFUNC(*) One (0<=I1<=15) of 16 Boolean functions of
I2,I3 (bitwise, like ANDINT). For any valid
I1, BOOLFUNC(I1,5,3)=I1.
B T,T CALLMIC Uses MIC to perform other tasks and
optionally return
T T,T CHECKEXTENSION Adds default extension if file spec contains
no dot and is not just of the form DEV:
I I1,I2,I3,I4 DEPBYTE(*) I=I2 with byte at bit I3 of length I4 replaced
by I1.
P X,I ECHO(*) Suppresses monitor echoing of terminal input
I X,T FILCOP(*) Efficient copying of disk files. Also
copies creation date and version.
K FILED Reads and writes DEC 10 line numbered files
T X,I FILSPC Returns file specification string for file X
in format controlled by value of I.
I I FLOKUP(*) Look up file specified by FILOP. and LOOKUP
blocks.
I I1,I2 GETTAB(*) Returns item I1 in monitor table I2
T I IDRX50(*) Interprets a 36-bit word as a "RADIX50"
symbol (code bits and 6-character
identifier)
T I1,I2 IDSIXBIT(*) ASCII representation of up to 12 character
identifier given in I1 and I2 in SIXBIT (DEC
64-character code)
I R INTREA(*) "Retype" R as integer (same 36-bit pattern)
I X JOBSTATUS(*) Get JOBSTS word for PTY or TTY (subjob
control)
I I1,I2 LOADBYTE(*) Get any byte in readable core.
I I LOADWORD(*) Get word at address (I) - any readable word.
I I1,I2,I3 MATCH6(*) SIXBIT match of I1 to I2 according to
wildcard mask I3.
B NUMBERED(*) Did last inimage get a line-numbered line?
T T,I OCTAL(*) Octal representation of I, using T as work
area.
I X,R PTYCHECK(*) Any PTY (Infile X) activity in R seconds?
X X PTYFIL(*) PTY Outfile companion to PTY Infile X.
I X PTYINIMAGE(*) Get line of input from PTY Infile X. Result
shows how line ended.
I T,I RDX50 Converts I,T to "RADIX50"
R I REAINT(*) "Retype" I as real (same 36-bit pattern)
B X/T,T[,B] RENAME(*) Renames or deletes first arg (file ref/spec)
to second arg (file spec).
B RESCAN(*) Makes invoking monitor command readable by
invoked program
I T SIXBIT(*) First 6 characters in T converted to sixbit
word.
I I1,I2,I3 STOREBYTE(*) Stores the byte I1 using byte pointer I2,
modified (I3) bytes.
I I1,I2 STOREWORD(*) Store I1 at (I2) (abs memory address).
I I SXRX50 RADIX50 to SIXBIT.
T T,B TMPIN(*) Reads a "TMPCOR" core file into a new text
object, and deletes the file if B is TRUE.
T T TMPNAM(*) Creates a temporary file name like
"021PIP.TMP"
B T1,T2 TMPOUT(*) Writes a "TMPCOR" core file from T2.
Returns TRUE if successful.
I I,X,I TRMOP(*) Modifies monitor-terminal interface
I I TTYLINE Gives network node and line for tty number I
T I1,I2 TTYNUMBER TTY number for node I1 line I2 in network
I I1,I2,B,I3 XCALLI(*) Execute CALLI AC1,(I2). AC1=I1. Return
(I3) if CALLI does not skip and B is TRUE,
otherwise return new value of AC1.
I T,I1,I2 WILDSIX(*) SIXBIT translation of T, recording wildcards
(? or *) in I1.
[END OF LIBSIM.HLP]