Google
 

Trailing-Edge - PDP-10 Archives - ap-c800d-sb - pure.mac
There are 9 other files named pure.mac in the archive. Click here to see a list.
; UPD ID= 1830 on 4/13/79 at 1:11 PM by N:<NIXON>
SUBTTL	PURE CONSTANTS FOR COBOL		A.BLACKINGTON/CAM/SEB



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.
;
;COPYRIGHT (C) 1974, 1979 BY DIGITAL EQUIPMENT CORPORATION


	SEARCH	P
	%%P==:%%P
	ONESEG==:ONESEG
	MCS==:MCS
	TCS==:TCS
	DBMS6==:DBMS6
	DBMS4==:DBMS4
	DBMS==:DBMS
	DEBUG==:DEBUG
	RPW==:RPW
	STRING==:STRING
	ISAM==:ISAM
	SERCH==:SERCH
	EBCMP.==:EBCMP.
	MPWCEX==:MPWCEX

	SEARCH	TABLES

;EDITS
;NAME	DATE		COMMENTS

;V12*****************
;DAW	20-FEB-79	[634] ADD QUAD-WORD SIZE ERROR ROUTINES.
;DMN	 4-DEC-78	[605] ADD FILE-TABLE OFFSET FOR VAR. LEN. READ
;DMN	 6-OCT-78	[570] ADD QUAD-WORD ROUNDING FUNCTION.

;V10*****************
;SSC	28-SEPT-77	ADD NEW DBMS-V6 ENTRY PTS: OPENT,FIND6,DELTR,CLOTR
;	27-AUG-76	; [441] ADD ZERO COMPARE ROUTINES, NEEDS 454 IN LIBOL
;SSC	29-JUL-76	ADD ENTRY POINTS FOR DBMS S. U.
;ACK	12-JAN-75	ADDED CAPABILITY TO HANDLE DIAGS UP TO 1023.
;ACK	12-JAN-75	CHANGED FILE TABLE STRUCTURE:
;			1.  MOVED EXTERNAL RECORDING MODE FIELD FROM
;				WORD 6 BITS 0-1 TO WORD 5 BITS 5-7.
;			2.  ADDED A WORD (20) FOR SIMULTANEOUS ACCESS.
;			3.  ADDED FOUR WORDS (21-24) FOR I/O ERROR HANDLING
;				RE THE FILE-STATUS CLAUSE.
;ACK	31-JAN-75	MOVED INTERNAL RECORDING MODE FIELD FROM WORD 6
;				BITS 14-15 TO WORD 5 BITS 8-10.
;ACK	10-MAR-75	ADDED AN ASSEMBLY CODE FOR EBCDIC LITERALS.
;ACK	13-APR-75	MOVED TABLE DESCRIPTIONS TO UNIVERSAL TABLES.
;DBT	5/5/75		ADD EDIT.B - BIS EXTERNAL EDIT ROUTINE
;********************

; EDIT 263 MAKE TALLY RECOGNIZABLE IN PHASE F 
; [201] ADDED EXTERNAL COBST.


TWOSEG
RELOC	400000
; THIS LOCATION IS DEFINED SO THAT ANY GIVEN COBOL COMPILER SEGMENT
; CAN BE EXAMINED TO SEE WHAT FEATURE TEST SWITCHES WERE USED
; TO BUILD IT
;     EXAMINE   400010

COBSW%::	EXP	SWSET%

;THIS SOURCE IS IDENTICAL FOR PROGRAMS PURAB, PUREC, PURED, PUREE, PUREO & PURFG
;	EXCEPT FOR THE VALUE OF MLOAD.

;ASSEMBLE WITH THE APPROPRIATE PARAMETER FILE PURAB.MAC,
;    PUREC.MAC, PURED.MAC, PUREE.MAC, PUREO.MAC, OR PURFG.MAC TO MAKE THE
;    CORRESPONDING REL FILE

	SALL

IFN ANS68,<
	DEFINE .TITLE (X),<TITLE X FOR COBOL-68 12		>
>
IFN ANS74,<
	DEFINE .TITLE (X),<TITLE X FOR COBOL-74 12		>
>
A.==1
B.==2
C.==4
D.==10
E.==20
F.==40
G.==100
O.==200

AB.==A.!B.
ABC.==A.!B.!C.
ABCD.==A.!B.!C.!D.
ABCDE.==A.!B.!C.!D.!E.
ABCDEO.==A.!B.!C.!D.!E.!O.
ADEFG.==A.!D.!E.!F.!G.!O.
CDE.==C.!D.!E.
BC.==B.!C.
BCE.==B.!C.!E.
BCD.==B.!C.!D.
BCDE.==B.!C.!D.!E.
BCDEFG==B.!C.!D.!E.!F.!G.!O.
BD.==B.!D.
BDE.==B.!D.!E.
CD.==C.!D.
DE.==D.!E.
DEFG.==D.!E.!F.!G.!
EO.==E.!O.
EOG.==E.!O.!G.
EG.==E.!G.
FG.==F.!G.
OG.==O.!G.

IFNDEF %MLOAD,< %MLOAD=="A">		;GIVE THIS A VALUE FOR ONE-SEG COMPILER

IFE %MLOAD-"A",<MLOAD==A.!B.>
IFE %MLOAD-"C",<MLOAD==C.>
IFE %MLOAD-"D",<MLOAD==D.>
IFE %MLOAD-"E",<MLOAD==E.>
IFE %MLOAD-"F",<MLOAD==F.!G.>
IFE %MLOAD-"O",<MLOAD==O.>
IFE ONESEG,<

	IFN MLOAD&AB.,	<.TITLE PURAB
		SUBTTL CONSTANTS USED BY PHASE A & B
		ENTRY PUREA
		PUREA:
		ENTRY PUREB
		PUREB:
		>

	IFN MLOAD&C.,	<.TITLE PUREC
		SUBTTL CONSTANTS USED BY PHASE C
		ENTRY PUREC
		PUREC:
	>

	IFN MLOAD&D.,	<.TITLE PURED 
		SUBTTL CONSTANTS USED BY PHASE D
		 ENTRY PURED
		 PURED:>

	IFN MLOAD&E.,	<.TITLE PUREE
		 SUBTTL CONSTANTS USED BY PHASE E
		 ENTRY PUREE
		 PUREE:>

	IFN MLOAD&O.,	<.TITLE PUREO
		 SUBTTL CONSTANTS USED BY PHASE O
		 ENTRY PUREO
		 PUREO:>

	IFN MLOAD&FG.,	<.TITLE PURFG
		 SUBTTL CONSTANTS USED BY PHASES F & G
		ENTRY PUREF
		PUREF:
		ENTRY PUREG
		PUREG:
		>
>
IFN ONESEG,<
	.TITLE	PURE
	ENTRY	PUREA,PUREB,PUREC,PURED,PUREE,PUREO,PUREF,PUREG
PUREA: PUREB: PUREC: PURED: PUREE: PUREF: PUREG: PUREO:
>


	INTERNAL MLOAD1
	MLOAD1=="B"	;HIGHEST PHASE IN FIRST MACHINE LOAD
IFE ONESEG,<
;GET NEXT MACHINE LOAD

	IFN MLOAD&AB.,<INTERNAL COBOLC
COBOLC:
IFN ANS68,<
	MOVE	TA,['COBOLC']
>
IFN ANS74,<
	MOVE	TA,['CBL74C']
>
	JRST	GETFAZ
	>

	IFN MLOAD&E.,<INTERNAL COBOLO
COBOLO:
IFN ANS68,<
	MOVE	TA,['COBOLO']
>
IFN ANS74,<
	MOVE	TA,['CBL74O']
>
	JRST	GETFAZ
	>

	IFN MLOAD&ABC.,<INTERNAL COBOLD
COBOLD:
IFN ANS68,<
	SKIPA	TA,['COBOLD']
>
IFN ANS74,<
	SKIPA	TA,['CBL74D']
>
	>

	IFN MLOAD&ABCD.,<INTERNAL COBOLE
COBOLE:
IFN ANS68,<
	MOVE	TA,['COBOLE']
>
IFN ANS74,<
	MOVE	TA,['CBL74E']
>
	>

	IFN MLOAD&EO.,<INTERNAL COBOLF
COBOLF:
IFN ANS68,<
	MOVE	TA,['COBOLF']
>
IFN ANS74,<
	MOVE	TA,['CBL74F']
>
	>

	IFN MLOAD&ABCDEO.,<EXTERNAL GETFAZ
	JRST	GETFAZ
	>
	>


	DEFINE SETUP (A,B), <
		INTERNAL A
		A: B
	>

	DEFINE SETVAL (A,B), <
		INTERNAL A
		A==B>
;CONSTANTS USED BY ALL PHASES


	SETUP ERAPOS,<POINT 7,DW,21>;  CHARACTER POSITION FIELD IN DIAG WORD
	SETUP ERALN,<POINT 13,DW,14>;  LINE NUMBER FIELD IN DIAG WORD
	SETUP ERANUM,<POINT 10,DW,35>;  DIAG NUMBER FIELD IN DIAG WORD
	SETUP ERAFAZ,<POINT 3,DW,24>;  PHASE NUMBER FIELD IN DIAG WORD
	SETUP OUTBOP,<OUTBUF 2>;	OUTBUF UUO
	SETUP INBOP,<INBUF 2>;		INBUF UUO

	SETVAL LINPAG,^D56;		;LINES PER PRINTED PAGE
	SETVAL CPMAXN,^D112		;CHARACTERS PER PRINTED LINE

	SETVAL MAXWSS,777777	;SIZE OF LARGEST ALLOWED ITEM IN WORKING-STORAGE
	SETVAL MAXFSS,7777	;SIZE OF LARGEST ALLOWED ITEM IN FILE SECTION
	SETVAL MAXOCC,77777	;GREATEST NUMBER OF OCCURENCES ALLOWED
	SETVAL WRKSIZ,^D10*2000	;SIZE OF IMPURE AREA
	SETVAL NAMCST,2		;A CONSTANT USED BY TRYNAM&BLDNAM

EXTERNAL NNDLNT,NODLST,NSVLNT,SAVLST
EXTERNAL ARGLST,ARGLSZ,ARGL2,ARG2SZ,PPSIZE,PPLIST

	SETUP INDPTR,<XWD NNDLNT,NODLST-1>
	SETUP ISVPTR,<XWD NSVLNT,SAVLST-1>
	SETUP IARGL,<XWD ARGLSZ,ARGLST-1>
	SETUP IARGL2,<XWD ARG2SZ,ARGL2-1>
	SETUP PPOINT,<XWD PPSIZE,PPLIST-1>
;PARAMETERS USED WHEN PLAYING WITH TABLE LINKS

	SETUP LNKCOD,<POINT 3,TA,20>	;CODE IN A TABLE LINK
	SETVAL LMASKB,77777	;MASK OF LINK BITS FOR TABLE-LINK OF BIG TABLE
	SETVAL LMASKS,77777	;SAME FOR SMALL TABLE
	DEFINE TABVAL (NAME,CODE),<
	INTERNAL TB.'NAME,TC.'NAME,TM.'NAME
	TB.'NAME==CODE
	TC.'NAME==CODE'*100000
	TM.'NAME==77777
	>

	TABVAL FIL,0
	TABVAL DAT,1
	TABVAL CON,2
	TABVAL LIT,3
	TABVAL PRO,4
	TABVAL EXT,5
	TABVAL VAL,6
	TABVAL MNE,7

	SETVAL TM.TAG,77777
;CONSTANTS USED BY PHASE A

	IFN MLOAD&A.!ONESEG,<

	SETUP ENTROP,<ENTER I1>;  ENTER UUO
	SETUP LIBSET,<SIXBIT "DSK"
			SIXBIT "LIBARY"
			SIXBIT "LIB"
			Z>;


;QUANTUM VALUES FOR SIZES OF NM1TAB&NM2TAB.
;SEE 'NTNSIZ' IN IMPURE FOR NUMBER OF ENTRIES.

	SETVAL NTSIZE,.
	DEC	1009
	DEC	1499
	DEC	1999
	DEC	2503
	DEC	3001
	DEC	3499
	DEC	4001
	DEC	4507
	DEC	5003
	DEC	5501
	DEC	6007
	DEC	6491
	DEC	7001
	DEC	7499
	DEC	8009
	DEC	8501
	DEC	9001
	DEC	9497
	DEC	10007

>
;CONSTANTS USED BY PHASES A,B,C,D

	IFN MLOAD&ABCD.!ONESEG,<

	SETUP I0CHAN,<POINT 4,I0,12>;  AC FIELD OF "I0"
	SETUP OPENOP,<OPEN I1>;	OPEN UUO
	SETUP LOOKOP,<LOOKUP I1>;	LOOKUP UUO
	SETVAL TRACEI,1B32	;CORESW FLAG FOR TRACEING ID
	SETVAL TRACEE,1B33	;CORESW FLAG FOR TRACEING ED
	SETVAL TRACED,1B34	;CORESW FLAG FOR TRACEING DD
	SETVAL TRACEP,1B35	;CORESW FLAG FOR TRACEING PD

	SETUP NAMVAL,<POINT 15,(TA),17>;VALUE OF RESERVED WORD IN NAMTAB ENTRY

	>

;CONSTANTS USED BY PHASES B,C,D

	IFN MLOAD&BCD.!ONESEG, <

	SETVAL COMWD,GWRESV+765;	"W1" VALUE FOR COMMA
	SETVAL SEMIWD,GWRESV+766;	"W1" VALUE FOR SEMI-COLON
	SETVAL LPARWD,GWRESV+767;	"W1" VALUE FOR LEFT-PAREN
	SETVAL PERWD,GWRESV+771;	"W1" VALUE FOR PERIOD
	SETVAL PLUSWD,GWRESV+772;	"W1" VALUE FOR PLUS
	SETVAL MINWD,GWRESV+773;	"W1" VALUE FOR MINUS OR HYPHEN
	SETVAL MULWD,GWRESV+775;	"W1" VALUE FOR STAR
	SETVAL EXPWD,GWRESV+776;	"W1" VALUE FOR "**"
	SETVAL ENDIT,GWRESV+777;	"W1" VALUE FOR END-OF-SOURCE
	SETUP RPARWD,<XWD GWRESV+770,")">	;W1 VALUE FOR RIGHT PAREN
	XWD GWRESV+774,"/"	;W1 VALUE FOR SLASH
	XWD GWRESV+342,74	;W1 VALUE FOR LESS
	XWD GWRESV+322,"="	;W1 VALUE FOR EQUAL
	XWD GWRESV+332,76	;W1 VALUE FOR GREATER
	XWD GWRESV+776,"^"	;W1 VALUE FOR EXPONENTIATION "^"

	SETUP PUNPTR,<XWD RPARWD-.,RPARWD>

	SETUP GWNAMP,<POINT 15,W2,15>;	NAMTAB POINTER FIELD IN "W2"
	SETUP GWLN,<POINT 13,W2,28>;	LINE-NUMBER FIELD IN "W2"
	SETUP GWCP,<POINT 7,W2,35>;	CHARACTER-POSITION FIELD IN "W2"
	SETUP GWVAL,<POINT 9,W1,17>;	RESERVED-WORD VALUE IN "W1"

>
	IFN MLOAD&DE.!ONESEG,<
;GENFIL OPERATOR CODES

	SETVAL OPMOVE,001	;MOVE A TO B,...
	SETVAL OPADD, 002	;ADD A,B... (GIVING...)
	SETVAL OPADDT,003	;ADD A,... (TO...)
	SETVAL OPSUB, 004	;SUBTRACT A,... FROM B (GIVING...)
	SETVAL OPSUBF,005	;SUBTRACT A,... (FROM...)
	SETVAL OPMUL, 006	;MULTIPLY A BY B (GIVING...)
	SETVAL OPMULB,007	;MULTIPLY A (BY...)

	SETVAL OPDIV, 010	;DIVIDE A BY B (GIVING...)
	SETVAL OPRESU,011	;GIVING (FROM,TO,BY) A,...
	SETVAL OPREMA,012	;REMAINDER A
	SETVAL OPDIVB,013	;DIVIDE A BY B (NO GIVING)

	SETVAL OPIF,  020	;IF A (=, <, >) B
	SETVAL OPIFC, 021	;IF CONDITION-NAME-A
	SETVAL OPIFT, 022	;IF NUMERIC, POSITIVE,...
	SETVAL OPSPIF,023	;AT END, INV.KEY, SIZE ERROR
	SETVAL OPELSE,024	;BEGINNING OF ELSE PATH FOR CONDITIONAL
	SETVAL OPENDI,026	;END OF CONDITIONAL

	SETVAL OPGO,  030	;GO TO A
	SETVAL OPGODE,031	;GO TO A,... DEPENDING ON B
	SETVAL OPPERF,032	;PERFORM A [THRU B]
	SETVAL OPPRFT,033	;PERFORM A [THRU B] C TIMES
	SETVAL OPALTE,034	;ALTER A TO PROCEED TO B
	SETVAL OPSEAR,035	;SEARCH A
	SETVAL OPSINC,036	;SEARCH INCREMENT

	SETVAL OPSTOP,040	;STOP RUN, STOP A
	SETVAL OPEXAM,042	;EXAMINE A TALLYING B [REPLACING C]
	SETVAL OPSETT,043	;SET A,... TO B
	SETVAL OPSETD,044	;SET A,... DOWN BY B
	SETVAL OPSETU,045	;SET A,... UP BY B
	SETVAL OPUSIN,046	;(ENTER B) USING A,...
	SETVAL OPENTE,047	;ENTER

	SETVAL OPCOMP,050	;COMPUTE B=...
	SETVAL OPCADD,051	;+A
	SETVAL OPCSUB,052	;-A
	SETVAL OPCMUL,053	;*A
	SETVAL OPCDIV,054	;/A
	SETVAL OPCEXP,055	;**A

	SETVAL OPCEND,057	;END OF COMPUTE
	SETVAL OPACCE,060	;ACCEPT A,... [FROM B]
	SETVAL OPDISP,061	;DISPLAY A,... [UPON B]
	SETVAL OPOPEN,062	;OPEN A
	SETVAL OPCLOS,063	;CLOSE A
	SETVAL OPREAD,064	;READ A
	SETVAL OPWRIT,065	;WRITE A [ADVANCING B]
	SETVAL OPRERI,066	;REWRITE A
	SETVAL OPSEEK,067	;SEEK A

	SETVAL OPLPAR,070	;LEFT PARENTHESIS
	SETVAL OPRPAR,071	;RIGHT PARENTHESIS
	SETVAL OPEXP, 072	;START EXPRESSION
	SETVAL OPENDE,073	;END EXPRESSION
	SETVAL OPJUMP,074	;GENERATED CONTROL TRANSFER
	SETVAL OPERAU,075	;ERROR USE PROCEDURE
	SETVAL OPCLRE,076	;CLEAR EOPTAB

	SETVAL OPSECN,100	;SECTION-NAME-A
	SETVAL OPPARN,101	;PARAGRAPH-NAME-A
	SETVAL OPTAGN,102	;SPECIAL TAG (%NNNNN)
	SETVAL OPSENA,103	;REFERENCE POINT FOR SENTENCES
	SETVAL OPENDS,104	;END OF SECTION
	SETVAL OPYECC,105	;IGNORE ALL PRECEDING OPERANDS

	SETVAL OPSORT,110	;SORT A ...
	SETVAL OPKEY, 111	;KEY A
	SETVAL OPINPR,112	;INPUT PROCEDURE IS A [THRU B]
	SETVAL OPOUTP,113	;OUTPUT PROCEDURE IS A [THRU B]
	SETVAL OPGIVI,114	;GIVING A
	SETVAL OPUSIN,115	;USING A
	SETVAL OPENDS,116	;END OF SORT STATEMENT
	SETVAL OPMERG,117	;MERGE A ...

	SETVAL OPRELE,120	;RELEASE A [FROM B]
	SETVAL OPRETU,121	;RETURN A [INTO B]
	SETVAL OPDELE,122	;DELETE A
	SETVAL OPINIT,123	;INITIATE A
	SETVAL OPGENR,124	;GENERATE A
	SETVAL OPTERM,125	;TERMINATE A
	SETVAL OPTRAC,126	;TRACE ON/OFF

	SETVAL OPENDI,377	;END OF SOURCE

	>
;FILTAB DEFINITIONS

	IFN MLOAD&BCDEFG!ONESEG,<

	FITB%C

	SETVAL FI.CLR,-^O34	;[605] REL. LOC. OF NO. OF CHAR. LAST READ

>


;DATAB DEFINITIONS

	IFN MLOAD&BCDEFG!ONESEG,<

	DATB%C

	SETVAL DA.EDW,^D10-1	;RELATIVE LOC OF FIRST EDIT WORD
	SETVAL DA.RKL,^D14-1	;RELATIVE LOC FOR FIRST KEY

>


;EXTAB DEFINITIONS

	IFN MLOAD&BDE.!ONESEG,<

	EXTB%C

>


;LITAB DEFINITIONS

	IFN MLOAD&C.!ONESEG,<

	LITB%C

>
;CONTAB DEFINITIONS

	IFN MLOAD&CDE.!ONESEG,<

	COTB%C

>


;HLDTAB DEFINITIONS

	IFN MLOAD&BCDE.!ONESEG,<

	HLTB%C

	SETVAL HL.XBY,^O20	;CODE FOR 'INDEXED BY' ENTRY

>


IFN DBMS,<

;USETAB DEFINITIONS

	IFN MLOAD&DEFG.!ONESEG,<

	USTB%C

>
>	;END OF IFN DBMS
;FLOTAB DEFINITIONS

	IFN MLOAD&BCDEFG!ONESEG,<

	FLTB%C


;PROTAB DEFINITIONS

	PRTB%C

>


;CDTAB DEFINITIONS

IFN MCS!TCS,<

	CDTB%C

>	;END OF IFN MCS


;RPWTAB DEFINITIONS.

	IFN MLOAD&ABCDE.!ONESEG,<

	RWTB%A

>

	IFN MLOAD&CDE.!ONESEG,<

	RWTB%B

>
;FLAGS AND BITS IN GENFIL OPERATORS

	RADIX	10

	IFN MLOAD&D.!ONESEG,<

	EXTERNAL OPRTR


OBIT9:	POINT 1,OPRTR,9
OBIT10:	POINT 1,OPRTR,10
OBIT11:	POINT 1,OPRTR,11
OBIT12:	POINT 1,OPRTR,12
OBIT13:	POINT 1,OPRTR,13
OBIT14:	POINT 1,OPRTR,14
OBIT15:	POINT 1,OPRTR,15

	DEFINE OPBIT (X,Y),<SETVAL OP.'X,OBIT'Y>
	DEFINE OPFLD (W,X,Y,Z),<SETUP OP.'W,<POINT X,OPRTR+Z,Y>>

;FIELDS IN OPRTR WORD

	OPFLD LN,13,28,0
	OPFLD CP,7,35,0
	OPFLD LNC,20,35,0
	OPFLD OPC,9,8,0
	OPFLD IO,2,10,0
	OPFLD USE,2,10,0
	OPFLD OP2,8,35,1
	OPFLD COB,5,13,0
	OPFLD INO,2,10,0
	OPFLD AAD,2,10,0
	OPFLD TRG,15,17,1
	OPFLD SWT,6,35,0


;MASKS  IN OPRTR WORD

	SETVAL OPM.IF,^O700
;FLAG SETTINGS IN OPRTR WORD

	OPBIT INP,10
	OPBIT OUT,9
	OPBIT AFT,11
IFN ANS68,<
	OPBIT BEG,12
	OPBIT END,13
	OPBIT UNT,14
	OPBIT FIL,15
>
IFN ANS74,<
	OPBIT XTD,14	;USE ... EXTEND
>
	OPBIT OPN,15
	OPBIT TRC,9
	OPBIT RUN,9
	OPBIT PD,9	;ENTRY
	OPBIT MAC,9	;ENTER
IFN ANS68,<
	OPBIT FOR,10
>
	OPBIT USI,11	;  (ALSO USED BY ENTRY)
	OPBIT CAL,12
	OPBIT F10,13
	OPBIT CLN,9
	OPBIT UPO,9
	OPBIT ATE,9
	OPBIT SZE,10
	OPBIT INK,11
	OPBIT OVR,13
	OPBIT EOP,15	;END OF PAGE
	OPBIT SPI,9
	OPBIT REE,9
	OPBIT NRW,11
	OPBIT EXT,13	;OPEN EXTEND
IFN ANS74,<
	OPBIT REV,14	;OPEN REVERSED
>
	OPBIT LCK,10
	OPBIT REM,13	;FOR REMOVAL
	OPBIT LEA,9
	OPBIT FIR,10
	OPBIT UFR,11
	OPBIT RPL,12
	OPBIT TAL,13
IFN ANS74,<
	OPBIT CHR,11
	OPBIT IBF,14
	OPBIT IAF,15
	OPBIT EIN,12	;"LAST INSPECT ARG"
>
	OPBIT BAD,9
	OPBIT ADV,9	;ADVANCING.
	OPBIT FRM,11
	OPBIT PSG,12	;POSITIONING.
	OPBIT IN2,9
	OPBIT NXT,10
	OPBIT UNM,9
	OPBIT FLS,14
	OPBIT GRT,10
	OPBIT LES,9
	OPBIT EQU,11
	OPBIT ALF,10
	OPBIT NUM,9
	OPBIT ZER,13
	OPBIT POS,11
	OPBIT NEG,12
	OPBIT NOT,15
	OPBIT ON,9
	OPBIT OFF,10
	OPBIT COR,12
	OPBIT ASC,9
	OPBIT DNA,10
	OPBIT WDL,12
	OPBIT ALL,9	;USED BY UDELIM AND OTHERS
	OPBIT GOB,9	;GOBACK
	OPBIT PGM,10
	OPBIT WSC,9	;WITH SEQUENCE CHECK FOR MERGE
IFN DBMS,<
	OPBIT EMP,9	;IFDB
	OPBIT MEM,10
	OPBIT OWN,11
	OPBIT MOO,12
	>
IFN STRING,<
	OPBIT	DSZ,9	;SDELIM
	OPBIT	OVF,9	;STRNG,UNSTR
	OPBIT	PTR,10	;STRNG,UNSTR
	OPBIT	DEL,9	;UNSDES: DELIMITER IN
	OPBIT	COU,10	;UNSDES: COUNT IN
	OPBIT	TLG,11	;UNSTR: TALLYING IN
	>

IFN MCS!TCS,<
	OPBIT	IFM,9		;IF MESSAGE
	OPBIT	ENA,9
	OPBIT	TRM,10
	OPBIT	OT2,11
	OPBIT	AF2,9
	OPBIT	PAG,10
	OPBIT	SEG,9
	OPBIT	NDP,10		;NO DATA PHRASE
	>

	>
	RADIX 8

;CONSTANTS USED BY B,C,D,E,F,G

	IFN MLOAD&BCDEFG!ONESEG,<

	SETUP TABCOD,<POINT 3,0(DT),2>	;TABLE CODE IN MAJOR TABLES

	SETUP FTCMOD,<POINT 3,4(DT),10>	;CORE MODE (0=SIXBIT,2=ASCII
					; 3=EBCDIC)
	SETUP FTRSIZ,<POINT 12,6(DT),17> ;RECORD SIZE IN FILE-TABLE
	SETUP FTRECD,<POINT 18,6(DT),35>;LOCATION OF "DATA RECORD" LINK IN FILE-TABLE
	SETUP FTDBAS,<POINT 18,^D15(DT),35>;BASE ADDRESS FOR ASSOCIATED DATA ENTRIES
	SETUP PTSEGN,<POINT 7,2(DT),24>	;SEGMENT NUMBER FOR PROTAB
	SETVAL PTFLAG,2		;PROTAB WORD WHICH CONTAINS FLAGS

	>

;HERE TO KEEP LINK HAPPY WHILE LOADING CBL74 AND CBL74D
IFE ONESEG,<
 IFN MLOAD&BD.,<
	SETUP	PSCAN,<HALT>	;CAN NEVER GET HERE
>>
;ASSEMBLY CODES

	IFN MLOAD&BCDEFG!ONESEG,<

	SETVAL AC.CNS,0	;ADDRESS IS A CONSTANT .LT. 100000
	SETVAL AC.DAT,1	;ADDRESS IS A DATA-NAME
	SETVAL AC.PRO,2	;ADDRESS IS A PROCEDURE NAME
	SETVAL AC.EXT,3	;ADDRESS IS AN EXTERNAL NAME
	SETVAL AC.FIL,4	;ADDRESS IS A FILE-NAME
	SETVAL AC.TAG,5	;ADDRESS IS A TAG (%N)
	SETVAL AC.CNB,6	;ADDRESS IS A CONSTANT .GT. 77777
	SETVAL AC.MSC,7	;ADDRESS IS MISCELLANEOUS

	SETVAL AC.MS1,71 ;ADDRESS IS EXTENDED MISCELLANEOUS.
	SETVAL AC.MS2,72 ;ADDRESS IS MISC WITH NEGATIVE INCREMENT

	SETVAL AS.CNS,<AC.CNS*1B20>
	SETVAL AS.DAT,<AC.DAT*1B20>
	SETVAL AS.PRO,<AC.PRO*1B20>
	SETVAL AS.EXT,<AC.EXT*1B20>
	SETVAL AS.FIL,<AC.FIL*1B20>
	SETVAL AS.TAG,<AC.TAG*1B20>
	SETVAL AS.CNB,<AC.CNB*1B20>
	SETVAL AS.MSC,<AC.MSC*1B20>

	SETVAL AS.MS1,<AC.MS1*1B23>
	SETVAL AS.MS2,<AC.MS2*1B23>

	SETVAL AC.ABS,0	;INCREMENT IS ABSOLUTE NUMBER
	SETVAL AC.PAR,1	;INCREMENT TO %PARAM
	SETVAL AC.FLS,2	;FILES.
	SETVAL AC.LIT,3	;INCREMENT TO %LIT
	SETVAL AC.GO,4	;GOTO.
	SETVAL AC.DOT,5	;CURRENT PC
	SETVAL AC.TMP,6	;INCREMENT TO %TEMP
	SETVAL AC.ALT,7	;INCREMENT TO %ALT

	SETVAL AC.BSA,0 ;BASE ADDRESS OF PROGRAM
	SETVAL AC.PFF,1 ;IF LISTING ASSEMBLED CODE, PUT OUT A FORM FEED HERE.

	SETVAL AS.ABS,<AC.ABS*1B20>
	SETVAL AS.PAR,<AC.PAR*1B20>
	SETVAL AS.FLS,<AC.FLS*1B20>
	SETVAL AS.LIT,<AC.LIT*1B20>
	SETVAL AS.GO,<AC.GO*1B20>
	SETVAL AS.DOT,<AC.DOT*1B20>
	SETVAL AS.TMP,<AC.TMP*1B20>
	SETVAL AS.ALT,<AC.ALT*1B20>

	SETVAL AS.BSA,AC.BSA
	SETVAL AS.PFF,AC.PFF
	SETVAL LAS.M1,AS.PFF ;LAST EXTENDED MISCELLANEOUS OF TYPE 1.
	SETVAL AS.BYT,4B20	;BYTE POINTER
	SETVAL AS.XWD,5B20	;XWD
	SETVAL AS.ASC,6B20+1B21	;ASCII
	SETVAL AS.SIX,6B20+1B22	;SIXBIT
	SETVAL AS.D1,6B20+1B23	;1-WORD DECIMAL
	SETVAL AS.D2,6B20+1B24	;2-WORD DECIMAL
	SETVAL AS.FLT,6B20+1B25	;COMP-1
	SETVAL AS.OCT,6B20+1B26	;OCTAL
	SETVAL AS.EBC,6B20+1B27	;EBCDIC

	SETVAL AS.PN,7B20+1B21	;PROCEDURE NAME
	SETVAL AS.%X,7B20+1B22	;TAG DEFINITION
	SETVAL AS.REL,7B20+1B23	;RELOC
	SETVAL AS.ENT,7B20+1B24	;ENTRY
	SETVAL AS.SMC,7B20+1B25 ;SPECIAL MISCELLANEOUS STUFF.

	>
;TABLE OF PRESET EXTERNAL NAMES

	IFN	MLOAD&ADEFG.!ONESEG,<

	NUMEXT==0
	USRNO==0
	USRFLG==0

	DEFINE EXTAB (X),<
	IFN MLOAD&A.!ONESEG,<
	SIXBIT "X"
	>
	IFN MLOAD&EOG.!ONESEG,<
	SETVAL X,NUMEXT*2+AS.EXT+1
	>
	NUMEXT==NUMEXT+1
IFN USRFLG,<USRNO==USRNO+1>
	>

	DEFINE OLDUUO (X,Y),<
	IFN MLOAD&A.!ONESEG,<
	SIXBIT "X'.'Y"
	>
	IFN MLOAD&EOG.!ONESEG,<
	SETVAL X'%'Y,NUMEXT*2+AS.EXT+1
	>
	NUMEXT==NUMEXT+1
IFN USRFLG,<USRNO==USRNO+1>
	>

	DEFINE	NEWPJ	(X,Y)<OLDUUO	(X,Y)>

EXTNAM:

USR:	USRFLG==1		;ALL EXTERNALS NOW - NO MORE UUO'S

	OLDUUO	FIX,
	OLDUUO	PERF,
	IFN MLOAD&D.!ONESEG,<SETVAL PERF%,NUMEXT*2+AS.EXT-1>
	OLDUUO	FLOT,1
	OLDUUO	FLOT,2
	OLDUUO	PD6,
	OLDUUO	PD7,
	OLDUUO	GD6,
	OLDUUO	GD7,
	OLDUUO	NEG,
	OLDUUO	MAG,
	OLDUUO	ADD,12
	OLDUUO	ADD,21
	OLDUUO	ADD,22
	OLDUUO	SUB,12
	OLDUUO	SUB,21
	OLDUUO	SUB,22
	OLDUUO	MUL,12
	OLDUUO	MUL,21
	OLDUUO	MUL,22
	OLDUUO	DIV,11
	OLDUUO	DIV,12
	OLDUUO	DIV,21
	OLDUUO	DIV,22
	OLDUUO	C,OPEN
	OLDUUO	C,CLOS
	OLDUUO	DSPLY,
	OLDUUO	ACEPT,
	OLDUUO	READ,
	OLDUUO	WRITE,
	OLDUUO	WADV,
IFN ANS68,<
	OLDUUO	SEEK,
>
IFN ANS74,<
	OLDUUO	RDNXT,
>
	OLDUUO	DELET,
	OLDUUO	RERIT,
	OLDUUO	PURGE,
	OLDUUO	INIT,
	OLDUUO	TERM,
	OLDUUO	DSPL,6
	OLDUUO	DSPL,7
	OLDUUO	COMP,
	OLDUUO	CMP,76
	OLDUUO	SPAC,6
	OLDUUO	NUM,6
	OLDUUO	ALF,6
	OLDUUO	ZERO,6
	OLDUUO	POS,6
	OLDUUO	NEG,6
	OLDUUO	SPAC,7
	OLDUUO	NUM,7
	OLDUUO	ALF,7
	OLDUUO	ZERO,7
	OLDUUO	POS,7
	OLDUUO	NEG,7
	OLDUUO	COMP,D		;OBSOLETE
	OLDUUO	MOVE,
	OLDUUO	C,D6D7
	OLDUUO	C,D7D6
	OLDUUO	CMP,E
	OLDUUO	CMP,G
	OLDUUO	CMP,GE
	OLDUUO	CMP,L
	OLDUUO	CMP,LE
	OLDUUO	CMP,N
	OLDUUO	EDIT,S
	OLDUUO	EDIT,U
IFN ANS68,<
	OLDUUO	EXAM,
>
IFN ANS74,<
	OLDUUO INSP,
>
	OLDUUO	SUBSC,
	OLDUUO	SIZE,1
	OLDUUO	SIZE,2
	OLDUUO	SIZE,3
	OLDUUO	E,C3C1
	OLDUUO	E,C3C3
	OLDUUO	OVLAY,
	OLDUUO	C,EXIT
	OLDUUO	ARGS,
	OLDUUO	PUTF,
	OLDUUO	RESF,
	OLDUUO	GETNM,
	OLDUUO	ILLC,
	
	NEWPJ	C,D6D9
	NEWPJ	C,D7D9
	NEWPJ	C,D9D6
	NEWPJ	C,D9D7
	NEWPJ	PC3,
	NEWPJ	PD9,
	NEWPJ	GC3,
	NEWPJ	GD9,
	NEWPJ	POS,9
	NEWPJ	NEG,9
	NEWPJ	ZERO,9
	NEWPJ	ALF,9
	NEWPJ	NUM,9
	NEWPJ	SPAC,9
	NEWPJ	CMP,96
	NEWPJ	CMP,97
	NEWPJ	MUL,41
	NEWPJ	MUL,42
	NEWPJ	DIV,41
	NEWPJ	DIV,42

	NEWPJ	ZERC,6;; [441] SIXBIT ZERO COMPARE
	NEWPJ	ZERC,7;; [441] ASCII ZERO COMPARE
	NEWPJ	ZERC,9;; [441] EBCDIC ZERO COMPARE
	NEWPJ	NUM,3		;COMP-3 NUMERIC TEST

	EXTAB C.RSET
	EXTAB STOPR.
	EXTAB C.STOP
	EXTAB KILL.
	EXTAB GOTO.
IFN ANS68,<
	EXTAB TODAY.
	EXTAB TALLY.
>
	EXTAB KDECL.
	EXTAB KPROG.
	EXTAB SZERA.
	EXTAB PSORT.
	EXTAB RELES.
	EXTAB RETRN.
	EXTAB MERGE.
	EXTAB ENDS.
	EXTAB KEY.
	EXTAB PMERG.
	EXTAB MCLOS.
	EXTAB DSP.FP
	EXTAB OVFLO.
	EXTAB LINE.C
	EXTAB LINE.D
	EXTAB LINE.H
	EXTAB LIN.RH
IFN MCS!TCS,<
	EXTAB	M.INIT
	EXTAB	M.RMW
	EXTAB	M.RSW
	EXTAB	M.RMNW
	EXTAB	M.RSNW
	EXTAB	M.SEND
	EXTAB	M.AC
	EXTAB	M.IFM
	EXTAB	M.DI
	EXTAB	M.DIT
	EXTAB	M.DO
	EXTAB	M.EI
	EXTAB	M.EIT
	EXTAB	M.EO
	>
IFN STRING,<
	EXTAB	STR.
	EXTAB	STR.O
	EXTAB	UNS.
	EXTAB	UNS.O
	>
IFN ANS74,<
	EXTAB	C.STRT
	EXTAB	DATE.
	EXTAB	DAY.
	EXTAB	TIME.
	>

	EXTAB	CANCL.
IFN ANS74,<
	EXTAB	S.CALL;		;CALL TO RUNTIME NAMED SUBROUTINE
>
	EXTAB	EDIT.B;		;BIS EDIT ROUTINE
	EXTAB	PUTF$;		;PUTF WHEN $ HAS BEEN CHANGED
	EXTAB	RESF$;		RESF WHEN "$" HAS BEEN CHANGED
	EXTAB	LFENQ.
	EXTAB	LRENQ.
	EXTAB	LRDEQ.
	EXTAB	(CNTAI.)		;NON-DBMS PART OF COMPOUND RETAIN
	EXTAB	PTFLG.
	EXTAB	C.TRCE
	EXTAB	CBDDT.
	EXTAB	COBST.
	EXTAB	LEVEL.
	EXTAB	TRAC1.
	EXTAB	TRAC2.
	EXTAB	TRAC3.

IFN DBMS,<
	EXTAB	SETCON
	EXTAB	RECMEM
	EXTAB	RECOWN
	EXTAB	RECMO
	EXTAB	INITDB
	>


DEFINE EXTABN(DBROUT),<
	EXTAB	DBROUT
	IFN MLOAD&D.!ONESEG,<%'DBROUT==:500000+NUMEXT*2-1>
	>

IFN DBMS,<
	EXTABN CLOSED
	IFN DBMS6,<EXTABN (CLOTR)>
	EXTABN	STORED
	EXTABN INSRT
	EXTABN	MODIF
	EXTABN GETS
	EXTABN REMOV
	EXTABN DELETR
	IFN DBMS6,<EXTABN (DELTR)>
	EXTABN	MOVEC
	EXTABN FIND1
	EXTABN FIND2
	EXTABN FIND3
	IFN DBMS4,<EXTABN	(FINDO)>	;SEP OUT FIND OFFSET.
	EXTABN	FIND4
	EXTABN	FIND5
	IFN DBMS6,<EXTABN (FIND6)>
	EXTABN	OPEND
	IFN DBMS6,<EXTABN (OPENT)>
	EXTABN	SBIND
	EXTABN	BIND
	EXTABN	RCLAIM
	>

IFN CSTATS,<
	EXTAB	METER.		;METER POINT BASE
	EXTAB	METR.		;RUN TIME POINTER
>
	EXTAB	SUBE1.		;INLINE SUBSCRIPT ERROR ROUTINES
	EXTAB	SUBE2.
	EXTAB	SUBE3.
	EXTAB	EXIT.E		;INLINE ERROR FROM PERFORM EXIT
IFN BIS,<
	EXTAB	XTND.E		;INLINE ERROR FROM EXTEND INST
	EXTAB	ALP.66		;SIXBIT TO SIXBIT CONVERSION TABLE
	EXTAB	ALP.67		;SIXBIT TO ASCII ...
	EXTAB	ALP.69		;SIXBIT TO EBCDIC ...
	EXTAB	ALP.76		;ASCII TO SIXBIT ...
	EXTAB	ALP.77		;ASCII TO ASCII
	EXTAB	ALP.79		;ASCII TO EBCDIC ...
	EXTAB	ALP.96		;EBCDIC TO SIXBIT ...
	EXTAB	ALP.97		;EBCDIC TO ASCII ...
	EXTAB	ALP.99		;EBCDIC TO EBCDIC
	EXTAB	ALPS.6		;ALPHABETIC SIXBIT
	EXTAB	ALPS.7		;ALPHABETIC ASCII
	EXTAB	ALPS.9		;ALPHABETIC EBCDIC
	EXTAB	NUM.66		;NUMERIC SIXBIT TO SIXBIT
	EXTAB	NUM.67		;NUMERIC SIXBIT TO ASCII
	EXTAB	NUM.69		;NUMERIC SIXBIT TO EBCDIC
	EXTAB	NUM.76		;NUMERIC ASCII TO SIXBIT
	EXTAB	NUM.77		;NUMERIC ASCII TO ASCII
	EXTAB	NUM.79		;NUMERIC ASCII TO EBCDIC
	EXTAB	NUM.96		;NUMERIC EBCDIC TO SIXBIT
	EXTAB	NUM.97		;NUMERIC EBCDIC TO ASCII
	EXTAB	NUM.99		;NUMERIC EBCDIC TO EBCDIC
	EXTAB	CVTDB.		;BIS CONVERT DECIMAL TO BINARY
	EXTAB	CBDOV.		;OVERFLOW ROUTINE TO CONVERT BINARY-DECIMAL
	EXTAB	CVBD.6		;LIBOL TRANSLATION TABLES
	EXTAB	CVBD.7		; FOR BINARY-DECIMAL CONVERSION
	EXTAB	CVBD.9
	EXTAB	E0.6		;LIBOL SIXBIT EDIT TABLE
	EXTAB	E0.7		;LIBOL ASCII EDIT TABLE
	EXTAB	E0.9		;LIBOL EBCDIC EDIT TABLE
	EXTAB	E0.6.1		;E0.6+1
	EXTAB	E0.7.1		;E0.7+1
	EXTAB	E0.9.1		;E0.9+1
	EXTAB	DVI41.		;FOR 4-WD DIVIDE, SAVING REMAINDER IN 1ST
	EXTAB	DVI42.		; OPERAND

	EXTAB	ADD.4R		;[570] QUAD-WORD ROUNDING FUNCTION
IFN TCS,<
	EXTAB	MBIND
	EXTAB	MNAME
>;END IFN TCS
>;END IFN BIS
	EXTAB	MVD.AL		;MOVE ALL "LIT" TO DEPENDING VARIABLE
	EXTAB	WADVV.		;WRITE ADVANCING, VARIABLE LENGTH RECORDS
	EXTAB	WRITV.		;WRITE, VARIABLE LENGTH RECORDS
IFN BIS,<			;[634]
	EXTAB	SIZE.4		;[634] 4-WORD SIZE ERROR CHECKS
	EXTAB	SIZE.5		;[634] . .
>;END IFN BIS			;[634]
	EXTAB	FLT.12		;FLOAT 1-WORD COMP TO COMP-2
	EXTAB	FLT.22		;FLOAT 2-WORD COMP TO COMP-2
	EXTAB	FIX.2		;FIX COMP-2 TO 2-WORD COMP
	EXTAB	E.F2D1		;EXPONENTIATE, BASE COMP-2, POWER 1-WORD COMP
	EXTAB	E.F2D2		;EXPONENTIATE, BASE COMP-2, POWER 2-WORD COMP
	EXTAB	E.F2FP		;EXPONENTIATE, BASE COMP-2, POWER COMP-1
	EXTAB	E.F2F2		;EXPONENTIATE, BASE COMP-2, POWER COMP-2
	EXTAB	PPOT4.;;	;USED BY COBDDT TO PRINT WHERE WE ARE
	EXTAB	ISBPS.;;	;USED BY COBDDT TO INCREMENT SBPSA.

	IFN MLOAD&A.!ONESEG,<
	SETUP EXTPTR,<XWD -NUMEXT,EXTNAM>
	>

	SETVAL NUMEXT,<<NUMEXT-USRNO>*2>

	>
;CONSTANTS USED BY PHASE F

	IFN MLOAD&F.!ONESEG,<

	SETUP ERALNA,<POINT 14,DW,14>;	LINE NUMBER IN "DW" PLUS "IMBED" BIT

>

;CONSTANTS USED BY PHASE G

	IFN MLOAD&OG.!ONESEG, <

	SETUP	ASOP,<POINT 7,W1,8>;	INSTRUCTION OP-CODE
	SETUP	INCTYP,<POINT 3,W2,20>;	INCREMENT CODE TYPE
	SETUP	ADRTYP,<POINT 3,W1,20>;	ADDRESS CODE TYPE
	SETUP	MSC.CL,<POINT 3,W1,23>; EXTENDED MISCELLANEOUS TYPE

>

	END