Trailing-Edge
-
PDP-10 Archives
-
bb-bt99e-bb
-
alglib.c05
There are 15 other files named alglib.c05 in the archive. Click here to see a list.
REP 3/1 ;05C1
;COPYRIGHT (C) 1975,1981,1982 BY
WIT
;COPYRIGHT (C) 1975,1982,1983 BY
DEL 47/2 ;05C2
.PTSFD==3 ; [275] PATH. BLOCK INDEX FOR SFD'S
.PTPPN==2 ; [275] INDEX FOR PPN
DEL 83/2 ;05C3
HRLZI A1,%JBEDT
LSH A1,^D9
MOVEI A2,3
HRLZI A5,(SIXBIT/ALG/)
MOVE A3,[POINT 6,A5,17]
MOVE A4,[POINT 7,SEGMES+6,6]
GET2: SETZ A0,
LSHC A0,3
ADDI A0,20 ; TO SIXBIT
IDPB A0,A3
ADDI A0,40 ; TO ASCII
IDPB A0,A4 ; TO ERROR-MESSAGE
SOJG A2,GET2
MOVEM A5,HSEG+1
MOVEM A5,HSEG1+1
REP 102/2 ;05C4
JRST NOSYS ; NOT FOUND
WIT
JRST NOSEG ; [322] NOT FOUND
DEL 107/2 ;05C5
NOSYS: MOVEI A0,HSEG1
GETSEG A0, ; TRY ON DSK INSTEAD
JRST NOSEG ; NOT THERE EITHER
JRST GET1 ; FOUND ON DSK
REP 14/3 ;05C6
HSEG: SIXBIT /SYS/
0 0
WIT
HSEG: SIXBIT /SYS/ ; [340]
SIXBIT /ALGOTS/ ; [340]
SIXBIT /EXE/ ; [340]
DEL 20/3 ;05C7
HSEG1: SIXBIT /DSK/
0 0
0
0
0
REP 36/3 ;05C8
?ALGOL object time system ALGNNN.EXE not found, GETSEG error code / ; [265]
WIT
?ALGOL object time system ALGOTS.EXE not loaded, GETSEG error code /
; [340] [322] [265]
DEL 166/115 ;05C9
;[245] XCTA .A(DL) ; GET ADDRESS OF A
REP 25/116 ;05C10
LDB A0,[
POINT 24,STR2(A2),35] ; AND ITS LENGTH
WIT
LDB A0,[POINT 24,STR2(A2),35] ; AND ITS LENGTH
INS 1/117 ;05C11
REP 5/117 ;05C12
LDB A0,[
POINT 6,STR1(A2),11] ; GET BYTE SIZE
WIT
LDB A0,[POINT 6,STR1(A2),11] ; GET BYTE SIZE
INS 14/129 ;05C13
MOVE AX,PRGLNK(DL) ; [335] GET RETURN ADDR.
MOVE AX,-1(AX) ; [335] GET FORMAL BITS
MOVEM AX,A01TMP(DB) ; [335] PUT THEM HERE UNTIL WE NEED THEM
REP 24/129 ;05C14
SETZ A0, ; [256] GET READY TO DELETE STRING SPACE
TLC A2,STRDYN!STRPRC; [256] COMPLEMENT STRING STATUS BITS
TLCE A2,STRDYN!STRPRC; [256] WAS THIS A TRANSIENT STRING?
JRST .EXIT(DL) ; [256] NO, EXIT
PUSHJ SP,GETOWN ; [256] YES, DELETE IT
WIT
HLRZ A0,A01TMP(DB) ; [335] GET FORMAL BITS INTO RIGHT HALF
TRZ A0,77 ; [335] TURN OFF WHAT WE DON'T CARE ABOUT
CAIE A0,$PRO!$S ; [335] STATIC SIMPLE STRING PROC (USER PROC.)?
CAIN A0,$D!$EXP!$S ; [335] DYNAMIC SIMPLE STR EXPR (STR EXPRSION)?
JRST LAB321 ; [335] YES, GO DELETE IT
CAIE A0,$PRO!$S!$EXT ; [335] STATIC EXTERN STR PROC. (ALGLIB PROC.)?
JRST .EXIT(DL) ; [335] NO, EXIT BUT DON'T DELETE IT
LAB321: SETZ A0, ; [335] YES, GET READY TO DELETE THE STRING
PUSHJ SP,GETOWN ; [335] DO IT
INS 14/130 ;05C15
MOVE AX,PRGLNK(DL) ; [335] GET RETURN ADDR.
MOVE AX,-1(AX) ; [335] GET FORMAL BITS
MOVEM AX,A01TMP(DB) ; [335] PUT THEM HERE UNTIL WE NEED THEM
REP 22/130 ;05C16
SETZ A0, ; [256] GET READY TO DELETE STRING SPACE
TLC A2,STRDYN!STRPRC; [256] COMPLEMENT STRING STATUS BITS
TLCE A2,STRDYN!STRPRC; [256] WAS THIS A TRANSIENT STRING?
JRST .EXIT(DL) ; [256] NO, EXIT
PUSHJ SP,GETOWN ; [256] YES, DELETE IT
WIT
HLRZ A0,A01TMP(DB) ; [335] GET FORMAL BITS INTO RIGHT HALF
TRZ A0,77 ; [335] TURN OFF WHAT WE DON'T CARE ABOUT
CAIE A0,$PRO!$S ; [335] STATIC SIMPLE STRING PROC (USER PROC.)?
CAIN A0,$D!$EXP!$S ; [335] DYNAMIC SIMPLE STR EXPR (STR EXPRSION)?
JRST LAB326 ; [335] YES, GO DELETE IT
CAIE A0,$PRO!$S!$EXT ; [335] STATIC EXTERN STR PROC. (ALGLIB PROC.)?
JRST .EXIT(DL) ; [335] NO, EXIT BUT DON'T DELETE IT
LAB326: SETZ A0, ; [335] YES, GET READY TO DELETE THE STRING
PUSHJ SP,GETOWN ; [335] DO IT
DEL 15/131 ;05C17
EDIT (133) ; AVOID STACK-SHIFT PROBLEMS
REP 1/132 ;05C18
TITLE CONCAT - STRING CONCATENATION ROUTINE
WIT
TITLE CONCAT - STRING CONCATENATION ROUTINE
DEL 35/132 ;05C19
REP 15/133 ;05C20
LDB A0,[
POINT 6,STR1(A2),11] ; GET BYTE-SIZE INTO A0
LDB A1,[
POINT 24,STR2(A2),35] ; AND LENGTH INTO A1
WIT
LDB A0,[POINT 6,STR1(A2),11] ; GET BYTE-SIZE INTO A0
LDB A1,[POINT 24,STR2(A2),35] ; AND LENGTH INTO A1
REP 6/134 ;05C21
LDB A5,[
POINT 24,STR2(A2),35] ; GET LENGTH OF STRING
WIT
LDB A5,[POINT 24,STR2(A2),35] ; GET LENGTH OF STRING
REP 35/145 ;05C22
IOERR 6,(A13) ; [251][E1017] HIT EOF, ERROR WITH CH. # IN A13
WIT
JRST READ90 ; [312] EOF, DONE
INS 14/148 ;05C23
MOVE AX,PRGLNK(DL) ; [335] GET RETURN ADDR.
MOVE AX,-1(AX) ; [335] GET FORMAL BITS
MOVEM AX,A01TMP(DB) ; [335] PUT THEM HERE UNTIL WE NEED THEM
REP 19/148 ;05C24
WRIT1: MOVE A3,STR1(A0) ; [237] GET BYTE-POINTER
LDB A1,[POINT 24,STR2(A0),35] ; [237] GET STRING LENGTH
WIT
MOVE A3,A0 ; [325] [237] GET BYTE-POINTER
LDB A1,[POINT 24,A1,35] ; [325] [237] GET STRING LENGTH
REP 30/148 ;05C25
SETZ A0, ; [256] GET READY TO DELETE STRING SPACE
TLC A2,STRDYN!STRPRC; [256] COMPLEMENT STRING STATUS BITS
TLCE A2,STRDYN!STRPRC; [256] WAS THIS A TRANSIENT STRING?
JRST .EXIT(DL) ; [256] NO, EXIT
PUSHJ SP,GETOWN ; [256] YES, DELETE IT
JRST .EXIT(DL) ; [256] AND EXIT
WRIT4: JSP AX,WRIT2 ; GET NEXT BYTE
WRIT5: CAIN A13,"[" ; LEFT SQUARE BRACKET?
XCT [
AOJA A4,WRIT4
AOJA A4,WRIT4
SOJA A4,WRIT6]+1(A4)
CAIN A13,"]" ; NO - RIGHT SQUARE BRACKET?
XCT [
AOJA A4,WRIT6
SOJA A4,WRIT4
SOJA A4,WRIT6]+1(A4)
XCT [
AOJA A4,WRIT6
JRST WRIT6
JRST WRIT8]+1(A4) ; NO
WIT
HLRZ A0,A01TMP(DB) ; [335] GET FORMAL BITS INTO RIGHT HALF
TRZ A0,77 ; [335] TURN OFF WHAT WE DON'T CARE ABOUT
CAIE A0,$PRO!$S ; [335] STATIC SIMPLE STRING PROC (USER PROC.)?
CAIN A0,$D!$EXP!$S ; [335] DYNAMIC SIMPLE STR EXPR (STR EXPRSION)?
JRST LAB413 ; [335] YES, GO DELETE IT
CAIE A0,$PRO!$S!$EXT ; [335] STATIC EXTERN STR PROC. (ALGLIB PROC.)?
JRST .EXIT(DL) ; [335] NO, EXIT BUT DON'T DELETE IT
LAB413: SETZ A0, ; [335] YES, GET READY TO DELETE THE STRING
PUSHJ SP,GETOWN ; [335] DO IT
JRST .EXIT(DL) ; [256] AND EXIT
WRIT4: JSP AX,WRIT2 ; GET NEXT BYTE
WRIT5: CAIN A13,"[" ; LEFT SQUARE BRACKET?
XCT [AOJA A4,WRIT4
AOJA A4,WRIT4
SOJA A4,WRIT6]+1(A4)
CAIN A13,"]" ; NO - RIGHT SQUARE BRACKET?
XCT [AOJA A4,WRIT6
SOJA A4,WRIT4
SOJA A4,WRIT6]+1(A4)
XCT [AOJA A4,WRIT6
JRST WRIT6
JRST WRIT8]+1(A4) ; NO
REP 22/149 ;05C26
WRIT8: TDZA A5,A5 ; CLEAR COUNT (FIRST TIME)
WIT
WRIT8: TDZA A5,A5 ; CLEAR COUNT (FIRST TIME)
INS 15/160 ;05C27
.SFMAX=6 ; [324] MAX. DEPTH OF SFD'S ALLOWED + 1
REP 29/160 ;05C28
OPF0: JRST OPF0(A1) ; BRANCH ON NUMBER OF PARAMETERS
WIT
OPNFIL: JRST OPNFIL(A1) ; [324] BRANCH ON NUMBER OF PARAMETERS
REP 46/160 ;05C29
MOVE A2,.LU(DL) ; RESTORE ADDRESS OF STRING
MOVEI A2,@A2 ; STATICISE IT
LDB A0,[POINT 24,STR2(A2),35] ; GET IT'S LENGTH
MOVE A4,STR1(A2) ; AND SAVE BYTE POINTER
SETZB A5,A6 ; CLEAR FILE AND EXTENSION
JUMPE A0,OPF5 ; NULL STRING?
MOVE A7,[POINT 6,A5,]; BYTE POINTER FOR FILE NAME
MOVEI A10,1 ; BYTE INDEX
OPF1: PUSHJ SP,OPF6 ; GET NEXT BYTE
CAIN A2,'.' ; POINT?
AOJA A10,OPF3 ; YES
IDPB A2,A7 ; PLANT BYTE IN NAME
CAIGE A10,6 ; NAME FULL?
AOJA A10,OPF1 ; NO - KEEP GOING
AOJ A10, ; [210] COUNT THE SIXTH CHARACTER
OPF2: PUSHJ SP,OPF6 ; SCAN FOR POINT
CAIE A2,'.'
AOJA A10,OPF2
ADDI A10,1
OPF3: MOVE A7,[POINT 6,A6,]; BYTE POINTER FOR FILE EXTENSION
MOVEI A11,3 ; BYTE COUNT
OPF4: PUSHJ SP,OPF6 ; GET NEXT BYTE
IDPB A2,A7 ; AND PLANT IT IN EXTENSION
SOJE A11,OPF5 ; ANY MORE EXTENSION?
AOJA A10,OPF4 ; NO - KEEP GOING
EDIT(); FIX STACK ON RETURN FROM OPF6
OPF5A: POP SP,(SP) ; [E037] STEP BACK OVER RETURN ADDRESS
OPF5: MOVE A1,.N(DL) ; RESTORE CHANNEL NUMBER
LRLOAD A2,A5 ; LOAD FILE NAME AND EXTENSION
HRLZ A4,.P(DL)
LSH A4,11 ; PROTECTION
MOVE A5,.PP(DL) ; PROJECT-PROGRAMMER
PUSHJ SP,OPFILE ; AND OPEN FILE
POP SP,A2 ; GET ADDR OF I (OR 0)
SKIPN A0, ; ERROR ?
EDIT(160); Don't clobber label address when storing error code.
JRST [POP SP,(SP) ; [E160]
JRST .EXIT(DL)] ; [E160]
SUBI A0,100 ; ERR-CODE HAS 100 ADDED TO IT BY OTS
SKIPE .I(DL) ; YES - I ?
XCT .I+1(DL) ; YES - PUT ERROR-CODE IN IT
POP SP,A2 ; [E160] Get label address
EDIT(020) ; FORLAB NEEDS ADDRESS IN A2, NOT A3 !
SKIPE A2 ; [E020][E160] IS THERE AN ERROR EXIT ?
JRST (A2) ; [E020] IF SO, TAKE IT
IOERR 5,(A1) ; ELSE GIVE ERROR MESSAGE
OPF6: CAMLE A10,A0 ; GET SIXBIT BYTE SUBROUTINE
JRST OPF5A ; [E037] NONE LEFT - ERROR RETURN
ILDB A2,A4 ; AND GET NEXT BYTE
SUBI A2,40
JUMPL A2,OPF7 ; TOO LOW
CAILE A2,132
JRST OPF7 ; TOO HIGH
CAIL A2,100 ; LOWER CASE ALPHA?
SUBI A2,40 ; YES - RECODE TO UPPER CASE ALPHA
POPJ SP,0
OPF7: MOVEI A2,0
POPJ SP,0
WIT
MOVEI A0,.SFMAX+4 ; [324] NEED SPACE FOR PATH BLOCK
PUSHJ SP,GETCLR ; [324] GET THE SPACE
PUSH SP,A1 ; [324] SAVE ADDR. OF PATH BLOCK
MOVE A2,.LU(DL) ; [324] GET ADDR. OF STRING
MOVEI A2,@A2 ; [324] STATICISE IT
MOVE A0,.PP(DL) ; [324] GET PPN
MOVEM A0,.PTPPN(A1) ; [324] STORE IN PATH BLOCK
SETZB A5,A6 ; [324] CLEAR FILENAME AND EXTENSION
LDB A10,[POINT 24,STR2(A2),35] ; [324] GET STRING LENGTH
JUMPE A10,OPFNOW ; [324] ALLOW NULL NAME TO DELETE FILE
MOVE A4,STR1(A2) ; [324] COPY BYTE POINTER
MOVE A7,[POINT 6,A5] ; [324] BYTE POINTER FOR FILE NAME
MOVEI A0,6 ; [324] MAX. LENGTH OF FILENAME
PUSHJ SP,GETCHR ; [324] GET FIRST BYTE OF FILESPEC
PUSHJ SP,OPFERR ; [324] ERROR IF STRING EOF IS FOUND
CAIG A2,'Z' ; [324] FIRST CHR. MUST BE ALPHANUMERIC
CAIGE A2,'0' ; [324]
PUSHJ SP,OPFERR ; [324] ISN'T, CHR. CAN'T APPEAR HERE
JRST OPFNM1 ; [324] NO, BEGIN BUILDING FILENAME
; [324] PARSE AND BUILD FILENAME IN A5
OPFNAM: PUSHJ SP,GETCHR ; [324] GET NEXT BYTE
JRST OPFNOW ; [324] GO OPEN FILE IF STRING EOF IS FOUND
CAIN A2,'.' ; [324] POINT?
JRST OPFEXT ; [324] YES, GO PARSE EXTENSION
CAIN A2,'[' ; [324] NO, BEGINNING OF PPN AND SFD SPEC.?
JRST OPFPPN ; [324] YES, GO PARSE IT
OPFNM1: IDPB A2,A7 ; [324] NO, PLANT BYTE IN FILENAME
SOJG A0,OPFNAM ; [324] LOOP UNTIL SIX CHRS. OR A DELIMITER
PUSHJ SP,GETCHR ; [324] SIX CHRS. FOUND, GET NEXT ONE
JRST OPFNOW ; [324] GO OPEN FILE IF STRING EOF IS FOUND
CAIN A2,'[' ; [324] BEGINNING OF PPN AND SFD SPEC.?
JRST OPFPPN ; [324] YES, GO PARSE IT
CAIE A2,'.' ; [324] NO, POINT?
PUSHJ SP,OPFERR ; [324] NO, FILESPEC IS BAD
; [324] PARSE AND BUILD EXTENSION IN A6
OPFEXT: MOVEI A0,3 ; [324] MAX. LENGTH OF EXTENSION
MOVE A7,[POINT 6,A6] ; [324] BYTE POINTER FOR EXTENSION
OPFEX1: PUSHJ SP,GETCHR ; [324] GET NEXT BYTE
JRST OPFNOW ; [324] GO OPEN FILE IF STRING EOF IS FOUND
CAIN A2,'[' ; [324] BEGINNING OF PPN AND SFD SPEC.?
JRST OPFPPN ; [324] YES, GO PARSE IT
IDPB A2,A7 ; [324] NO, PLANT IT IN EXTENSION
SOJG A0,OPFEX1 ; [324] LOOP UNTIL THREE CHRS. OR A DELIMITER
PUSHJ SP,GETCHR ; [324] GET NEXT CHR.
JRST OPFNOW ; [324] GO OPEN FILE IF STRING EOF IS FOUND
CAIE A2,'[' ; [324] BEGINNING OF PPN AND SFD SPEC?
PUSHJ SP,OPFERR ; [324] NO, BAD FILESPEC
; [324] PARSE PPN AND SFD SPEC. PPN IS BUILT FIRST, IN A7
OPFPPN: PUSHJ SP,GETPP ; [324] GET PROJECT NUMBER IN A3 RIGHTHALF
JRST [JUMPE A3,OPFERR ; [324] DON'T ALLOW EOF AFTER BRACKET
MOVEI A2,']' ; [324] OK, FAKE OURSELVES OUT
JRST .+1] ; [324] AND CONTINUE
HRLZ A7,A3 ; [324] SAVE PROJECT NUMBER IN A7 LEFTHALF
CAIN A2,']' ; [324] END OF ENTIRE FILESPEC?
JRST OPFPP1 ; [324] YES, GO BUILD PPN AND OPEN FILE
PUSHJ SP,GETPP ; [324] NO, GET PROGRAMMER NUMBER
MOVEI A2,']' ; [324] EOF, FAKE OURSELVES OUT
HRR A7,A3 ; [324] MAKE COMPLETE PPN
OPFPP1: JUMPE A7,OPFSFD ; [324] IF PPN IS ZERO, DON'T DEFAULT HERE!
GETPPN A0, ; [324] SOME PPN SPEC WAS GIVEN, GET OUR PPN
TRN ; [324] IGNORE NORMAL RETURN
HLRZ A3,A7 ; [324] GET PROJECT NUMBER
SKIPN A3 ; [324] ZERO?
HLL A7,A0 ; [324] YES, DEFAULT TO OUR PROJECT NUMBER
HRR A3,A7 ; [324] NO, GET PROGRAMMER NUMBER
SKIPN A3 ; [324] ZERO?
HRR A7,A0 ; [324] YES, DEFAULT TO OUR PROGRAMMER NUMBER
MOVEM A7,.PP(DL) ; [324] NO, SAVE COMPLETED PPN
MOVE A1,(SP) ; [324] GET PATH BLOCK ADDR. BACK
MOVEM A7,.PTPPN(A1) ; [324] STORE PPN IN PATH BLOCK
; [324] NOW BUILD SFD LIST
OPFSFD: CAIN A2,']' ; [324] DONE WITH SFD'S?
JRST OPFNOW ; [324] YES, GO OPEN FILE
MOVEI A1,.SFMAX ; [324] NO, LOAD MAX. DEPTH OF SFD'S ALLOWED
OPFSF1: PUSHJ SP,GETSFD ; [324] GET FIRST SFD NAME
JUMPE A7,OPFSF2 ; [324] DONE WITH SFD LIST IF NULL
MOVE A3,(SP) ; [324] GET PATH BLOCK ADDR.
SUBI A3,(A1) ; [324] POINT TO PROPER SFD NAME ENTRY
MOVEM A7,.PTSFD+.SFMAX(A3) ; [324] PLANT SFD NAME
CAIN A2,']' ; [324] LAST NAME IN SFD LIST?
JRST OPFNOW ; [324] YES, GO OPEN FILE
SOJG A1,OPFSF1 ; [324] NO, LOOP UNTIL MAX. SFD NAMES ARE READ
PUSHJ SP,GETCHR ; [324] GET NEXT CHR. AFTER MAX. SFD'S READ
JRST OPFNOW ; [324] HAD BETTER BE EOF
PUSHJ SP,OPFERR ; [324] ELSE BAD FILESPEC
OPFSF2: CAIN A2,',' ; [324] NULL SFD NAME FOUND?
PUSHJ SP,OPFERR ; [324] YES, ILLEGAL FILESPEC
; [324] THE PPN AND SFD'S ARE ALL NOW IN PLACE - OPEN THE FILE.
OPFNOW: MOVE A1,.N(DL) ; [324] RESTORE CHANNEL NUMBER
LRLOAD A2,A5 ; [324] LOAD FILENAME AND EXTENSION
HRLZ A4,.P(DL) ; [324] GET PROTECTION CODE
LSH A4,11 ; [324] MOVE IT OVER
MOVE A5,(SP) ; [324] GET PATH BLOCK ADDR.
PUSHJ SP,OPFILE ; [324] AND GO OPEN FILE
POP SP,A1 ; [324] RESTORE PATH BLOCK ADDR.
PUSH SP,A0 ; [324] SAVE ERROR CODE FROM ALGOTS
SETZ A0, ; [324] RETURN SPACE TO HEAP
PUSHJ SP,GETOWN ; [324] DO IT
POP SP,A0 ; [324] RESTORE ERROR CODE
POP SP,A2 ; [324] GET ADDR. OF I (OR 0)
JUMPE A0,[POP SP,(SP) ; [324] RESTORE LABEL ADDR.
JRST .EXIT(DL)] ; [324] AND EXIT
SUBI A0,100 ; [324] ERROR CODE HAS 100 ADDED TO IT BY OTS
SKIPE .I(DL) ; [324] HAVE ANYPLACE TO PUT ERROR CODE?
XCT .I+1(DL) ; [324] YES, PLANY CODE
POP SP,A2 ; [324] GET LABEL ADDRESS
JUMPN A2,(A2) ; [324] TAKE ERROR EXIT IF ONE EXISTS
MOVE A1,.N(DL) ; [324] ELSE GET CHANNEL NUMBER BACK
IOERR 5,(A1) ; [324] AND GIVE ERROR MESSAGE
JRST .EXIT(DL) ; [324] CONTINUE AT USER'S RISK ONLY
; [324] GET UP TO SIX OCTAL NUMBERS IN A3 RIGHTHALF. USED IN BUILDING PPN.
; [324] DELIMITING CHR. IS LEFT IN A2.
GETPP: MOVEI A0,6 ; [324] MAX. LENGTH OF NUMBER
SETZ A3, ; [324] INIT. A3 TO BUILD SIX DIGIT NUMBER
GETPP1: PUSHJ SP,GETCHR ; [324] GET NEXT CHR.
POPJ SP, ; [324] RETURN IF EOF
CAIN A2,',' ; [324] COMMA?
JRST AOSRET ; [324] YES, END OF PROJECT NUMBER
CAIN A2,']' ; [324] NO, CLOSE BRACKET?
JRST AOSRET ; [324] YES, END OF PROJECT NUMBER
CAIG A2,'7' ; [324] NO, WITHIN RANGE OF
CAIGE A2,'0' ; [324] OCTAL NUMBERS?
PUSHJ SP,OPFERR ; [324] NO, BAD SPEC.
SUBI A2,'0' ; [324] YES, CONVERT TO BINARY
LSH A3,3 ; [324] MAKE ROOM FOR NEW DIGIT
ADD A3,A2 ; [324] CONTINUE BUILDING PROJECT NUMBER
SOJG A0,GETPP1 ; [324] LOOP UNTIL 6 CHRS. READ
PUSHJ SP,GETCHR ; [324] GET NEXT CHR.
JRST AOSRET ; [324] YES, END OF PROJECT NUMBER
CAIN A2,',' ; [324] COMMA?
JRST AOSRET ; [324] YES, END OF PROJECT NUMBER
CAIN A2,']' ; [324] NO, END OF WHOLE FILESPEC?
JRST AOSRET ; [324] YES, END OF PROJECT NUMBER
PUSHJ SP,OPFERR ; [324] NO, BAD FILESPEC
; [324] GET UP TO SIX SFD-TYPE CHRS. IN A7. DELIMITING CHR. IS LEFT IN A2.
GETSFD: MOVEI A0,6 ; [324] MAX. NUMBER OF CHRS. IN SFD NAME
MOVE A3,[POINT 6,A7] ; [324] LOAD SIXBIT ILDB PTR. TO BUILD SFD NAME
SETZ A7, ; [324] CLEAR SFD NAME
GETSF1: PUSHJ SP,GETCHR ; [324] GET CHR.
POPJ SP, ; [324] RETURN IF EOF
CAIN A2,',' ; [324] COMMA?
POPJ SP, ; [324] YES, END OF THIS SFD NAME
CAIN A2,']' ; [324] NO, CLOSE BRACKET?
POPJ SP, ; [324] YES, END OF WHOLE FILESPEC
CAIG A2,'Z' ; [324] OUTSIDE RANGE OF
CAIGE A2,'0' ; [324] LEGAL SFD NAME CHRS.?
PUSHJ SP,OPFERR ; [324] YES, BAD FILESPEC
CAILE A2,'9' ; [324] WITHIN RANGE OF
CAIL A2,'A' ; [324] GOOD CHRS.?
TRNA ; [324] YES, SKIP
PUSHJ SP,OPFERR ; [324] NO, BAD FILESPEC
IDPB A2,A3 ; [324] CONTINUE BUILDING SFD NAME
SOJG A0,GETSF1 ; [324] LOOP UNTIL SIX CHRS. ARE READ
PUSHJ SP,GETCHR ; [324] GET NEXT CHR.
POPJ SP, ; [324] RETURN IF EOF
CAIN A2,',' ; [324] COMMA?
POPJ SP, ; [324] YES, END OF THIS SFD NAME
CAIN A2,']' ; [324] NO, CLOSE BRACKET?
POPJ SP, ; [324] YES, END OF WHOLE FILESPEC
PUSHJ SP,OPFERR ; [324] NO, BAD FILESPEC
; [324] GET SIXBIT BYTE SUBROUTINE - RETURNS THE NEXT SIXBIT CHARACTER OF
; [324] THE FILESPEC IN A2. THE CHR. IS GUARANTEED TO BE A LEGITIMATE
; [324] SIXBIT FILESPEC-TYPE CHR. (UPPERCASE, ALPHANUMERIC, COMMA, OPEN
; [324] OR CLOSE BRACKET, OR PERIOD).
; [324]
; [324] RETURN: +1 END OF FILESPEC STRING
; [324] +2 NORMAL, A2/ SIXBIT CHR.
; [324]
; [324]
GETCHR: SOJGE A10,.+2 ; [324] KEEP CHR. COUNT - DONE?
POPJ SP, ; [324] YES, RETURN
ILDB A2,A4 ; [324] NO, GET NEXT ASCII BYTE
CAILE A2,"]" ; [324] LOWER CASE?
SUBI A2,"a"-"A" ; [324] MAYBE, CONVERT TO UPPER CASE
CAILE A2,"[" ; [324] NO, ABOVE MAX. LIMIT FOR LEGAL CHR.?
CAIN A2,"]" ; [324] CHECK THIS CHR. TOO
TRNA ; [324] SKIP IF GOOD SO FAR
PUSHJ SP,OPFERR ; [324] ELSE BAD CHR.
CAIE A2,"." ; [324] IS THIS A DOT?
CAIN A2,"," ; [324] OR COMMA?
JRST GETCH1 ; [324] YES, GOOD CHR.
CAIGE A2,"0" ; [324] NO, BELOW ASCII ZERO?
PUSHJ SP,OPFERR ; [324] YES, BAD CHR.
CAILE A2,"9" ; [324] LAST CHECK FOR GOOD CHR.
CAIL A2,"A" ; [324] BETWEEN ASCII "9" AND "A"?
TRNA ; [324] NO, CHR. IS GOOD AT LAST
PUSHJ SP,OPFERR ; [324] YES, CHR. IS BAD
GETCH1: SUBI A2,"A"-'A' ; [324] CONVERT TO SIXBIT
AOSRET: AOS (SP) ; [324] PREPARE FOR GOOD RETURN
POPJ SP, ; [324] RETURN WITH GOOD FILESPEC CHR. IN A2
OPFERR: MOVE A1,.N(DL) ; [324] BAD FILESPEC, GET CHANNEL NUMBER BACK
IOERR 16,(A1) ; [324] AND GIVE THE ERROR (STACK IS WRONG)
JRST .EXIT(DL) ; [324] CONTINUE AT USER'S RISK ONLY
REP 17/168 ;05C30
SETO A2, ; PRESET ANSWER
WIT
MOVEI A2,1 ; [336] PRESET ANSWER
REP 21/168 ;05C31
AOJA A2,INFO1 ; NO
WIT
LIBERR 10, ; [336]
REP 26/168 ;05C32
INFOTB: HRRZ A2,.JBREL ; 0 -CORE SIZE
WIT
INFOTB: ADD A2,.JBREL ; [336] 0 - CORE SIZE (.JBREL LEFT MUST BE 0)
REP 31/168 ;05C33
PUSHJ SP,INFPRC ; 5 - PROCESSOR (1=KA,2=KI,3=KL)
WIT
LDB A2,[POINT 2,DB,1] ; [336] GET PROCESSOR TYPE (1=KA,2=KI,3=KL)
DEL 41/168 ;05C34
INFPRC: HLRZ A2,DB
LSH A2,-^D16 ; GET OMC BITS (PROCESSOR TYPE)
AOS 2(A2) ; KLUDGE - IF 0, MAKE IT 1 !
POPJ SP,
REP 42/169 ;05C35
MOVE A2,[
XWD %CNMON,.GTCNF]
WIT
MOVE A2,[%CNMON,,.GTCNF]
REP 47/169 ;05C36
ADD A2,[
POINT 7,MONTAB-2] ; GET POINTER TO ASCII MONTH
MOVE A0,.LU(DL) ; RECOVER # CHARS (3 OR MANY)
WIT
ADD A2,[POINT 7,MONTAB-2] ; GET POINTER TO ASCII MONTH
MOVE A0,.LU(DL) ; RECOVER # CHARS (3 OR MANY)
REP 58/169 ;05C37
MOVE A2,[
XWD %CNYER,.GTCNF]
WIT
MOVE A2,[%CNYER,,.GTCNF]
REP 15/170 ;05C38
HRLI A1,440700 ; MAKE BYTE-POINTER TO IT
MOVE A2,[
STRDYN!STRPRC,,^D8]
LRSTOR A1,.EXIT+1(DL) ; THE ANSWER (8 CHARS, DYNAMIC, RESULT-OF-PROC)
MOVEI A4,":" ; GET SEPARATOR
MOVE A2,[
XWD %CNHOR,.GTCNF]
PUSHJ SP,TIME2 ; GET HOUR & CONVERT TO ASCII
IDPB A4,A1 ; DEPOSIT SEPARATOR
MOVE A2,[
XWD %CNMIN,.GTCNF] ; MINUTE
PUSHJ SP,TIME2
IDPB A4,A1
MOVE A2,[
XWD %CNSEC,.GTCNF] ; SECOND
WIT
HRLI A1,(POINT 7,) ; [334] MAKE BYTE-POINTER TO IT
MOVE A2,[STRDYN!STRPRC,,^D8]
LRSTOR A1,.EXIT+1(DL) ; THE ANSWER (8 CHARS, DYNAMIC, RESULT-OF-PROC)
MOVEI A4,":" ; GET SEPARATOR
MOVE A2,[%CNHOR,,.GTCNF]
PUSHJ SP,TIME2 ; GET HOUR & CONVERT TO ASCII
IDPB A4,A1 ; DEPOSIT SEPARATOR
MOVE A2,[%CNMIN,,.GTCNF] ; MINUTE
PUSHJ SP,TIME2
IDPB A4,A1
MOVE A2,[%CNSEC,,.GTCNF] ; SECOND
REP 12/173 ;05C39
HLRZ A0,%SYS17(DB)
WIT
HLRZ A0,%UUOTM(DB) ; [320] PICK UP TRAP NUMBER
SUM 66881