Trailing-Edge
-
PDP-10 Archives
-
ap-c800d-sb
-
cobolb.mac
There are 14 other files named cobolb.mac in the archive. Click here to see a list.
; UPD ID= 1933 on 6/15/79 at 4:09 PM by N:<NIXON>
TITLE COBOLB FOR COBOL V12
SUBTTL ID AND ED CONTROL PROGRAM W.NEELY/CAM
;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
DEBUG==:DEBUG
RPW==:RPW
ISAM==:ISAM
BIS==:BIS
;EDITS
;V12*****************
;NAME DATE COMMENTS
;DMN 30-APR-79 [702] LIST COMMENTS IN DATE-COMPILED PARAGRAPH.
;EHM 17-SEP-78 [553] GIVE WARNING IF RECORDS/RERUN TO LARGE
;V10*****************
;NAME DATE COMMENTS
; 27-JUL-77 [505] ADD CHECKS SO "KEY" TYPE MATCHES ACCESS MODE
;EHM 3-JUN-77 [501] ENFORCE NO PRINTER CHANNEL GREATER THAN 8
; 6-APR-76 [422] FIX LOSS OF FIRST CHAR IN DATE=COMPILED OR SOURCE-COMPUTER STATEMENTS
;ACK 12-JAN-75 ADDED ROUTINES FOR:
; 1. RECORDING MODE IS STANDARD-ASCII/F/V.
; 2. RECORDING DENSITY IS 1600.
; 3. I/O ERROR RECOVERY.
;********************
; EDIT 355 ALLOW FOR 1 BUFFER, ALSO CHECK FOR MAX OF 62 ALTERNATE AREAS.
; EDIT 277 FIX CODE FOR OBJECT AND SOURCE COMPUTER STATEMENTS TO HANDLE LC LETTERS.
; EDIT 175 FIXES ERROR RECOVERY FOR SELECT STATEMENTS ERRORS
; EDIT 153 FIXES NUMERIC DATA IN DATE-WRITTEN SKIPPING NEXT PARA.
TWOSEG
RELOC 400000
SALL
ENTRY COBOLB
EXTERN BTREE
EXTERN FNDLNK,KILL,LITVAL
EXTERN SAVETA,SAMSRT
EXTERN CTR,GETVAL
EXTERN PNTR
EXTERN TRYNAM,CPYBHO
EXTERN CFLM,FI.SDL
EXTERN LNKSET
EXTERN PROGID
EXTERN NAMWRD,NAMADR,BLDNAM,GETENT,PUTLNK,OBJSIZ
EXTERN DOLLR.,STDATE,PUTCPY,GETITM
EXTERN FILLOC,TBLOCK,ESIZE,VALADR,CURNAM
EXTERN LSIZE,MNETYP,SKPSRC
EXTERN CURVAL
EXTERN FI.LNC,FI.ERM,FI.LBL,FI.ACC
EXTERN FI.RCT,FI.MLT
EXTERN FI.IRM,FI.NXT,FI.OPT,FI.NDV,FI.VAL,FI.NBF,FI.NFL
EXTERN FI.SRA,FI.RRC,FI.RER,FI.SAL,FI.POS
EXTERN FI.RM2,FI.RD,FI.RP
EXTERN ISVPTR,INDPTR,CURFIL,LSTFIL
EXTERN SQURL.,SEGLIM
EXTERN KILL
EXTERN CURHLD,HL.NAM,HL.COD,HL.LNC,HL.QAL,HL.LNK
EXTERN HLDLOC
IFN DEBUG,<
EXTERN CORESW,TRACEI,TRACEE
>
COBOLB: SETFAZ B; ;INIT PHASE B
MOVE SAVPTR,ISVPTR ;INITIALIZE SAVE LIST POINTER
MOVE NODPTR,INDPTR ;INITIALIZE NODE POINTER
IFN DEBUG,<
MOVE TE,CORESW
SWOFF FNDTRC ;CLR TRACE REQUEST
TRNE TE,TRACEI ;TRACE ID NODES?
SWON FNDTRC ;YES, TURN ON TRACER
>
HRRZI TA,62 ;50 DECIMAL IS SEGLIM INITIAL VALUE
MOVEM TA,SEGLIM
HRRZI TA,ID0.## ;AIM AT FIRST ID NODE
PUSH NODPTR,TA
SETZM CURFIL ;INIT FILE TABLE PTRS
SETZB W2,LSTFIL
PUSHJ PP,SQURL. ;START SCAN
TTCALL 3,[ASCIZ "COBOLB--LOST; TOO MANY POPJ'S
"]
JRST KILL
SUBTTL ACTIONS FOR ID AND ED SYNTAX PROCESSING
;CHECK FOR PERIOD, THEN SKIP TO END OF PARAGRAPH
;MUST ALSO WATCH FOR THERE BEING NOTHING TO SKIP
INTER. IA0A.
IA0A.:
IFN ANS74,<
SETOM NOIDHY## ;SET HYPHEN CONTINUATION NOT ALLOWED
>
;HACK TO PREVENT FIRST WORD OF PARAGRAPH FROM GOING TO THE CREF LISTING.
; PUSHJ PP,CKPERI ;CHECK FOR PERIOD
PUSH PP,CREFSW## ;SAVE THE STATE OF THE CREF SWITCH.
SETZM CREFSW## ;DON'T CREF WHILE CHEKING FOR PERIOD.
PUSHJ PP,CKPERI ;CHECK FOR PERIOD.
POP PP,CREFSW## ;RESTORE THE CREF SWITCH TO IT'S ORIGINAL STATE.
IFN ANS74,<
TRNN TYPE,2000 ;A-MARGIN?
PUSHJ PP,IA0. ;NO, SKIP TO END OF PARAGRAPH
SETZM NOIDHY ;TURN IT BACK ON
POPJ PP,
>
IFN ANS68,<
TRNE TYPE,2000 ;A-MARGIN?
POPJ PP, ;YES, NEW PARAGRAPH.
SKPNAM
>
;SKIP TO END OF PARAGRAPH, PASSING DATA TO LISTING FILE
INTER. IA0.
IA0.: SWOFF FNOCPY ;TURN OFF 'NO LISTING' FLAG
TRZ FGTPER ; DONT GET PERIOD FROM GETITM [153]
PUSHJ PP,SKPPGF## ;SKIP TO END OF PARAGRAPH
PUSHJ PP,GETITM ;GET A SOURCE ITEM
SKPNAM
;SET TO REGET LAST ITEM SEEN
INTER. IA0.R
IA0.R: SWON FREGWD ;SET REGET WORD BIT
POPJ PP,
;TURN OFF REGET WORD FLAG
INTER. IA0.A
IA0.A: SWOFF FREGWD;
POPJ PP,
;ADVANCE TO NEXT WORD
INTER. IA0.G
IA0.G: SWOFF FREGWD ;CLR REGET WORD FLAG
PJRST GETITM ;GET NEXT ITEM
;FLAG MISSING IDENTIFICATION DIVISION, THEN TRY ITEM AGAIN
INTER. IA0E1.
IA0E1.: EWARNW E.1 ;NO IDENTIFICATION DIV.
JRST IA0.R ;SET TO REGET WORD
;IF /S NOT SEEN, SET /S AND TRY AGAIN, GIVE WARNING
INTER. IA0S1.
IA0S1.: TSWFS FSEQ ;WAS /S SEEN
EWARNJ E.1 ;YES, GIVE OLD MESSAGE
EWARNJ E.601 ;NO, GIVE NEW MESAGE
;FLAG ILLEGAL PARAGRAPH, THEN SKIP TO NEXT PARAGRAPH
INTER. IA0E7.
IA0E7.: EWARNW E.7 ;'ILLEGAL PARAGRAPH NAME'
JRST IA0.
;FLAG ILLEGAL SECTION, THEN SKIP TO NEXT PARAGRAPH
INTER. IA0E43
IA0E43: EWARNW E.43 ;'ILLEGAL SECTION NAME'
JRST IA0.
;OBJECT COMPUTER WASN'T 'DECSYSTEM-10' SEE IF IT'S 'DECSYSTEM-10NN'.
INTER. IA0E5.
IA0E5.: MOVE TA, [SIXBIT /DECSYS/] ;CHECK THE FIRST PART.
MOVE TB, [SIXBIT /TEM:10/]
CAMN TA, NAMWRD##
CAME TB, NAMWRD##+1
JRST IA0E5H ;IT'S NOT 'DECSYSTEM-10', COMPLAIN.
MOVE TA, NAMWRD##+2 ;GET THE NN PART.
SETZI TC,
IA0E5D: SETZI TB,
IMULI TC, ^D10
LSHC TB, 6
CAIL TB, '0'
CAILE TB, '9'
JRST IA0E5H ;IT'S NOT A NUMBER, COMPLAIN.
ADDI TC, -20(TB)
JUMPN TA, IA0E5D
JRST IA0.A ;CLEAR REGET WORD BIT.
IA0E5H: SWOFF FREGWD; ;CLR REGET WORD BIT.
EWARNJ E.5 ;'DECSYSTEM-10/20 ASSUMED'.
;STOP SOURCE FROM GOING TO LISTING
INTER. IA1.
IA1.: SWON FNOCPY ;SET NO LISTING BIT
POPJ PP,
INTER. IA1.N
IA1.N: SWON FNOCPY ;SET NO LISTING BIT
PUSHJ PP,SKPNW. ;SKIP BLANKS ETC.
JRST IA0.G ;GET NEXT ITEM
;START SOURCE GOING TO LISTING AGAIN
INTER. IA1.L
IA1.L: SWOFF FNOCPY ;CLEAR NO LISTING BIT
POPJ PP,
;GET NEXT ITEM & VERIFY THAT IT IS A PERIOD
;IF NOT A PERIOD, FLAG IT
CKPERI: PUSHJ PP,GETITM ;READ FOR PERIOD
LDB TA,[POINT 10,TYPE,35] ;GET TYPE OF ITEM
CAIE TA,PRIOD. ;IS IT A PERIOD?
JRST BE125. ;NO, GIVE PERIOD ASSUMED MSG
PUSHJ PP,GETITM ;IF PERIOD THERE GET NEXT ITEM FOR CONSISTENCY
JRST IA0.R ;SET REGET WORD FLAG JUST LIKE BE125. DOES
INTER. BE125.
BE125.: MOVE LN,BLNKLN##
MOVE CP,BLNKCP##
HRRZI DW,E.125 ;DIAGNOSTIC 125
SWON FREGWD ;READ THAT AGAIN LATER
JRST WARN## ;WARNING ONLY
;SKIP TO START OF NEXT WORD
;THE TRICK IS TO FIND A CHARACTER IN THE A-FIELD OR B-FIELD THAT IS NOT
;EITHER A SPACE, TAB, OR HYPHEN
;(ASTERISKS ARE FILTERED OUT AT A MUCH EARLIER STAGE)
SKPNW.: PUSHJ PP,SKPSRC ;GET NEXT SOURCE CHAR.
CAIN CP,7 ;ALREADY AT COLUMN 7?
JRST SKPNW2 ;YES, WHAT KIND OF CHAR.?
JRST SKPNW4 ;MUST BE IN A-FIELD OR B-FIELD
SKPNW1: PUSHJ PP,SKPSRC ;GET CHARACTER
SKPNW2: TSWF FEOF ;END-OF-FILE?
JRST END2## ;EOF FOUND
CAIN CP,7 ;COLUMN 7?
CAIE CH," " ;YES, SPACE?
JRST SKPNW1 ;NO, MUST BE A HYPHEN OR NOT COL. 7
SKPNW3: PUSHJ PP,SKPSRC ;GET CHARACTER
TSWF FEOF ;END-OF-FILE?
JRST END2 ;YES
SKPNW4: CAIN CH," " ;IS IT A SPACE?
JRST SKPNW3 ;YES
CAIL CH,"a" ;ABOVE LOWER CASE A?
MOVEI CH,-40(CH) ;YES MOVE IT INTO THE UPPER CASE SET.
CAIL CH,"A" ;IS IT ALPHABETIC?
CAILE CH,"Z"
JRST SKPNW2 ;NOT A LETTER
JRST END2 ;REGET LAST CHARACTER
;GET PROGRAM TITLE
;IF NO NAME GIVEN, GIVE IT THE NAME 'MAIN'
INTER. IA2.
IA2.: SKIPE PROGID ;'PROGRAM-ID' SEEN ALREADY?
EWARNJ E.3 ;YES, DUPLICATE PARAGRAPH
PUSHJ PP,CKPERI ;GET THE PERIOD
TRNN TYPE,AMRGN. ;AT THE A-MARGIN?
JRST IA2.0 ;NO
IA2.2: MOVE TD,[SIXBIT /MAIN/] ;YES, NO ID THERE
MOVEM TD,NAMWRD ;SO GIVE IT A DUMMY NAME
TSWF FDSKC ;CCL?
TTCALL 3,[ASCIZ /MAIN/]
IA2SUB: MOVEM TD,PROGID ;STORE RESULT
TSWT FDSKC ;CCL OR CMD FILE?
JRST IA2SU3 ;NO
TTCALL 3,[ASCIZ / [/] ;PRINT "[FILNAM.EXT]"
MOVEI TA,'.' ;PUT A DOT WHERE THERE IS A SPACE
DPB TA,[POINT 6,SRCFIL+1,5]
MOVE TA,[POINT 6,SRCFIL##]
MOVEI TB,^D10
IA2SU2: ILDB TC,TA
ADDI TC,40 ;CONVERT TO ASCII
CAIE TC,40 ;SPACE?
TTCALL 1,TC ;NO, PRINT IT
SOJG TB,IA2SU2
SETZ TA, ;CLR '.' AGAIN
DPB TA,[POINT 6,SRCFIL+1,5]
TTCALL 3,[ASCIZ /]
/]
IA2SU3: SETZM NAMWRD+1
MOVE TA,[NAMWRD+1,,NAMWRD+2]
BLT TA,NAMWRD+5
PUSHJ PP,TRYNAM ;PROGRAM-ID A RESERVED WORD?
JRST .+3 ;NO
EWARNW E.315 ;YES
JRST IA2.2 ;TRY IT WITH "MAIN"
PUSHJ PP,BLDNAM ;MAKE NAMTAB ENTRY
HLRS TA
DPB TA,[POINT 15,W2,15] ;SAVE NAMTAB LINK
MOVE TA,[CD.EXT,,SZ.EXT] ;PUT PROGRAM-ID IN EXTAB
PUSHJ PP,GETENT
HLRM TA,PIDLNK## ;SAVE EXTAB LINK
LDB TB,[POINT 15,W2,15]
IORI TB,<CD.EXT>B20 ;EXT FLAG + NAMTAB LINK
MOVSM TB,(TA) ;TO 1ST WORD OF ENTRY
SETO TC, ;SET PROG-ID FLAG
DPB TC,EX.PID##
DPB TC,EX.ENT## ;ALSO SET ENTRY FLAG
HRRI TA,(TB) ;LINK NAMTAB TO EXTAB
PJRST PUTLNK
IA2.0: PUSHJ PP,GETITM ;REGET SOURCE ITEM AFTER THE PERIOD
SKIPE NAMWRD ;IS IT A USER-NAME?
JRST IA2.12 ;YES
SKIPE LITVAL ;IS IT A LITERAL?
JRST .+3 ;YES
EWARNW E.4 ;NEITHER A WORD NOR A LITERAL
JRST IA2.2 ;USE "MAIN"
MOVE TD,[POINT 6,NAMWRD] ;SET PTRS TO MOVE THE
MOVE TE,[POINT 7,LITVAL] ;LITERAL INTO THE NAMWRD TABLE
LDB TB,GWVAL## ;GET # OF CHARS
CAILE TB,6 ;IF LESS THAN OR = SIX, USE IT
MOVEI TB,6 ;SET CTR FOR 1ST 6 CHARS
IA2.11: ILDB TA,TE ;GET LITERAL CHARACTER
JUMPE TA,IA2.12 ;END OF LITERAL
CAIL TA,"0" ;LETTER OR DIGIT?
CAILE TA,"Z"
JRST IA2110 ;NO
CAILE TA,"9"
CAIL TA,"A"
TRNA ;YES
IA2110: HRRZI TA,":" ;CHANGE NON-LETTER/DIGIT TO POINT (:)
HRRZI TA,-40(TA) ;CONVERT TO SIXBIT
IDPB TA,TD ;PUT IN NAMWRD
SOJG TB,IA2.11 ;CONT. IN LOOP UNTIL 6 CHARS MOVED
IA2.12: SETZ TD, ;INIT AC FOR RESULT
MOVEI TB,6 ;CTR FOR 6 CHARS
MOVE TA,[POINT 6,NAMWRD]
IA2.N2: ILDB TC,TA ;GET 6BIT CHAR
CAIN TC,32 ;IS IT A COLON (WHICH AROSE FROM A HYPHEN, ETC)?
MOVEI TC,16 ;YES, CHANGE IT TO A DOT
LSH TD,6 ;SHIFT PREVIOUS RESULT LEFT 6
OR TD,TC ;MERGE IN NEW CHAR
TSWT FDSKC ;CCL OR COMMAND FILE?
JRST IA2.N3 ;NO, DONT PRINT NAME
ADDI TC,40 ;CONVERT 6BIT TO ASCII
TTCALL 1,TC ;PRINT CHAR
IA2.N3: SOJG TB,IA2.N2 ;CONT. THRU 6 CHARS.
PUSHJ PP,IA2SUB
JRST IA0.
;REPLACE DATE-COMPILED COMMENTS WITH TODAY'S DATE
INTER. IA4.
IA4.:
IFN ANS74,<
SETOM NOIDHY## ;SET HYPHEN CONTINUATION NOT ALLOWED
>
PUSHJ PP,IA5SUB ;PUT SPACE AFTER 'DATE-COMPILED.'
MOVE TA,[POINT 7,STDATE]
MOVEM TA,PNTR ;POINTER FOR DATE
MOVEI TB,11 ;9 CHARACTERS
MOVEM TB,CTR
IA4.G: ILDB CH,PNTR ;GET CHARACTER
PUSHJ PP,PUTCPY ;PUT ON LISTING
SOSLE CTR
JRST IA4.G
HRRZI CH,"." ;PUT A PERIOD AFTER DATE
PUSHJ PP,PUTCPY
SWON FNOCPY ;[702] TURN ON NO LISTING FLAG
PUSHJ PP,GETSRC## ;[702] READ NEXT CHARACTERS
CAIE CH,12 ;[702] <CR-LF>
JRST .-2 ;[702] NO, LOOK FOR END OF LINE
SWOFF FNOCPY ;[702] RE-ENABLE LISTING
SWON FREGCH ;[702] GET EOL AGAIN
PUSHJ PP,GETITM ;GET A SOURCE ITEM
IFN ANS74,<
SETZM NOIDHY ;TURN IT BACK ON
>
JRST IA0.R ;AND RETURN IT LATER
;REENABLE LISTING, SEE IF LAST CHAR OUTPUT TO IT WAS "."
;IF SO, PUT A SPACE AFTER THE "."
;IF NOT, REPLACE WHATEVER IT WAS BY SPACE
IA5SUB: SWOFF FNOCPY ;ENABLE OUTPUT TO LISTING
HRRZI CH," " ;GET A SPACE
LDB TA,CPYBHO+1 ;GET LAST CHAR PUT ON LISTING
CAIN TA,"." ;WAS IT A "."
JRST PUTCPY ;YES, PUT SPACE AFTER "."
DPB CH,CPYBHO+1 ;NO, REPLACE IT BY SPACE
POPJ PP,
IFN CSTATS,<
;"WITH METER--ING" SPECIFIED
INTER. IA6.
IA6.: SETOM METRSW##
JRST IA0.G ;GET NEXT
>;END IFN CSTATS
IFN ANS74,<
INTER. IA7.
IA7.: SETOM DEBSW##
EWARNJ E.717 ;HOWEVER IT DOESN'T REALLY DO ANYTHING
>
;PUT SAVED INTEGER INTO OBJECT-COMPUTER MEMORY SIZE WORD
INTER. IA8.
IA8.: POP SAVPTR,TB ;GET INTEGER FROM SAVE LIST
IA8.1: CAMN TB,OBJSIZ ;IF INTEGER=OBJSIZ, IGNORE IT
POPJ PP,
SKIPN OBJSIZ ;OBJSIZ=0?
JRST IA8.P ;YES
EWARNJ E.6 ;NO, 'MORE THAN 1 OBJ-COMPUTR PARA'
IA8.P: MOVEM TB,OBJSIZ ;PUT INTEGER IN OBJSIZ
POPJ PP,
;CONVERT #MODULES TO #WORDS & PUT INTO OBJSIZ
INTER. IA9.
IA9.: POP SAVPTR,TB ;GET SAVED INTEGER
IMULI TB,^D1024 ;#MODULES * 1K WORDS EACH
JRST IA8.1
;CONVERT #CHARACTERS (SIXBIT) TO #WORDS & PUT INTO OBJSIZ
INTER. IA10.
IA10.: POP SAVPTR,TB ;GET SAVED INTEGER
ADDI TB,5 ;FORCE ROUNDING UPWARD
IDIVI TB,6 ;N CHARS = N+5/6 WORDS
JRST IA8.1
;TURN OFF 'FILE OPTIONAL' FLAG
INTER. IA12.
IA12.: SWOFF FOPT ;OFF
POPJ PP,
;TURN ON 'FILE OPTIONAL' FLAG
INTER. IA13.
IA13.: SWON FOPT ;ON
POPJ PP,
;PUT SELECTED FILE-NAME IN FILE TABLE
INTER. IA14.
IA14.: TLO W2,GWDEF ;PUT DEFINING REFERENCE ON CREF FILE
PUSHJ PP,PUTCRF##
TLNE W1,GWNOT ;IS NAME IN NAMTAB?
JRST IA14.B ;NO--PUT IN
HLRZ TA,W2 ;YES, GET NAMTAB RELATIVE ADDR.
LSH TA,-2
HRLZM TA,NAMADR ;SAVE IT
JRST IA14.C ;NOT FOUND--CREATE
IA14.B: PUSHJ PP,BLDNAM ;ENTER NAME IN NAMTAB
MOVEM TA,NAMADR ;SAVE ADDRESS
IA14.C: MOVE TA,CURFIL ;CURRENT FILE ENTRY ADDRESS
MOVEM TA,LSTFIL ;SAVE IT
MOVE TA,[XWD CD.FIL,SZ.FIL] ;GET 15-WORD FILTAB ENTRY
PUSHJ PP,GETENT
MOVEM TA,CURFIL ;SAVE ADDRESS OF CURRENT FILTAB ENTRY
HLLZ TB,NAMADR ;NAMTAB ENTRY REL.ADDR.
MOVEM TB,(TA) ;TO WORD 1 OF FILTAB ENTRY
DPB W2,FI.LNC ;LINE NUMBER, CHARACTER POSITION
HRRZI TB,3 ;INITIALIZE OPTIONS AS NOT YET DECLARED
DPB TB,FI.ERM ;EXT. RECORDING MODE
DPB TB,FI.LBL ;LABELS
DPB TB,FI.ACC ;ACCESS MODE
DPB TB,FI.IRM ;AND INT. RECORDING MODE
TSWF FOPT ;TEST WHETHER OPTIONAL FILE
DPB TB,FI.OPT ;SET FLAG IF IT IS
HLRZ TA,LSTFIL ;REL.ADDR.OF LAST FILTAB ENTRY
JUMPE TA,IA14.D ;NULL PREVIOUS ENTRY
HRRZ TB,FILLOC ;STARTING ADDRESS OF FILTAB
ADD TA,TB ;ABS.ADDR. OF LAST FILTAB ENTRY
HLRZ TB,CURFIL ;REL. ADDR. OF CURRENT FILTAB ENTRY
DPB TB,FI.NXT ;'NEXT ENTRY' LINK
IA14.D: HLLZ TA,CURFIL ;ENTRY REL. ADDR.
HLR TA,NAMADR ;NAMTAB ENTRY REL. ADDR.
JRST PUTLNK ;LINK FILTAB & NAMTAB
;GET VALUE OF INTEGER & PUT ON SAVLST
INTER. IA16.
IA16.: PUSHJ PP,IA16S. ;GET VALUE OF INTEGER
HRRZI TC,1 ;ERROR -- ASSUME VALUE OF 1
IA16.A: MOVE LN,WORDLN## ;[553] GET LINE & CHAR POS. OF THE
MOVE CP,WORDCP## ;[553] INTEGER - SO WE CAN POINT TO
MOVEM LN,SAVPLN## ;[553] IT IF IT IS OUT OF
MOVEM CP,SAVPCP## ;[553] RANGE
PUSH SAVPTR,TC ;SAVE INTEGER VALUE ON SAVLST
POPJ PP,
;GET VALUE OF NUMERIC LITERAL
;CALL: PUSHJ PP,IA16S.
; ERROR RETURN (MESSAGE BE25. GIVEN)
; NORMAL RETURN (VALUE IN TC)
IA16S.: HLRZ TB,W1 ;L.H. OF FIRST GETWRD PARAMETER
TRNE TB,GWNLIT ;IS THIS A NUMERIC LITERAL?
TRNE TB,GWDP ;YES, IS IT AN INTEGER?
EWARNJ E.25 ;NO, 'POSITIVE INTEGER REQUIRED' -- EXIT
HRRZI TA,LITVAL ;ADDRESS OF INTEGER (ASCII STRING FORM)
ANDI TB,000777 ;LENGTH OF STRING
MOVEM TB,CTR
AOS (PP) ;SKIP RETURN
PJRST GETVAL ;GET VALUE OF INTEGER
INTER. IA16C.
IA16C.: PUSHJ PP,IA16. ;[501] GET THE VALUE
CAIL TC,11 ;[501] IF GREATER THAN 8
EWARNW E.99 ;[501] TROUBLE
POPJ PP,
;GET DEVICE NAME
INTER. IA18.
IA18.: TLNE W1,GWLIT ;LITERAL?
JRST IA18.A ;YES
TLNE W1,GWHYF ;HYPHEN IN DEV-NAME?
EWARNW E.83 ;YES, 'IMPROPER DEVICE NAME'
SETZM NAMWRD+1 ;DELETE ALL BUT 6 CHARS
MOVE TA,[POINT 6,NAMWRD] ;PTR TO SIXBIT NAME
MOVE TB,[POINT 7,TBLOCK,6] ;PTR TO ASCII NAME STORE
MOVNI TD,6 ;6 CHAR CTR
IA18.L: ILDB TC,TA ;GET CHARACTER OF NAME
JUMPE TC,IA18.M ;END OF NAME
ADDI TC,40 ;CONVERT SIxBIT TO ASCII
IDPB TC,TB ;SAVE CHARACTER
AOJL TD,IA18.L ;CONTINUE UNTIL 6 CHARS
IA18.M: ADDI TD,6 ;GET # OF CHARS IN NAME
IA18.N: DPB TD,[POINT 7,TBLOCK,6]
IDIVI TD,5 ;GET LENGTH OF VALTAB ENTRY (INCL CHAR CNT)
ADDI TD,1 ;AT LEAST 1 WORD
MOVEM TD,ESIZE ;SAVE ENTRY SIZE
HRLI TD,CD.VAL ;VALTAB CODE
MOVE TA,TD
PUSHJ PP,GETENT ;FIND VALTAB ENTRY
MOVEM TA,VALADR ;SAVE ADDRESS
MOVE TD,TBLOCK ;MOVE WORD OF NAME
MOVEM TD,(TA) ;TO VALTAB
MOVE TD,TBLOCK+1 ;POSSIBLE 2ND WORD OF NAME
SOSLE ESIZE ;1 OR 2 WORDS NEEDED?
MOVEM TD,1(TA) ;2, STORE 2ND WORD
HRRZ TA,CURFIL ;ABS. ADDR. OF FILTAB ENTRY
LDB TB,FI.NDV ;DEVICE COUNT FOR CURRENT FILE
ADDI TB,1 ;SET DEV COUNT UP BY 1
DPB TB,FI.NDV ;DEPOSIT NEW DEVICE COUNT
LDB TB,FI.VAL ;VALTAB LINK TO UNIT NAME
JUMPN TB,CPOPJ ;EXIT IF ALREADY SET
HLRZ TB,VALADR ;VALTAB POINTER
DPB TB,FI.VAL ;PUT LINK IN ENTRY
POPJ PP,
IA18.A: MOVE TA,[POINT 7,LITVAL] ;PTR TO LITERAL NAME
MOVE TB,[POINT 7,TBLOCK,6] ;PTR TO ASCII NAME STORE
LDB TD,GWVAL ;GET SIZE
CAILE TD,6 ;6 CHAR AT MOST
MOVEI TD,6
PUSH PP,TD ;SAVE COUNT FOR LATER
IA18.B: ILDB TC,TA ;GET CHARACTER OF NAME
CAIL TC,"0" ;LETTER OR DIGIT?
CAILE TC,"Z"
EWARNW E.83 ;NO, 'IMPROPER DEVICE NAME'
CAILE TC,"9"
CAIL TC,"A"
TRNA ;YES
EWARNW E.83 ;NO, 'IMPROPER DEVICE NAME'
IDPB TC,TB ;SAVE CHARACTER
SOJG TD,IA18.B ;CONTINUE UNTIL 6 CHARS
POP PP,TD ;GET EXACT COUNT BACK
JRST IA18.N
;GET NUMBER OF ALTERNATE BUFFERS
INTER. IA19.
IA19.: PUSHJ PP,IA16S. ;GET VALUE OF INTEGER IN TC
POPJ PP, ;NOT AN INTEGER
IFN ANS74,<
SUBI TC,2 ; REMOVE THE DEFAULT SIZE
>
JUMPGE TC,.+2 ; [355] IF NEGATIVE SET TO
SETOI TC, ; [355] MAX-LIBOL WILL INTERPRET AS ONE BUFFER
CAIG TC,^D62 ; [355] IF LESS THAN OR EQUAL TO 62
JRST IA19A ; [355] OK, GO ON.
EWARNW E.587 ; [355] OTHERWISE WARN USER.
MOVEI TC,^D62 ; [355] SET TO MAX.
IA19A: HRRZ TA,CURFIL ;FILTAB ENTRY ABSOLUTE ADDRESS
LDB TB,FI.NBF ;GET NUMBER OF BUFFERS FIELD
JUMPE TB,IA19.P ;RESERVE CLAUSE SEEN ALREADY?
CAIE TB,(TC) ;YES, IS THIS THE SAME VALUE?
JBE16.: EWARNJ E.16 ;NO, 'DUPLICATE CLAUSE' MSG
POPJ PP,
IA19.P: DPB TC,FI.NBF ;INSERT NO. OF EXTRA BUFFERS IN FILTAB ENTRY
POPJ PP,
;FLAG MISSING INTEGER OR 'NO' AFTER 'RESERVE'
;AND ASSUME 'NO' SEEN
INTER. IA20E.
IA20E.: EWARNW E.18 ;'IMPROPER CLAUSE'
SKPNAM
;INDICATE NO ALTERNATE BUFFERS
IFN ANS68,<
INTER. IA20.
IA20.: HRRZ TA,CURFIL ;FILTAB ENTRY ABS. ADDR.
LDB TB,FI.NBF ;GET NUMBER OF BUFFERS FIELD
CAILE TB,1 ;0 OR 1?
EWARNJ E.16 ;NO, GIVE 'DUPLICATE CLAUSE' MSG
HRRZI TC,1 ;SET TO 1 BUFR (NO ALTERNATES)
JRST IA19.P ;PUT INTO FILTAB ENTRY
>
;CHECK FOR MORE THAN 1 ORGANIZATION MODE SETTING PER FILE
INTER. IA21.
IA21.: HRRZ TA,CURFIL ;AIM AT CURRENT FILTAB ENTRY
LDB TB,FI.ACC ;GET CURRENT SETTING OF ACCESS MODE BITS
CAIN TB,3 ;IS IT AT INITIAL VALUE?
POPJ PP, ;YES
HRRZI TA,ED12.## ;AFTER DOING BE16., GO TO SYNTAX NODE ED12.
MOVEM TA,(NODPTR)
EWARNJ E.16 ;'DUPLICATE CLAUSE'
;SAVE SYMBOLIC KEY CODE FOR HLDTAB
IFN ANS68,<
INTER. IA22.
IA22.:
IFN ISAM,<
HRRZ TA,CURFIL ;[505] ABS. ADDR. OF FILTAB ENTRY
LDB TB,FI.ACC ;[505] GET ACCESS MODE
CAIE TB,%%ACC ;[505] IS IT THE "DEFAULT"?
CAIN TB,%ACC.I ;[505] NO, INDEXED?
JRST IA22A. ;[505] YES, OK
MOVEI DW,E.595 ;[505] NO, ERROR - WRONG TYPE KEY
PUSHJ PP,FATALW## ;[505] FLAG IT
HRRZI TB,%HL.AK ;[505] GET PROPER CODE
SKIPA ;[505]
IA22A.: HRRZI TB,%HL.SY ;[505] GET CODE
JRST IA24X.
>
IFE ISAM,<EWARNJ BE91.> ;?NOT IMPLEMENTED
>
;SAVE RECORD KEY CODE FOR HLDTAB
INTER. IA22R.
IA22R.:
IFN ISAM,<
HRRZI TB,%HL.RC ;GET CODE
JRST IA24X.
>
IFE ISAM,<EWARNJ BE91.> ;?NOT IMPLEMENTED
;INITIALIZE FILE-LIMIT CLAUSE
IFN ANS68,<
INTER. IA23.
IA23.: PUSHJ PP,IA62. ;RE-INIT SAVLST
HRRZ TA,CURFIL ;FILTAB ENTRY ABS. ADDR.
LDB TB,FI.NFL ;GET NO. OF FILE-LIMIT CLAUSES
JUMPN TB,JBE16. ;ERROR IF NOT 0 (DUP. CLAUSE)
POPJ PP,
>
;SAVE ACTUAL/RELATIVE KEY CODE FOR HLDTAB
INTER. IA24.
IA24.: HRRZ TA,CURFIL ;[505] ABS. ADDR. OF FILTAB ENTRY
LDB TB,FI.ACC ;[505] GET ACCESS MODE
CAIE TB,%%ACC ;[505] IS IT "DEFAULT"?
CAIN TB,%ACC.R ;[505] NO, IS IT RANDOM?
JRST IA24A. ;[505] YES, OK
MOVEI DW,E.595 ;[505] NO, ERROR - WRONG TYPE KEY
PUSHJ PP,FATALW## ;[505] FLAG IT
HRRZI TB,%HL.SY ;[505]
SKIPA ;[505]
IA24A.: HRRZI TB,%HL.AK ;[505] GET CODE
IA24X.: MOVEM TB,CTR ;STORE CODE IN HLDTAB
POPJ PP,
;SET SEQUENTIAL ORGANIZATION/ACCESS FLAG
INTER. IA25.
IA25.: HRRZI TB,%ACC.S ;ACCESS MODE SEQUENTIAL CODE
JRST IA27.X ;INSERT IN FILTAB ENTRY
;SET INDEXED-SEQUENTIAL ORGANIZATION/ACCESS MODE
INTER. IA26.
IA26.:
IFN ISAM,<
HRRZI TB,%ACC.I ;ACCESS MODE IS ISAM CODE
JRST IA27.X ;INSERT IN FILTAB ENTRY
>
IFE ISAM,<EWARNJ BE91.> ;?NOT IMPLEMENTED
;SET RANDOM ORGANIZATION/ACCESS FLAG
INTER. IA27.
IA27.: HRRZI TB,%ACC.R ;ACCESS MODE RANDOM CODE
IA27.X: HRRZ TA,CURFIL ;ABS. ADDR. OF FILTAB ENTRY
DPB TB,FI.ACC ;DEPOSIT IN FILTAB ENTRY
POPJ PP,
IFN ANS74,<
;CHECK FOR MORE THAN 1 ACCESS MODE SETTING PER FILE
INTER. IA25X.
IA25X.: HRRZ TA,CURFIL ;AIM AT CURRENT FILTAB ENTRY
LDB TB,FI.FAM ;GET CURRENT SETTING OF ACCESS MODE BITS
JUMPN TB,JBE16. ;'DUPLICATE CLAUSE'
POPJ PP, ;AT INITIAL SETTING
;SET SEQUENTIAL ACCESS MODE
INTER. IA25S.
IA25S.: MOVEI TB,%FAM.S
IA25.X: HRRZ TA,CURFIL
DPB TB,FI.FAM## ;STORE IN FILTAB
POPJ PP,
;SET RANDOM ACCESSS MODE
INTER. IA25R.
IA25R.: MOVEI TB,%FAM.R
JRST IA25.X
;SET DYNAMIC ACCESS MODE
INTER. IA25D.
IA25D.: MOVEI TB,%FAM.D
JRST IA25.X
>
;PUT KEY DATA-NAME IN HLDTAB
INTER. IA28.
IA28.: PUSHJ PP,IA59S. ;SAVE NAMTAB ADDR
PUSHJ PP,IA28S. ;SET UP HLDTAB ENTRY
HRRZ TB,CTR ;GET KEY CODE
DPB TB,HL.COD ;& PUT IT IN HLDTAB
HLRZ TB,CURFIL ;STORE FILTAB LINK IN HLDTAB
DPB TB,HL.LNK
POPJ PP,
;SET UP HLDTAB ENTRY
IA28S.: MOVE TA,[XWD CD.HLD,SZ.HLD] ;GET A HLDTAB ENTRY
PUSHJ PP,GETENT
MOVEM TA,CURHLD ;SAVE ADDR
HLRZ TB,CURNAM ;PUT LINK TO NAMTAB IN HLDTAB
DPB TB,HL.NAM
DPB W2,HL.LNC ;ALSO POSITION OF ITEM IN SOURCE
SETZ TB, ;CLR # OF QUALIFIERS
DPB TB,HL.QAL
POPJ PP,
;LITERAL FILE-LIMIT
IFN ANS68,<
INTER. IA29.
IA29.: HLRZ TB,W1 ;GET SIZE OF LITERAL
ANDI TB,000777
TLNE W1,GWNLIT ;IS IT A NUMERIC LITERAL?
TLNE W1,GWDP ;DOES IT HAVE A DECIMAL POINT?
EWARNJ E.264 ;NOT AN INTEGER
MOVE TC,[POINT 7,LITVAL] ;GET PTR TO LITERAL
ILDB TD,TC ;AND PICK UP FIRST CHARACTER
CAIN TD,"-" ;IS IT -?
EWARNW E.25 ;YES, GIVE ERROR MESSAGE
HRRZI TB,1(TB) ;1 MORE FOR NUMBER OF CHARACTERS
MOVEM TB,LSIZE ;SAVE
HRRZI TB,4(TB) ;ROUND UPWARDS
IDIVI TB,5 ;NO. OF WORDS REQUIRED
HRRZI TA,(TB) ;GET A VALTAB ENTRY OF THIS SIZE
HRLI TA,CD.VAL
PUSHJ PP,GETENT
MOVEM TA,CURVAL ;SAVE ADDRESS
MOVE TB,[POINT 7,(TA)] ;PTR TO VALTAB STORE
MOVE TC,[POINT 7,LITVAL] ;PTR TO LITERAL
MOVE TE,LSIZE ;CHAR COUNT FOR THE MOVE
MOVEI TD,-1(TE) ;1ST STORE THE TRUE CHAR COUNT
JRST IA29.L+1
IA29.L: ILDB TD,TC ;GET CHARACTER
IDPB TD,TB ;STASH IT
SOJG TE,IA29.L
HLRZ TA,CURVAL ;SAVE VALTAB PTR
JRST IA30.X
;PUT FILE-LIMIT DATA-NAME IN HLDTAB
INTER. IA30.
IA30.: PUSHJ PP,IA59S. ;SAVE NAMTAB ADDR
PUSHJ PP,IA28S. ;SET UP HLDTAB ENTRY
HLRZ TA,CURHLD ;PUT HLDTAB PTR ON SAVE LIST
IA30.X: PUSH SAVPTR,TA
POPJ PP,
;ERROR OF TYPE: "FILE-LIMITS 1 THRU 200, FOO."
;(OBJECT IS TO KEEP HLDTAB FROM GETTING MIXED UP)
INTER. IA30E
IA30E: PUSHJ PP,IA32. ;SET UP DUMMY LOW LIMIT
PUSHJ PP,IA34. ;MAKE FOO THE HIGH LIMIT
EWARNJ E.303 ;?'THRU' EXPECTED
;ITEM BEFORE 'THRU' BECOMES LOW FILE-LIMIT
INTER. IA31.
IA31.: HRRZ TA,CURFIL ;GET PTR TO CURRENT FILTAB ENTRY
LDB TC,FI.NFL ;INCREMENT NO. OF FILE-LIMITS CLAUSES
ADDI TC,1
DPB TC,FI.NFL ;PUT NEW VALUE IN FILTAB FIELD
MOVE TA,[XWD CD.FIL,1] ;GET 1 WORD IN FILTAB FOR FILE-LIMITS
PUSHJ PP,GETENT
MOVEM TA,CFLM ;SAVE ADDRESS
POP SAVPTR,TD ;GET POINTER FROM SAVE LIST
CAIL TD,<CD.VAL>B20 ;SAVING LOW-LIM ON VALTAB OR HLDTAB?
HRLZM TD,(TA) ;VALTAB, PUT PTR TO LOW-LIMIT IN FILTAB
HRRZI TB,%HL.LL ;SET LOW-LIMIT FLAG IN HLDTAB
IA31.X: TRNE TD,600000 ;VALTAB OR HLDTAB ADDR?
POPJ PP, ;VALTAB
HRRZ TA,HLDLOC ;GET HLDTAB START ADDR.
ADDI TA,(TD) ;PLUS REL ADDR. OF CURRENT WORD
DPB TB,HL.COD
HLRZ TB,CFLM ;PUT FILTAB LINK IN HLDTAB
DPB TB,HL.LNK
POPJ PP,
;SINGLE-ITEM FILE-LIMIT SEEN -- ASSUME 1 AS LOW LIMIT
INTER. IA32.
IA32.: MOVE TA,[XWD CD.VAL,1] ;GET 1-WORD VALTAB ENTRY
PUSHJ PP,GETENT
MOVSI TB,5420 ;PUT '1' IN VALTAB
MOVEM TB,(TA)
HLRZ TB,TA ;PUT VALTAB POINTER ON SAVE LIST
PUSH SAVPTR,TB
JRST IA31. ;PUT LOW LIMIT OF 1 IN FILTAB
;STORE HIGH LIMIT IN FILTAB FILE-LIMIT WORD
INTER. IA34.
IA34.: HLRZ TA,CFLM ;REL ADDR OF FILE-LIMIT WORD
HRRZ TB,FILLOC ;FILTAB ENTRY ADDR
ADD TA,TB ;ABS. ADDR. OF CURRENT FILE-LIMIT
POP SAVPTR,TD ;GET POINTER TO LAST ITEM
CAIL TD,<CD.VAL>B20 ;SAVING HI-LIM ON VALTAB OR HLDTAB?
JRST IA34.X ;VALTAB, CHECK AGAINST LOW LIMIT
HRRZI TB,%HL.HL ;SET HI-LIM FLAG IN HLDTAB
JRST IA31.X
IA34.X: HLRZ TB,(TA) ;PICK UP LOW LIMIT POINTER FROM FILTAB
CAIGE TB,<CD.VAL>B20 ;IS IT VALTAB?
JRST IA34.Y ;NO, CAN'T CHECK LIMITS
PUSH PP,TA ;SAVE POINTER TO FILE LIMITS WORD
PUSH PP,TD ;SAVE POINTER TO HI-LIMIT
MOVE TA,TB ;MOVE RELATIVE POINTER FOR LOW LIMIT
HRRZ TC,VALLOC## ;GET POINTER TO VALTAB
ADD TA,TC ;MAKE LOW-LIMIT PTR ABSOLUTE
TRZ TA,600000 ;GET RID OF FLAGS
MOVE TD,[POINT 7,(TA)] ;BYTE POINTER TO LOW LIMIT
ILDB TB,TD ;PICK UP FIRST BYTE
MOVEM TB,CTR## ;AND USE IT AS CHAR COUNT
PUSHJ PP,GETV2## ;GO GET VALUE FOR LOW LIMIT
POP PP,TA ;NOW SET UP FOR HIGH LIMIT
PUSH PP,TC ;SAVE LOW LIMIT VALUE
HRRZ TC,VALLOC ;CONVERT RELATIVE HI-LIMIT
ADD TA,TC ;POINTER TO ABSOLUTE
TRZ TA,600000 ;AND GET RID OF FLAGS
MOVE TD,[POINT 7,(TA)] ;GET ITS FIRST BYTE
ILDB TB,TD ;INTO TB
MOVEM TB,CTR## ;AND USE AS COUNT
PUSHJ PP,GETV2 ;NOW GET HI-LIMIT VALUE INT TC
POP PP,TD ;RESTORE LOW LIMIT VALUE TO TD
CAMG TC,TD ;IS HI-LIM GREATER?
JRST IA34.Z ;NO, FIX STACK AND GIVE ERROR
TRO TA,600000 ;YES, RESTORE FLAGS
HRRZ TB,VALLOC## ;AND MAKE POINTER RELATIVE
SUB TA,TB ;TO VALTAB
MOVE TD,TA ;RETURN IT TO ITS USUAL PLACE
POP PP,TA ;AND RESTORE POINTER TO FILE LIMITS WORD
IA34.Y: HRRM TD,(TA) ;HERE IF ALL OK, STORE HI-LIM
HRRZI TB,%HL.HL ;AND SET HI-LIM FLAG IN HLDTAB
JRST IA31.X
IA34.Z: POP PP,TA ;HERE ON ERROR, CLEAR THE STACK
EWARNJ E.272 ;GO GIVE ERROR
>;END IFN ANS68
;GET VALUE OF INTEGER & PUT INTO SEGMENT LIMIT WORD
INTER. IA35.
IA35.: PUSHJ PP,IA16S. ;GET VALUE OF INTEGER
POPJ PP, ;ITEM NOT AN INTEGER
JUMPLE TC,JBE19. ;<=0 IS ILLEGAL
CAILE TC,^D49 ;>=50 IS ILLEGAL
JBE19.: EWARNJ E.19 ;'IMPROPER SEGMENT LIMIT' -- EXIT
MOVE TA,SEGLIM ;GET PREVIOUS LIMIT
CAIN TA,^D50 ;50 IS INITIAL VALUE
JRST IA35.A ;HAS NOT YET BEEN RESET
CAMN TC,TA ;RESETTING TO SAME VALUE?
POPJ PP, ;YES, IGNORE IT
EWARNJ E.16 ;NO, 'CLAUSE DUPLICATED'
IA35.A: MOVEM TC,SEGLIM ;STORE NEW SEGMENT LIMIT
POPJ PP,
;SAME RECORD AREA (ONLY) FOR FILES IN LIST
INTER. IA36.
IA36.: SWON FSAME ;SET FLAG
POPJ PP,
;SAME AREA (REC. AREA & BUFRS) FOR FILES IN LIST
INTER. IA37.
IA37.: SWOFF FSAME ;CLR SAME-REC-AREA FLAG
POPJ PP,
;SAVE PTR TO FIRST FILE IN SAME-AREA CLAUSE
INTER. IA38.
IA38.: SKIPE SAMSRT ;IF 'SAME SORT' CLAUSE, DONT DO ANYTHING
POPJ PP,
PUSHJ PP,IA38S. ;GET PTR TO FILTAB ENTRY FOR THIS FILE
HLRZ TC,TB ;GET FILTAB ENTRY REL. ADDR.
PUSH SAVPTR,TC ;PUT ON SAVLST
PUSH SAVPTR,TC ;TWICE
HRRZ TA,TB ;GET FILTAB ENTRY ABS. ADDR.
LDB TB,FI.SAL ;EXAMINE SAME-AREA LINK
TSWF FSAME ;IS THIS A SAME-AREA OR A SAME-REC-AREA CLAUSE?
LDB TB,FI.SRA ;THE LATTER -- EXAMINE SAME-REC-AREA LINK
JUMPE TB,CPOPJ## ;IF NOT ON, RETURN
TSWF FSAME ;'SAME REC. AREA'?
EWARNW E.173 ;YES, 'FILE ALREADY IN SAME RECORD AREA CLAUSE'
TSWT FSAME ;'SAME AREA'?
EWARNW E.174 ;YES, 'FILE ALREADY IN SAME AREA CLAUSE'
HRRZI NODE,ED135.## ;NEXT SYNTAX NODE WILL BE ED135.
MOVEM NODE,0(NODPTR)
JRST IA62. ;RESET SAVE LIST POINTER
;GET PTR TO FILTAB ENTRY
IA38S.: HLRZ TA,W2 ;GET NAMTAB REL. ADDR
LSH TA,-2
HRRZI TB,CD.FIL ;FIND FILTAB ENTRY FOR THIS NAME
PUSHJ PP,FNDLNK
JRST IA38.E ;NONE FOUND
POPJ PP,
IA38.E: TTCALL 3,[ASCIZ /IA38S.--TYPE=FILE-NAME BUT NO FILTAB LINK FOUND.
/]
JRST KILL
;LINK THIS FILE TO PREVIOUS FILE IN SAME AREA CLAUSE
;AND SAVE PTR TO THIS FILE IN CASE THERE ARE MORE
INTER. IA38A.
IA38A.: SKIPE SAMSRT ;IF 'SAME SORT' CLAUSE, DONT DO ANYTHING
POPJ PP,
PUSHJ PP,IA38S. ;GET PTR TO FILTAB ENTRY FOR THIS FILE
MOVE TD,(SAVPTR) ;GET PTR TO PREVIOUS FILE
HRRZ TA,FILLOC
ADD TA,TD ;ABS. ADDR. OF THAT FILTAB ENTRY
HLRS TB ;GET LINK TO THIS FILE
TSWT FSAME ;SAME-AREA OR SAME-REC-AREA?
JRST IA38AA ;SAME-AREA
LDB TE,FI.SRA ;GET SAME-REC-AREA LINK
JUMPN TE,JBE173 ;IF NOT 0, 'FILE ALREADY IN SAME-REC-AREA CLAUSE'
DPB TB,FI.SRA ;STORE LINK TO THIS FILE IN THAT FILE'S ENTRY
JRST IA38AB
IA38AA: LDB TE,FI.SAL ;GET SAME-AREA LINK
JUMPN TE,JBE174 ;IF NOT 0, 'FILE ALREADY IN SAME-AREA CLAUSE'
DPB TB,FI.SAL ;STORE LINK TO THIS FILE IN THAT FILE'S ENTRY
IA38AB: MOVEM TB,(SAVPTR) ;SAVE POINTER TO THIS FILE
POPJ PP,
JBE173: EWARNJ E.173
JBE174: EWARNJ E.174
;LINK LAST FILE IN SAME-AREA CLAUSE TO THE FIRST
INTER. IA39.
IA39.: SKIPE SAMSRT ;IF 'SAME SORT' CLAUSE, DONT DO ANYTHING
POPJ PP,
HRRZ TA,0(SAVPTR) ;REL. ADDR. OF LAST FILE IN GROUP
PUSHJ PP,LNKSET ;GET ABS. ADDR.
HRRZ TB,-1(SAVPTR) ;REL. ADDR. OF FIRST FILE IN GROUP
TSWF FSAME ;SAME-REC AREA?
DPB TB,FI.SRA ;YES, STORE LINK
TSWT FSAME ;SAME-AREA?
DPB TB,FI.SAL ;YES, STORE LINK
JRST IA62. ;RESET SAVE LIST POINTER
;SAVE PTR TO FILE FOR SAME-DEVICE LINKAGE
INTER. IA40.
IA40.: PUSHJ PP,IA38S. ;GET PTR TO FILTAB ENTRY FOR THIS FILE
HRRZI TA,1 ;SAVE POSITION 1 (DEFAULT POS.)
PUSH SAVPTR,TA
PUSH SAVPTR,TB ;SAVE FILTAB ENTRY ADDR
MOVE TA,TB ;GET NO. OF DEVICES FOR THIS FILE
LDB TB,FI.NDV
CAIE TB,1 ;MUST BE 1
EWARNJ E.197 ;'ONLY ONE DEVICE ALLOWED'
LDB TC,FI.SDL ;GET SAME-DEVICE LINK
JUMPN TC,CPOPJ ;IF ON, LEAVE IT ALONE
HLRZ TB,TA ;GET REL ADDR OF FILTAB ENTRY
DPB TB,FI.SDL ;MAKE FILE POINT TO ITSELF IF NOWHERE ELSE
POPJ PP,
;GET POSITION OF FILE ON TAPE & STORE IN FILTAB ENTRY
INTER. IA41.
IA41.: PUSHJ PP,IA16S. ;GET VALUE OF INTEGER
POPJ PP, ;NOT AN INTEGER
IA41.A: MOVEM TC,TBLOCK ;SAVE POSITION
HLRZ TA,(SAVPTR) ;GET FILTAB ENTRY REL. ADDR.
PUSHJ PP,LNKSET ;GET ABS. ADDR
MOVE TC,TBLOCK ;GET POSITION ON TAPE
LDB TB,FI.POS ;EXAMINE TAPE POSITION FIELD
JUMPE TB,IA41.P ;ON?
CAIE TB,(TC) ;YES, SAME AS NEW ONE?
EWARNJ E.16 ;NO, 'DUPLICATE CLAUSE'
MOVEM TC,-1(SAVPTR) ;YES, PUT ON SAVE LIST AS POSITION
POPJ PP,
IA41.P: DPB TC,FI.POS ;PUT INTEGER IN POSITION FIELD
MOVEM TC,-1(SAVPTR) ;AND ON SAVE LIST
POPJ PP,
;NO POSITION CLAUSE
;GET POSITION FROM SAVLST & STORE IN FILTAB ENTRY
INTER. IA42.
IA42.: MOVE TC,-1(SAVPTR) ;GET SAVED INTEGER
JRST IA41.A
;CHAIN SAME-DEVICE LINKS
;AND CHECK NEW FILE FOR SAME DEVICE AS PREVIOUS
INTER. IA43.
IA43.: PUSHJ PP,IA38S. ;GET PTR TO FILTAB ENTRY FOR THIS FILE
MOVE TA,TB ;FILTAB ENTRY ADDR.
LDB TB,FI.NDV ;NO. OF DEVICES FOR THIS FILE
CAIE TB,1 ;MUST BE 1
EWARNJ E.197 ;'ONLY ONE DEVICE ALLOWED'
MOVEM TA,TBLOCK ;SAVE POINTER TO CURRENT FILTAB ENTRY
LDB TA,FI.VAL ;VALTAB LINK
PUSHJ PP,LNKSET ;GET ABS. ADDR.
MOVEM TA,SAVETA ;AND SAVE ADDR OF DEVICE NAME
HRRZ TA,(SAVPTR) ;GET SAVED FILE FILTAB ADDR
LDB TA,FI.VAL ;VALTAB LINK
PUSHJ PP,LNKSET ;GET ABS. ADDR. OF DEVICE NAME OF PREV. FILE
HLRZ TC,(TA)
LSH TC,-13 ;LENGTH OF ENTRY IN CHARACTERS
IDIVI TC,5
ADDI TC,1 ;AND IN WORDS, ROUNDED UP
MOVE TB,SAVETA ;CURRENT FILE VALTAB ADDRESS
IA43.L: MOVE TD,(TA) ;COMPARE WORD OF DEVICE NAMES
CAME TD,(TB)
JRST IA43.E ;DIFFERENT DEVICES
ADDI TA,1 ;GO TO NEXT WORD
ADDI TB,1
SOJG TC,IA43.L ;ALL WORDS DONE?
AOS -1(SAVPTR) ;YES, DEFAULT TAPE POS. IS NEXT ON TAPE
HRRZ TA,(SAVPTR) ;FILTAB ADDR OF LAST FILE IN LIST
LDB TC,FI.SDL ;GET REL ADDR OF 1ST FILE IN LIST
HRRZ TA,TBLOCK ;STORE LINK TO 1ST FILE IN NEW FILE ENTRY
DPB TC,FI.SDL
HLRZ TC,TBLOCK ;REL. FILTAB ADDR OF NEW FILE
HRRZ TA,(SAVPTR) ;STORE LINK TO NEW FILE IN OLD FILE ENTRY
DPB TC,FI.SDL
MOVE TA,TBLOCK ;SAVE ADDR OF NEW FILE
MOVEM TA,(SAVPTR)
POPJ PP,
IA43.E: HRRZI TA,ED158.## ;AFTER ERROR MSG, GO TO SYNTAX NODE ED158.
MOVEM TA,(NODPTR)
EWARNJ E.23 ;'NOT SAME DEV. AS PREV. FILE'
;GET MNEMONIC-NAME FOR CONSOLE
INTER. IA44.
IA44.: HRLZI TA,040000 ;GET CONSOLE TYPE FLAG
;ENTER HERE TO STORE NAME IN MNETAB
;TA SHOULD CONTAIN APPROPRIATE TYPE FLAG
IA44.D: MOVEM TA,MNETYP ;STORE TYPE FLAG
JUMPGE W1,IA44.A ;IS THIS NAME IN NAMTAB?
TLNE W1,30000 ;IS IT A LITERAL OR RESERVED WORD?
EWARNJ E.24 ;YES, 'ILLEGAL MNEMONIC-NAME'
TLO W2,GWDEF ;PUT DEFINING REFERENCE ON CREF FILE
PUSHJ PP,PUTCRF
PUSHJ PP,BLDNAM ;PUT IN NAMTAB
IA44.C: MOVEM TA,CURNAM ;SAVE NAMTAB PTR
IA44.B: MOVE TA,[XWD CD.MNE,SZ.MNE] ;GET MNETAB ENTRY
PUSHJ PP,GETENT
IFN ANS74,<
HLRZM TA,CURMNE## ;SAVE POINTER TO IT
>
HLRZ TC,CURNAM ;GET NAMTAB POINTER
ORI TC,700000 ;SET MNETAB FLAG
MOVSM TC,(TA) ;PUT NAMTAB LINK IN MNETAB
MOVE TC,MNETYP ;GET TYPE FLAG
TLNE TC,730000 ;SKIP IF NOT SWITCH, CHANNEL, CODE, OR STATUS
HRR TC,(SAVPTR) ;GET SWITCH OR CHANNEL NUMBER
MOVEM TC,1(TA) ;TO WORD 2 OF ENTRY
HLR TA,CURNAM ;NAMTAB REL. ADDR.
PJRST PUTLNK ;LINK NAMTAB TO MNETAB
IA44.A:
IFN ANS74,<
TLNE TA,(1B6) ;ALPHABET-NAME?
JRST IA44.E ;YES
>
HLRZ TA,W2 ;GET NAMTAB PTR
LSH TA,-2
HRRZI TB,CD.MNE ;MNETAB FLAG
HRLZM TA,CURNAM ;SAVE NAMTAB REL. ADDR.
PUSHJ PP,FNDLNK ;FIND MNETAB LINK
JRST IA44.B ;NOT FOUND
EWARNJ E.28 ;'MNEMONIC-NAME ALREADY IN USE'
IFN ANS74,<
IA44.E: TLO W2,GWDEF ;PUT DEFINING REFERENCE ON CREF FILE
PUSHJ PP,PUTCRF
PUSHJ PP,TRYNAM ;GET NAME
PUSHJ PP,BLDNAM ;BUT WE REALLY KNOW IT IS
JRST IA44.C ;SAVE POINTER AND CONTINUE
>
;GET MNEMONIC-NAME FOR LPT CHANNEL
INTER. IA46.
IA46.: HRLZI TA,020000 ;GET CHANNEL TYPE FLAG
JRST IA44.D
;GET MNEMONIC-NAME FOR HARDWARE SWITCH
INTER. IA47.
IA47.: HRLZI TA,400000 ;GET SWITCH TYPE FLAG
JRST IA44.D
;SET SWITCH-ON STATUS FLAG
INTER. IA48.
IA48.: SWON FSTAT ;ON
POPJ PP,
;SET SWITCH-OFF STATUS FLAG
INTER. IA49.
IA49.: SWOFF FSTAT ;OFF
POPJ PP,
;GET MNEMONIC-NAME FOR SWITCH STATUS
INTER. IA50.
IA50.: TSWT FSTAT;
HRLZI TA,100000 ;'OFF STATUS'
TSWF FSTAT;
HRLZI TA,200000 ;'ON STATUS'
JRST IA44.D
;GET CHARACTER FOR CURRENCY SIGN
INTER. IA51.
IA51.: TLNE W1,200000 ;IS ITEM A LITERAL?
TLNE W1,174000 ;SIMPLE ALPHANUMERIC?
EWARNJ E.27 ;NO, 'MUST BE A 1 CHAR NON-NUMERIC LITERAL'
TLNE W1,000776 ;IS ITS LENGTH 1?
EWARNJ E.27 ;NO
LDB TA,[POINT 7,LITVAL,6] ;YES, GET THAT CHARACTER
SKIPN DOLLR. ;CURR. SIGN ALREADY GIVEN?
JRST IA51.P ;NO
CAMN TA,DOLLR. ;YES, IS NEW ONE THE SAME?
POPJ PP, ;YES
EWARNJ E.16 ;NO, 'DUPLICATE CLAUSE'
IA51.P: MOVEI TB,-40(TA) ;CONVERT TO SIXBIT
CAIL TB,1 ;IN SIXBIT RANGE & NOT SPACE?
CAIL TB,100
EWARNJ E.175 ;NO, INVALID CHARACTER
MOVE TD,[POINT 6,CSL] ;AIM AT LIST OF ILLEGAL CHARS
IA51.R: ILDB TC,TD ;GET A CHAR FROM LIST
JUMPE TC,IA51.Q ;END OF LIST -- ALL IS WELL
CAIN TB,(TC) ;IS THIS A MATCH?
EWARNJ E.175 ;YES, INVALID CHARACTER
JRST IA51.R ;NO, TRY NEXT
IA51.Q: MOVEM TA,DOLLR. ;STASH NEW CURRENCY SIGN
POPJ PP,
;ITEMS ILLEGAL AS CURRENCY SIGN
;(SPACE MARKS END OF LIST)
CSL:
IFN ANS68,<
SIXBIT /0123456789*+-,.;()"ABCDPRSVXZ /
>
IFN ANS74,<
SIXBIT '0123456789*+-,.;()"=/ABCDLPRSVXZ '
>
;SWITCH FUNCTIONS OF COMMA AND DECIMAL POINT
INTER. IA52.
IA52.: MOVEI TA,"." ;COMMA = .
MOVEM TA,COMA.##
MOVEI TA,"," ;DEC.PT. = ,
MOVEM TA,DCPNT.##
POPJ PP,
;MISSING INTEGER -- WARN AND ASSUME 0
INTER. IA54E.
IA54E.: EWARNW E.25 ;'POSITIVE INTEGER REQUIRED'
SKPNAM
;PUT A ZERO VALUE ON THE SAVLST
INTER. IA54.
IA54.: SETZ TC, ;PUT 0 ON SAVE LIST
JRST IA16.A
;SET RERUN FLAG & COUNT FOR FILE
INTER. IA55.
IA55.: PUSHJ PP,IA38S. ;GET PTR TO FILTAB ENTRY FOR THIS FILE
HRRZ TA,TB ;FILTAB ENTRY ABS. ADDR.
POP SAVPTR,TC ;GET SAVED INTEGER
JUMPE TC,IA55.A ;RERUN END-OF-REEL
CAIG TC,177777 ;[553] TOO BIG TO FIT?
JRST IA55.0 ;[553] NO, STASH IT
MOVE LN,SAVPLN## ;[553] YES - RESTORE THE LINE NO. &
MOVE CP,SAVPCP## ;[553] CHARACTER POS. OF INTEGER
MOVEI DW,E.609 ;[553] GET CORRECT ERROR NUMBER
PUSHJ PP,WARN ;[553] GIVE USER WARNING
MOVEI TC,177777 ;[553] ASSUME THE MAXIMUM
IA55.0: DPB TC,FI.RCT ;[553] RERUN COUNT
HRRZI TC,1
DPB TC,FI.RRC ;SET RERUN ON COUNT FLAG
POPJ PP,
IA55.A: HRRZI TC,1
DPB TC,FI.RER ;SET RERUN END-OF-REEL FLAG
POPJ PP,
;SET SPECIAL-NAMES PARAGRAPH FLAG
INTER. IA56.
IA56.: TSWF FSPNAM ;ALREADY SEEN A SPECL-NAMES PARA?
EWARNJ E.30 ;YES, 'DUPLICATE PARAGRAPH'
SWON FSPNAM ;NO, BUT NOW WE HAVE
POPJ PP,
;WIPE LAST ENTRY OFF SAVLST
INTER. IA57.
IA57.: POP SAVPTR,TA ;LOSE SAVE LIST ENTRY
POPJ PP,
;PUT DATA-NAME QUALIFIER IN NEXT WORD OF HLDTAB
INTER. IA59.
IA59.: PUSHJ PP,IA59S. ;SAVE NAMTAB ADDR
MOVE TA,CURHLD ;GET # OF QUALIFIERS BEFORE THIS
LDB TB,HL.QAL
AOJ TB, ;INCREMENT COUNT
DPB TB,HL.QAL ;& PUT BACK
ROT TB,-1 ;DIV BY 2
HLRZ TC,CURNAM ;GET NAMTAB LINK
JUMPL TB,IA59.A ;IF BIT0 ON, USE ODD HALF-WORD
ADDI TA,1(TB) ;PTR TO EVEN HALF-WORD
HRRM TC,(TA) ;STORE IN EVEN HALF
POPJ PP,
IA59.A: PUSH PP,CURHLD ;SAVE PTR TO HLDTAB ENTRY
MOVE TA,[XWD CD.HLD,1] ;GET ONE MORE WORD FOR THE ENTRY
PUSHJ PP,GETENT
HLRZ TC,CURNAM ;GET NAMTAB LINK
HRLZM TC,(TA) ;STORE NAMTAB LINK IN ODD HALF
POP PP,CURHLD ;RESTORE HLDTAB PTR
POPJ PP,
;STORE NAMTAB RELATIVE ADDRESS FOR NEW NAME
IA59S.: TLNN W1,GWNOT ;NAME IN NAMTAB?
JRST IA59SA ;YES
PUSHJ PP,BLDNAM ;NO, BUILD NAMTAB ENTRY
MOVEM TA,CURNAM ;SAVE ADDR
HLRZS TA ;LEAVE LINK IN RIGHT HALF
DPB TA,[POINT 15,W2,15] ;& IN W2
POPJ PP,
IA59SA: LDB TA,[POINT 15,W2,15] ;GET NAMTAB REL ADDR
HRLZM TA,CURNAM ;& SAVE
POPJ PP,
;ILLEGAL DATA-NAME IN FILE-LIMIT CLAUSE
INTER. IA61.
IA61.: HLRZ TA,CFLM ;GET CURRENT FILE LIMIT POINTER
PUSHJ PP,LNKSET ;GET ABS. ADDR.
HLRS (TA) ;MAKE HIGH-LIMIT=LOW-LIMIT
EWARNJ E.17 ;'ILLEGAL DATA NAME'
;REFRESH SAVLST
;(SAVLST IS USED FOR TEMPORARY STORAGE)
INTER. IA62.
IA62.: MOVE SAVPTR,ISVPTR ;RESET SAVE LIST
POPJ PP,
;FLAG MISSING DATA DIVISION, THEN GO TO COBOLC
INTER. IA63F.
IA63F.: EWARNW E.31 ;'NO DATA DIVISION'
SKPNAM
;INIT MISSING ENVIRONMENT DIVISION, THEN GO TO COBOLC
INTER. IA63E.
IA63E.: PUSHJ PP,IA67. ;DO ENV. DIV. INITS
SKPNAM
;CLEAN-UP AT END OF PHASE B, AND THEN CALL IN COBOLC
INTER. IA63.
IA63.: SWON FREGWD ;REGET 'DATA' OR WHATEVER
;INIT MISSING ENVIRONMENT ITEMS
SKIPN OBJSIZ ;MEMORY SIZE = 0?
SETOM OBJSIZ ;IF SO, SET TO -1
MOVEI TA,"$" ;DEFAULT DOLLAR SIGN IS "$"
SKIPN DOLLR. ;HAS HE SET ONE?
MOVEM TA,DOLLR. ;NO
SKIPN PROGID ;DID HE SET PROGRAM-ID?
PUSHJ PP,IA2.2 ;NO, NAME IT "COBOL."
SKIPN DEFDSP ;DEFAULT DISPLAY MODE GIVEN?
AOS DEFDSP ;NO, SO MAKE IS DISPLAY-6
IFN ANS74,<
PUSHJ PP,IA210. ;CLEANUP ALPHABET-NAMES
>
ENDFAZ B; ;CLOSE OUT PHASE B & GO TO COBOLC
;INITIALIZE ENVIRONMENT DIVISION
INTER. IA67.
IA67.:
IFN DEBUG,<
MOVE TE,CORESW
SWOFF FNDTRC ;CLR OLD TRACE REQUEST
TRNE TE,TRACEE ;TRACE ED NODES?
SWON FNDTRC ;YES, TURN ON TRACER
>
MOVE TA,[XWD CD.DAT,SZ.DAT] ;MAKE A DUMMY DATAB ENTRY
PUSHJ PP,GETENT ;FOR DATA-DIV. BREAK
HRRZI TB,CD.DAT
DPB TB,[POINT 3,(TA),2] ;ENTER DATTAB CODE
POPJ PP,
;SET MULTIPLE REEL FLAG FOR FILE
IFN ANS68,< INTER. IA68.
IA68.: HRRZ TA,CURFIL ;FILTAB ENTRY ADDR
LDB TB,FI.MLT ;GET MULTIPLE REEL BIT
JUMPN TB,JBE16. ;IF ON, GIVE 'DUPLICATE CLAUSE' MSG
SETO TB, ;OK, SET MULTIPLE REEL BIT
DPB TB,FI.MLT
POPJ PP,
>
;RECORDING MODE CLAUSE
;ASCII
INTER. IA69.
IA69.: HRRZI TB,%RM.7B ;ASCII RECORDING MODE BITS
IA69.X: HRRZ TA,CURFIL ;AIM AT FILE ENTRY
LDB TC,FI.RM2 ;ENTERED ALREADY?
JUMPN TC,JBE16. ;YES, ERROR
DPB TB,FI.ERM ;NO, ENTER IT
HRRZI TB,%RM.DC ;SAY IT IS ENTERED
DPB TB,FI.RM2
POPJ PP,
;STANDARD ASCII
INTER. IA69A.
IA69A.: HRRZI TB,%RM.SA
JRST IA69.X
;BYTE MODE
INTER. IA69B.
IA69B.: HRRZ TA,CURFIL ;AIM AT FILE ENTRY
SETO TB,
DPB TB,FI.BM## ;SET BYTE MODE FLAG
POPJ PP,
;SIXBIT
INTER. IA70.
IA70.: HRRZI TB,%RM.6B ;SIXBIT RECORDING MODE BITS
JRST IA69.X
;BINARY
INTER. IA71.
IA71.: HRRZI TB,%RM.BN ;BINARY
JRST IA69.X
;EBCDIC
INTERN IA72.
IA72.: HRRZI TB,%RM.EB ;EBCDIC
JRST IA69.X
;SEE IF IT IS F OR V.
INTER. IA72A.
IA72A.: HLRZ TC, NAMWRD ;SEE WHAT WE GOT.
CAIE TC, (SIXBIT /F/) ;WAS IT F OR
CAIN TC, (SIXBIT /V/) ; V?
JRST IA72FV ;YES.
HRRZI TB, ED271.## ;FAKE SQUIRL OUT BY MAKING IT
MOVEM TB, (NODPTR) ; LOOK LIKE WE WERE ALWAYS AT
JRST IA0.R ; ED271. AND REGETTING THE ITEM.
IA72FV: SWOFF FREGWD ;DON'T REGET THE ITEM.
HRRZ TA, CURFIL ;GET THE FILE TABLE ADR.
LDB TB, FI.RM2 ;DID WE ALREADY GET A RECORDING MODE?
JUMPN TB, JBE16. ;YES, ERROR.
SETO TB, ;GET SOME ONES.
CAIN TC, (SIXBIT /V/) ;WAS IT V?
DPB TB, FI.VLR## ;YES, TURN ON THE VLR FLAG.
JRST IA72. ;GO SET EBCDIC MODE.
;RECORDING MODE CLAUSE
;DENSITY
INTER. IA73.
IA73.: PUSHJ PP,IA16S. ;GET THE INTEGER
POPJ PP, ;NOT AN INTEGER
HRRZ TA, CURFIL ;GET THE FILE TABLE'S ADR.
LDB TB, FI.RD ;GET THE RECORDING DENSITY.
JUMPN TB, JBE16. ;ALREADY SAW ONE - DUP CLAUSE.
CAIN TC, ^D200 ;200 BPI?
HRRZI TB, %RD.2
CAIN TC, ^D556 ;556 BPI?
HRRZI TB, %RD.5
CAIN TC, ^D800 ;800 BPI?
HRRZI TB, %RD.8
CAIN TC, ^D1600 ;1600 BPI?
HRRZI TB, %RD.16
CAIN TC, ^D6250 ;6250 BPI?
HRRZI TB, %RD.62
DPB TB, FI.RD ;PUT IT IN THE FILE TABLE.
JUMPN TB, CPOPJ ;RETURN IF IT WAS VALID.
EWARNJ E.327 ;OTHERWISE GIVE AN ERROR MSG.
;ODD PARITY
INTER. IA74.
IA74.: HRRZI TB,%RP.OD ;ODD PARITY BITS
IA74.X: HRRZ TA,CURFIL ;AIM AT FILE ENTRY
LDB TC,FI.RP ;DECLARED ALREADY?
JUMPN TC,JBE16. ;YES, ERROR
DPB TB,FI.RP ;NO, ENTER IT
POPJ PP,
;EVEN PARITY
INTER. IA75.
IA75.: HRRZI TB,%RP.EV ;EVEN PARITY BITS
JRST IA74.X
;SET SAME SORT AREA CLAUSE FLAG
INTER. IA76.
IA76.: SETOM SAMSRT
POPJ PP,
;INIT SAME <RECORD, SORT> AREA CLAUSE
INTER. IA77.
IA77.: SETZM SAMSRT ;CLEAR SAME SORT AREA FLAG
JRST IA62. ;CLR SAVLST
IFN RPW,<
;STASH LITERAL FOR CODE UNTIL MNEMONIC SEEN
INTER. IA78.
IA78.: HLRZ TC,W1 ;PUT SIZE IN THE SPECIAL PLACE
ANDI TC,177
MOVEM TC,(SAVPTR)
IDIVI TC,5 ;CONVERT TO WORDS
JUMPE TB,.+2
ADDI TC,1
MOVEM TC,1(SAVPTR)
MOVE TA,[LITVAL,,TBLOCK] ;STORE LITERAL
MOVEI TB,TBLOCK-1(TC)
BLT TA,(TB)
POPJ PP,
;GET LITERAL FOR REPORT CODE
INTER. IA79.
IA79.: HRLZI TA,010000 ;"CODE" FLAG
PUSHJ PP,IA44.D ;MAKE A CODE MNETAB ENTRY
HRRZ TA,1(SAVPTR) ;# WORDS IN LITERAL
HRLI TA,CD.MNE ;GET THAT MUCH SPACE IN MNETAB
PUSHJ PP,GETENT
HRLI TA,TBLOCK ;MOVE LITERAL TO MNETAB
HRRZI TB,-1(TA)
ADD TB,1(SAVPTR)
BLT TA,(TB)
POPJ PP,
>
;DEFERRED OUTPUT ISAM
INTER. IA80.
IA80.:
IFN ISAM,<
HRRZ TA,CURFIL ;AIM AT FILTAB ENTRY
MOVEI TB,1 ;SET DEFERRED BIT
DPB TB,FI.DFR##
>
SKPNAM
INTER. IA80X.
IA80X.:
IFN ANS74,<
SKIPE FLGSW## ;NEED TO FLAG EXTENSIONS?
EWARNJ E.722
>
POPJ PP, ;NO
;RMS I/O
INTER. IA81.
IA81.:
IFN TOPS20,<
HRRZ TA,CURFIL ;AIM AT FILTAB ENTRY
MOVEI TB,1 ;SET RMS BIT
DPB TB,FI.RMS##
>
JRST IA80X.
;CHECKPOINT OUTPUT ISAM
INTER. IA82.
IA82.:
IFN ISAM,<
HRRZ TA,CURFIL ;AIM AT FILTAB ENTRY
MOVEI TB,1 ;SET CHECKPOINT BIT
DPB TB,FI.CKP##
>
JRST IA80X.
;SAW "FILE-STATUS"
INTER. IA100.
IA100.: HRRZ TA, CURFIL ;GET FILTAB ABS ADR.
LDB TB, FI.PFS## ;GET FIRST STATUS WORD LINK.
JUMPN TB, IA100A ;IF WE ALREADY HAVE ONE - DUP CLAUSE.
MOVE TB, FI.SPT## ;GET BYTE POINTER TO ENTRIES.
MOVEM TB, SAVLST## ;SAVE IT.
HRREI TB, -11 ;-MAXIMUM NUMBER OF NAMES ALLOWED.
MOVEM TB, SAVLST+1 ;SAVE IT.
POPJ PP, ;GO LOOK FOR NAMES.
;DUPLICATE CLAUSE - SKIP TO NEXT NON USER-NAME
IA100A: MOVEI TB, 1
MOVEM TB, SAVLST+1 ;FORCE SKIPPING.
JRST JBE16. ;GO GIVE ERROR MSG.
;SAW THE NAME OF A FILE STATUS ITEM.
INTER. IA101.
IA101.: AOSGE TA, SAVLST+1 ;DO WE HAVE AN ERROR CONDITION.
JRST IA101A ;NO.
JUMPN TA, CPOPJ## ;FIRST TIME?
EWARNJ E.227 ;YES, TOO MANY NAMES.
JRST IA101. ;BUMP COUNT AGAIN AND LEAVE.
IA101A: PUSHJ PP, IA59S. ;GET THE NAMTAB ADDRESS.
PUSHJ PP, IA28S. ;SET UP THE HLDTAB ENTRY.
MOVE TA, CURHLD ;GET THE HLDTAB ADDRESS.
MOVEI TB, %HL.ER ;I AM A FILE-STATUS.
DPB TB, HL.COD ;PUT IT IN HLDTAB.
MOVS TB, CURFIL ;GET THE FILTAB ADDRESS.
DPB TB, HL.LNK ;FILTAB LINK TO HLDTAB.
EXCH TA, TB
MOVSS TA, TA
MOVSS TB, TB
IDPB TB, SAVLST ;HLDTAB LINK TO APPROPRIATE
; FILTAB LOCATION.
IFN ANS74,<
SKIPN FLGSW## ;NEED TO FLAG EXTENSIONS?
POPJ PP, ;GO LOOK FOR MORE NAMES OR FOR
; SOME QUALIFICATION.
HRRZ TB,SAVLST+1 ;SEE IF SECOND TIME THROUGH
CAIN TB,-7 ;SO WE GIVE ERROR ONLY ONCE
EWARNJ E.722
>
POPJ PP, ;NO
;SAW SOME QUALIFICATION.
INTER. IA102.
IA102.: SKIPLE SAVLST+1 ;DO WE HAVE AN ERROR CONDITION?
POPJ PP, ;YES, IGNORE QUALS.
JRST IA59. ;GO SAVE THE QUALS.
;DISPLAY IS DISPLAY-6/9/9
INTER. IA106.
IA106.: MOVEI TC,%US.D6 ;DISPLAY-6
SKIPL DEFDSP## ;DON'T CHANGE IF SET BY SWITCH
HRRM TC,DEFDSP ;SET RHS
POPJ PP,
INTER. IA107.
IA107.: MOVEI TC,%US.D7 ;DISPLAY-7
SKIPL DEFDSP ;DON'T CHANGE IF SET BY SWITCH
HRRM TC,DEFDSP
POPJ PP,
INTER. IA109.
IA109.: MOVEI TC,%US.EB ;DISPLAY-9
HRROM TC,DEFDSP ;SET LHS -1 TO MAKE TESTS EASIER LATER
POPJ PP,
IFN ANS74,<
INTER. IA200.
IA200.: HRLZM LN,COLNCP## ;STORE LINE NUMBER
HRRM CP,COLNCP ;AND CHAR POSITION INCASE OF ERROR
TLNN W1,GWLIT!GWRESV ;CANNOT ALLOW EITHER LIT OR RESERVED WORD
JUMPL W1,IA200A ;AND BETTER NOT BE IN NAMTAB YET
MOVEI DW,E.709
PUSHJ PP,FATAL##
SETZ W1, ;STORE NO COLLATING SEQUENCE
JRST IA201.
IA200A: PUSHJ PP,BLDNAM## ;CREATE NAMTAB ENTRY
HLRZ W1,TA ;SAVE NAMTAB ENTRY
SKPNAM
INTER. IA201.
IA201.: SKIPE COLSEQ## ;ALREADY DEFINED?
EWARNJ E.30 ;YES, DUPLICATED
MOVEM W1,COLSEQ ;STORE RESERVED WORD
JRST IA0.G ;GET NEXT WORD
INTER. IA201N
IA201N: SKIPGE DEFDSP ;IS DEFAULT EBCDIC?
JRST IA201E ;YES
SKPNAM
INTER. IA201S
IA201S: MOVEI W1,%AN.AS
JRST IA201.
INTER. IA201E
IA201E: MOVEI W1,%AN.EB
JRST IA201.
;PUT ALPHABET-NAME IN MNETAB
INTER. IA202.
IA202.: HRLZ TA,LN ;SAVE LINE NUMBER
HRR TA,CP ;AND CHARACTER POSITION
PUSH PP,TA ;FOR LATER
MOVSI TA,(1B6) ;ALPHABET-NAME
PUSHJ PP,IA44.D ;PUT IN MNETAB
MOVE TA,[CD.MNE,,1] ;NEED ONE MORE WORD
PUSHJ PP,GETENT
POP PP,(TA) ;SAVE LN,,CP
POPJ PP,
;SET ALPHABET-NAME TO BE NATIVE (EITHER ASCII OR EBCDIC)
INTER. IA203N
IA203N: SKIPGE DEFDSP ;IS DEFAULT EBCDIC?
JRST IA203E ;YES
SKPNAM
;SET ALPHABET-NAME TO BE STANDARD-1 OR ASCII
INTER. IA203S
IA203S: MOVE TA,CURMNE ;GET REL ADDRESS
ANDI TA,77777 ;OFFSET
ADD TA,MNELOC## ;ABS.
HRRZ TB,1(TA) ;GET TYPE
JUMPN TB,JBE16. ;DUPLICATE
MOVEI TB,%AN.AS ;SET TYPE BIT
IORM TB,1(TA)
POPJ PP,
;SET ALPHABET-NAME TO BE EBCDIC
INTER. IA203E
IA203E: MOVE TA,CURMNE ;GET REL ADDRESS
ANDI TA,77777 ;OFFSET
ADD TA,MNELOC ;ABS.
HRRZ TB,1(TA) ;GET TYPE
JUMPN TB,JBE16. ;DUPLICATE
MOVEI TB,%AN.EB ;SET TYPE BIT
IORM TB,1(TA)
POPJ PP,
;SET ALPHABET-NAME TO BE LITERAL AND STORE FIGCON
INTER. IA203F
IA203F: MOVE TA,CURMNE ;GET REL ADDRESS
ANDI TA,77777 ;OFFSET
ADD TA,MNELOC ;ABS.
HRRZ TB,1(TA) ;GET TYPE
JUMPN TB,JBE16. ;DUPLICATE
JRST IA204F ;COPY FIRST FIGCON
;SET ALPHABET-NAME TO BE LITERAL AND STORE FIRST INTEGER
INTER. IA203I
IA203I: MOVE TA,CURMNE ;GET REL ADDRESS
ANDI TA,77777 ;OFFSET
ADD TA,MNELOC ;ABS.
HRRZ TB,1(TA) ;GET TYPE
JUMPN TB,JBE16. ;DUPLICATE
JRST IA204I ;COPY FIRST LITERAL
;SET ALPHABET-NAME TO BE LITERAL AND STORE FIRST LITERAL
INTER. IA203L
IA203L: MOVE TA,CURMNE ;GET REL ADDRESS
ANDI TA,77777 ;OFFSET
ADD TA,MNELOC ;ABS.
HRRZ TB,1(TA) ;GET TYPE
JUMPN TB,JBE16. ;DUPLICATE
SKPNAM ;COPY FIRST LITERAL
;STORE LITERAL IN MNETAB
INTER. IA204.
IA204.: LDB TA,GWVAL ;GET LITERAL SIZE
HRLI TA,CD.MNE
PUSHJ PP,GETENT
LDB TB,GWVAL
MOVE TC,[POINT 7,LITVAL]
IA204L: ILDB TD,TC
SKIPGE DEFDSP ;IS DEFAULT IS DISPLAY-9
PUSHJ PP,IA205C ;YES, CONVERT TO EBCDIC
MOVEM TD,(TA)
ADDI TA,1
SOJG TB,IA204L ;COPY LITERAL INTO MNETAB
POPJ PP,
;STORE FIGCON IN MNETAB
INTER. IA204F
IA204F: MOVE TA,[CD.MNE,,1]
PUSHJ PP,GETENT
PUSHJ PP,GETFCN
MOVEM TD,(TA)
POPJ PP,
;STORE INTEGER IN MNETAB
INTER. IA204I
IA204I: PUSHJ PP,IA16S. ;GET VALUE
JFCL ;ERROR RETURN
CAILE TC,^D256 ;IS IT IN RANGE?
JRST IA205E ;NO
SOSN TC ;REDUCE TO INDEX
TRO TC,1B20 ;SO ZERO WILL WORK
PUSH PP,TC ;SAVE VALUE
MOVE TA,[CD.MNE,,1]
PUSHJ PP,GETENT
POP PP,(TA)
POPJ PP,
;STORE THRU LITERAL IN MNETAB
INTER. IA205.
IA205.: LDB TA,GWVAL ;GET LITERAL SIZE
CAIE TA,1
JRST IA206E
HRLI TA,CD.MNE
PUSHJ PP,GETENT
LDB TD,[POINT 7,LITVAL,6]
SKIPGE DEFDSP ;IS DEFAULT DISPLAY-9
PUSHJ PP,IA205C ;YES, CONVERT TO EBCDIC
TRO TD,1B18 ;SET THRU FLAG
MOVEM TD,(TA)
POPJ PP,
;STORE THRU INTEGER IN MNETAB
INTER. IA205I
IA205I: PUSHJ PP,IA16S. ;GET VALUE
JFCL ;ERROR RETURN
CAILE TC,^D256 ;IS IT IN RANGE?
JRST IA205E ;NO
SUBI TC,1
TRO TC,1B18 ;SET THRU FLAG
PUSH PP,TC ;SAVE VALUE
MOVE TA,[CD.MNE,,1]
PUSHJ PP,GETENT
POP PP,(TA)
POPJ PP,
;STORE ALSO LITERAL IN MNETAB
INTER. IA206.
IA206.: LDB TA,GWVAL ;GET LITERAL SIZE
CAIE TA,1
JRST IA206E
HRLI TA,CD.MNE
PUSHJ PP,GETENT
LDB TD,[POINT 7,LITVAL,6]
SKIPGE DEFDSP ;IS DEFAULT DISPLAY-9
PUSHJ PP,IA205C ;YES, CONVERT TO EBCDIC
TRO TD,1B19 ;SET ALSO FLAG
MOVEM TD,(TA)
POPJ PP,
;STORE ALSO FIGCON IN MNETAB
INTER. IA206F
IA206F: MOVE TA,[CD.MNE,,1]
PUSHJ PP,GETENT
PUSHJ PP,GETFCN
TRO TD,1B19 ;SET ALSO FLAG
MOVEM TD,(TA)
POPJ PP,
;STORE ALSO INTEGER IN MNETAB
INTER. IA206I
IA206I: PUSHJ PP,IA16S. ;GET VALUE
JFCL ;ERROR RETURN
CAILE TC,^D256 ;IS IT IN RANGE?
JRST IA205E ;NO
SUBI TC,1
TRO TC,1B19 ;SET ALSO FLAG
PUSH PP,TC ;SAVE VALUE
MOVE TA,[CD.MNE,,1]
PUSHJ PP,GETENT
POP PP,(TA)
POPJ PP,
GETFCN: LDB TB,GWVAL ;GET WHICH
SETO TD, ;MAKE IT
CAIN TB,HIVAL. ;HIGH-VALUE?
MOVEI TD,177
CAIN TB,LOVAL. ;LOW-VALUE?
SETZ TD,
CAIN TB,QUOTE. ;QUOTE?
MOVEI TD,42
CAIN TB,SPACE. ;SPACE?
MOVEI TD," "
CAIN TB,ZERO. ;ZERO?
MOVEI TD,"0"
JUMPGE TD,CPOPJ ;VALID CHAR, RETURN
POP PP,(PP)
JRST JBE16. ;MUST BE ILLEGAL
IA205E: MOVEI DW,E.720
PJRST FATAL
IA206E: MOVEI DW,E.712
PJRST FATAL
IA205C: ;ROUTINE TO CONVERT AN ASCII CHAR TO EBCDIC.
ROT TD,-2 ;FORM THE INDEX INTO THE TABLE.
JUMPL TD,IA205D ;LEFT OR RIGHT HALF?
HLR TD,ASEBC.(TD) ;LEFT.
CAIA
IA205D: HRR TD,ASEBC.(TD) ;RIGHT.
TLNN TD,(1B1) ;IS THE CHAR RIGHT JUSTIFIED?
LSH TD,-^D9 ;IT IS NOW.
ANDI TD,377 ;CLEAR JUNK
POPJ PP,
IA210.: HRRZ TA,MNELOC
ADDI TA,1 ;BYPASS ZERO
IA210L: MOVE TB,1(TA) ;GET 2'ND WORD
TLNE TB,(1B5) ;RD CODE?
JRST IA210D ;YES
TLNE TB,(1B6) ;ALPHABET-NAME?
TRNE TB,-1 ;YES, BUT IS IT A LITERAL?
AOJA TA,IA210E ;NO, BUT ACCOUNT FOR <LN,,CP> WORD
HRRZ TB,TA ;SETUP AOBJP COUNTER
SKIPLE TC,3(TB) ;START OF NEXT ENTRY OR TABLE
JRST [TRZE TC,1B20 ;NO, CLEAR ZERO MARKER
MOVEM TC,3(TB) ;PUT LIT VALUE BACK
AOBJP TB,.-1] ;NOT YET
HLRZ TB,TB ;GET COUNT OF ITEMS
HRRM TB,1(TA) ;STORE COUNT
HLRZ TC,(TA) ;GET FIRST WORD
ANDI TC,77777 ;GET INDEX TO MNETAB
CAMN TC,COLSEQ ;IS IT SAME AS PROGRAM COL. SEQ.?
HRLM TA,COLSEQ ;YES, STORE MNETAB LOCATION
ADDI TA,1 ;ACCOUNT FOR <LN,,CP> WORD
IA210D: ADDI TA,(TB) ;ADD IN SIZE OF RD CODE
IA210E: ADDI TA,SZ.MNE ;ADD IN NORMAL SIZE
HRRZ TB,MNENXT##
CAIGE TA,(TB) ;FINISHED?
JRST IA210L ;NO
HLRZ TA,COLSEQ ;DO WE HAVE A PROGRAM COLLATING SEQUENCE
JUMPE TA,CPOPJ ;NO
;YES
;;USE CODE TAKEN FROM COBOLE TO SETUP THE PROGRAM COLLATING SEQUENCE
;THIS IS NEEDED HERE SO THAT LOW-VALUES AND HIGH-VALUES CAN BE SETUP CORRECTLY
HRRZS COLSEQ ;RESTORE COLSEQ
MOVE TB,1(TA) ;GET 2'ND WORD
TLNE TB,(1B5) ;RD CODE?
POPJ PP, ;YES, SHOULD NEVER HAPPEN
TLNN TB,(1B6) ;ALPHABET-NAME?
POPJ PP, ;NO
ANDI TB,777 ;YES, BUT IS IT A LITERAL?
JUMPE TB,CPOPJ ;NO
MOVE TC,[PRGCOL##,,PRGCOL+1]
SETOM PRGCOL
BLT TC,PRGZRL## ;INITIALIZE ALL OF TABLE
MOVN TB,TB
HRL TA,TB ;SETUP AOBJN POINTER
SETO TC, ;STORE POINTER (INCREMENTED BEFORE STORE)
SETZB TD,ILCSIX## ;ALSO COUNT AND SIXBIT OFFSET
SETZM EXCEBC## ;CLEAR EBCDIC ONLY COUNT
CSMNEN: MOVE TB,3(TA) ;GET LITERAL
TRZE TB,1B18 ;THRU?
JRST CSMNET ;YES
TRZE TB,1B19 ;ALSO?
JRST CSMNEA ;YES
ADDI TC,1(TD) ;IN CASE ALSO
SETZ TD,
PUSHJ PP,CSMTST ;STORE IF FIRST TIME
JRST CSMNEJ ;GET NEXT
CSMNEA: PUSHJ PP,CSMTST ;STORE IF FIRST TIME
AOJA TD,CSMNEJ ;GET NEXT
CSMNET: ADDI TC,0(TD) ;INCASE ANY ALSO
MOVE TD,TB ;SAVE THRU LIT
MOVE TB,2(TA) ;GET PREVIOUS LITERAL
SUBM TB,TD ;GET -NO. TO DO
JUMPG TD,CSMNER ;ORDER IS REVERSED
ADDI TB,1 ;GET NEXT
HRL TB,TD ;AOBJN POINTER
SETZ TD,
CSMNEU: ADDI TC,1 ;POINT TO CURRENT
PUSHJ PP,CSMTST ;STORE IF FIRST TIME
AOBJN TB,CSMNEU ;LOOP
JRST CSMNEJ
CSMNER: SUBI TB,(TD) ;GET OTHER END
MOVN TD,TD ;GET - LENGTH
HRL TB,TD ;AOBJN LOOP PTR
MOVN TD,TD ;+ SIZE
ADDI TC,1(TD) ;GET LAST FIRST
SUBI TD,1 ;WHAT TO ADD ON WHEN FINISHED
CSMNEV: SUBI TC,1 ;POINT TO CURRENT
PUSHJ PP,CSMTST ;STORE IF FIRST TIME
AOBJN TB,CSMNEV ;LOOP
CSMNEJ: AOBJN TA,CSMNEN ;NOT YET
;NOW LOOP THROUGH TABLE FILLING IN MISSING VALUES
ADDI TC,1(TD) ;IN CASE ANY ALSO'S LEFT
MOVSI TA,-40 ;SCAN FIRST PART OF TABLE
PUSH PP,TC ;SAVE NUMBER KNOWN
CSMNEH: SKIPL PRGCOL(TA)
JRST CSMNEI
HRLM TC,PRGCOL(TA) ;STORE ASCII ONLY
AOS ILCSIX ;ACCOUNT FOR NO SIXBIT HERE
ADDI TC,1
CSMNEI: AOBJN TA,CSMNEH
HRLI TA,-100 ;SCAN REST OF SIXBIT TABLE
CSMNEF: SKIPL PRGCOL(TA) ;ALREADY SET
JRST CSMNEG ;YES
HRLM TC,PRGCOL(TA) ;STORE NEW VALUE
SUB TC,ILCSIX ;REMOVE EFFECT OF NO SIXBIT
HRLM TC,PRGCOL+200(TA)
ADD TC,ILCSIX
ADDI TC,1
CSMNEG: AOBJN TA,CSMNEF ;TRY NEXT
HRLI TA,-40 ;SCAN LAST PART OF TABLE
CSMNEK: SKIPL PRGCOL(TA)
JRST CSMNEM
HRLM TC,PRGCOL(TA) ;NO SIXBIT
ADDI TC,1
CSMNEM: AOBJN TA,CSMNEK
POP PP,TC ;RESTORE COUNT
MOVSI TA,-400 ;SCAN EBCDIC TABLE
CSMNEO: HRRE TB,PRGCOL(TA) ;GET EBCDIC PART
JUMPGE TB,CSMNEP ;ALREADY SET UP
HRRM TC,PRGCOL(TA)
ADDI TC,1
CSMNEP: AOBJN TA,CSMNEO
;NOW LOOP THROUGH LOOKING FOR LOW-VALUES AND HIGH-VALUES
SETOB TB,COHVLV## ;INITIALIZE TABLE
MOVE TC,[COHVLV,,COHVLV+1]
BLT TC,COHVLV+5 ;TO LOWEST VALUE
MOVSI TA,-200 ;ASCII
HVLVA: HLRZ TC,PRGCOL(TA)
JUMPN TC,HVLVA1 ;NOT LOW-VALUES
SKIPGE COHVLV+4 ;FIRST TIME?
HRRZM TA,COHVLV+4 ;YES, STORE CHARACTER
HVLVA1: CAMGE TC,TB ;HIGH-VALUE
JRST HVLVA2 ;NO
HRRZM TA,COHVLV+1 ;YES, STORE LATEST CANDIDATE
MOVE TB,TC ;UPDATE CURRENT HIGHEST
HVLVA2: AOBJN TA,HVLVA
MOVSI TA,-100 ;SIXBIT
SETO TB,
HVLVS: HLRZ TC,PRGCOL+240(TA)
JUMPN TC,HVLVS1 ;NOT LOW-VALUES
SKIPGE COHVLV+3 ;FIRST TIME?
HRRZM TA,COHVLV+3 ;YES, STORE CHARACTER
HVLVS1: CAMGE TC,TB ;HIGH-VALUE
JRST HVLVS2 ;NO
HRRZM TA,COHVLV ;YES, STORE LATEST CANDIDATE
MOVE TB,TC ;UPDATE CURRENT HIGHEST
HVLVS2: AOBJN TA,HVLVS
MOVSI TA,-400 ;EBCDIC
SETO TB,
HVLVE: HRRZ TC,PRGCOL(TA)
JUMPN TC,HVLVE1 ;NOT LOW-VALUES
SKIPGE COHVLV+5 ;FIRST TIME?
HRRZM TA,COHVLV+5 ;YES, STORE CHARACTER
HVLVE1: CAMGE TC,TB ;HIGH-VALUE
JRST HVLVE2 ;NO
HRRZM TA,COHVLV+2 ;YES, STORE LATEST CANDIDATE
MOVE TB,TC ;UPDATE CURRENT HIGHEST
HVLVE2: AOBJN TA,HVLVE
POPJ PP,
CSMTST: SKIPGE DEFDSP ;IS DEFAULT DISPLAY-9
JRST CSMSTX ;YES
SKIPL PRGCOL(TB) ;ALREADY SETUP?
POPJ PP, ;YES, ERROR WILL BE CAUGHT BY COBOLE
PUSH PP,TB ;SAVE TB
CSMSTR: CAIL TB,200 ;IN ASCII RANGE?
SOJA TC,CSMSNA ;NO
HRLM TC,PRGCOL(TB) ;STORE NEW ASCII VALUE
HRRZ TB,TB ;INCASE AOBJN PTR
CAIL TB,40 ;IS IT IN SIXBIT RANGE?
CAIL TB,140 ;...
JRST CSMSNS ;NO
SUB TC,ILCSIX ;REMOVE NON-SIXBIT COUNT
HRLM TC,PRGCOL+200(TB) ;STORE SIXBIT
ADD TC,ILCSIX ;RESTORE COUNT
CSMSTE: SKIPGE DEFDSP ;IS DEFAULT DISPLAY-9
JRST CSMSTZ ;YES, WE'RE ALL DONE
;ROUTINE TO CONVERT AN ASCII CHAR TO EBCDIC.
CAIL TB,200 ;IS IT OUTSIDE ASCII RANGE?
JRST CSMSTG ;YES, USE AS IS
ROT TB,-2 ;FORM THE INDEX INTO THE TABLE.
JUMPL TB,CSMSTF ;LEFT OR RIGHT HALF?
HLR TB,ASEBC.##(TB) ;LEFT.
CAIA
CSMSTF: HRR TB,ASEBC.##(TB) ;RIGHT.
TLNN TB,(1B1) ;IS THE CHAR RIGHT JUSTIFIED?
LSH TB,-^D9 ;IT IS NOW.
ANDI TB,377 ;CLEAR JUNK
CSMSTG: ADD TC,EXCEBC ;ADD IN EXCESS COUNT
HRRM TC,PRGCOL(TB) ;STORE EBCDIC
SUB TC,EXCEBC
CSMSTZ: POP PP,TB ;RESTORE
POPJ PP,
CSMSNA: AOSA EXCEBC ;ONE MORE THAT IS ONLY EBCDIC
CSMSNS: AOS ILCSIX ;ONE MORE THAT ISN'T SIXBIT
JRST CSMSTE ;TRY EBCDIC
CSMSTX: HRL TC,PRGCOL(TB) ;GET CURRENT CHAR.
JUMPGE TC,CPOPJ ;ALREADY EXISTS
HRRZ TC,TC ;CLEAR LHS.
ADD TC,EXCEBC ;ADD EXCESS
HRRM TC,PRGCOL(TB) ;SAVE EBCDIC CHAR
SUB TC,EXCEBC
PUSH PP,TB ;SAVE CHAR
HRRZ TB,TB ;INCASE AOBJN PTR
;ROUTINE TO CONVERT AN EBCDIC CHAR TO ASCII.
ROT TB,-2 ;FORM THE INDEX INTO THE TABLE.
JUMPL TB,CSMSTY ;LEFT OR RIGHT HALF?
HLR TB,EBASC.##(TB) ;LEFT.
CAIA
CSMSTY: HRR TB,EBASC.##(TB) ;RIGHT.
TLNN TB,(1B1) ;IS THE CHAR RIGHT JUSTIFIED?
LSH TB,-^D9 ;IT IS NOW.
ANDI TB,177 ;CLEAR JUNK
CAIE TB,134 ;\ IS SPECIAL
JRST CSMSTR ;NOW STORE ASCII
HRRZ TB,0(PP) ;AS IT MIGHT BE ILLEGAL CHAR
CAIE TB,340 ;UNLESS EBCDIC \
SOJA TC,CSMSNA ;ILLEGAL SO DON'T STORE
MOVEI TB,134 ;RESTORE \
JRST CSMSTR ;AND STORE IT
>
END COBOLB