Google
 

Trailing-Edge - PDP-10 Archives - bb-4157h-bm_fortran20_v10_16mt9 - fortran-ots-debugger/forprm.mac
There are 13 other files named forprm.mac in the archive. Click here to see a list.

	UNIVERSAL FORPRM	UNIVERSAL FILE FOR FOROTS ,10(4203)

;COPYRIGHT (C) DIGITAL EQUIPMENT CORPORATION 1981, 1985
;ALL RIGHTS RESERVED.
;
;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED AND COPIED
;ONLY  IN  ACCORDANCE  WITH  THE  TERMS  OF  SUCH LICENSE AND WITH THE
;INCLUSION OF THE ABOVE COPYRIGHT NOTICE.  THIS SOFTWARE OR ANY  OTHER
;COPIES THEREOF MAY NOT BE PROVIDED OR OTHERWISE MADE AVAILABLE TO ANY
;OTHER PERSON.  NO TITLE TO AND OWNERSHIP OF THE  SOFTWARE  IS  HEREBY
;TRANSFERRED.

;THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT  NOTICE
;AND  SHOULD  NOT  BE  CONSTRUED  AS A COMMITMENT BY DIGITAL EQUIPMENT
;CORPORATION.

;DIGITAL ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY  OF  ITS
;SOFTWARE ON EQUIPMENT WHICH IS NOT SUPPLIED BY DIGITAL.


	SALL
;REVISION HISTORY


COMMENT \

***** Begin Revision History *****

1267	EGM	15-Feb-81	Q10-04519
	Clean up FORPRM, add checks for feature test conflicts, and
	rework byte definition such that macro GLBS references and
	macro BYTPTS defines byte pointers for ALL bytes defined in
	the DDB.

1271	EGM	18-Feb-81	--------
	Allow DEFSTR storage macros to use previously defined DDB byte
	pointer when indexing using (d), and allow the other cases to
	work correctly also.

1276	DAW	20-Feb-81
	Copy useful field/mask macros from MACSYM:
	FLD, POINTR.

1277	JLC	23-Feb-81
	Created new DDB entry for rounded record size (RSIZR) plus
	added bytes/word entry (BPW) to -10 (removed it from -20-only).

1301	JLC	24-Feb-81
	Created new DDB entry for line sequence number.

1310	DAW	26-Feb-81
	Change half-words to full-words in the DDB: ERR=, END=, IOST=, AVAR=
	that are addresses in the user's program or data.

1314	EDS	4-Mar-81
	Add feature test switch FTNLC1 to allow skipping of column 1
	of NAMELIST input data.

1316	JLC	5-Mar-81
	Separated flag D%LIO (last I/O direction) into 2 flags, D%LIN
	and D%LOUT.

1320	DAW	6-Mar-81
	New feature test switches for type of global byte pointer
	to use, when indexed byte pointers are not appropriate.

1334	DAW	19-Mar-81
	Define macros for dealing with the different flavors of byte
	pointers:  $BLDBP, $LODBP, $STRBP.

1337	JLC	12-Mar-81
	Moved MAXARG definition from FOROTS.MAC to here, and increased
	it to 128.

1365	JLC	25-Mar-81
	Typo in renaming of IBPTR/OBPTR to IPTR/OPTR.

1377	JLC	01-Apr-81
	Changed FLGS from a 36-bit byte to a word (FLAGS).

1404	EGM	6-Apr-81	--------
	Add feature test FTGFL for checking GFLOAT args in complex double
	precision library routines.

1411	DAW	8-Apr-81
	Replace JFN field in the DDB with IJFN and OJFN.

1416	JLC	10-Apr-81
	Separate record buffer parameters for input and output.

1417	DAW	10-Apr-81
	Added F%EDM, so FOROTS knows it should type traceback info
	before throwing the user into DIALOG mode, when the reason
	for the DIALOG mode is because of an OPEN error.

1427	JLC	15-Apr-81
	Changed RSIZ from a halfword to a full word (RSIZE) so
	we can eliminate flag D%RSIZ.

1441	JLC	17-Apr-81
	Removed D%RSIZ, replaced with D%OPEN for future use in CLOSE.

1456	PY/JLC	27-Apr-81
	Remove extra angle brackets from POINTR macro, was causing
	MACRO to create Polish string in pass 2 after pooling literals
	in pass 1, so hiseg break was incorrect.

1463	JLC	7-May-81
	Add new words to -20 file database (WADR,WSIZ) plus
	places to store P1-P4 for %GETIO.

1464	DAW	12-May-81
	Error message cleanup, also get rid of $2HAK.

1465	JLC	15-May-81
	Added data words to the -20 disk database for major I/O
	changes, mostly to magtape operations.

1532	DAW	14-Jul-81
	OPEN rewrite: Base level 1

1535	JLC	14-Jul-81
	Added word for virtual output record size for T format.

1540	DAW	17-Jul-81
	Delete IS from DDB, use IOSTAT variable directly.
	Set IOSTAT variable to zero at the start of each IO statement.
	Set D%ERR if "?" error in IOERR.

1542	JLC	17-Jul-81
	Removed D%EOF, hopefully forever.

1543	DAW	17-Jul-81
	Allow SCRATCH files to devices besides DSK.

1551	DAW	20-Jul-81
	Fix structure macros so "MOVE" of a quantity that's not full-word
	produces a "Q" error.

1560	DAW	28-Jul-81
	OPEN rewrite, base level 2

1570	DAW	30-Jul-81
	Add flag F%NION.

1615	DAW	19-Aug-81
	Get rid of two word BP options.

1622	JLC	21-Aug-81
	Make ORLEN a full word.

1625	DAW	21-Aug-81
	Get rid of "DF".

1643	JLC	25-Aug-81
	Make IRBUF & ORBUF full word byte pntrs.

1656	DAW	2-Sep-81
	Define error table entries symbolically to get rid
	of some magic numbers all over FOROTS.

1657	DAW	2-Sep-81
	Delete 7.01 definitions.

1663	JLC	8-Sep-81
	Added TPAGE(D) to record top page written in a file,
	so CLOSE can unmap unused pages.

1712	JLC	15-Sep-81
	Added IRVIR, the position in the input record.
	Eliminated D%ERR forevermore.

1716	JLC	16-Sep-81
	Changed the names of IRVIR/ORVIR to IRPOS/ORPOS.

1717	DAW	16-Sep-81
	New flag D%NCLS

1725	DAW	18-Sep-81
	New error flag I%TCH.

1745	JLC	24-Sep-81
	Made IRBLN, ORBLN, and IRLEN full words. Removed the silly %
	from the TV macro.

1747	DAW	28-Sep-81
	Added defs for more FOROP. functions.

1752	DAW	29-Sep-81
	Add flag F%INDST.

1775	JLC	9-Oct-81
	Change parity options to be non-zero, so we can tellif program
	gave one.

2005	JLC	15-Oct-81
	Added new FOROP call, removed OPDEF of PJRST.

2011	DAW	19-Oct-81
	Got rid of FSTAT on the -10.

***** Begin Version 7 *****

3035	JLC	5-Feb-82
	Parameters to support rework of binary I/O. Make KL the
	default processor, as KI's are no longer supported.
	Do away with D%BIN, D%UNF and D%EOR, as code in FORIO
	and FOROPN no longer needs them.

3036	BL	10-Feb-82
	Inserted NLBFLN, initial buffer length for list-directed
	character string input buffer.

3037	JLC	11-Feb-82
	Removed ERRN from DDB; it was useless.

3050	BL	25-Feb-82
	Changed NLBFLN TO NLDIBF (See #3036).

3053	AHM	4-Mar-82
	Defined TWOSEG and RELOC macros  under an FTXLIB feature  test
	that expand to .PSECT and .ENDPS pseudo ops for psects  .CODE.
	and .DATA.   They  will  be used  during  extended  addressing
	development.

3056	JLC	23-Mar-82
	Changed the defs of IOERR and ERR to remove literal def.

3060	JLC	25-Mar-81
	Remove RELEA. entry vector. Replace it with EXIT1.

3062	JLC	25-Mar-82
	Make the error entry in the FOROTS vector table point
	to the AC save-type routine.

3073	JLC	31-Mar-82
	Undo edit 3062. The error routine saves the ACs locally, and
	should continue doing so.

3122	JLC	28-May-82
	Changed error macros, made FORPRM a module added to MTHPRM.

3125	JLC	3-Jun-82
	Moved the error character in the error macros.

3127	AHM	8-Jun-82
	Remove temporary TWOSEG and RELOC macros created by edit  3053
	from FORPRM because edit 3122 put SEGMENT macros in FORLIB.

3136	JLC	26-Jun-82
	Install new DDB entries for performance improvement.

3161	JLC	16-Aug-82
	Change NREC(U) to CREC(D). Increase size of FOROTS stack
	to a page.

3165	JLC	28-Aug-82
	Add a DDB entry for handling large files on TOPS-10.

3176	JLC	9-Sep-82
	Added some FUNCT. codes for use within FOROTS.

3202	JLC	26-Oct-82
	Added new DDB entries for ANSI magtapes.
	Added SPCWD, a word of spaces, to the DDB.

3203	AHM	1-Nov-82
	Define a lot more FUNCT. codes for use outside of FOROTS.

3212	JLC	11-Nov-82
	Removed special binary SINR pointer and byte ratio and added
	flag to signal whether to do formatted or 36-bit SINRs/SOUTRs.

3215	JLC	15-Nov-82
	Change name of DMBS (data mode and byte size) to DMABS.

3225	JLC	24-Nov-82
	Install new call ($FJCAL) for JSYS errors from FORLIB.

3231	JLC	14-Dec-82
	Add new FOROTS entry macro FENTRY, for use with DBMS
	interface, and allows changing the lowseg/hiseg interface
	easily for V8.

3245	JLC	5-Jan-83
	Fixed value of ENDP for DBMS.

3252	JLC	12-Jan-83
	Created FORPRG macro to purge global symbols created by MONSYM
	which do not have "%" or "." in them.

***** End V7 Development *****

3276	TGS	22-Mar-83	SPR:NONE
	Fixed value of ENDP for UDDT

3300	TGS	1-Apr-83	SPR:NONE
	Delete FTGFL flag as it is also defined in MTHPRM.  Move ARGKWD,
	ARGTYP and ARGADR from FORPRM to MTHPRM (MTHLIB edit 3242).

***** Begin Version 10 *****

4000	JLC	22-Feb-83
	Remove D%IO and D%RAN, as they are used no more.

4005	JLC	28-Feb-83
	Added DDB entry for FIN address.

4006	JLC	1-Mar-83
	V7 becomes v10.

4010	JLC	19-Apr-83
	Add IOKWD, for I/O keywords in IOLST calls.

4014	JLC	14-Jun-83
	Changed names of some DDB variables so they wouldn't conflict
	with definitions in MACSYM and MONSYM. Expand CC for CC.TRN.
	Add definitions for INQUIRE and RMS/tape support.

4023	JLC	29-Jun-83
	Remove FTSHR, D%SP, and D%BZ. Search MTHPRM.

4036	JLC	3-Aug-83
	Add a word flag for ASCII-only device.

4040	JLC	6-Sep-83
	Add FB%FOR temporarily until it is defined in MONSYM.

4044	JLC	19-Sep-83
	Added new FOROP functions for memory manager debugger, and
	left room for the SORT functions for V7A patch.

4045	JLC	30-Sep-83
	Removed UBSZ from DDB. Added a new device type - RMS file.

4052	JLC	12-Oct-83
	Add word for saving DEVCHR bits so we can know
	whether magtape is assigned.

4055	JLC	28-Oct-83
	Added synonym for IJFN/OJFN in TOPS-10 FILOP block.

4060	JLC	2-Nov-83
	Fix TOPS-10 tapemode values, had one missing.

4064	JLC	14-Nov-83
	Add new RMS keywords for OPEN.

4065	JLC	6-Dec-83
	Add new entries in DDB for RMS.

4066	JLC	11-Jan-84
	Yet more entries in the DDB for the RMS preparations.

4071	JLC	18-Jan-84
	Fixed BLANK= values for new code in FOROPN.

4072	JLC	24-Jan-84
	Add new DDB variables for user id, account string, and password
	for RMS remote file access.

4101	CDM	16-Feb-84
	Create and expand the  character stack differently when  running
	in extended addressing.   Give the stack  its own section(s)  so
	that it has plenty of room.  Also add user subroutine ALCCHR.

4102	JLC	17-Feb-84
	Add yet more DDB variables for RMS, plus some flags for
	compatibility flagging, and a MACRO to call the compatibility error
	entry point.

4104	JLC	23-Feb-84
	Remove $CERR, as it is not needed after all.

4105	JLC	28-Feb-84
	Modify the calling sequence for error calls.

4111	JLC	16-Mar-84
	Modify the calling sequence for error calls again.

4112	JLC	19-Mar-84
	Remove FDBMS from FORVEC, as it is no longer necessary.

4114	JLC	28-Mar-84
	Remove I%TCH on TOPS-10, as it is almost useless
	and didn't work anyhow.

4116	JLC	6-Apr-84
	Add DT.NUL for TOPS-10, same as DT.DSK.

4122	JLC	2-May-84
	A whole raft of changes to make the TOPS-10 and TOPS-20
	DDB databases the same.

4123	JLC	5-May-84
	Add some MONSYM symbols to the TOPS-10 parameters for TABLK.

4124	JLC	8-May-84
	Fix some AC definitions.

4127	JLC	15-May-84
	Add some TOPS-10 UUOSYM definitions.

4131	JLC	12-Jun-84
	Remove some F flags.

4132	JLC	15-Jun-84
	Increased size of IOKWD to 17 from 7.

4135	JLC	10-Jul-84
	Add TMPFIL for temporary files on TOPS-20. Add PPNSTR for TOPS-10
	style PPNs for TOPS-20.

4144	JLC	29-Aug-84
	Add keyword and table values for DISPOSE='PLOT'.

4152	JLC	24-Sep-84
	Add symbols for symbol vectors in PDVs.

4153	JLC	27-Sep-84
	Add a new offset (FSTAD) for the initialization arg block.

4155	JLC	4-Oct-84
	Change FO$SBA to FO$GBA, since it now gets the break address
	rather than setting anything. Move $DCALL and $DJCAL here
	from MTHPRM.

4161	JLC	1-Nov-84
	Change ASCFLG to IMGFLG, indicating that the device in question is
	an image-mode device which cannot have LSCWs. This will then include
	the ASCII-only devices. Remove all tests of MODE(D)=MD.IMG, since
	this test is not general enough; instead just check IMGFLG.
	Widen CNSL1 and CNSL2 in DDB to full-word addresses.

4171	JLC	29-Nov-84
	Add some 7.03 parameters and set .RBMAX to its 7.03 value so
	that CARRIAGECONTROL='FORTRAN' will work when the customers
	receive 7.03.

4174	JLC	9-Jan-85
	Remove private definition of .RBMAX, since the TOPS-10 monitor
	group wedged the carriage control bits into the current RIB.

4200	TGS	28-Jan-85
	Implement V7 edit 3442: Initialize ENDP/%ENDP to 777. In section
	0, set %ENDP for MINILP to 763 if DDT is in core; if not, leave
	at 777. For non-zero sections, simply set page 777 as unavailable.
	(Modules FORPRM, FORMEM)

4203	JLC	13-Mar-85
	Add user-supplied bytesize (UBSIZ) to DDB, to differentiate it
	from the actual bytesize of the file.

***** End V10 Development *****

***** End Revision History *****
\

	SEARCH	MTHPRM
IF10,<	SEARCH	UUOSYM>
IF20,<	SEARCH	MONSYM>
;INSTALLATION-DEPENDENT PARAMETERS

;FT10			;TOP10 (NONZERO=YES)
;FT20			;TOPS-20 (NONZERO=YES)
;FTKL			;KL/KS PROCESSOR (NONZERO=YES)
;FTPSCT			;PSECTED FOROTS (NONZERO=YES)
;FTVAX			;ALL UNITS ARE DSK: EXCEPT 5, WHICH IS TTY (NONZERO=YES)
;FTDSK			;ALL UNITS DEFAULT TO DSK: (NONZERO=YES)
;FTAST			;ASTERISK FILL; FIELD WIDTH OVERFLOW (NONZERO=YES)
;STARTP			;PAGE TO START LOOKING FOR MEMORY
;FTNLC1			;IGNORE DATA IN COL 1 OF NAMELIST INPUT (NONZERO=YES)
;FTGGL			;GFLOATING DOUBLE PRECISION LIBRARY CHECKS
;WRNCNT			;*UNSUPPORTED* NUMBER OF WARNINGS OF A SPECIFIC
;			; TYPE THAT GET PRINTED. FOROTS's default is 2.

;DEFAULTS:
;FT20:		NO
;FT10:		NO
;FTKL:		YES IF NO PROCESSOR SPECIFIED
;FTPSCT:	NO
;FTVAX:	NO
;FTDSK:		NO
;FTAST:		YES
;STARTP:	577
;FTNLC1:	NO

IFNDEF FTMATH,<?PRINTX MODULE MUST BE ASSEMBLED WITH MTHPRM.MAC
		END>

IFNDEF FTVAX,<FTVAX==0>		;UNITS DON'T DEFAULT TO VAX DEVICE TABLE
IFNDEF FTDSK,<FTDSK==0>		;ALL UNITS DON'T DEFAULT TO DEVICE DSK
IFNDEF FTAST,<FTAST==-1>	;ASTERISK FILL
IFNDEF STARTP,<STARTP==577>	;600 UP ARE LAST USED BY FOROTS MEMORY MGR
IFNDEF FTNLC1,<FTNLC1==0>	;DO NOT SKIP COLUMN 1 ON NAMELIST INPUT
IFNDEF WRNCNT,<WRNCNT==2>	;Number of warnings of a specific type
				; that get printed.
;FOROTS AC DEFINITIONS

	D==S1			;POINTER TO CURRENT DDB
	U==S2			;THE UNIT BLOCK POINTER
	F==S3			;LOCAL FLAGS
	FREEAC==S4		;FOR NOW, IT'S THE "FREE AC"

;BYTE POINTER AND BYTE SIZE DEFINITIONS

	IBPW==5			;CURRENTLY 5 BYTES/WORD INTERNALLY IN FOROTS
	IBSZ==7			;BYTE SIZE = 7
	IFBYT==<POINT 7>	;ONE-WORD LOCAL FIRST BYTE POINTER
	IFOWG==<610000,,0>	;ONE-WORD GLOBAL FIRST BYTE POINTER

;$BLDBP - build byte ptr from address, when you want a 7-bit
;	byte pointer that will give you first byte at the address
;	when you ILDB.

	DEFINE $BLDBP (AC),<
		TLNE	AC,-1	;Skip if local address
		 TXOA	AC,B1WBP7 ;Global address, make BP and skip
		HRLI	AC,(POINT 7,) ;Local address, make BP
	>
;OTHER DEFS

	RWKWD==17B8		;READ, WRITE KEYWORDS GO FROM 0 TO 17 ONLY
	IOKWD==17B8		;I/O KEYWORDS GO FROM 0 TO 17 ONLY
	MOSBSZ==6		;MTOPR STATUS BLOCK SIZE
	BUFNM==4		;DEFAULT BUFFER COUNT - NUMBER OF PAGES/FILE
	CHMSIZ==200		;MINIMUM SIZE TO ADD TO FN%GAD CHAR STACK CALLS
	ETBSIZ==^D30		;ERROR TABLE SIZE FOR ERRSET, ETC.
	IFMTSZ==200		;INITIAL FORMAT ENCODING AREA SIZE
	LPDL==1000		;LENGTH OF STACK
	LRECBF==^D80		;INITIAL LENGTH OF RECORD BUFFER, BYTES
	LTEXTW==100		;LENGTH OF BUFFER FOR FULL FILESPEC
	LTEXTC==LTEXTW*5		;# CHARACTERS IN FILESPEC BUFFER
	LATOMW==40		;ATOM BUFFER LENGTH
	LATOMC==LATOMW*5	;AND IN CHARS
	NLDIBF==^D140		;List-directed input character string buffer
				;byte length
	FLSIZE==20		;INITIAL SIZE OF LS FREE LIST
	PLEN==1			;LENGTH OF PAGE. ARG BLOCK
				;*** DO NOT SET ABOVE 1 UNTIL MONITOR FIXED
	FMTN==^D47		;POINTERS TO ENCODED FORMAT STATEMENTS

	INQUNT==-^D12		;INQUIRE
	IFIUNI==-^D11		;INTERNAL FILE INPUT
	IFOUNI==-^D10		;INTERNAL FILE OUTPUT
	ENCUNI==-^D9		;ENCODE
	DECUNI==-^D8		;DECODE
	MINUNIT==-7		;MIN LEGAL UNIT NUMBER
	RRUNIT==-6		;REREAD UNIT
	MAXUNIT==^D99		;MAX LEGAL UNIT NUMBER
	MAXPDV==5		;MAX PDVS TO SCAN AT ONCE

	MAXARG==^D128		;MAX # ARGS IN AN I/O LIST

	VFOROTS==10		;FOROTS MAJOR VERSION
				;FORHST.MAC DEFINES WHOLE VERSION NUMBER

	B1WBP7==<61>B5		;Bits to TXO when you want a one-word
				;global byte pointer, 7-bits, such that
				;ILDB gets first byte in the word.

;Character stack

	ICHRSZ==1000	;Create 1 page non-extended character stack
	ECHSIZ==1	;Minimum words for extended char stack

;COMPATIBILITY FLAGGING INDICES

	VAXIDX==1		;INDICATES VAX FLAGGING
	ANSIDX==2		;INDICATES ANSI-77 FLAGGING

;PROCESSOR-DEPENDENT DEFAULTS
IF20,<
	ENDP==777		;[3276][4200] TOP OF CORE ON -20 (LEAVE UDDT)
	PRTDIG==6		;6 DIGITS IN PROTECTION

> ;END IF20

IF10,<
	ENDP==775		;TOP OF CORE ON -10 (LEAVE PFH)
	PRTDIG==3		;3 DIGITS IN PROTECTION

> ;END IF10


;CHARACTER CONSTANTS

	.CHLAB==74		;Left angle bracket "<"
	.CHRAB==76		;Right angle bracket ">"
;MISCELLANEOUS DEFINITIONS

IF10,<
;TOPS-10 DEFINITIONS NOT IN RELEASE 7.01 UUOSYM

	ERDAJ%==52		;UNIT ASSIGNED TO ANOTHER JOB
	ERNFC%==57		;NOT ENOUGH CHANNELS

;PAGE. UUO FUNCTIONS

	.PAGSC==12		;SECTION MANIPULATION
	PG.GSF==1B0		;FOR .PAGSC, 1=DESTROY, 0=CREATE SECTION
	PG.GMS==1B1		;FOR .PAGSC, MAP SECTIONS TOGETHER

;FOROTS-10 DEFINITIONS FOR TOPS-20 SYMBOLS

	CM%FW==1B7		;FLAG WORD IN TABLK TABLE
	CM%ABR==1B33		;THIS IS AN ABBREVIATION STRING
	CM%INV==1B35		;INVISIBLE (NOT ACTUALLY USED BY FOROTS-10)

;FOROTS DEFINITION OF .RBTYP (AND OTHER 7.03 PARAMETERS)
;SO FORTRAN CARRIAGE CONTROL
;WILL WORK WHEN THE CUSTOMER PUTS UP 7.03

	.RBTYP==22		;FILE TYPE WORD
	  RB.DEC==1B0		;TELLS TOPS-10 TO PAY ATTENTION TO .RBTYP
	  RB.DCC==77B35		;CARRIAGE CONTROL
	    .RBCFO==1		;FORTRAN CARRIAGE CONTROL

> ;END IF10

IF20,<

	GT%ARG==1B22		;Arg block supplied for GET
	GT%BAS==1B2		;BASE-address word supplied in arg block
	FB%FOR==100000		;NOT DEFINED IN FIELD IMAGE MONSYM
	JS%NOD==400000,,0	;NOT DEFINED IN 5.1 MONSYM

	OPDEF	XGVEC%	[JSYS 606] ;[3156] Get extended entry vector info
	OPDEF	XSVEC%	[JSYS 607] ;[3156] Set extended entry vector info
	OPDEF	PDVOP%	[JSYS 603] ;[4120] MANIPULATES PROGRAM DATA VECTORS

;FUNCTION CODES ACCEPTED IN AC1:

.POGET==:0			;GET A SET OF PDVAS
				;(PROGRAM DATA VECTOR ADDRESSES)

;ARG BLOCK OFFSETS FOR BLOCK ADDRESSED BY AC2

.POCT1==:0			;SIZE OF ARG BLOCK INCLUDING THIS WORD
.POPHD==:1			;PROCESS HANDLE
.POCT2==:2			;SIZE OF DATA BLOCK (AND SIZE OF RETURNED DATA)
.PODAT==:3			;ADDRESS OF DATA BLOCK
.POADR==:4			;SMALL ADDRESS OF DATA VECTOR
.POADE==:5			;LARGE ADDRESS OF DATA VECTOR ADDRESS RANGE

;OFFSETS DEFINED WITHIN PROGRAM DATA VECTORS

.PVCNT==:0			;Length of vector
.PVNAM==:1			;Address of a word-aligned ASCIZ program name
.PVMEM==:5			;Address of a block describing program memory
.PVSYM==:6			;Address of the program symbol table

;[4120] PVMEM BLOCK (NOT YET IN MONSYM)
.PMCNT==:0			;COUNT OF ALL WORDS IN BLOCK
.PMDAT==:0			;HEADER FOR SUB-TABLE (BITS,,LENGTH)
.PMLOW==:1			;XFIW FOR BLOCK LO ADDRESS
.PMHI==:2			;XFIW FOR BLOCK HI ADDRESS
.PMRES==:3			;RESERVED TO DEC

;SYMBOL VECTOR DEFINITIONS
.STLEN==0			;SYMBOL VECTOR LENGTH
.STDAT==0			;TYPE AND SYMBOL TABLE LENGTH WORD
ST%TYP==77B5			;SYMBOL TABLE TYPE
ST%LEN==7777777777B35		;SYMBOL TABLE LENGTH
.STPTR==1			;SYMBOL TABLE POINTER WORD
.R50D==1

> ;END IF20


;FOROTS INITIALIZATION ARG BLOCK PARAMETERS

FDBS==0				;ADDRESS OF DBSTP$
FLAL==1				;ADDRESS OF USER FIXUP ARG BLOCK
FLGVX==2			;VALUE OF VAX FLAGGER
FLG77==3			;VALUE OF ANSI FLAGGER
FSTAD==4			;ADDRESS OF LOCATION CONTAINING START ADDRESS


;FOROP FUNCTIONS

FO$APR==0			;READ APR TABLE ADDRESSES
FO$ILL==1			;READ ILL FLAG ADDRESS
FO$ERR==2			;READ ERRSNS INFO
FO$DIV==3			;Set DIVERT unit
FO$HSP==4			;READ HIGH SEG SYMBOL POINTER
FO$FSV==5			;ENCODE A FORMAT
FO$FCL==6			;DELETE IT
FO$GLN==7			;GET THE CURRENT LSA LINE NUMBER
FO$MEM==10			;RETURN VARIOUS MEMORY PARAMETERS
FO$CHN==11			;RETURN ADDR OF CHANNEL WORD
FO$QIT==12			;QUIET EXIT FROM FORTRAN
FO$GDV==13			;Get DIVERT unit
FO$CLS==14			;CLOSE ALL FILES
FO$GCH==15			;GET CHANNEL # (-10) OR JFN (-20)
FO$GFB==16			;GET FILOP BLK ADDR (-10) OR 0 (-20)
FO$GFU==17			;GET FIRST FREE UNIT NUMBER
FO$GBA==20			;GET FORDDT BREAK ADDRESS FOR FOROTS ERRORS
FO$NOS==21			;SET FOROTS FOR NO SORT IN FOROTS' SECTION
FO$SRT==22			;PREMARK SORT SPACE IN FOROTS' SECTION
FO$UDB==23			;[3432] GET ADDRESS OF %UDBAD
FO$PAT==24			;GET AND ALLOW PA1050
FO$SVF==25			;SET FOROTS TO SAVE ENCODED FORMATS
FO$NSF==26			;SET FOROTS TO NOT SAVE ENCODED FORMATS
FO$DEF==27			;DEALLOCATE ENCODED FORMATS
FO$DMM==30			;SET DEBUG SWITCH FOR MEMORY MANAGER

.ETMAX==^D100			;Maximum FOROTS error msg # is 99
;MNEMONICS FOR OPEN/CLOSE KEYWORD NUMBERS


OK.IGN==0			;OMITTED ARG, IGNORED
OK.DIA==1			;DIALOG
OK.ACC==2			;ACCESS
OK.DEV==3			;DEVICE
OK.BFC==4			;BUFFER COUNT
OK.BLK==5			;BLOCK SIZE
OK.FIL==6			;FILE
OK.PRO==7			;PROTECTION
OK.DIR==10			;DIRECTORY
OK.LIM==11			;LIMIT
OK.MOD==12			;MODE
OK.FLS==13			;FILE SIZE
OK.REC==14			;RECORD SIZE
OK.DISP==15			;DISPOSE
OK.VER==16			;VERSION
OK.ORG==17			;ORGANIZATION
OK.SHR==20			;SHARED
OK.IOS==21			;IOSTAT
OK.ASV==22			;ASSOCIATE VARIABLE
OK.PAR==23			;PARITY
OK.DEN==24			;DENSITY
OK.BLNK==25			;BLANK
OK.CC==26			;CARRIAGE CONTROL
OK.FORM==27			;FORM
OK.BYT==30			;LABELS
OK.PAD==31			;PADCHAR
OK.RTP==32			;RECTYPE
OK.STAT==33			;STATUS
OK.TAPM==34			;TAPE MODE
OK.RO==35			;READONLY
OK.UNIT==36			;UNIT
OK.ERR==37			;ERR
OK.XST==40			;EXIST
OK.FRM==41			;FORMATTED
OK.NMD==42			;NAMED
OK.NRC==43			;NEXTREC
OK.NBR==44			;NUMBER
OK.OPN==45			;OPENED
OK.SEQ==46			;SEQUENTIAL
OK.UNF==47			;UNFORMATTED
OK.NAM==50			;NAME
OK.KEY==51			;KEY
;MNEMONICS FOR READ/WRITE/BACKSPACE (& FRIENDS) KEYWORD NUMBERS

IK.IGN==0			;OMITTED ARG, IGNORED
IK.UNIT==1			;UNIT
IK.FMT==2			;FMT
IK.FMS==3			;FORMAT SIZE
IK.END==4			;END
IK.ERR==5			;ERR
IK.IOS==6			;IOSTAT
IK.REC==7			;REC
IK.NML==10			;NAMELIST ADDRESS
IK.MTOP==11			;MTA OP CODE
IK.HSA==12			;HOLLERITH STRING (ENCODE/DECODE) ADDRESS
IK.HSL==13			;HOLLERITH STRING LENGTH, CHARS

;ORTHOGONAL DISPOSE/STATUS INDEX VALUES

SD.ILL==-1		;ILLEGAL
SD.NOU==0		;NOTHING, UNKNOWN
SD.NOS==1		;NOTHING, SAVE
SD.NOD==2		;NOTHING, DELETE
SD.NOX==3		;NOTHING, EXPUNGE
SD.PRU==4		;PRINT, UNKNOWN
SD.PRS==5		;PRINT, SAVE
SD.PRD==6		;PRINT, DELETE
SD.PRX==7		;PRINT, EXPUNGE
SD.PUU==10		;PUNCH, UNKNOWN
SD.PUS==11		;PUNCH, SAVE
SD.PUD==12		;PUNCH, DELETE
SD.PUX==13		;PUNCH, EXPUNGE
SD.SUU==14		;SUBMIT, UNKNOWN
SD.SUS==15		;SUBMIT, SAVE
SD.SUD==16		;SUBMIT, DELETE
SD.SUX==17		;SUBMIT, EXPUNGE
SD.PLU==20		;PLOT, UNKNOWN
SD.PLS==21		;PLOT, SAVE
SD.PLD==22		;PLOT, DELETE
SD.PLX==23		;PLOT, EXPUNGE
;FLAG BITS


	DEFINE	FLG (F) <
 %F==%F_-1
 F==%F_1>


;F: LOCAL FLAGS
;  Set to initial value at start of each I-O statement

%F==1B0
	FLG	F%ETP		;TYPE "E" FOR SCIENTIFIC NOTATION
	FLG	F%DTP		;TYPE "D" FOR SCIENTIFIC NOTATION
	FLG	F%GTP		;G FORMAT


;PERMANENT FLAGS, LEFT UNTIL EXPLICITLY CLEARED

%F==1B0
	FLG	D%WRT		;WE HAVE WRITE ACCESS TO FILE
	FLG	D%SEOL		;SUPPRESS NEXT END OF LINE SEQUENCE
	FLG	D%PDOL		;DOLLAR FORMAT IN PREVIOUS RECORD
	FLG	D%END		;EOF REACHED IN FILE
	FLG	D%MOD		;(20) DISK FILE MODIFIED, MUST UPDATE FDB
	FLG	D%IN		;FILE IS OPEN FOR INPUT
	FLG	D%OUT		;FILE IS OPEN FOR OUTPUT
	FLG	D%OPEN		;Explicit OPEN statement has been done

;TEMP FLAGS, CLEARED AT START OF EACH I/O STATEMENT

	FLG	D%STCR		;$ FORMAT IN THIS RECORD
	FLG	D%NML		;NAMELIST I/O
	FLG	D%LSD		;LIST-DIRECTED I/O

;Here are the flags to clear
	D%CLR== D%STCR+D%NML+D%LSD

;FLAGS FOR USE IN IOERR MACRO

%F==1B0
	FLG	I%REC		;TYPE ERRONEOUS RECORD WITH ARROW UNDER IT
	FLG	I%REC1		;SAME AS ABOVE BUT MOVE ARROW LEFT 1 CHAR
	FLG	I%FMT		;TYPE FORMAT STATEMENT WITH ARROW UNDER IT
	FLG	I%JERR		;ERROR CONTAINS $J, MUST GET ERROR # IN T1


	PURGE %F
;MACRO DEFINITIONS



;FOROTS ENTRY VECTOR

	DEFINE	FORVEC <

X	INIT		;FOROTS INITIALIZATION
X	FORER		;ERROR PROCESSOR
X	OPEN		;DEVICE OPEN
X	CLOSE		;DEVICE CLOSE
X	EXIT1		;CLOSE ALL FILES
X	IN		;FORMATTED INPUT
X	OUT		;FORMATTED OUTPUT
X	RTB		;UNFORMATTED BINARY INPUT
X	WTB		;UNFORMATTED BINARY OUTPUT
X	ENC		;ENCODE
X	DEC		;DECODE
X	NLI		;NAMELIST INPUT
X	NLO		;NAMELIST OUTPUT
X	IOLST		;INPUT/OUTPUT LIST ITEM PROCESSING
X	FIN		;INPUT/OUTPUT LIST TERMINATION
X	MTOP		;DEVICE POSITIONING/UTILITY FUNCTIONS
X	FIND		;RANDOM ACCESS RECORD FIND
X	EXIT		;PROGRAM TERMINATION
X	ALCOR		;DYNAMIC CORE ALLOCATION
X	DECOR		;DYNAMIC CORE DEALLOCATION
X	ALCHN		;ALLOCATE AN I/O CHANNEL
X	DECHN		;DEALLOCATE AN I/O CHANNEL
X	TRACE		;TRACEBACK OF ROUTINE CALLS
X	FUNCT		;GENERAL OTS INTERFACE
X	INQU		;INQUIRE BY UNIT
X	FOROP		;MISCELLANEOUS LIBRARY UTILITIES
X	IFI		;INTERNAL FILE INPUT
X	IFO		;INTERNAL FILE OUTPUT
X	MTHER		;MATH LIBRARY ERROR
X	ABORT		;ABORT WITH TRACE
X	INQF		;INQUIRE BY FILE

> ;END FORVEC

	DEFINE	FENTRY	(NAME1,NAME2)

<	ENTRY	NAME1'.
	SIXBIT	/NAME1'./
NAME1'.:

IFNB <NAME2>,
<	ENTRY	NAME2'.
NAME2'.:
> ;END IFNB NAME2

> ;END FENTRY

;FATAL JSYS ERROR REPORTING
; E.IJE (AND ERRIJE) LIVE IN FOROTS, AND WHEN INVOKED WILL
; TELL WHERE THE ERROR OCCURED AND HALT.

IF20,<
	DEFINE	JSHALT <
  IF2,<IFNDEF E.IJE,<EXTERN E.IJE>>
	ERCAL	E.IJE
 > ;END JSHALT
> ;END IF20

;STACK VARIABLE MACROS

;ALLOCATE ROOM FOR VARIABLES ON THE STACK
; GIVEN THE LIST OF VARIABLES 'L', COUNT
; THE NUMBER OF ITEMS, DEFINE THEM USING THE
; NAME GIVEN IN THE LIST 'L', ADJUST THE STACK
; UP FOR ALLOCATION, AND DEFINE THE UNSTK MACRO
; TO ADJUST THE STACK SIZE BACK DOWN

	DEFINE	STKVAR (L) <
 .L==0
 IRP L,<.L==.L+1>		;COUNT ARGS
 .N==0

 IRP L,<
  IFNB <L>,<
   STKDEF (L,\<.L-.N-1>)	;DEFINE NAMED ARG
  > ;END IFNB
  .N==.N+1
 > ;END IRP

	ADJSP	P,.L		;ALLOCATE STACK SPACE
	DEFINE	UNSTK <	ADJSP P,-.L >	;DEFINE DEALLOCATOR
 PURGE .N
> ;END STKVAR


;DEFINE STACK VARIABLE
; NAME 'E', DEFINED AS OFFSET -'V'

	DEFINE	STKDEF (E,V) <DEFINE E <-V(P)>>



;CONVENIENT DOUBLE WORD CLEAR, LOCATION 'E'AND 'E+1'

	DEFINE	DSETZM (E) <
	SETZM	E
	SETZM	1+E>
;Macros for field masks

;These are the standard TOPS-20 macros taken from MACSYM.

;CONSTRUCT BYTE POINTER TO MASK

	DEFINE	POINTR(LOC,MASK)<POINT WID(MASK),LOC,POS(MASK)>

;PUT RIGHT-JUSTIFIED VALUE INTO FIELD SPECIFIED BY MASK

	DEFINE	FLD(VAL,MSK)<<VAL>B<POS(MSK)>>

;ERROR MACROS

;	FERR	(CHR,COD,N1,N2,MSG,ARGS,FLGS)	;FORLIB ERROR
;	TERR	(CHR,COD,N1,N2,MSG,ARGS,FLGS)	;APR TRAP CALL
;
;CHR	INITIAL CHAR FOR ERROR MESSAGE ([, %, ?)
;	IF [, MESSAGE IS TERMINATED WITH ]
;	IF ?, TYPEAHEAD CLEARED AFTER MESSAGE
;	IF NULL, 3-CHAR PREFIX ISN'T TYPED
;	IF $, FIRST ARG IS INITIAL CHAR
;COD	3-CHARACTER PREFIX
;N1	ERROR CLASS NUMBER
;N2	2ND ERROR NUMBER
;MSG	TEXT OF ERROR MESSAGE
;	$ INDICATES AN ARG TO BE SUBSTITUTED INTO THE MESSAGE
;	THE CHAR AFTER THE $ GIVES THE FORMAT OF THE SUBSTITUTION
;ARGS	LIST OF ARGUMENT ADDRESSES, ONE-TO-ONE CORRESPONDENCE WITH $S
;	IN MESSAGE TEXT
;FLGS	ERROR FLAGS
;
;THE ERROR MACROS GENERATE 1 WORD IN LINE, SO CAN BE SKIPPED OVER.
;THEY DO NOT ALTER ANY ACS.

;
; MSG CAN INCLUDE FORMAT DESCRIPTORS OF THE FORM '$X'
; EACH FORMAT DESCRIPTOR TAKES AN ARGUMENT FROM THE LIST 'ARGS'
; THE CURRENT FORMATTING AVAILABLE IS:
;
;	$$		;TYPE $
;	$[		;TYPE LEFT ANGLE BRACKET
;	$O		;OCTAL NUMBER
;	$D		;DECIMAL NUMBER
;	$A		;ASCIZ STRING
;	$C		;ASCII CHAR, RIGHT-JUSTIFIED
;	$S		;SIXBIT WORD
;	$X		;XWD FORMAT, OCTAL
;	$5		;RADIX50 WORD
;	$L		;ADDRESS AS LABEL+OFFSET
;	$T		;SPACES TO GET TO COL N
;	$J		;JSYS ERROR MESSAGE [NO ARG] (FT20)
;	$Y		;MS TIME AS HH:MM:SS.S
;	$P		;ERROR PC, OCTAL [NO ARG]
;	$E		;LOOKUP/ENTER/RENAME ERROR STRING (FT10)
;	$I		;IO ERROR BITS CONVERTED TO ASCII [USES (D)] (FT10)
;	$F		;FILESPEC FROM DDB [NO ARG, USES (D)] (FT10)
;	$Z		;SIXBIZ OR ASCIZ STRING (FT10)
;	$Z		;SIXBIZ OR ASCIZ STRING (FT20)
;
; EACH CALL GENERATES 1 WORD OF CODE IN LINE, AND CAN BE SKIPPED

%EOFF==1			;OFFSET TO ERROR BLOCK

	DEFINE	EMSG (CHR,PFX,N1,N2,MSG,ARGS,FLAGS) <

	ENTRY	E.'PFX
E.'PFX:				;DEFINE THE ERROR IF NOT NULL
		"CHR"			;ERROR CHARACTER
		SIXBIT	/PFX/		;ERROR PREFIX
		EXP	N1,N2		;ERROR NUMBERS
		POINT 7,[ASCIZ \MSG\]	;POINTER TO MESSAGE
		EXP	FLAGS		;ATTRIBUTE FLAGS
IRP ARGS,	<ARGS>			;ARGUMENTS, IF ANY

> ;END EMSG
;SPECIAL ERRORS

;$SNH - generate "SHOULD NOT HAPPEN" error
	DEFINE	$SNH,<
	$ECALL	SNH
>;END DEFINE $SNH

;$IOERR TYPES A ONE-LINE PREFIX IDENTIFYING THE
; STATEMENT CONTAINING THE ERROR AND THE NAME OF THE CURRENT FILE.
; EXAMPLES:
;  $IOERR (ILF,,,?,ILLEGAL CHARACTER IN FORMAT)
;  $IOERR (RBR,39,310,?,REREAD NOT PROCEEDED BY READ)



	DEFINE	$IOERR (CHR,PFX,N1,N2,MSG,ARGS,FLAGS) <

	INTERN	E.'PFX
E.'PFX:

 IF2,<IFNDEF %IOERR,<EXTERN %IOERR>>
		PUSHJ	P,%IOERR
		"CHR"			;ERROR CHARACTER
		SIXBIT	/PFX/		;ERROR PREFIX
		EXP	N1,N2		;ERROR NUMBERS
		POINT 7,[ASCIZ \MSG\]	;POINTER TO MESSAGE
		EXP	FLAGS		;ATTRIBUTE FLAGS
IRP ARGS,	<ARGS>			;ARGUMENTS, IF ANY

> ;END $IOERR


;$FERR IS FOR USE BY FORLIB
; IT CALLS FORER.
; EXAMPLE:
;  FERR (DNO,21,125,?,DIVERT: UNIT $D IS NOT OPEN,<@(L)>)

	DEFINE	$FERR (CHR,PFX,N1,N2,MSG,ARGS,FLAGS) <

	ENTRY	F.'PFX
F.'PFX:
		PUSHJ	P,FORER.##
		"CHR"			;ERROR CHARACTER
		SIXBIT	/PFX/		;ERROR PREFIX
		EXP	N1,N2		;ERROR NUMBERS
		POINT 7,[ASCIZ \MSG\]	;POINTER TO MESSAGE
		EXP	FLAGS		;ATTRIBUTE FLAGS
IRP ARGS,	<ARGS>			;ARGUMENTS, IF ANY

>; END $FERR

;$DCALL CALLS AN ERROR ROUTINE DEFINED SOMEWHERE BY AN $DERR MACRO

	DEFINE	$DCALL (PFX,CONT) <
IFNB <CONT>,<PRINTX ?DCALL CONTINUATION ADDRESS SPECIFIED - IGNORED>
	EXTERN	D.'PFX
	JRST	D.'PFX
> ;END $DCALL

;$DJCAL CALLS AN ERROR ROUTINE DEFINED SOMEWHERE BY AN $DERR MACRO
;WITH AN ERJMP

	DEFINE	$DJCAL (PFX,CONT) <
IFNB <CONT>,<PRINTX ?DJCAL CONTINUATION ADDRESS SPECIFIED - IGNORED>
	EXTERN	D.'PFX
	ERJMP	D.'PFX
> ;END $DJCAL

;$FCALL CALLS AN ERROR ROUTINE DEFINED SOMEWHERE BY A FERR MACRO

	DEFINE	$FCALL (PFX,CONT) <
	EXTERN	F.'PFX
IFB <CONT>,<	PUSHJ	P,F.'PFX >
IFNB <CONT>,<JRST	[PUSHJ P,F.'PFX
			JRST CONT] >
> ;END $FCALL

;$FJCAL CALLS AN ERROR ROUTINE DEFINED SOMEWHERE BY A FERR MACRO

	DEFINE	$FJCAL (PFX,CONT) <
	EXTERN	F.'PFX
IFB <CONT>,<	ERCAL	F.'PFX >
IFNB <CONT>,<ERJMP	[PUSHJ P,F.'PFX
			JRST CONT] >
> ;END $FJCAL
;STORAGE/STRUCTURE DEFINITION MACROS
; NAME is defined to be a small offset, starting at 0.
;	or'ed with a bit in the left half that indicates special cases
;	(and causes a "U" MACRO error if used incorrectly!)
; %'NAME is defined to be RH= the rightmost bit used.
; LH(%'NAME) = 0 unless it is a byte ptr (not a halfword).
;    	then LH (%'NAME) = size of byte.

;Macro to start a structure definition

	DEFINE	DEFST,<
	$LOC==0
	$P==-1
	>

;Macro to define a name as a number and make sure
; that it had not been previously defined.
	DEFINE	DFN(NAME,LOC),<

	IF1,<
	IFDEF NAME, PRINTX ?NAME ALREADY DEFINED
	>;END IF1

	NAME==LOC

>;END DFN


;Macro to define N words.

	DEFINE	DEFWD (NAME,N<1>),<

IFGE $P,<
	$P==-1
	$LOC==$LOC+1	;Jump to next word
	>

	DFN (NAME,$LOC)
	%'NAME==^D35

	$LOC==$LOC+N
>;END DEFWD
;Macro to define a random byte

	DEFINE	DEFBYT (NAME,S),<

  IFG <$P+^D<S>-^D35>,<
	$P==-1
	$LOC==$LOC+1
	>
  $P==$P+^D<S>		;Find end position in word

	DFN (NAME,$LOC)	;Plain name is offset
	%'NAME==$P	;RH (%NAME) = rightmost bit

  %%DONE==0
  IFE <S - ^D18>,<	;Halfword
	IFE <$P - ^D35>,<	;Right halfword

		NAME==NAME+1B0
		%%DONE==1
	>
	IFE <$P - ^D17>,<	;Left halfword

		NAME==NAME+1B1
		%%DONE==1
	>
  >
  IFE %%DONE,<			;Not a halfword

		NAME==NAME+1B2
		%'NAME==%'NAME+ <<S>_^D30>	;Byte size in LH
  >
>;END DEFBYT



;Macro to define a DEFBYT or DEFWD such that
;  B simply renames A.
	DEFINE	DEFSNN (NEWNAM, OLDNAM),<

	DFN	NEWNAM,OLDNAM	;Check for name conflict
				; and define it the same
	%'NEWNAM==%'OLDNAM

>;END DEFSNN
;Macro to load a field

	DEFINE	LOAD (AC,NAME,THIRD),<
	IFNB <THIRD>,< PRINTX ?LOAD used with more than 2 args - AC, NAME >

	%%BTS==<NAME> & 7B2
	%%IDX==<<NAME>_-^D18> & ^O77	;Get index field if any
	%%LFT==<NAME> & ^O777777
	IFE <%%IDX>,<PRINTX %Index is zero for LOAD AC,NAME >

  IFE %%BTS,<
	MOVE	AC,NAME
  >
 IFN <%%BTS & 1B0>,<
	HRRZ	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B1>,<
	HLRZ	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B2>,<
	%%%S==<%'NAME>_-^D30	;Size of field
	%%%P==<%'NAME> & ^O77	;"P"
	LDB	AC,[POINT %%%S,%%LFT(%%IDX),%%%P]
  >
>;END DEFINE LOAD
;Macro to store a field

	DEFINE	STORE (AC,NAME,THIRD),<
	IFNB <THIRD>,<PRINTX ?STORE with more than 2 args - AC, NAME >

	%%BTS==<NAME> & 7B2
	%%IDX==<<NAME>_-^D18> & 77	;Get index field if any
	%%LFT==<NAME> & ^O777777
	IFE <%%IDX>,<PRINTX %Index is zero for STORE AC,NAME >

  IFE %%BTS,<
	MOVEM	AC,NAME
  >
 IFN <%%BTS & 1B0>,<
	HRRM	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B1>,<
	HRLM	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B2>,<
	%%%S==<%'NAME>_-^D30	;Size of field
	%%%P==<%'NAME> & ^O77	;"P"
	DPB	AC,[POINT %%%S,%%LFT(%%IDX),%%%P]
  >
>;END DEFINE STORE
;Macro to generate a "HRRE" or "HLRE"
;Gives error if the field is not a halfword.
	DEFINE	HXRE (AC,NAME,THIRD),<

	IFNB <THIRD>,< PRINTX ?HXRE used with more than 2 args - AC, NAME >

	%%BTS==<NAME> & 7B2
	%%IDX==<<NAME>_-^D18> & 77	;Get index field if any
	%%LFT==<NAME> & ^O777777
	IFE <%%IDX>,<PRINTX %Index is zero for HXRE AC,NAME >

  IFE <%%BTS & 3B1>,<
	PRINTX ?HXRE ERROR - NAME
  >
  IFN <%%BTS & 1B0>,<
	HRRE	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B1>,<
	HLRE	AC,%%LFT(%%IDX)
  >
>;END DEFINE HXRE


;Macro to generate a "HRL" or a "HLL"
;  Prints error if the field is not a halfword
	DEFINE	HXL (AC,NAME,THIRD),<

	IFNB <THIRD>,< PRINTX ?HXL used with more than 2 args - AC, NAME >

	%%BTS==<NAME> & 7B2
	%%IDX==<<NAME>_-^D18> & 77	;Get index field if any
	%%LFT==<NAME> & ^O777777
	IFE <%%IDX>,<PRINTX %Index is zero for HXL AC,NAME >

  IFE <%%BTS & 3B1>,<
	PRINTX ?HXL ERROR - NAME
  >
  IFN <%%BTS & 1B0>,<
	HRL	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B1>,<
	HLL	AC,%%LFT(%%IDX)
  >
>;END DEFINE HXL

;Macro to generate a "HRLZ" or a "HLLZ"
;  Prints error if the field is not a halfword
	DEFINE	HXLZ (AC,NAME,THIRD),<

	IFNB <THIRD>,< PRINTX ?HXLZ used with more than 2 args - AC, NAME >

	%%BTS==<NAME> & 7B2
	%%IDX==<<NAME>_-^D18> & 77	;Get index field if any
	%%LFT==<NAME> & ^O777777
	IFE <%%IDX>,<PRINTX %Index is zero for HXLZ AC,NAME >

  IFE <%%BTS & 3B1>,<
	PRINTX ?HXLZ ERROR - NAME
  >
  IFN <%%BTS & 1B0>,<
	HRLZ	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B1>,<
	HLLZ	AC,%%LFT(%%IDX)
  >
>;END DEFINE HXLZ
;Macro to generate a "HRR" or a "HLR"
;  Prints error if the field is not a halfword
	DEFINE	HXR (AC,NAME,THIRD),<

	IFNB <THIRD>,< PRINTX ?HXR used with more than 2 args - AC, NAME >

	%%BTS==<NAME> & 7B2
	%%IDX==<<NAME>_-^D18> & 77	;Get index field if any
	%%LFT==<NAME> & ^O777777
	IFE <%%IDX>,<PRINTX %Index is zero for HXR AC,NAME >

  IFE <%%BTS & 3B1>,<
	PRINTX ?HXR ERROR - NAME
  >
  IFN <%%BTS & 1B0>,<
	HRR	AC,%%LFT(%%IDX)
  >
  IFN <%%BTS & 1B1>,<
	HLR	AC,%%LFT(%%IDX)
  >
>;END DEFINE HXR
	SUBTTL	UDB - Unit Data Block
;+
;  Structure Definition For Unit Data Block 
;
;  Pointed to by AC U
;-

	DEFST			;Start the structure UDB

	DEFWD	DDBAD		;DDB address
	DEFWD	CNSL1		;Link to next unit block marked for
				; consolidation
	DEFWD	CNSL2		;Link to previous unit block marked for
				; consolidation
	DEFBYT	UNUM,^D18	;Unit number
	DEFBYT	BLNK,1		;/BLANK=
	  BL.NULL==0		;NULL (DEFAULT FOR OPEN STATEMENT)
	  BL.ZERO==1		;ZERO (DEFAULT FOR NO OPEN STATEMENT)

	DEFBYT	CC,3		;/CARRIAGECONTROL=
	  CC.DEV==0		;DEVICE (DEFAULT)
	  CC.FOR==1		;FORTRAN (SET FDB FORTRAN BIT)
	  CC.LST==2		;LIST (ADD CRLF WHEN PRINTING EACH RECORD)
	  CC.NON==3		;NONE (ADD NOTHING WHEN PRINTING FILE)
	  CC.TRN==4		;TRANSLATED (DO IMMEDIATE CC TRANSLATION)

	DEFBYT	PADCH,9		;/PADCHAR

	DEFBYT	PADSP,1		;PADCHAR SPECIFIED FLAG

	DEFWD	ULEN,0		;Length of UDB
	SUBTTL	DDB - Device Data Block
;+
;  Device Data Block (DDB) Offsets. There is only one DDB per open unit, 
;  however, there may be multiple units per DDB.
;
;  Pointed to by AC D
;-

	DEFST			;Start the structure definition

	DEFWD	USCNT		;How many unit blocks point to this DDB
	DEFWD	DVICE		;TOPS-10: Physical device name
				;TOPS-20: Device number

	DEFWD	IRPTR		;Current input record byte pointer
	DEFWD	IRCNT		;Current input record byte count

	DEFWD	ORPTR		;Current output record byte ptr
	DEFWD	ORCNT		;Current output record byte count

	DEFWD	IRBUF		;INPUT RECORD BUFFER PNTR
	DEFWD	ORBUF		;OUTPUT RECORD BUFFER PNTR

	DEFWD	IRBEG		;PNTRS TO BEG OF DATA
	DEFWD	ORBEG

	DEFWD	IRLEN		;INPUT RECORD LENGTH
	DEFWD	ORLEN		;Current output record length

	DEFWD	IRBLN		;INPUT RECORD BUFFER LENGTH
	DEFWD	ORBLN		;OUTPUT RECORD BUFFER LENGTH

	DEFWD	IRSIZ		;ROOM FOR DATA IN RECORD BUFFER
	DEFWD	ORSIZ

	DEFWD	ROFSET		;OFFSET FROM REC BUFFER TO DATA
	DEFWD	BOFSET		;OFFSET FROM BLOCK BUFFER TO DATA

	DEFWD	FAB		;ADDRESS OF RMS FAB
	DEFWD	RAB		;ADDRESS OF RMS RAB
	DEFWD	XAB		;ADDRESS OF RMS XAB

	DEFWD	WTAB		;Address of in-core page table
	DEFWD	PFTAB		;Address of page flag table (-1=modified)
	DEFWD	WPTR		;Core page address of file pages
	DEFWD	WSIZ		;Size of window in bytes
	DEFWD	WADR		;Sequential - Local (18-BIT) Address of window
				;Random - Offset into WTAB of least used page

IF20,<
	DEFSNN	BUFADR,WADR	;BUFFER ADDRESS SAME AS WINDOW ADDRESS

	DEFWD	IPTR		;Byte ptr to next byte from file
	DEFWD	ICNT		;Free byte count
	DEFWD	IJFN		;JFN
	DEFWD	OJFN		;Output JFN
				;Note: Always the same except if
				;     .PRIIN, .PRIOU
	DEFWD	TMPFIL		;-1=TEMPORARY FILE
	DEFWD	PPNSTR		;PPN STRING FOR TOPS-10 PROGRAMS
> ;END IF20

	DEFWD	BYTN		;Current byte number in file
	DEFWD	BLKN		;Block number
	DEFWD	AVAR		;/ASSOCIATE variable address
	DEFWD	CREC		;Number of current record

	DEFWD	FUMXD		;-1=FORMATTED/UNFORMATTED MIXED MODE FILE
	DEFWD	IOREC		;ROUTINE TO CALL TO READ OR WRITE A RECORD
	DEFWD	IOSUB		;ROUTINE TO CALL FOR IOLST.
	DEFWD	IOFIN		;ROUTINE TO CALL FOR FIN.
	DEFWD	LSNUM		;Line seq. number for this channel
	DEFWD	FLAGS		;DDB control flags (From DF)
	DEFWD	RSIZE		;Record size, in bytes or words
	DEFWD	MRSIZE		;MAXIMUM RECORD SIZE
	DEFWD	FRSIZW		;FORMATTED RECORD SIZE IN WORDS
	DEFWD	FRSIZB		;FORMATTED RECORD SIZE IN BYTES
	DEFWD	URSIZW		;UNFORMATTED RECORD SIZE IN WORDS
	DEFWD	URSIZB		;UNFORMATTED RECORD SIZE IN BYTES
	DEFWD	BPW		;BYTES PER WORD
	DEFWD	SPCWD		;A WORD OF SPACES FOR THIS FILE
	DEFWD	ORPOS		;VIRTUAL OUTPUT RECORD POSITION
	DEFWD	B36FLG		;FILE OPENED IN 36-BIT MODE
	DEFWD	IMGFLG		;IMAGE MODE - NO LSCW'S IN THIS FILE
	DEFWD	FILPRS		;FILESPEC HAS BEEN PARSED

	DEFWD	RECTP		;/RECORDTYPE
	  RT.UND==0		    ;  UNDEFINED (STREAM)
	  RT.FIX==1		    ;  FIXED
	  RT.DEL==2		    ;  DELIMITED (VARIABLE)
	  RT.SEG==3		    ;  SEGMENTED

	DEFBYT	QNSWT,9		;For /DISP:QUEUE, number of extra switches
	DEFBYT	QCNT,9		;LENGTH OF EXTRA SWITCHES, WORDS
	DEFBYT	QASWT,^D18	;ADDRESS OF BLOCK OF EXTRA SWITCHES
	DEFBYT	BLKSZ,^D18	;/BLOCK SIZE
	DEFBYT	LIMIT,^D18	;/LIMIT

	DEFBYT	BYTPT,^D18	;BYTE POINTER TO LAST BYTE OF WORD


	DEFBYT	TTYW,9		;LINE WIDTH, CHARACTERS

	DEFBYT	LTYP,6		;(MTA) LABEL TYPE
IF20,<	  LT.UNL==.LTUNL	    ;0 - UNLABELED>
IF10,<	  LT.UNL==0		    ;0 - UNLABELED>

	DEFBYT	ACC,4		;/ACCESS
	  AC.SIO==0		    ;  SEQUINOUT (SEQUENTIAL)
	  AC.SIN==1		    ;  SEQIN
	  AC.SOU==2		    ;  SEQOUT
	  AC.RIN==3		    ;  RANDIN
	  AC.RIO==4		    ;  RANDOM
	  AC.APP==5		    ;  APPEND
	  AC.NUM==6		    ;  NUMBER OF TYPES OF ACCESS (FOR SAIDX)

	DEFBYT	SAIDX,4		;STATUS/ACCESS INDEX
	  SA.ILL==-1		    ;  ILLEGAL COMBINATION OF STATUS/ACCESS
	  SA.UR==0		    ;  UNKNOWN, READ (MUST BE ZERO!)
	  SA.UW==1		    ;  UNKNOWN, WRITE
	  SA.URW==2		    ;  UNKNOWN, READ, WRITE
	  SA.UA==3		    ;  UNKNOWN, APPEND
	  SA.OR==4		    ;  OLD, READ
	  SA.OW==5		    ;  OLD, WRITE
	  SA.ORW==6		    ;  OLD, READ, WRITE
	  SA.OA==7		    ;  OLD, APPEND
	  SA.NW==10		    ;  NEW, WRITE
	  SA.SW==11		    ;  SCRATCH, WRITE

	DEFBYT	RENAM,1		;RENAME SPECIFIED IN CLOSE

	DEFBYT	BUFCT,6		;/BUFFER COUNT (0-63)
	DEFBYT	DEN,3		;/DENSITY
	  DN.DEF==0		    ;  DEFAULT (UNIT DEFAULT)
	  DN.200==1		    ;  200
	  DN.556==2		    ;  556
	  DN.800==3		    ;  800
	  DN.1600==4		    ;  1600
	  DN.6250==5		    ;  6250
	  DN.SYS==0		    ;  SYSTEM

	DEFBYT	UBSIZ,6		;/BYTESIZE (USER-SUPPLIED)

	DEFBYT	DISP,4		;/DISPOSE
	  DS.NOT==0		    ;  NOTHING (ALSO RENAME - IGNORED)
	  DS.SAVE==1		    ;  SAVE
	  DS.DEL==2		    ;  DELETE
	  DS.EXP==3		    ;  EXPUNGE
	  DS.PRNT==4		    ;  PRINT
	  DS.LIST==5		    ;  LIST
	  DS.PNCH==6		    ;  PUNCH
	  DS.SUB==7		    ;  SUBMIT
	  DS.PLT==10		    ;  PLOT

	DEFBYT	ODISP,2		;ORTHOGONAL DISPOSE VALUE
	  OD.NOT==0		    ;  NOTHING
	  OD.PRI==1		    ;  PRINT
	  OD.PUN==2		    ;  PUNCH
	  OD.SUB==3		    ;  SUBMIT
	  OD.PLT==4		    ;  PLOT

	DEFBYT	FORM,2		;/FORM
	  FM.FORM==1		    ;  FORMATTED
	  FM.UNF==2		    ;  UNFORMATTED

	DEFBYT	MODE,4		;/MODE
	  MD.IMG==1		    ;  IMAGE
	  MD.BIN==2		    ;  BINARY
	  MD.DMP==3		    ;  DUMP
	  MD.ASC==4		    ;  ASCII 7-BIT
	  MD.ASL==5		    ;  LINED
	  MD.AS9==6		    ;  ASCII 9-BIT

	DEFBYT	ORGAN,2		;/ORGANIZATION
	  OR.SEQ==0		    ;  SEQUENTIAL
	  OR.REL==1		    ;  RELATIVE (DIRECT)
	  OR.IDX==2		    ;  INDEXED (ISAM)

	DEFBYT	PAR,2		;/PARITY
	  PR.ODD==1		    ;  ODD (DEFAULT)
	  PR.EVEN==2		    ;  EVEN

	DEFBYT	RO,1		;/READONLY

	DEFBYT	SHARE,1		;/SHARED

	DEFBYT	STAT,4		;/STATUS
	  ST.UNK==0		    ;  UNKNOWN
	  ST.OLD==1		    ;  OLD
	  ST.NEW==2		    ;  NEW
	  ST.SCR==3		    ;  SCRATCH
	  ST.DISP==4		    ;  F-77 CLOSE STATUS WHICH IS REALLY
				    ;  DISPOSITION
	  ST.SAV==4		    ;  SAVE
	  ST.DEL==5		    ;  DELETE
	  ST.EXP==6		    ;  EXPUNGE
	  ST.NUM==7		    ;  NUMBER OF STATUS VALUES (FOR DSIDX)

	DEFBYT	OSTAT,2		;ORTHOGONAL CLOSE STATUS VALUE
	  OS.UNK==0		    ;  UNKNOWN
	  OS.SAV==1		    ;  SAVE
	  OS.DEL==2		    ;  DELETE
	  OS.EXP==3		    ;  EXPUNGE

	DEFBYT	TAPM,3		;/TAPEMODE
IF20,<
	  TM.SYS==.SJDDM 	   ;  (0) SYSTEM DEFAULT 
	  TM.DMP==.SJDMC 	   ;  (1) CORE-DUMP (36-BIT BYTES)
	  TM.SIX==.SJDM6 	   ;  (2) SIXBIT (7-TRACK)
	  TM.ANS==.SJDMA 	   ;  (3) ANSI-ASCII
	  TM.IND==.SJDM8 	   ;  (4) INDUSTRY COMPATIBLE
	  TM.HDN==.SJDMH 	   ;  (5) HIGH-DENSITY
> ;END IF20

IF10,<
	  TM.SYS==.TFMDD	   ;  (0) SYSTEM DEFAULT
	  TM.DMP==.TFMID	   ;  (1) 9-TRACK CORE-DUMP
	  TM.SX9==.TFM6B	   ;  (3) 9-TRACK SIXBIT
	  TM.IND==.TFM8B	   ;  (2) INDUSTRY-COMPATIBLE
	  TM.ANS==.TFM7B	   ;  (4) ANSI-ASCII
	  TM.SIX==.TFM7T	   ;  (5) SIXBIT (7-TRACK)
> ;END IF10

	DEFWD	DVBTS,0		;DEVCHR BITS

IF20,<
	DEFBYT	DVIO,2		;INPUT/OUTPUT LEGAL
	DEFBYT	DRDVF,1		;1= "this is a directory device"
	DEFBYT	DVAS,1		;ASSIGNABLE
	DEFBYT	DVMDD,1		;MULTIPLE DIRECTORIES
	DEFBYT	DVAV,1		;AVAILABLE
	DEFBYT	DVASN,1		;ASSIGNED
	DEFBYT	DVJNK,1		;NOT USED
	DEFBYT	DVMNT,1		;MOUNTED
	DEFBYT	DVTYP,9		;DEVTYP CODE

	  DT.DSK==.DVDSK	    ;DISK
	  DT.MTA==.DVMTA	    ;MTA
	  DT.DTA==.DVDTA	    ;DTA
	  DT.NUL==.DVNUL	    ;NULL DEVICE
	  DT.TTY==.DVTTY	    ;TTY
	  DT.PTY==.DVPTY	    ;PTY
	  DT.LPT==.DVLPT	    ;LPT
	  DT.PLT==.DVPLT	    ;PLOTTER
> ;END IF20

IF10,<
	DEFBYT	DFILL,16	;DEVCHR FIELDS WE DON'T USE
	DEFBYT	DVIO,2		;DEVICE CAN DO INPUT, OUTPUT

	  DV%IN==DV.IN		;DEVICE CAN DO INPUT
	  DV%OUT==DV.OUT	;DEVICE CAN DO OUTPUT

	DEFWD	DVTW,0		;DEVTYP WORD
	DEFBYT	DFIL2,30	;DEVTYP FIELDS WE DON'T USE
	DEFBYT	DVTYP,6		;DEVICE TYPE

	  DT.NUL==.TYDSK	    ;NULL DEVICE
	  DT.DSK==.TYDSK	    ;DISK
	  DT.DTA==.TYDTA	    ;DTA
	  DT.MTA==.TYMTA	    ;MTA
	  DT.PTY==.TYPTY	    ;PTY
	  DT.LPT==.TYLPT	    ;LPT
	  DT.PLT==.TYPLT	    ;PLOTTER
	  DT.TTY==.TYTTY	    ;TTY
> ;END IF10

	DEFBYT LGLM,^D16	;LEGAL DATA MODES

	DEFBYT INDX,3		;DEVICE INDEX (FOR SPECIAL-CASE CODE)
	  DI.TTY==0		    ;TTY
	  DI.DSK==1		    ;DISK
	  DI.MTA==2		    ;MTA
	  DI.OTHR==3		    ;ANYTHING ELSE
	  DI.RMS==4		    ;RMS FILE

	DEFWD	EOFN		;(Disk) Number of bytes in file

	DEFWD	FILSPC,0	;BEGINNING OF FILESPEC PART OF DDB

	DEFWD	PASWRD,8	;REMOTE ACCESS PASSWORD
	DEFWD	ACCNT,8		;ACCOUNT STRING
	DEFWD	USERID,8	;USER ID

	LFILW==20		;LENGTH OF FILENAME
	LFILC==LFILW*5		;AND IN CHARS
	LEXTW==20		;LENGTH OF EXTENSION
	LEXTC==LEXTW*5		;AND IN CHARS
	LDEVW==20		;LENGTH OF DEVICE
	LDEVC==LDEVW*5		;AND IN CHARS
	LDIRW==20		;LENGTH OF DIRECTORY
	LDIRC==LDIRW*5		;AND IN CHARS
	LNODW==2		;LENGTH OF NODENAME
	LNODC==LNODW*5		;AND IN CHARS
	LPROTW==2		;LENGTH OF PROTECTION CODE
	LPROTC==LPROTW*5	;AND IN CHARS
	LGENW==2		;LENGTH OF GENERATION
	LGENC==LGENW*5		;AND IN CHARS

	DEFWD	NODNAM,LNODW	;Node name
	DEFWD	DEV,LDEVW	;Device name (1-39 chars, ASCIZ)
	DEFWD	DIRNAM,LDIRW	;Directory name (can include ^V's)
	DEFWD	FILNAM,LFILW	;File name
	DEFWD	EXT,LEXTW	;Extension
	DEFWD	PROT,LPROTW	;Protection (0-6 chars, ASCIZ)
	DEFWD	GEN,LGENW	;Generation number (0-6 chars, ASCIZ)
.FSSLN==$LOC-FILSPC-1		;Length of filespec stuff

IF20,<
	DEFWD	DMABS,0		;Data mode & byte size
	DEFBYT	BSIZ,6		;Byte size
	DEFBYT	DMODE,4		;Data mode

	DEFWD	VERN		;Version number (ignored)
> ;END IF20
IF10,<
	DEFWD	BSIZ		;BYTE SIZE

	DEFWD	FBLK,.FOMAX	;FILOP block.
	DEFSNN	CHAN,FBLK	;Channel,,FN
	DEFSNN	IJFN,FBLK	;MORE FOR COMPATIBILITY
	DEFSNN	OJFN,FBLK	;DITTO

	DEFWD	LKPB,.RBMAX	;LOOKUP/ENTER block
	VERN==LKPB+.RBVER	;VERSION NUMBER

	DEFWD	PTHB,.PTMAX	;PATH. block. Set by FILOP to the real
				; true path to the file.

	DEFWD	BUFADR		;BUFFER ADDRESS

	DEFWD	IBCB		;Input buffer control block
	DEFWD	IPTR,0		;Byte pointer.
	DEFBYT	FILL2,6		;FILLER
	DEFBYT	IBSIZ,6		;Byte size
	DEFWD	ICNT		;Count

	DEFWD	TBCB		;Output buffer control block
	DEFWD	TPTR,0		;Byte ptr.
	DEFBYT	FILL3,6		;FILLER
	DEFBYT	TBSIZ,6		;Byte size
	DEFWD	TCNT		;Count

> ;END IF10

	DEFWD	DLEN,0		;Length of DDB

;  CLEAN UP AFTER DDB DEFINITION

	PURGE $P,$LOC,%%DONE
	SUBTTL	FORPRG - Purge Global Symbols 
;+
;  Purge global symbols created by MONSYM which do not have "%" 
;  or "." in them. Also to purge JS%DEV, which changed its value between
;  Release 5.1 and Release 6 of the monitor.

;-

	DEFINE	FORPRG<

	PURGE	ERJMP,ERCAL,GJFX3,GJFX18,GJFX19,GJFX24,GJFX27
	PURGE	IOX4
	PURGE	IPCFX6,IPCFX8
	PURGE	LNGFX1
	PURGE	NPXAMB,NPXNC,NPXNOM
	PURGE	OPNX2,OPNX9
	PURGE	JS%DEV

> ;END FORPRG

	END