Google
 

Trailing-Edge - PDP-10 Archives - custsupcuspmar86_bb-x130b-sb - failsa.mac
There are 6 other files named failsa.mac in the archive. Click here to see a list.
TITLE  FAILSA       /RT/MGM/RCC/CM/SP/JEF	1 APRIL 73
;COPYRIGHT 1969,1970,1971,1972, 1973 DIGITAL EQUIPMENT CORP., MAYNARD, MASS.
SUBTTL 

EDITNO=="@"
;THE EDIT - ION OF THIS CUSP

TECONO==47
;THE # TIMES TECO-ED

;NO EDIT NUMBER
AARDVARK==100
VERSION=EDITNO-"@"+AARDVARK*100,,TECONO
	MLON




	.JBVER==137
	LOC .JBVER
	VERSION

; . . . EDIT HISTORY . . .
;
; EDIT 32 - PROVIDES PROPER OPERATION OF /K WITH /F. PREVIOUSLY
;           SAVED AND DELETED FILES ACCESSED AFTER RATHER THAN
;           BEFORE THE /F DATE.
;           AREAS AFFECTED: CUSPPN, MORE10

; EDIT 33 - REMOVES UNCONDITIONAL DEFINITION OF ALFLEX.
;            AREAS AFFECTED: ALFLEX
;

; EDIT 34 - REINITIALIZES THE TTY PRIOR TO ATTEMPTING ERROR
;           MESSAGE PRINT ON OUTPUT FILE LOOKUP FAILURE.
;           AREAS AFFECTED: PRINT

; EDIT 35 - ADDS A CONTROL-Z TRAP.
;           AREAS AFFECTED: ILCH, NOTYET

; EDIT 36 - MASKS DATE TO 15 BITS. THIS IS A PATCH TO THE
;           DATE75 CODE.
;           AREAS AFFECTED: YRSMOS

; EDIT 37 - EXTENDS THE CRITERIA FOR EXEMPTING FILES FROM A /K
;           PURGE TO INCLUDE ALL PROJECTS<10.
;           AREAS AFFECTED: UNCONS

; EDIT 40 - ZERO THE PROTECTION FIELD WHEN PREFORMING ENTER FOR
;	    FAILSA.DIR.  PREVENTS SUBSEQUENT ENTERS FROM FAILING.

; EDIT 41 - DONT CHECK THE VERSION NUMBER WHEN SAVING FILES AT
;	    THE CHKCRE ROUTINE. THIS FIX ALLOWS THE "/E" SWITCH
;	    TO WORK PROPERLY.

; EDIT 42 - ARGUMENTS FOR DSKCHR AT "X:" ARE NOT INITIALIZED

; EDIT 43 - "SWAPQ" ROUTINE REENTERS THE "TAPFL4" ROUTINE AT THE
;           WRONG POINT. THIS PROBLEM OCCURES WHEN SAVING WITH
;           A /G OR /O SWITCH AND EOT IS ENCOUNTERED.

; EDIT 44 - /E STILL DOESN'T WORK. THE TIME FIELDS ARE NOT ALIGNED
;           BEFORE THEY ARE COMPARED.

; EDIT 45 - FIXES "ADDRESS CHECK FOR DPA0..." WHEN COMMAND WAS
;           "/W/U/W/U" AND NO FILES WERE SAVED FOR THE LAST FILE
;           STRUCTURE IN THE SEARCH LIST

; EDIT 46 - FIXES EDIT 37 WHICH CAUSED ALL PROJECTS .GE. 10
;	    TO BE SAVED AND DELETED IF IN "/K" MODE.

; EDIT 47 - THIS PATCH CAUSES FAILSA TO SAVE ALL FILES WITH
;		A CREATION OR ACCESS DATE OLDER THAN 1/1/67 OR
;		WITH A DATE EQUAL TO 1/5/75. THIS IS DONE WITHOUT
;		REGARD TO /E OR /F SWITCH SETTINGS IN AN ATTEMPT
;		TO PREVENT THE USER FROM LOSING FILES DUE TO DATE75
;		BUGS. IN A /K/U SAVE FILES WITH "FUNNY" DATES ARE NOT
;		DELETED OR SAVED SINCE THEY ARE ASSUMED TO BE NEW FILES.



	RELOC
		;ASSEMBLY PARAMETERS

	IFNDEF	DEBUG,<DEBUG==0>		;IF NOT DEBUGGING = PRODUCTION
	IFN DEBUG,<
SUBTTL	BUG HUNT IS ON
>
	IFNDEF	PAGING,<PAGING==0>		;IF DESIRED, TYPE OUT
						;TEXT CAN BE HELD IN THE LITERAL
						;POOL
						;NOTE THAT THE
						;LINK WORD CAN SOMETIMES
						;BE AS LONG AS THE MESSAGE
						;
	IFNDEF	NONSTP,<NONSTP==0>		;NON-0 = MULTIPLE PASSES
						;NON-0 IS THE HOOK FOR
						;IMPLEMENTING AN AUTOMATIC
						;SWITCH-OVER FROM DRIVE
						;N TO DRIVE N+1
						;NORMALLY (FOR THE
						;PRESENT, LEAVE = 0)
	IFNDEF	PRIVL,<PRIVL==0>		;NON-0=ONLY 1,2
						;CAN FIDDLE AROUND WITH OTHER
						;PEOPLES' DISK AREAS

	IFNDEF	REWIND,<REWIND==0>		;0=NO AUTOMATIC REWINDS
	IFNDEF	SFDDIR,<SFDDIR==0>		;SUB-FILE DIRECTORIES
	IFNDEF	ALPJ1S,<ALPJ1S==1>		;NORMALLY, PJ 1 ALWAYS BYPASSES
						;THE /E /F CRITERIA CHECK
						;ON SAVE
	IFNDEF	ALPJ1R,<ALPJ1R==1>		;NORMALLY, PJ 1 LIKEWISE BYPASSES
						;CHECK FOR /F & /E
						;ON RESTORE


	IFNDEF	UNLOAD,	<UNLOAD==1>		;UNLOAD TAPE FROM DRIVE
						;ON FULL REEL AT RESTORE
						;AND SAVE TIME


	IFNDEF	LOCK,	<LOCK==1>		;TRY TO LOCK YOURSELF IN CORE
						;DURING /S (SAVE) TIME
						;RATIONALE BEHIND NOT DOING
						;SAME DURING /R IS THAT 
						;THIS (/R) WILL BE DONE
						;PRETTY CLOSE TO STAND ALONE

 
						;ALL FILES LESS THAN OR =
						;ALFLEX WORDS(!) ARE
						;RESTORED
	IFNDEF	ALFLEX,<ALFLEX==0>		;

						;NO FILES ARE RESTORED OR SAVED
						;UNCONDITIONALLY
						;HOWEVER, FILES
						;LESS THAN OR = ALFLEX
						;WILL BYPASS THE /E & /F CHECKS




	IFNDEF	BELL,<BELL==0>			;IF BELL IS ASSEMBLED
						;POSITIVE, GENERATE
						;CODE TO GIVE ^G + *
						;INSTEAD OF JUST *
						;WHENEVER A COMMAND HAS
						;BEEN PROCESSED

	IFNDEF	COMUFD,<COMUFD==0>		;NORMALLY (COMUFD=0)
						;COMPRESS UFD'S.. DEALLOCATE
						;UNUSED BLOCKS


	IFNDEF	COMFIL,<COMFIL==0>		;CONTRARIWISE, FILES ARE NORMALLY
						;LEFT "EXPANDED".


	IFNDEF	MINREL,<			;ATTEMPT TO MINIMIZE
	MINREL==0			;NUMBER OF RELEASE UUOS
>
;ACCUMULATOR ASSIGNMENTS
	TMP=0
	Q=1	;R-1
	R=2	;COMMAND INPUT COUNT
	S=3	;R+1	;COMMAND BYTE POINTER
	PAKNAM=4	;DEVNAM FOR DSKCHR UUO
	WASTE=5		;USED BY DSKCHR UUO
	PAKFRE=6	;# OF FREE BLKS RETURNED BY DSKCHR UUO
	T=7	;WORD BEING TRANSFERRED
	F=10	;FLAG AC
	A=11	;SCRATCH ;JSP ON ME TO PRINT ROUTINES
	B=12	;A+1 ;SCRATCH ;BYTE PTR IN PRINT ROUTINES
	CH=13	;B+1	;CHAR
	D=14	;NUMBER FOR SWITCHES
	U=15	;FIRST WORD ON A READ
	W=16	;SECOND WORD ON A READ
	P=17	;PUSHDOWN POINTER

;PARAMETER ASSIGNMENTS
	PDSIZ==60	;PUSHDOWN LIST SIZE
	SLPMIN==^D60	;MINUTES BETWEEN CONSECUTIVE SAVES WITH /M
	XLOOKN==40	;NO. OF ARGS FOR EXTENDED LOOKUP/ENTER
	IFNDEF	NUMSTR,<
	NUMSTR==^D25	;NUMBER OF STRUCTURES RETURNED BY SYSSTR UUO
	>

;CALLI ADDRESSES
	RESET==0
	DEVCHR==4
	WAIT==10
	CORE==11
	EXIT==12
	DATE==14
	MSTIME==23
	GETPPN==24
	PJOB==30
	SLEEP==31
	DSKCHR==45
	SYSSTR==46
	JOBSTR==47		;UUO FOR FINDING OUT SUCCESSIVE STR'S IN
				;THIS JOB'S EARCH LIST

	STRUUO==50
	GOBSTR==66		;RETURN SUCCESSIVE STR'S FOR SYS OR A PARTICULAR JOB

	LOKUUO==60
	MTCHR.==112		;MTA BIT DENSITY
	UNLOCK==120		;UUO TO ATTEMPT TO UNLOCK THE JOB THAT WAS
				;LOCKED IN CORE

EXTERN	.JBFF,.JBDDT,.JBREN
;I/O PARAMETERS
;DEVICE ASSIGNMENTS
	MES==0	;.HLP MESSAGE OUT ON THIS CHANNEL
	TTO==1	;TTY AND LISTING DEVICE OUTPUT
	TTI==2	;TTY INPUT
	TAP==3	;MAGNETIC TAPE FOR READ OR WRITE
	MFD==4	;DISK FOR MASTER FILE DIRECTORY
	UFD==5	;DISK FOR USER FILE DIRECTORY
	FIL==6	;DISK FOR USER FILE
	CHK==7	;DISK FOR FILE DATE CHECK
	DGA==10 ;DON'T GO AWAY CHANNEL, SEE BELOW
						;A PHANTOM CHANNEL IS
						;OPENED UP TO
						;GET FILSER TO RETAIN SOME
						;MORE-THAN-NORMALLY-KEPT-IN
						;CORE INFORMATION IN CORE.
						;
						;BY OPENING UP THIS
						;SHADOW CHANNEL, WE EFFECTIVELY
						;DO A DEFAULT PATH UUO,
						;EXCEPT THAT IF WE CRASH 
						;WE DO NOT LEAVE
						;USER X SET TO 1,2!!!!!
;NUMBER OF BUFFERS/CHANNEL


	TTYINN==2
	TTON==^D22
	TAPN==^D06
	MFDN==2
	UFDN==^D5		;NOTE THAT BY GRABBING MOST OF THE UFD AT
				;ONCE, A STATIC PICTURE OF THE PPN'S
				;DISK AREA IS TAKEN... I.E., FILES THAT
				;APPEAR "LATE" IN THE UFD ARE
				;NOT SAVED AT A SIGNIFICANTLY LATER TIME
				;THAN FILES WHICH APPEAR "EARLY" IN THE UFD
				;FOR EXAMPLE, THE .BAK AND ORIGINAL FILES
				;WHICH TECO MAKES WOULD BE SAVE AT THE
				;SAME (OR NEARLY SO) INSTANT, AND
				;THE PROBLEM OF THE ORIGINAL BEING SAVED
				;EARLIER (LESS RECENT) THAN THE .BAK IS
				;AVOIDED.


	ALTFLN=4			;NUMBER OF BUFFERS FOR A NON-
					;1/2 OPERATION SAVE OR RESTORE
	FILN==^D20
					;IF CORE IS TO E CONSERVED
						;CONSIDER FEWER DISK BUFFERS
					;FIRST
					;@@@@@@@@@@@@@@@@ NOTE WELL ^^^^@@@@
					;NOTE WELL ^^^^^^^  @@@@@@@

				;DISK THROUGHPUT IS MAXIMIZED
				;WHENEVER NUMBER OF BUFFERS
				;= 2*CCWMAX [CCWMAX IS DEFINED IN COMMOD.MAC, AS
				;THE MAXIMUM # OF CHANNEL
				;COMMAND WORDS FOR A DF-TYPE DEVICE].
				;EMPIRICAL RESULTS SHOW
				;FAILSAFE(!) THROUGH PUT DOES
				;NOT IMPROVE AFTER 5 BUFFERS ARE
				;ALLOCATED [I.E., 20 DISK BUFFERS
				;DOES NOT SPEED UP A STAND-ALONE SAVE,
				;EVEN USING A TU-30].
				;BUT
				;WITH THE MAXIMUM NUMBER OF BUFFERS
				;ACTIVE, FAILSAFE WILL NOT BOTHER
				;THE CHANNEL-COMMAND
				;ORGANIZER AS OFTEN AND,
				;WHEN A DISK PACK GETS ON-CYLINDER FOR
				;A FAILSAFE TRANSFER, IT WILL TRANSFER
				;A COMPLETE CYLINDER 'ROUND.
				;
;SIZE OF BUFFERS/DEVICE
	TTYSIZ==23
	TTOSIZ==TTOLEN-3
	TTOSIZ==TTOSIZ*^D5		;NUMBER OF CHUNKS PER BUFFER
					;=
					;NUMBER OF DATA WORDS *
					;NUMBER OF CHUNKS (BYTES) PER WORD
				;SIZ IN THIS CASE IS THE # CHARACTERS
	TTOLEN=^D6
				;THE TTY OUTPUT BUFFERS ARE 10 ASCII CHARACTERS
				;LONG ..  NOTE THAT JOB GOES INTO QUASI-TTY SLEEP
				;WHENEVER 100 OR SO CHARACTERS
				;GAVE BEEN ACCUMULATED BUT NOT OUTPUT.
				;HAVE ABOUT 90 CHARACTER BUFFER CAPACITY

	TAPLEN=1003
	TAPSIZ=TAPLEN-3		;SIZ OF USEFUL BUFFER SPACE IN CHUNKS OR
				;BYTES
	LPTSIZ==25
	DSKSIZ==203

;I/O STATUS BIT ASSIGNMENTS
	ASCII=0
	AL==1		;ASCII LINE MODE
	BUFBIN==14	;BUFFERED BINARY MODE
	DUMP=17		;DUMP MODE
	NOCNT==20	;MONITOR IS NOT TO COMPUTE BUFFER WORD COUNT
	IOEND==20000	;END OF FILE
	IOTBOT==4000	;BEGINNING OF TAPE
	IOTEND==2000	;END OF TAPE
	IOBAD==740000	;I/O ERROR
	DONXFR==40	;DON'T XFER  ON  CLOSING
	BTL==40000	;BLOCK TOO LARGE FOR BUFFER
	DNC==10		;DO NOT CHG ACCESS DATE
	DONDAL==04	;DON'T DE-ALLOCATED UNUSED BLOCKS WHEN RESTORING
			;ON AN OUTPUT CLOSE

;EXTENDED LOOKUP FILE STATUS BITS
	.RPDIR==400000	;(RH) UFD BIT
	.RPNFS==40000	;(RH) DO-NOT-SAVE BIT
	.RPBFA==10	;(BOTH HALVES OF UFD - RH FOR OTHER) BAD FILE ACC. BIT
	URBLGI==400000	;(LH) LOGGED IN BIT
;STATUS BITS RETURNED BY DSKCHR UUO

	.UPRHB==1B18		;MONITOR MUST REREAD HOME BLOCK
	.UPOFL==1B19		;UNIT IS OFF-LINE
	.UPHWP==1B20		;UNIT IS HARDWARE WRITE PROTECTED
	.UPSWP==1B21		;UNIT IS SOFTWARE WRITE PROTECTED
	.UPSAF==1B22		;UNIT IS SINGLE ACCESS
	.UPZMT==1B23		;ZERO MOUNT COUNT FOR THIS UNIT
	.UPNNA==1B28		;UNIT BELONGS TO A FILE STRUCTURE FOR WHICH THE
				;OPERATOR HAS REQUESTED NO MORE NEW
				;INIT'S LOOKUPS ENTERS ON
	.UNIAWL==1B29		;STRUCTURE IS WRITE PROTECTED FOR ALL JOBS







;OFFSETS WITHIN ENTER/LOOKUP BLOCK
	.RBZRO==0	;COUNT OF ARGS FOLLOWING IN RIGHT HALF
			;IF LEFT HALF NON-ZERO, 4-WORD
			;ENTER-BLOCK
	.RBPPN==1	;PROJ-PROG WHO OWNS FILE
	.RBNAM==2	;SIXBIT NAME OF FILE
	.RBEXT==3	;EXTENSION IN LEFT HALF, POSSIBLE ERROR CODE
			;ON LOOKUP RETURNED IN RIGHT HALF

	.RBPRV==4	;PRIVILEGE
			;MODE
			;CREATE
			;TIME+DATE

	.RBSIZ==5	;OFFSET FROM 1ST WORD IN ENTER BLOCK FOR SIZE
			;IN WORDS
	.RBVER==6	;OCTAL VERSION NUMBER
	.RBFUT==7	;RESERVED
	.RBEST==10	;OFFSET FOR ESTIMATED SIZE (IN BLOCKS)
	.RBALC==11	;OFFSET FOR HIGHEST RELATIVE BLOCK NUMBER
			;WITHIN FILE STRUCTURE ALLOCATED
	.RBPOS==12	;LOGICAL BLOCK NUMBER OF FIRST BLOCK
	.RBFT1==13	;RESERVED

	.RBNCA==14	;RESERVED FOR CUSTOMER
	.RBMTA==15	;TAPE!!LABEL IF ON A BACKUP TAPE


	.RBDEV==16	;UNIT NAME ON WHICH THE FILE IS LOCATED
	.RBSTS==17	;STATUS BITS
	;SEE COMMOD.MAC  MONITOR LISTING FOR FULL DESCRIPTION
			;IN THE STATUS WORD:
			RIPLOG==400000;(LEFT HALF) A 1 IF LOGGED IN
			RIPBDA==1	;A 1 IF ANY FILE IN UFD
				;FOUND BAD BY DAMAGE ASSESSMENT PROG
			RIPCRH==4	;A 1 IF ANY FILE CLOSED AFTER
				;A CRASH
			RIPBFA==10	;A 1 IF FILE(S) FOUND BAD BY ME, FAILSAFE[NOT USED]
			RIPHRE==100	;A 1 IF READ DATA ERROR IS HARD
			RIPHWE==200	;WRITE DATA ERROR IS HARD
		RIPSCE=400	;A 1 ID SOFTWARE CHECKSUM ERROR


	.RBELB==20	;BAD LOGICAL BLOCK
	.RBEUN==21	;ERROR INFO
	.RBQTF==22	;UFD ONLY -- FCFS LOGGED IN QUOTA IN BLOCKS
	.RBQTO==23	;UFD ONLY -- LOGGED OUT QUOTA IN BLOCKS

	.RBQTR==24	;UFD ONLY -- RESERVED LOGGED IN QUOTA
	.RBUSD==25	;UFD ONLY -- # OF BLOCKS USED AT LAST LOGOUT
	.RBAUT==26	;AUTHOR PROJECT-PROGRAMMER #
	.RBNXT==27	;NEXT FILE STRUCTURE NAME IF FILE CONTINUED

	.RBPRD==30	;PREDECESSOR FILE STUCTURE
	.RBPCA==31	;RESERVED FOR CUSTOMER
	.RBUFD==32	;RIB INFO



			;;TO ALLOCATE



	;MISCELLANEOUS EXTENDED ENTER PARAMETER ASSIGNMENTS
	FRAGER==17		;FRAGMENTATION ERROR CODE
				;RETURNED IN ENTER EFFECTIVE ADDRESS
				;+3, RIGHT HALF

	NOROOM==14		;SIMILAR TO FRAGER, BUT SIGNIFIES THAT
				;THAT THERE IS NO MORE ROOM FOR USER

;FLAG ASSIGNMENTS (LH OF AC F)
;	NAME & DEF	MEANING= 1

	SWITCH==400000	;SWITCH MODE
	SLASH==200000	;SWITCH MODE ENTERED W/ SLASH
	CSSW==100000	;CHAR SEEN AND STASHED INTO IDENT
	NAMESW==40000	;DO NOT COMPARE NAME OF FILE
	EXTSW==20000	;DO NOT COMPARE EXT OF FILE
	FIRSW==10000	;FIRST TAPE 
	PERSW==4000	;PERIOD SEEN
	PPFSW==2000	;PROJ-PROG AREA FOUND ON TAPE

	POPGOT==1000	;NEED TO POPJ, NOT GO FURTHER

	ETWASW==400	;SOMETHING SEEN ON THIS LINE
	ALLFSW==200	;ALL FILES CHAR SEEN
	MFDDNE==100	;SET WHEN THRU WITH MFD
	FILFND==40	;A FILE WAS SAVED FOR THIS USER
	LOCKER==20	;LOCK REQUEST
	TENDF==10	;END OF TAPE FOUND
	ACCESS==4	;RESET ACCES DATE WORD
	NEWRSW==4	;DON'T CHECK DISK FILE DATES ON RESTORE
	USRDNE==2	;ON MULTIPLE SAVE, TAPE ENDS BY ENDING A USER AREA
	KILLSW==1	;ON /S OR /U ZONK ALL FILES FROM DISK WHICH ARE SAVED ON TAPE
			;ONLY SAVE THOSE FILES WHOSE ACCESS DATES ARE LESS THAN
			;ACCDAT. DON'T SAVE FILES BELONGING TO 1,1

;POSITIONING FLAGS (MARKING POSITION PROGRAM FOR REENTER) RH OF F

	SLRESW==1	;PROGRAM IS SELECTIVELY RESTORING
	RESTSW==2	;PROGRAM IS IN RESTORING PROCESS (/R ISSUED)
	LISTSW==4	;PROGRAM IS LISTING (/L ISSUED)
	SAVSW==10	;PROGRAM IS IN SAVING PROCESS (/S ISSUED)
			;ABOVE ARE USED AS A MAGIC OCTAL #.
			; DO NOT CHANGE.
	CONTSW==20	;CONTINUING ON NEW TAPE
	PRNTSW==40	;PRINT TAPE DIRECTORY ON DEVICE LST
	USRSW==100	;SINGLE USER ONLY SAVE
	UUOERR==200	;UUO ERROR FLAG
	DOINGJ==400	;SET WHEN /J IN PROGRESS SO TAPIN CAN IGNORE
			;MISCELLANEOUS MINUS VALUES THAT MIGHT BE AT START OF
			;BOOTSTRAP FILE
	MFDI==1000	;MFD INPUT IN PROGRESS
	UFDI==2000	;UFD INPUT IN PROGRESS
	FILI==4000	;FILE INPUT IN PROGRESS (ALL FROM DSK)
	TAPO==10000	;TAPE OUTPUT IN PROGRESS
	TAPI==20000	;TAPE INPUT IN PROGRESS
	UFDO==40000	;UFD OUTPUT IN PROGRESS
	FILO==100000	;USER FILE OUTPUT IN PROG. (TO DSK)
	IFNDEF	LEVELC,<
	LEVELC==000000	;IF ENABLED FOR 5-SERIES TO 4-SERIES RESTORES
	>
				;LEVELC=200000
				;OTHERWISE, (IF LEVELC NOT = 200000,)
				;RIG FOR 5-SERIES ONLY
	IFLE	LEVELC,
	<
	AARDVARK=AARDVARK+1
VERSION=EDITNO-"@"+AARDVARK*100,,TECONO
	LOC	.JBVER
	VERSION
	RELOC
	>

	XSWITC==400000	;E"X"TRACT PROJECT-PROGRAMMER NUMBERS
			;FROM THIS TAPE



	SYNCH=40		;SYNCHRONOUS INPUT/OUTPUT

	SECVER=30		;VERSION NUMBER INCLUDING AND AFTER
				;WHICH SECONDS AS WELL AS HOURS AND MINUTES
				;ARE GIVEN
	FST5S=27		;1ST OF THE FIVE-SERIES FAILSAFES WAS VERSION 27
	TRACK7=1B33		;IT'S A 7/9 CHANNEL DRIVE ON/OFF
	ITSTTY=10		;10 RETURNED IN LEFT HALF OF
	LPT=40000
				;DEVCHR UUO SAYS DEVICE IS A TTY
				;






;MACRO DEFINITIONS


	DEFINE	TYPES		(ARG)	<
	MOVEI	CH,"ARG"
	PUSHJ	P,TYPEA
	PUSHJ	P,SPACE
	>


	DEFINE	SETBUF	(ARG)<

	IFGE	ARG'N-4<

	MOVEI	B,ARG'N-1
	SKIPA	A,[	XWD	ARG'LEN-2,ARG'BUF+1+ARG'LEN]
	HRRI	A,ARG'LEN(A)
	SETZM	-ARG'LEN-1(A)
	MOVEM	A,-ARG'LEN(A)
	SOJG	B,.-3

	MOVEI	B,(A)
	SETZM	-1(B)
	HRRI	A,ARG'BUF+1
	MOVEM	A,(B)

	>


	IFL	ARG'N-4<
	IFL	ARG'N-2<
	SETZM	ARG'BUF
	MOVE	A,[ARG'LEN-2,,ARG'BUF+1]
	MOVEM	A,ARG'BUF+1
	>
	IFGE	ARG'N-2<
	M=1
	N=M
	SETZM	ARG'BUF
	MOVE	A,[XWD	ARG'LEN-2,ARG'LEN+ARG'BUF+1]
	MOVEM	A,ARG'BUF+1

	REPEAT	ARG'N-2,<
	N=M
	M=M+1
	HRRI	A,M*ARG'LEN+ARG'BUF+1
	MOVEM	A,N*ARG'LEN+ARG'BUF+1
	SETZM	N*ARG'LEN+ARG'BUF
	>
	>
	HRRI	A,ARG'BUF+1
	MOVEM	A,M*ARG'LEN+ARG'BUF+1
	SETZM	M*ARG'LEN+ARG'BUF

	>
	>




		DEFINE	LOADPT	<
		IFE	REWIND,<
		PUSHJ	P,REWJMP>
		IFN	REWIND,<
		EMTAPE	1>
		>

	IFN	LEVELC,
	<
	DEFINE	CLOSE	(IT,UP)
	<
	TARGET==-IT
	IFNDEF	FINISH,<
	OPDEF	FINISH	[OCT	070000000000]
	>
	IFIDN	<IT><FIL>,<
	TARGET==IT>
	IFIDN	<IT><UFD>,<
	TARGET==IT>
	IFIDN	<IT><MFD>,<
	TARGET==IT>
	IFN	IT+TARGET,<
	PUSHJ	P,[
		TRNE	F,LEVELC		;IS LEVEL-C UP /
		JRST	[
			FINISH	IT,0		;YES!
			POPJ	P,
			]
		FINISH	IT,UP			;NO!
		POPJ	P,
		]
		>
		IFE	IT+TARGET,<
		FINISH	IT,UP
		>

		>
		>


	IFN	LEVELC,
	<
	DEFINE	FIXDEV<
	TRNE	F,LEVELC		;PUT THIS IN FRONT OF
					;EVERY 5-SERIES-TYPE INIT
	PUSHJ	P,[
	MOVE	A,(P)			;GET ADDRESS OF PUSHJ P,
	HRLI	A,(SIXBIT/DSK/)		;GENERATE DSK
	HLLZM	A,1(A)			;DUMP DSK BACK INTO CALL + 2
					;WHICH IS DEVICE NAME
					;SLOT
	POPJ	P,			;RETURN
	]
	>
	>




	IFLE	LEVELC,
	<
	DEFINE	FIXDEV<
	>
	>

DEFINE	PRLIN1(B)
<	XLIST
	JSP	A,PRLIN
	IFN PAGING,
	<
	JFCL	[SIXBIT	+B+]
	>
	IFE	PAGING,
	<
	SIXBIT	+B+
	>
	LIST
>


	IFN	LEVELC,
	<
	DEFINE	FIX	(IT)
	<
	TRNE	F,LEVELC
	PUSHJ	P,[
		MOVE	A,IT
		TLNE	A,-1
		POPJ	P,


		MOVE	CH,IT+1		;SAVE PPN
		MOVE	A,[XWD	IT+2,IT]
		BLT	A,IT+2
		MOVEM	CH,IT+3		;INSERT PPN
		POPJ	P,
		]
	>
	>

	IFLE	LEVELC,
	<
	DEFINE	FIX	(IT)
	<
	>
	>

					;IF LEVELC
					;AND WE ARE NOT
					;PRINTING
					;OR LISTING
					;SWAP HEADER-INFO
	IFN	LEVELC,
	<
	DEFINE	UNFIX	(IT)
	<
	TRNE	F,LEVELC!PRNTSW!LISTSW		;ARE WE IN LEVEL-C OUTPUT MODE ?
	PUSHJ	P,[
		TRNE	F,PRNTSW!LISTSW
		POPJ	P,

		MOVE	A,IT
		TLNN	A,-1			;ALREADY SWAPPED ?
		POPJ	P,


		EXCH	A,IT+2
		MOVEM	A,IT+4
		MOVE	A,IT+3
		EXCH	A,IT+1
		MOVEM	A,IT+3
		MOVEI	A,XLOOKN
		MOVEM	A,IT
		POPJ	P,
		]
		>
		>



	IFLE	LEVELC,
	<
	DEFINE	UNFIX		(IT)
	<>
		>

DEFINE	PR1(B)
<	XLIST
	JSP	A,PR
	IFN	PAGING,
	<
	JFCL	[SIXBIT	+B+]
	>
	IFE	PAGING,
	<
	SIXBIT	+B+
	>
	LIST
>
DEFINE	EMTAPE(B)
<	XLIST
	MTAPE	TAP,B
	MTAPE	TAP,0
	LIST
>
DEFINE	PRCHAR(B)
<	XLIST
	MOVEI	CH,"B"
	PUSHJ	P,TYPEA
	LIST
>



DEFINE GETBAD	(AC),
<	XLIST
	HRRZ	AC,(P)	;CALLED BY A PUSHJ FOLLOWING EXTENDED
			;ENTER, NOW GET ENTER'S EFFECTIVE ADDRESS
	MOVEI	AC,@-2(AC);AC POINTED TO ENTER +2
			;(A)-2 POINTS TO ENTER, INDIRECT BIT
			;STARTS CHAIN TO FINAL ENTER EFFECTIVE
			;ADDRESS
	IFN	LEVELC,<
	HLL	AC,(AC)	;GET LEFT HALF OF 1ST WORD OF ENTER/LOOKUP BLOCK
	TLNE	AC,-1	;IS IT = 0 ?
	JRST	LOOKER		;IF NON-ZER IN LEFT HALF
				; A FOUR-WORD ENTER
				;= A LEVELC-ENTER/LOOKUP
				;FORGET FRAGMENTATION & OTHER STRUCTURES
	>
	HRRZ	AC,3(AC);GET EFFECTIVE ADDRESS +3, RIGHT HALF
	CAIN	AC,FRAGER;FRAGMENTATION ERROR ?
	JRST	FIXFRG	;FRAGMENTATION, FIT IT
	POP	P,AC	;NOPE FIND OUT WHAT'S THE MATTER
	LIST
	>
;INITIALIZATION
;CODE MAY BE LOADED BEFORE THIS, BUT NOT AFTER... DUE TO
;CORE EXPANSION-CONTRACTION

START:	CALLI	RESET		;STOP THE WORLD
	MOVEI	A,TAPBUF+VSTBUF
	HRRM	A,GLEEP
	MOVSI	A,400000	;THE NOT USED YET BIT
	IORM	A,FILHED
	IORM	A,TAPHED	;FOR TAPE TOO
	MOVE	P,[ IOWD	PDSIZ,PDL]
	SETZM	ACCDAT#		;CLEAR ACCESS DATE WORD ON START ONLY
	SETZM	STARPT		;RESET WE HAVE SEEN A STARTING POINT
	SETZM	FNDBEG		;RESET WE HAVE SEEN THE HEADER RECORD
	SETZB	D,CRDATE#	;CLEAR DATE WORD ON START ONLY
	PUSHJ	P,DINSTD	;SETUP FOR STANDARD DENSITY
				;NOTE THAT THE SKIP IS TAKEN
	JFCL			;NEVER REACHED DUE TO SKIP
	MOVEI	A,RENTER	;REENTER ADDRESS
	MOVEM	A,.JBREN
	CALLI	A,GETPPN	;GET USER'S PROJ-PROG #
	  JFCL			;BE DEFENSIVE
	MOVEM	A,USRPPN#
	MOVEM	A,SLGPPN#		;SOUGHT PPN
	MOVEM	A,SLOPPN#		;DESIRED DESTINATION PPN
	SETZB	F,ONEFIL		;RESET FLAGS
					;RESET WE HAVE ALREADY OPENED SHADOW CHANNEL
					;AND SWITCHES
				;
				;I AM LOGGED IN AS XX,YY
				;MY USER PPN GOES INTO USRPPN
				;I HAVE THE RIGHT TO DO SO, SO I
				;ELECT TO GET (/G) ANOTHER'S AREA
				;SO, WITH /G, I GRAB MM,NN
				;AND I MY ALSO OVERWRITE THE 
				;AREA GRABBED (MM,NN) BY USING
				;THE /O SWITCH.... THUSLY
				;/OAA,BB
				;THE NET EFFECT IS THAT
				;AS XX,YY   I   CAN
				;GRAB  MM,NN'S AREAS
				;AND WRITE THEM OUT AS IF THEY BELONGED TO
				;AA,BB
					;N.B.
				;IF THE STRUCTURES ARE NOT THE SAME IN ALL CASES,
				;AND IF ACCESS IS NOT ALLOWED TO
				;AA,BB OR MM,NN
				;THE SAVE   AND/OR   RESTORE WILL
				;NOT WORK.
	PUSHJ	P,TTYINI	;INIT THE TTY

;BEGIN OPERATIONS
;ALSO VARIOUS REENTRY POINTS

FS1:	IFE	REWIND,<PRLIN1 (REWINDS ARE NOT AUTOMATIC.#)
	MOVE	A,[JRST	FS1.1]
	MOVEM	A,FS1			;SET SWITCH TO JUMP AROUND REWIND MESSSAGE
>;	END OF IFE REWIND
FS1.1:	IFN	LEVELC,
	<
	MOVE	A,[XWD	17,11]
	GETTAB	A,
	MOVEI	A,0
	TLNN	A,(7B9)
	TROA	F,LEVELC		;SETUP FOR LEVEL C
	TRZ	F,LEVELC
	>
	PRLIN1	<FAILSAFE VERSION#>
	MOVE	TMP,.JBVER		;FAILSAFE BRAND INTO TMP FOR PRINTING
	PUSHJ	P,PRPPN1

FS1.1A:	PR1	<; FOR HELP, READ SYS:FAILSA.HLP, OR TYPE /H@>
	MOVE	A,[JRST	[PUSHJ	P,CRLF
			JRST	FS1.1B]]
	MOVEM	A,FS1.1A
FS1.1B:	SETZM	TALKER#		;TELL TALK SWITCH TO BE QUITE
	SETZM	RECIRC#		;TELL REWJMP: TO REWIND 
	SETZM	JFLAG		;TELL THE /J CO-ORDINATOR THAT THERE
	SETZM	FNDBEG#
				;HAVEN'T BEEN ANY /J'S SO FAR
FS1.2:	TLZ	F,PPFSW		;PREVIOUS TAPE POSITION IGNORED
FS1AA:	MOVE	P,[IOWD PDSIZ,PDL]	;RESET PDL IN CASE OF REENTRY
FS1A:	SETZM	TTYI+2		;FLUSH PREVIOUS INPUT
	PUSHJ	P,ASTRSK	;TYPE "*"
GLEEP:	MOVEI	A,TAPBUF+VSTBUF	;ENOUGH CORE FOR TTY BUFS
				;AND VESTIGIAL BUFFER AREA
				;FOR MTAPE TAPE OPERATIOJNS
				;AND ANY DANGLING INFORMATION
				;LEFT IN MAG TAPE BUFS
PGLEEP:	MOVEI	B,MFDBUF	;BUT 1ST TIME THROUGH
	HRRM	B,GLEEP		;LEAVE ENOUGH CORE FOR TTY BUFS ONLY
	IFN	LOCK,<
	TLNE	F,LOCKER
	JRST	FS1B
		>
	IFE	DEBUG,<
	CALLI	A,CORE		;GET SOME MEMORY
	>
	IFN	DEBUG,<
	CAIA			;ALWAYS HAVE ENOUGH MEMORY
	>
	JRST	NOCORE		;NO CORE FOR YOU
FS1B:	TRZ	F,-1-LEVELC		;NO IO IN PROGRESS
	TLZ	F,SWITCH!SLASH!ETWASW!ALLFSW!FILFND!NEWRSW!MFDDNE	;ST NORML MOD
FS1.5:	TLZ	F,CSSW!PERSW!TENDF!KILLSW!USRDNE!ALLFSW!NAMESW!EXTSW!POPGOT
	;RDY FOR NXT IDNTIFIR
	HRROI	R,-6		;INIT NEXT IDENTIFIER SCAN
FS1.7:	MOVE	S,[POINT 6,IDENT#]
	SETZM	IDENT
;INPUT CHARACTER DISPATCH

FS2:	SETZM	SYNCIN		;RESET SYNCHRONOUS INPUT FLAG
				;SWITCH

	PUSHJ	P,TYI		;GET A COMMAND CHARACTER
	MOVE	A,CH		;DISPATCH ON COPY
	IDIVI	A,11		;ARRANGE ENTRY INTO MATRIX
	LDB	A,FS3(A+1)	;GET CLASSIFICATION CODE
	JUMPE	A,ILCH		;ZERO IS AN ILLEGAL CHAR
	CAIGE	A,4		;SHIFT CODES GREATER THAN 4
	TLNN	F,SWITCH	;TO ALLOW SPACE FOR SWITCH MODE
	MOVEI	A,3(A)
	CAIGE	A,10		;RH OR LF DISPATCH ?
	SKIPA	B,FS5-1(A)	;RIGHT HAND
	HLRZ	B,FS5-10(A)	;LEFT HAND DISPATCH
	JRST	(B)		;GO AWAY

;INPUT CHARACTER DISPATCH MATRIX

FS3:	POINT	4,FS4(A),3	;BYTE POINTERS TO CLASSIFICATION TABLE
	POINT	4,FS4(A),7
	POINT	4,FS4(A),11
	POINT	4,FS4(A),15
	POINT	4,FS4(A),19
	POINT	4,FS4(A),23
	POINT	4,FS4(A),27
	POINT	4,FS4(A),31
	POINT	4,FS4(A),35



;	CLASSIFICATION TABLE FOR INPUT CHARACTERS
;	ADD 3 TO CODE IF NOT IN SWITCH MODE
;	SECOND ALPHABET SET REPRESENTS LOWER CASE CHARACTER CODES

;	NUL SOH STX ETX EOT ENQ ACK BEL BS
;	HT  LF  VT  FF  CR  SO  SI  DLE DC1
;	DC2 DC3 DC4 NAK SYN ETB CAN EM  SUB
;	ESC FS  GS  RS  US  SP  !   "   #
;	$   %   &   '   (   )   *   +   ,
;	-   .   /   0   1   2   3   4   5
;	6   7   8   9   :   ;   <   =   >
;	?   @   A   B   C   D   E   F   G
;	H   I   J   K   L   M   N   O   P
;	Q   R   S   T   U   V   W   X   Y
;	Z   [   \   ]   ^   _   '   A   B
;	C   D   E   F   G   H   I   J   K
;	L   M   N   O   P   Q   R   S   T
;	U   V   W   X   Y   Z   173 174 175   
;	176 DEL

FS4:	BYTE	(4)4,0,0,0,0,0,0,0,0
	BYTE	(4)4,13,4,4,13,0,0,0,0
	EXP	0
	BYTE	(4)13,0,0,0,0,4,0,4,0
	BYTE	(4)0,0,0,0,5,3,6,0,11
	BYTE	(4)0,7,12,2,2,2,2,2,2
	BYTE	(4)2,2,2,2,2,0,0,10,0
	BYTE	(4)0,0,1,1,1,1,1,1,1
	BYTE	(4)1,1,1,1,1,1,1,1,1
	BYTE	(4)1,1,1,1,1,1,1,1,1
	BYTE	(4)1,0,0,0,0,10,0,0,0
	EXP	0
	EXP	0
	BYTE	(4)0,0,0,0,0,0,0,0,13
	BYTE	(4)13,4

;	BYTE	DISP	CLASSIFICATION

;	00	00	ILLEGAL CHARACTER

;	01	01	LETTER, SWITCH MODE
;	02	02	NUMBER, SWITCH MODE
;	03	03	ESCAPE CHAR, SWITCH MODE

;	01	04	LETTER, NORMAL MODE
;	02	05	NUMBER, NORMAL MODE
;	03	06	ESCAPE CHAR, NORMAL MODE

;	04	07	IGNORED CHAR
;	05	10	ENTER SWITCH MODE CHAR
;	06	11	ALL FILES CHAR
;	07	12	FILE EXTENSION DELIMITER
;	10	13	OUTPUT SPEC DELIMITER(=,_)
;	11	14	FILE DELIMITER
;	12	15	NEXT CHAR A SWITCH CHAR
;	13	16	LINE TERMINATION

FS5:	XWD	SENTER,SLETTR	;10,1
	XWD	ALLFIL,SDIGIT	;11,2
	XWD	EXTDLM,SLEAVE	;12,3
	XWD	NOTYET,NLETTR	;13,4
	XWD	COMMA,NLETTR	;14,5
	XWD	SLENTR,ILCH	;15,6
	XWD	LINTER,FS2	;16,7
SUBTTL ***SWITCH PROCESSOR***
;SWITCH MODE DISPATCHING

SDIGIT:	MOVEI	CH,133-60(CH)	;OFFSET NUMERIC VALUE PAST Z FOR SWITAB
SLETTR:	LDB	A,[POINT 9,.JBVER,11]		;INSURE HEADER KNOWS
						;WHICH VERSION YOU ARE
						;BEFORE EACH SWITCH ACTION
	HRLM	A,FIRBLK
	XCT	SWITAB-"A"(CH)				;PERFORM THE SWITCH FUNCTION
SLENTR:	TLOA	F,SLASH		;ENTER SLASH MODE
	TLZN	F,SLASH		;STAY IN SWITCH MODE?
SENTER:	TLOA	F,SWITCH	;ENTER SWITCH MODE
SLEAVE:	TLZ	F,SWITCH	;LEAVE SWITCH MODE
	MOVEI	D,0		;COUNTER OR MTAPE REGISTER
	JRST	FS2		;LOOK AT NEXT CHAR

SWITAB:	PUSHJ	P,SWSKIP	;A - ADVANCE THE MAGTAPE ONE FILE
	PUSHJ	P,SWBAKF	;B - BACKSPACE THE MAGTAPE ONE FILE
	PUSHJ	P,CONTIN	;C - CONTINUE
	PUSHJ	P,CALDDT	;D - GO TO DDT (IF EXTANT)
	PUSHJ	P,SETCRE	;E - SET CREATION DATE CHECK TIME AND DATE
	PUSHJ	P,SETACC	;F - SET ACCESS DATE CHECK DATE
	PUSHJ	P,AREA		;G - GET PROJECT-PROGRAMMER NUMBER
	PUSHJ	P,HELPER	;H - THE HELP MESSAGE FROM SYS:FAILSA.HLP
	PUSHJ	P,DINSTD	;I - DENSITY = INSTALLATION STANDARD
IFE	REWIND,<
	PUSHJ	P,JUMPSV	;J - JUMP TO NEXT TRAILER RECORD
	>
IFN	REWIND,<
	JRST	ILSW		;J - ILLEGAL
	>
	TLOA	F,KILLSW	;K - KILL ALL OLD DISK FILES SAVED ON TAPE
	PUSHJ	P,LIST		;L - LIST USERS FILES FROM TAPE
	JRST	MNYSAV		;M - MULTIPLE SAVES EVERY SLPMIN MINUTES
	TLOA	F,NEWRSW	;N - INHIBIT DISK FILE DATE CHECK ON RESTORE
	PUSHJ	P,SLOSWT	;O - OVERWRITE THE PERSON NAMED IN /G
	PUSHJ	P,PRINT		;P - PRINT DIRECTORY OF ALL FILES ON DEVICE LST
	PUSHJ	P,[SETZM TALKER	;Q - TURN OFF THE /T SWITCH
		JRST	CPOPJ1]
	PUSHJ	P,UNSAVE	;R - RESTORE THE DISK FROM MAGTAPE
	PUSHJ	P,SAVE		;S - SAVE THE DISK ON MAGTAPE
	PUSHJ	P,[SETOM TALKER	;T - TELL USER WHAT FILES WERE FOUND / XFERED
		JRST	CPOPJ1]
	PUSHJ	P,USAVE		;U - SAVE A USERS AREA
	IFNDEF	LOCK<
	JRST	ILSW		;V - ILLEGAL
	>
	IFN	LOCK,<
	PUSHJ	P,LOC		;V - VERY FAST SAVE (?) LOCK JOB IN CORE
				;    IF /S AND ALLOWED TO LOCK AS WELL AS /V
	>
	PUSHJ	P,SWREW		;W - REWIND THE MAGTAPE
	PUSHJ	P,GOTANX	;X - E"X"TRACT PROJECT PROGRAMMER NUMBERS
	SETZM	RECIRC		;Y - RECIRCULATE THE TAPE (REWIND IT)
				;Y AND Z FACILITATE MANUAL POSITIONING
				;OF THE TAPE TO JUST BEFORE THE NEXT
				;TRAILER RECORD, DOING A /J TO GET
				;TO THE END OF THE CURRENT SAVE SET,
				;AND THEN BEING ABLE TO GET AROUND THE
				;PROBLEM OF FAILSAFE'S THINKING THAT
				;THERE IS BUT 1 SAVE SET (1 /J DONE)
				;WHEN HT REWINDS AND DOES AUTOMATIC
				;/J'S.  ALSO SAVES TIME...
	SETOM	RECIRC		;Z - DEFEAT THE REWINDING OF THE TAPE
	JRST	NILSW		;0 - ILLEGAL
	JRST	NILSW		;1 - ILLEGAL
	PUSHJ	P,D200		;2 - DENSITY = 200 BPI
	JRST	NILSW		;3 - ILLEGAL
	JRST	NILSW		;4 - ILLEGAL
	PUSHJ	P,D556		;5 - DENSITY = 556 BPI
	JRST	NILSW		;6 - ILLEGAL
	JRST	NILSW		;7 - ILLEGAL
	PUSHJ	P,D800		;8 - DENSITY = 800 BPI
	JRST	NILSW		;9 - ILLEGAL
;"/H" SWITCH - TYPE <SYS:FAILSA.HLP>

HELPER:	OPEN	MES,HELPS
	JRST	ILSW
	MOVE	B,FS6BIT
	MOVSI	CH,(SIXBIT	/HLP/)
	LOOKUP	MES,B		;'FAILSA.HLP'
	  JRST	[PRLIN1 <"SYS:FAILSA.HLP" FILE NOT FOUND@>
		JRST	FS1.1	]
MORHLP:	INPUT	MES,
	STATZ	MES,20000	;EOF ON FAILSA.HLP (FINISHED ?)
	JRST	RELMES
	HRRZ	R,HELPIT+1
	OUTSTR	1(R)
	JRST	MORHLP

RELMES:	RELEAS	MES,0		;RELEAS THE CHANNEL
	JRST	CRLF

;"/V" SWITCH
	IFN	LOCK, <
LOC:	MOVEI	TMP,1
	TLNE	F,LOCKER		;LOCKED ALREADY ?
	JRST	UNLOC		;IF LOC & /V TYPED, TRY UNLOCKING JOB
	MOVEI	B,ENDIF2	;GET ALL THE CORE YOU WANT NOW!
	CALLI	B,CORE
	  JRST	NOCORE		;OOPS NO CORE
	TLOA	F,LOCKER		;SET THE FLAG AND POPJ
UNLOC:	CALLI	TMP,UNLOCK
	POPJ	P,
	TLZ	F,LOCKER		;AOK, RESET LOCK FLAG
	POPJ	P,			;AND RETURN
		>
;"/A /B /W" SWITCH - MAGTAPE OPERATIONS

SWBAKF:	MOVEI	D,1(D)		;BACKSPACE FILE (MTAPE 17)
SWSKIP:	MOVEI	D,15(D)		;SKIP FILE (MTAPE 16)
SWREW:	SKIPG	TAPHED		;SAY, DO WE NEED TO INIT THIS MTA /
				;WHEN IT WAS LOADED? IF SO, NO INIT DONE
	PUSHJ	P,SETI
				;(EITHER SETI OR SETO WILL DO)
				;(JUST BE SURE YOU HAVE AN MTA)
				;SETIN WILL
	MTAPE	TAP,1(D)	;REWIND + FUNCTION IN D
	IFG	LEVELC,<	;LEVELC MAY NOT ALLOW SUCCESSIVE MTAPES
				;WITHOUT WAITING
	MTAPE	TAP,0		;WAIT TIL DONE
	>

	RELEAS	TAP,0		;RELEASE TAPE.. WILL FORCE AN INIT
				;LATER WHICH IS NECESSARY DUE
				;TO OUR HAVING DESTROYED THE CORRELATION
				;BETWEEN PHYSICAL TAPE AND BUFFERS



	TLZ	F,PPFSW		;MOVED TO NEW PLACE ON TAPE
IFE	REWIND,<
	TRNN	D,-1		;REWIND ?
	SETZM	JFLAG		;YES, CLEAR /J CTR
	>
	TRZN	D,-1		;IF /A OR /B, DO NOT DESTROY RECORD OF HAVING
				;FOUND FIRST HEADER.. LET HIM HANG HIMSELF
RSTFBG:	SETZM	FNDBEG		;YES... RESET YOU'VE FOUND FIRST HEADER
	JRST	CPOPJ1		;RETURN AT SLENTR+1

;"/2 /5 /8" SWITCH - ROUTINES TO SET MAGTAPE DENSITY

D800:	MOVEI	D,1(D)		;DENSITY BITS = 11
D556:	MOVEI	D,1(D)		;DENSITY BITS = 10
D200:	MOVEI	D,1(D)		;DENSITY BITS = 01
DINSTD:	DPB	D,[POINT	2,INIT1,28]
	JRST	CPOPJ1		;RETURN AT SLENTR+1

;"/D" SWITCH - ENTER DDT

CALDDT:	SKIPE	A,.JBDDT	;DOES DDT EXIST
	JRST	(A)		;YES,GO TO IT
	PRLIN1	<$NO DDT@>
	JRST	CPOPJ1		;RETURN AT SLENTR+1

;"/M" SWITCH - DO A /S AT TIMES 00:00 + N*SLPMIN

MNYSAV:	PUSHJ	P,SAVE		;SAVE ENTIRE DISK
	JFCL			;RETURNS TO NEXT INSTRUCTION
	CALLI	A,MSTIME	;GET TIME IN MILLISECS
				;GET TIME IN MINUTES
	IDIVI	A,^D1000*^D60	;GET MINUTES TO NEXT SAVE INTO B
	IDIVI	A,SLPMIN	;NOW GET RESIDUE
SLP1:	MOVEI	A,^D60		;SLEEP ONE MINUTE
	CALLI	A,SLEEP
	SOJG	B,SLP1		;CONTINUE SLEEPING UNTIL B RUNS OUT
	JRST	MNYSAV		;WAKE UP & SAVE AGAIN

;"/J" SWITCH - JUMP TO THE BEGINNING OF THE NEXT SAVE SET

IFE	REWIND,<
JUMPSV:	SETZM	STARPT		;DOING A /J NULLIFIES OUR REMEMBERING
				;WHERE WE STARTED READING FROM ON THE TAPE
JMPSAV:	TRO	F,DOINGJ		;TURN ON /J FLAG
JMPINN:	PUSHJ	P,SETIN			;OOPS, NOT QUITE READY FOR INPUT
					;WE GOT HERE IF LAST DOING OUTPUT
					;OR INPUT DONE LAST, BUT CLOSE (AND POSSIBLY
					;A RELEASE !!!!!) DONE

JMP1:	PUSHJ	P,SKPTAP		;LOOK FOR SOMETHING LIKE A
					;DIRECTORY RECORD
					;(MIGHT BE A HEADER/TRAILER/OR DIRECTORY)
	MOVE	B,TAPHED
	HRRE	A,4(B)			;THIS A HEADER-TRAILER,  WHICH OF THE 2
	JUMPG	A,JMP1			;JUMP IF A HEADER
JMP4:	PUSHJ	P,GETEOF		;SKIP TO NEXT EOF
	AOS	JFLAG#		;UP /J COUNTER
	TRZ	F,DOINGJ	;TURN OFF /J
	JRST	RSTFBG		;RETURN
				;AFTER RESETTING
				;THAT YOU HAVE SEEN THE HEADER
				;RECORD FOR THIS
				;SAVE SET... YOU HAVE JUST SUCCESSFULLY
				;LEFT THIS SAVE SET


>
;SAVE OR RESTORE ONLY THOSE FILES CREATED ON OR LATER THAN
;DATE SPECIFIED IN /E COMMAND
;SAVE OR RESTORE ONLY THOSE FILES ACCESSED ON OR LATER THAN
;DATE SPECIFIED IN /F COMMAND

;IF /K IS USED WITH /S OR /U, TRANSFER ONLY THOSE FILES WHOSE ACCESS
;DATES ARE LESS THAN THAT SPECIFIED BY /F COMMAND.
;AND DELETE SUCH FILES FROM DISK.
;DON'T DO ANYTHING TO FILES BELONGING TO 1,1.
;COMMAND FORMAT IS

;/EMM/DD/YY,TTTT<CARRIAGE RETURN>

;WHERE MM = NUMERICAL MONTH (MAY BE SINGLE DIGIT)
;WHERE DD = NUMERICAL DAY (MAY BE SINGLE DIGIT)
;WHERE YY = TWO DIGIT YEAR
;WHERE TTTT = FOUR DIGIT MILITARY TIME

;IF COMMA IS TYPED,
;NULL DATE FIELD IMPLIES TODAY'S DATE
;NULL TIME FIELD IMPLIES 0000

;/E<CARRIAGE RETURN>  SETS TIME TO 1/1/64,0000

;D CONTAINS DECIMAL NUMBERS
;T CONTAINS TEMPORARY DATUM UNTIL COMMAND IS PROCESSED

;ON A /F COMMAND START AT SETACC AND SET A WORD WHICH IS COMPARED
;TO THE ACCESS DATE IN A LOOKUP BLOCK
;A NULL ARGUMENT WITHOUT COMMA SETS ACCESS DATE WORD TO 1/1/64
;A NULL ARGUMENT WITH COMMA SETS ACCESS DATE WORD TO TODAY'S DATE
;SET DATE AND TIME

;"/E /F" SWITCH
; ENTER AT SETACC ON /F
; ENTER AT SETCRE ON /E

SETACC:	TLO	F,ACCESS	;SET ACCESS DATE WORD ON /F
SETCRE:	SETZB	T,MONAT#
	SETZB	D,TAG#
				; FALL INTO GCHAR
;COMMAND INTERPRETER FOR /E OR /F COMMAND

G1CHAR:	MOVEI	D,0		;CLEAR D
GCHAR:	PUSHJ	P,TYI		;GET A CHAR
	MOVE	A,CH		;PROCESS IT IN A
	IDIVI	A,^D9		;SET UP FOR DISPATCH
	LDB	A,FS3(A+1)	;GET CHAR CODE
	CAIGE	A,6		;WHICH HALF OF THE TABLE ?
	SKIPA	B,CHRDSP(A)	;RIGHT HALF
	HLRZ	B,CHRDSP-6(A)	;LEFT ONE, NOW GET IT
	CAIN	CH,":"		;COLONS ARE NOT DIGITS		[44]
	MOVEI	B,GCHAR		; SO IGNORE IT		[44]
	CAIN	CH," "		;SPACES ARE IGNORED SO IT'S	[44]
	JUMPN	D,ILCH		; ILLEGAL AS A DATE TERMINATOR	[44]
	JRST	(B)		;NO, DISPATCH

;CHARACTER DISPATCH TABLE FOR /E OR /F COMMAND

CHRDSP:	XWD	ILCH,ILCH	;6,0
	XWD	ILCH,ILCH	;7,1
	XWD	ILCH,DIGIT	;10,2
	XWD	ACOMMA,ILCH	;11,3
	XWD	SLA,GCHAR	;12,4
	XWD	TERM,ILCH	;13,5

;COMPILE DECIMAL NUMBERS

DIGIT:	IMULI	D,^D10		;MUL LAST DIGIT BY 10
	ADDI	D,-60(CH)	;ADD DECIMAL VALUE OF NEW DIGIT
	JRST	GCHAR		;GET NEXT CHARACTER

;GET MONTH OR DAY PRECEDING SLASH

SLA:	SKIPE	MONAT		;DO WE HAVE MONTH YET?
	JRST	SLADAY		;YES, GO CHECK DAY
	JUMPE	D,COMERR	;NO, D = 0 IMPLIES COMMAND ERROR
	CAILE	D,^D12		;MONTH IN RANGE?
	JRST	NUMOUT		;NO, ERROR
	MOVEM	D,MONAT		;YES, SAVE VALUE
	JRST	G1CHAR		;GET NEXT CHARACTER

SLADAY:	SKIPE	TAG		;DO WE HAVE DAY YET?
	JRST	COMERR		;YES, COMMAND ERROR
	JUMPE	D,COMERR	;NO, VALUE = 0 IMPLES COMMAND ERROR
	CAILE	D,^D31		;DAY IN RANGE?
	JRST	NUMOUT		;NO, ERROR
	MOVEM	D,TAG		;SAVE VALUE
	JRST	G1CHAR		;GET NEXT CHAR
;PROCESS /E OR /F FIELD TERMINATORS

;COMMA SEPARATES DATE FROM TIME

ACOMMA:	PUSHJ	P,GETDAT	;COMPILE DATE
	TLNN	F,ACCESS	;/F OR /E?
	JRST	GCHAR		;/E, GO LOOK FOR TIME
ACOMM3:	MOVEM	T,ACCDAT	;/F, SAVE ACCESS DATE
	JRST	FS1AA		;GET NEXT COMMAND

;CARRIAGE RETURN TERMINATES /E OR /F

TERM:	JUMPN	T,.+2		;IF WE HAVE DATE ALREADY, GET TIME
	PUSHJ	P,GETDAT	;COMPILE DATE
	IDIVI	D,^D100		;GET HOURS IN D, MINUTES IN U
	IMULI	D,^D60		;CONVERT HOURS TO MINUTES
	ADD	D,U		;TOTAL MINUTES
	CAIL	D,^D24*^D60	;LESS THAN ONE DAY?
	JRST	NUMOUT		;NO, OUT OF RANGE
	LSH	D,^D15		;MOVE TO TIME FIELD
	ADD	T,D		;COMBINE TIME WITH DATE
	TLNE	F,ACCESS	;/F OR /E?
	JRST	ACOMM3		;/F
	MOVEM	T,CRDATE	;/E
	JRST	FS1AA		;RETURN FOR NEXT COMMAND

;COMPILE DATE

GETDAT:	SKIPE	TAG		;DAY SPECIFIED?
	JRST	GETDA1		;YES, COMBINE MONTH & YEAR
	SKIPN	MONAT		;NO, HAS MONTH BEEN SPECIFIED?
	JUMPN	D,COMERR	; OR YEAR?
				;PARTIAL DATE
	CAIN	CH,","		;IF TERM. CHAR. WAS CR, LEAVE T=0
	CALLI	T,DATE		;NULL DATE WITH COMMA IMPLIES TODAY
	POPJ	P,
GETDA1:	SKIPE	MONAT		;MONTH SPECIFIED?
	JUMPE	D,COMERR	; OR YEAR?
				;PARTIAL DATE
	SUBI	D,^D64		;SUBTRACT BASE YEAR (1964)
	JUMPL	D,NUMOUT	;YEAR OUT OF RANGE
	IMULI	D,^D12		;CALCULATE DATE: YEAR*12
	SOS	MONAT		;MONTH-1
	ADD	D,MONAT
	IMULI	D,^D31		;((Y-64)*12+M-1)*31
	SOS	T,TAG		;DAY-1
	ADD	T,D
	SETZ	D,		;CLEAR NUMBER REGISTER
	POPJ	P,
;"/G" SWITCH - GET PROJECT-PROGRAMMER NUMBER
;TO ALLOW /U OR /L OR SELECTIVE RESTORE
;ON AN AREA DIFFERENT FROM HIS OWN

AREA:	SETZB	D,SLGPPN	;INIT
AREA0:	PUSHJ	P,TYI		;GET CHAR FOLLOWING /G
	MOVE	A,CH		;(JUST LIKE GCHAR)
	IDIVI	A,11
	LDB	A,FS3(A+1)
	CAIGE	A,6		;WHICH 1/2 OF DISPATCH TABLE ?
	SKIPA	B,ARADSP(A)	;RIGHT
	HLRZ	B,ARADSP-6(A)
	JRST	(B)

;CHARACTER DISPATCH TABLE FOR /G

ARADSP:	XWD	ILCH,ILCH	;6,0
	XWD	ILCH,ILCH	;7,1
	XWD	ILCH,ADIGIT	;10,2
	XWD	ARACOM,ILCH	;11,3
	XWD	ILCH,AREA0	;12,4
	XWD	ATERM,ILCH	;13,5

;COMPILE NUMBRS FOR /G

ADIGIT:	IMULI	D,10		;PREVIOUS * 8
	ADDI	D,-60(CH)	;+ NEW
	JRST	AREA0

;STORE PROJECT # WHEN COMMA SEEN

ARACOM:	HRLZM	D,SLGPPN
	SETZ	D,
	JRST	AREA0

;STORE PROGRAMMER # WHEN CR SEEN

ATERM:	HRRM	D,SLGPPN
	XLIST
	IFN	PRIVL,
	<LIST
	MOVE	D,USRPPN		;CHECK OUT TO SEE IF WE SHOULD
				;ALLOW USER TO PLAY
	CAMN	D,FSPP		;FAILSAFE PROJECT PROGRAMMER NO
				;MAY TRY ANYHTING
	JRST	FS1AA		;ANDRETURN
	CAME	D,SLGPPN		;WELL, IF NOT FAILSAFE
	JRST	OHNO		;SEE IF HE IS TRYING TO GET HIMSELF
	LIST
	>
	LIST
	JRST	FS1AA		;RETURN FOR NEXT COMMAND
;"/O" SWITCH - WRITE FILES ON THIS PPN'S DSK AREA

SLOSWT:	SETZB	D,SLOPPN		;ZERO OUT BOTH
OSLASH:	PUSHJ	P,TYI			;GET SOME INPUT
	MOVE	A,CH			;SAVE WHAT YOU  GOT
	IDIVI	A,^D9			;DIVIDE BY 9
	LDB	A,FS3(A+1)		;COPIED DIRECTLY FROM /G
	CAIGE	A,6
	SKIPA	B,SLASHO(A)
	HLRZ	B,SLASHO-6(A)
	JRST	(B)


;CHARACTER DISPATCH TABLE FOR /O

SLASHO:	XWD	ILCH,ILCH		;6,0
	XWD	ILCH,ILCH		;7,1
	XWD	ILCH,DIGGIT		;10,2
	XWD	COMMER,ILCH		;11,3
	XWD	ILCH,OSLASH		;12,4
	XWD	TERMAL,ILCH		;13,5



DIGGIT:	IMULI	D,10
	ADDI	D,-60(CH)
	JRST	OSLASH

COMMER:	HRLZM	D,SLOPPN
	SETZ	D,
	JRST	OSLASH


TERMAL:	HRRM	D,SLOPPN
	XLIST
	IFN	PRIVL,
	<
	LIST
	MOVE	D,USRPPN
	CAMN	D,FSPP		;IF FAILSAFE IS RUNNING, LET HIM DO
				;ANYTHING
	JRST	FS1AA		;AOK
	CAME	D,SLOPPN		;HE CAN ONLY OVERWRITE HIMSELF
	JRST	OHNO
	>
	LIST
	CAME	D,SYSPP		;SEE IF THIS GUY IS TRYING
				;SOMETHING FUNNY WITH 1,1

	JRST	FS1AA			;RETURN FOR NEXT COMMAND

	PRLIN1	<?ONLY 1,2 MAY ACCESS THE MFD,#>
	JRST	NONO

	XLIST
	IFN	PRIVL,<
	LIST
OHNO:	PRLIN1	<?ONLY 1,2 MAY ACCESS OTHER USERS' FILES,#>
	>
	LIST
NONO:	MOVE	TMP,USRPPN
	PUSHJ	P,PRPPN1		;PRINT OUT PR-PPN
	JRST	REINFO
SUBTTL ***SAVE CODE***
;"/U" SWITCH - SAVE COMMAND EXECUTION

USAVE:	TRO	F,USRSW		;SINGLE USER SAVE
				;NOW CHECK FOR /G PPN = /O PPN
	MOVE	A,SLGPPN
	CAMN	A,SLOPPN
	JRST	SAVE1		;/G=/O....
	PRLIN1	<SAVING#>
	MOVE	TMP,SLGPPN
	PUSHJ	P,PRPPN1
	PUSHJ	P,CRLF		;BUG POINTED OUT IN QAR
	JRST	SAVE1

;"/S" SWITCH

SAVE:	CALLI	A,GETPPN
	  JFCL			;BE DEFENSIVE
	CAME	A,FSPP		;LOGGED IN AS 1,2?
	JRST	NOTFS		;NO, TELL USER
SAVE1:	TRO	F,SAVSW		;/S IN PROGRESS
	TRZ	F,RESTSW	;TURN OFF IN CASE OF /C
	IFE	REWIND,<	SETZM	JFLAG		;CLEAR /J CTR
	>
	SETZM	TAPNUM#		;FIRST TAPE IS #1
	SETZM	DSKNAM		;CLR DSKNAM BLK
	MOVE	A,[XWD DSKNAM,DSKNAM+1]
	BLT	A,DSKNME-1
	MOVE	A,[POINT 6,DSKNAM]	;SET SEMI-DYNAMIC POINTER
	MOVEM	A,DSKNPT#
	HRROI	Q,-NUMSTR	;NAME STORE CTR

;DISPATCH ROUTINE FOR READING FILE STRUCTURE NAMES AFTER /S,/U

SAVLST:	HRROI	R,-6		;NAME CHAR CTR
	MOVE	S,DSKNPT	;NAME STORE PTR
SAVLS0:	PUSHJ	P,TYI		;JUST LIKE GCHAR
	MOVE	A,CH
	IDIVI	A,11
	LDB	A,FS3(A+1)
	CAIGE	A,6
	SKIPA	B,STRDSP(A)
	HLRZ	B,STRDSP-6(A)
	JRST	(B)

STRDSP:	XWD	ILCH,ILCH	;6,0
	XWD	ILCH,SCHAR	;7,1
	XWD	ILCH,SCHAR	;10,2
	XWD	SCOMMA,ILCH	;11,3
	XWD	ILCH,SSPACE	;12,4
	XWD	STERM,ILCH	;13,5
;IGNORE SPACE OR TAB AFTER /S,/U

SSPACE:	CAIE	CH,11		;TAB?
	CAIN	CH,40		;SPACE?
	JRST	SAVLS0		;YES
	JRST	ILCH		;OTHERWISE, BAD CHAR

;STORE CHARACTER OF FILE STRUCTURE NAME

SCHAR:	AOJG	R,SAVLS0	;IGNORE AFTER 6TH
	MOVEI	CH,-40(CH)	;MAKE 6-BIT
	CAIE	CH,32		;IS IT A : ?
	IDPB	CH,S		;STORE IN DSKNAM
	JRST	SAVLS0

;FILE STRUCTURE DELIMITER

SCOMMA:	AOS	DSKNPT		;MOVE PTR TO NEXT WORD
	AOJL	Q,SAVLST	;GET NEXT
	JRST	TOOMNY


					;NOW CHECK /U
ASLUSV:	CAME	D,SLGPPN		;IF /G NOT = PPN RUNNING THIS
					;JOB, THEN JOBSTR NOT GOING TO WORK
					;SO USE SYSSTR,,  TO RETURN ALL STRUCTURES IN SYSTEM
					;YOU CANNOT GET THE SEARCH LIST OF
					;A JOB NOT LOGGED IN, SO YOU MUST
					;USE SYSSTR
					;ASSUMPTION:
					;YOU CAN ALWAYS JOBSTR ON YOUR OWN
					;PPN
					;BECAUSE TO DO SO, YOU MUST BE RUNNING

	JRST	STRLUP			;HAVE TO USE SYSSTR



	MOVE	CH,[1,,U]		;SET UP FOR JOBSTR UUO
					;1ST THEN SUBSEQUENT FILES
JOBLUP:	CALLI	CH,JOBSTR
	JRST	BEGSAV			;ALL THROUGH
	AOJE	U,BEGSAV		;DONE IF -1 IS RETURNED
	SUBI	U,1			;  RESTORE U
	MOVEM	U,(R)
	JUMPE	U,BEGSAV		;THROUGH
	AOBJN	R,JOBLUP
	JRST	BEGSAV			;THROUGH
;FILE STRUCTURE LIST TERMINATOR

STERM:	SKIPE	B,DSKNAM		;DSK STR NAMES EXPLICITLY GIVEN?
					;CLEAR B IF DSKNAM = 0
	JRST	BEGSAV		;YES
	MOVE	R,[XWD	-NUMSTR,DSKNAM]
				;NO GET ALL NAMES WITHIN SYSSTR UUO
	MOVSI	A,(SIXBIT /DSK/)	;DEFAULT = "DSK"
	MOVEM	A,DSKNAM
				;START WITH AC = 0<1ST STRUCTURE>
	SETZM	DSKNAM+1	;AND MARK THE END OF THE LIST
	SETOI	U,			;1ST THEN SUBSEQUENT STRUCTURES
	MOVE	D,USRPPN		;LOAD D WITH JOB RUNNING US
					;USED BY SEVERAL ROUTINES
	TRNE	F,USRSW			;IS THIS /S OR /U ?
					;/S = SAVSW 
					;/U = SAVSW&USRSW
	JRST	ASLUSV			;A SLASH U SAVE

					;SKIPE AT STERM LOADED B WITH 0
					;IF WE GOT HERE.. NOW, GET
					;1ST THEN SUBSEQUENT NAMES
STRLUP:	CALLI	B,SYSSTR		;GET 1ST & SUBSEQUENT STR IS SYS
					;SEARCH LIST
	  JRST	BEGSAV			;ERROR

	TRNE	F,USRSW		;/U SAVE ?
	JRST	[		CAME	D,FSPP		;ONLY 1,2
				JRST	X			;SHOULD DO
				JRST	Y	]		;A /U ON A
								;SINGLE ACCESS FILE
								;STRUCTURE
X:	MOVE	U,B		;SETUP U FOR DSKCHR	[42]
	MOVE	A,[XWD 1,U]
	CALLI	A,DSKCHR	;GET DISK CHARACTERISTICS	[42]
	JFCL			;WE KNOW IT'S THERE
	TLNE	A,.UPSAF	;PRIVATE PACK?
	JRST	STRLUP		;YES, SAVE ONLY PUBLIC PACKS
				;IF DOING A /S (SYSTEM SAVE) OR IF /U & NOT 1,2
Y:	MOVEM	B,(R)		;PUT NAME ON LIST
	JUMPE	B,BEGSAV	;THROUGH
	AOBJN	R,STRLUP
BEGSAV:	SETZM	STRNDX#		;INIT INDEX TO DSKNAM BLK
	TLO	F,FIRSW		;INDICATE FIRST TAPE
	MOVEM	P,SAVMFD#	;SAVE PDP FOR ENDTAP

	;FALL INTO SAVE2
;START A NEW TAPE

SAVE2:	PUSHJ	P,GETCOR		;FIRST TAPE NEEDS CORE + INIT
OTHERS:	PUSHJ	P,SETOU			;OTHER TAPES NEED INIT

	IFN	REWIND,<	EMTAPE	1		;REWIND THE MAGTAPE
	>
	IFN	LOCK,<
	MTAPE	TAP,0		;IF LOCK OPTION ASSEMBLED
				;INSURE THAT WE CAN GET TO MAG TAPE BEFORE
				;TRYING TO LOCK SO THAT SLEEP DURING REWIND
				;AND THEREFORE SWAPPING OF THIS JOB POSSIBLE

	MOVEI	TMP,1		;SET UP FOR POSSIBLE LOCK UUO
				;SAY WE HAVE ONLY THE LOW SEGMENT
	TLNE	F,LOCKER		;NO /V, NO ATTEMPT TO LOCK
	CALLI	TMP,LOKUUO
	JRST	PSEUDL		;SKIP AROUND LOCKED MESSAGE

	PRLIN1 <LOCKED@>

	>

PSEUDL:	SETZM	FNDBEG		;RESET FOUND HEADER RECORD FLAG
	PUSHJ	P,LOOKDT	;GET DATE & TIME RETURNED IN AC A
	SKIPGE	FIRBLK+3	;CONTINUE TAPE BIT SET IN LAST TRAILER?
	TLO	A,400000	;YES, KEEP IT IN THIS HEADER
	MOVEM	A,FIRBLK+3	;STASH AWAY IN HEADER LABEL
	PUSHJ	P,DAYTIM	;PRINT THEM OUT
	PUSHJ	P,TAPNO		;PRINT TAPE NUMBER
	AOS	A,TAPNUM		;INCREMENT TAPE NUMBER
	HRRM	A,FIRBLK+2		;PLACE CUM. TOTAL IN HEADER
	PUSHJ	P,PRNUM
	PUSHJ	P,SPACE
	MOVEI	CH,"@"
	PUSHJ	P,TYPEA
	PUSHJ	P,SPACE

	PUSHJ	P,LABBLT	;WRITE OUT HEADER
	TLNN	F,FIRSW		;FIRST TAPE ?
	JRST	TAPMES		;NOPE

	PUSHJ	P,TAPMES	;PUT TAPE BPI &
				;CHANNEL # OUT ONLY AFTER
				;YOU ARE SURE THERE HAS BEEN AN INTERRUPT
				;SO THAT THE DEVSTS UUO WORKS PROPERLY

	JRST	SAVE0		;FIRST TAPE PROCEEDES
TAPMES:	MOVEI	B,TAP		;GET TAPE INFO.
	DEVSTS	B,0			;SEE IF DEVSTS WILL RETURN INFO
					;ON CHANNELS
					;NO
	JRST	NOTELL			;NOT IMPLEMENTED
TELLCH:	MOVEI	CH,"7"
	TRNN	B,TRACK7				;CHECK 7 CH BIT
	MOVEI	CH,"9"		;OOOPS, 9 - TRACK

	PUSHJ	P,TYPEA
	PR1	< CH &#>
				;
NOTELL:	MOVEI	A,TAP		;GET DENSITY EITHER FROM CALLI
				;OR
	CALLI	A,MTCHR.
	LDB	A,[POINT 2,INIT1,28]	;ERROR SO GET DENSITY BITS FROM THE INIT
	ANDI	A,3		;STRIP OFF
				;

	MOVE	B,BPITXT(A)
	PUSHJ	P,PR3CHR			;GIVE BPI SEETING
	PR1	< BPI@>
	POPJ	P,


BPITXT:	SIXBIT	/STD   /
	SIXBIT	/200   /
	SIXBIT	/556   /
	SIXBIT	/800   /




	;RETURN IN (A) TIME, BITS 4-20, AND DATE, 21-35
LOOKDT:	CALLI	A,MSTIME		;TIME IN JIFFIES
	IDIVI	A,^D1000		;BASH A+1 WITH REMAINDER
	CALLI	B,DATE			;LOAD BASHED AC WITH DATE
	ANDI	B,377777		;ALL BUT THE SIGN BIT, PLEASE
	LSH	A,^D15			;MAKE ROOM FOR DATE
					;SHIFT LEFT 15 DECIMAL
	IORI	A,(B)			;SIGN BIT IS FREE, BUT TIME AND
					;DATE FILL REST OF WORD
	POPJ	P,			;
					;0-CONTINUATION BIT
					;4-20 TIME (HRS:MIN:SEC
					;21-35 DATE
TAPNO:	MOVE	B,[SIXBIT	/TAPE #/]
	PUSHJ	P,PRNAME
	JRST	SPACE
;LOOP TO SAVE EACH FILE STRUCTURE ON LIST

ENDMFD:	AOSA	A,STRNDX		;BUMP POINTER INTO NAMES TABLE
SAVE0:	MOVE	A,STRNDX	;GET NEXT NAME
	SKIPN	A,DSKNAM(A)	;GET NAME IF NOT NULL
	JRST	ENDMF0	;NULL NAME.. THROUGH

	MOVEM	A,CURSTR	;SAVE NAME
	MOVEM	A,ACTSTR	;ACTIVE FILE STRUCTURE
				;CURSTR IS THE NAME OF THE CURRENT STRUCTURE
				;ACTSTR = BY DEFINITION CURSTR, EXCEPT
				;THAT IT IS IN MFDSPK FOR THE OPEN ON MFD

	MOVEI	A,MFDHED
	MOVEM	A,MFDSPK+2
	OPEN	MFD,MFDSPK	;WANT TO READ MFD FOR THIS STR
	JRST	NOMFD		;HAVE TO SKIP THIS ONE
	MOVEI	A,MFDBUF	;SET UP BUFFERS
	MOVEM	A,.JBFF
	INBUF	MFD,MFDN
	MOVE	A,SYSPP		;LOOK FOR MFD
	MOVEM	A,MFDDIR+3	;IN THE MFD
	MOVEM	A,MFDDIR
	MOVSI	A,(SIXBIT /UFD/)
	MOVEM	A,MFDDIR+1
	SETZM	MFDDIR+2	;ERROR BITS, ETC GO AWAY
	LOOKUP	MFD,MFDDIR	;(OLD STYLE LOOKUP)
	JRST	BADMFD		;NOT ALL TOGETHER THERE
	MOVEM	P,SAVUFD#	;SAVE PDP FOR ENDUFD
MORE1:	PUSHJ	P,MFD2		;GET TWO WORDS FROM MFD
	HLRZ	W,W		;SECOND WORD
	CAIE	W,(SIXBIT /UFD/)	;IS HE A UFD?
	JRST	MORE1		;NO, TRY AGAIN
	TRNE	F,USRSW		;SINGLE USER SAVE?
	CAMN	U,SYSPP		;1,1.UFD?
	JRST	MORE6
	CAME	U,SLGPPN	;USER UFD?
	JRST	MORE1		;NO


MORE6:	MOVE	A,SLOPPN		;SEE IF /GPPN = /O PPN
	CAME	A,SLGPPN		;=?
	CAME	U,A			;/O NOT = /G
					;POSSIBILITY OF DUPLICATE UFD ENTRIES
					;IN MFD EXISTS, CHECK FURTHER
					;IS UFD PRESENTLY IN HAND (IN U)
					;THE SAME AS THE ONE TO BE BUILT
					;OUT OF THE /G /O SEQUENCE?
					;THEN (IF SO) TWO UFD'S
					;COULD BE WRITTEN ON THE
					;TAPE, THE ORIGINAL ONE AND
					;THE ONE CREATED BY THE /G/O PROCESS
MORE6A:	SKIPA	A,CURSTR		;ONE IN HAND NOT THE
					;SAME AS THE /O FELLOW
					;OR /G AND /O ARE THE SAME
	JRST	MORE1		;WHAT HO, AVAST! TWO UFD'S WILL BE
				;CREATED IF WE DON'T SKIP ONE
				;SKIP THIS ONE!


	MOVEM	A,MORE61
	MOVEM	A,MORE72	;SETUP DEVICE NAMES
	MOVEM	U,UFDDIR+2	;YES, LET'S HAVE A LOOKUP AT IT
	MOVEM	U,DGADIR	;PROJECT-PROGRAMMER # INTO 4-WORD ENTRY
				;HEADING
	INIT	UFD,BUFBIN	;IS IT AVAILABLE
MORE61:	SIXBIT	/DSK/
	XWD	0,UFDHED	;INPUT ONLY
	PUSHJ	P,LOOKER	;DISP. CORRECTLY AFTER ERROR MSG.


	MOVEI	A,UFDBUF	;GET BUFS
	MOVEM	A,.JBFF
	INBUF	UFD,UFDN


	MOVE	A,SYSPP		;LOOK FOR UFD
	MOVEM	A,UFDDIR+1	;IN THE UFD
	MOVEM	A,FILDIR+1	;AND INTO THE FILE NAME'S OWNER SLOT
				;THIS IS TO CUE THE PRNMEX ROUTINE
				;THAT IT SHOULD LOOK AT UFDDIR FOR THE
				;FILE'S NAME
	MOVEI	A,XLOOKN	;EXT. LOOKUP
	MOVEM	A,UFDDIR
	MOVSI	A,(SIXBIT /UFD/)
	MOVEM	A,UFDDIR+3
	TRO	F,UFDI		;UFD INPUT MODE FOR REENTER
	LOOKUP	UFD,UFDDIR	;IS IT STILL THERE
	PUSHJ	P,LOOKER	;ERROR RECOVERY ROUTINE


	TDZ	F,[XWD	FILFND,UFDI]	;NO FILES SAVED YET FOR THIS USER,,OUT OF UFD INPUT STATE



	SETZM	ONEFIL#		;OPEN SWITCH FOR AUXILLIARY CHANNEL

	MOVEM	P,SAVFIL#	;REMEMBER PDP FOR ENDFIL
MORE2:	PUSHJ	P,UFD2		;GET TWO WORDS FROM UFD
	HLRZ	W,W		;SECOND WORD LH
	CAIE	W,(SIXBIT /TMP/)	;TEMPORARY?
	CAIN	W,(SIXBIT /SFD/)	;OR AN SFD
	JRST	MORE2		;YES, DONT DUMP

;IF NO, FALL INTO MORE5
MORE5:	MOVEI	A,XLOOKN	;EXT. LOOKUP
	MOVEM	A,FILDIR
	MOVEM	U,FILDIR+2	;FIND THE FILE
	HRLZM	W,FILDIR+3
	MOVE	A,UFDDIR+2	;PROJ-PROG NUMBER
	MOVEM	A,FILDIR+1
	TRNE	F,USRSW		;SINGLE USER SAVE?
	CAME	A,SYSPP		;1,1?
	JRST 	MORE7		;MASS(/S) SAVE AND NOT 1,1
	CAIN	W,(SIXBIT /UFD/)	;UFD?
	CAME	U,SLGPPN		;PERSON TO BE GOTTEN ?
				;OR SINGLE USER SAVE
	JRST	MORE2		;NO, DON'T SAVE

				;NOW SEE IF /G PPN = /O PPN
				;IF SO, SAVE, AS NO DUPLICATION
				;OF UFD'S CAN RESULT THIS WAY
				;IF
				;ON THE OTHER HAND, /G NOT = /O,
				;CHECK TO SEE IF THIS FELLOW (IN U)
				;IS THE /O PPN.  IF SO, THE /G/O
				;PROCESS WILL DO THE SAVE OF /O
				;(CREATING /O FROM /G, EXPRESSED OR
				;IMPLIED).  IF U=SLOPPN, DON'T
				;SAVE AS A DUPLICATION WILL RESULT
MORE7:	MOVE	A,SLOPPN		;SEE IF/G=/O
	CAME	A,SLGPPN		;SKIP IF =
	CAME	U,A		;/O NOT = /G, SO IS THIS FELLOW THE /O GUY TO BE

	SKIPA	A,CURSTR	;DO THE INIT ON THE RIGHT STR
	JRST	MORE2		;SKIP DUPLICATE SAVE!!!!!!!!
	MOVEM	A,MORE71
	INIT	FIL,BUFBIN	;SET TO GET FILE
MORE71:	SIXBIT	/DSK/
	XWD	0,FILHED	;INPUT ONLY
	PUSHJ	P,LOOKER	;DISK NOT THERE
	PUSHJ	P,GETFBF	;GET BUFS FOR FILE
	INBUF	FIL,(CH)	;NUMBER OF BUFFERS RETURNED IN CH
	TRO	F,FILI		;ENTER FILE INPUT STATE
	LOOKUP	FIL,FILDIR	;IS IT THERE?
	PUSHJ	P,LOOKER	;GO TO SEE WHY LOOKUP FAILED(RTN TO MORE2)
	TRZ	F,FILI		;EXIT FROM FILE INPUT STATE
	SKIPN	ONEFIL		;IS THIS THE FIRST TIME THRU THE
				;USER ?  IF SO,
				;OPEN UP A SHADOW CHANNEL
				;ON ANY ONE FILE (IN THIS CASE, WE PICK
				;THE FIRST) IN HIS UFD.
				;
				;
				;THIS CAUSES THE UFD INFORMATION TI REMAIN
				;IN CORE
				;REDUCING THE NUMBER OF SEEKS
				;
	PUSHJ	P,KINCOR	;FIRST TIME THRIUGH, KEEP
				;INFORMATION IN CORE
				;BY OPENING UP AUXILLIARY CHANNEL
	MOVE	A,FRBSTS	;GET FILE STATUS
	TRNE	A,.RPNFS	;DO-NOT-SAVE BIT ON?
	JRST	MORE2		;YES
				;GOT A GOOD FILE TO SAVE
	XLIST
	IFG	ALPJ1S,
	<
	LIST
	HLRZ	A,FILDIR+1
	SOJE	A,UNCONS		;IT'S PROJECT 1
	>
	LIST

	XLIST
	IFG	ALFLEX,
	<
	LIST
	HRRZ	A,FILDIR+.RBSIZ	;GET # OF WORDS WRITTEN
	CAIG	A,ALFLEX		;A IS + OR ZERO AT THIS TIME
	JRST	UNCONS			;IS + OR 0 FOR JUMPL TO FAIL TO JUMP

	>
	LIST
	LDB	S,[POINT 3,CRDATE,23]	;INITALIZE R,S,U + W FOR CHKCRE
	LDB	W,[POINT 3,FILDIR+3,20]
	MOVE	R,CRDATE
	MOVE	U,FILDIR+4		;IS FILE NEWER THAN SET TIME AND DATE ?
	PUSHJ	P,CHKCRE
	 JRST	[LDB	W,[POINT 3,FILDIR+3,20]	;[47]BRING
		LDB	U,[POINT 12,FILDIR+4,35];[47] CREATION
		LSH	W,14		;[47] DATE
		IOR	U,W		;[47] TOGETHER
		CAIE	U,10000		;[47] DATE = 1/5/75 OR
		CAIGE	U,2134		;[47] LESS-THAN 1/1/67 ?
		CAIA			;[47] YES - SAVE THE FILE
		JRST	MORE2		;[47] CRDATE .GT. FILE'S CREATE-DATE
		SETZ	A,		;[47] TO PASS ACCESS DATE CHECK
		JRST	UNCONS	]	;[47] SAVE IT
	 JFCL				;DATES ARE EQUAL
	LDB	A,[POINT 15,FILDIR+3,35]	;GET ACCESS DATE OF FILE
							;/F CRITERIA
	CAIE	A,10000		;[47] IF DATE = 1/5/75 OR
	CAIGE	A,2134		;[47] OR LESS-THAN 1/1/67
	JRST	UNCONS		;[47] SAVE FILE ELSE
	SUB	A,ACCDAT	;COMPARE TWO DATES
UNCONS:	TLNN	F,KILLSW	;ARE WE IN KILL MODE?
	JRST	MORE10		;NO
;UNCONS+2 REPLACED 4 INSTRUCTIONS WITH THE FOLLOWING 2 [37]
	HLRZ	B,UFDDIR+2	;[37] GET THE PROJECT #
	CAIGE	B,10		;[37] IGNORE IF < 10
	JRST	MORE2		;DONT XFER ANY PROJECT .LT. 10	[46]

;CUSPPN+2 INSERTED 2 NEW INSTRUCTIONS [EDIT#32] SPR:10-11,965
	JUMPGE	A,MORE2		;DO NOT SAVE IF RECENTLY USED	[ED#32]
	JRST	.+2		;OLD FILE - SAVE & DELETE	[ED#32]
MORE10:	JUMPL	A,MORE2		;IF A 0 OR + SAVE FILE
				;SAYS THAT ACCESS DATE CRITERIA FROM
				;SWITCH & DISK IS O.K. FOR SAVE
				;OR THIS IS SAVE OF PROJECT 1,,*
				;OR THAT A FILE LESS THAN OR = TOLERANCE
				;IS BEING CONSIDERED

	PUSHJ	P,DIRBLT	;BLT DIRECTORY INTO TAPE BUFFER
	SETZM	RECCNT		;RESET # RECORDS OUTPUT SINCE LASST
				;EOF OR DIRECTORY RECORD
	HLRZ	W,FILDIR+3
	CAIN	W,(SIXBIT /UFD/)	;UFD FILE?
	JRST	ENDFLA		;YES, SAVE ONLY LOOKUP INFO
	TLO	F,FILFND	;FOUND US A FILE FOR THIS USER
;******************______________*****************************
	SKIPN	PAKFRE,FILHED+2		;SEE IF WE HAVE SOME INPUT
	JRST	ACFIL2			;GUESS NOT
	SKIPN	PAKNAM,TAPHED+2		;GET WORD COUNT
	JRST	ACTAP2			;OOPPS.. NO WORD COUNT
					;REFRESH IT
FASTAC:	HRLZ	S,FILHED+1
	HRR	S,TAPHED+1		;FROM,,TO
					;WHAT WE ARE ABOUT TO DO
		;IS AS FOLLOWS
		;BLT FROM INPUT BUFFER TO OUT BUFFER
		;THE LESSER OF THE 
		;TWO WORD COUNTS
		;UPDATE THE BYTE POINTERS
		;AND WORD COUNTS
		;AND CONTINUE

FAST:	CAIGE	PAKNAM,(PAKFRE)		;IF TAPE BUFFER IS
					;BIGGER (CAN TAKE MORE THAN DISK CAN GIVE)
					;BLT AS MUCH AS THE DISK HAS
	SKIPA	WASTE,PAKNAM		;SET TO TAPE AS SMALLER
					;WORD COUNT
					;OOOPS, NOT ENOUGH ROOM
					;IN DISK BUFFER,
					;SO ONLY BLT AS MUCH AS DISK
					;CAN GIVE YOU
	MOVEI	WASTE,(PAKFRE)		;SET UP INDIRECT ADDRESS TO
					;POINT TO TERMINAL WORD OF XFER
	HRRM	S,ACFAST		;GET POINTER TO CONTENTS OF TAPHED+1
					;# WORDS XMIT'ED =
					;E -AC(RIGHT)+1
	;WORDS XMIT'ED = [(PAKFRE) OR (PAKNAM) <WHICH IS IN RIGHT HALF OF WASTE>]+
	;[BITS 18-35 OF ACFAST:]
	;WHICH IS THE CONTENTS OF TAPHED + 1
	;=EFFECTIVE ADDRESS, E_
	;
	;-(AC <RIGHT HALF>) = CONTENTS OF <TAPHED +1>  + 1
;	SO THAT..
	;E[(TAPHED+1) + #WORDS WHICH CAN BE TRANSFERRED
	;-(AC<RIGHT>=(TAPHED+1)+1)
	;+1
	;
	;OR
	;[(TAPHED+1) + MINIMUM OF THE TWO WORD COUNTS -<(TAPHED+1)+1>+1]=# WORDS TO BLT'ED
	;WHICH IS...
	;[(TAPHED+1)-(TAPHED+1)-1  +1] +[MINIMUM OF THE TWO WORD COUNTS]
	;
	;THE MINIMUM OF THE TWO WORD COUNTS IS FROM EITHER
	;PAKNAM OR PAKFRE, BUT IS  LEFT IN  WASTE!
	;SO THAT IN THE END........
	;WORDS XMIT'ED = [(PAKNAM) OR (PAKFRE)]
					;WHICH WILL BE BUMPED BY 1
					;TO SIMULATE THE INCREMENT
					;OF AN ILDB/IDPB 
	AOBJP	S,ACFAST		;BUMP AWAY
					;WHICH IS WHERE BLT STARTS TO
ACFAST:	BLT	S,0(WASTE)		;BLT UNTIL YOU HAVE XMIT'ED
					;TO FLOOR LIMIT OF THE
					;TWO WORD COUNTS
					;BUT FIRST BUMP BOTH BYTE POINTERS
					;BY NUMBER OF WORDS MOVED
					;SO WE CAN
	SUBI	PAKNAM,(PAKFRE)		;GET HOW MANY WORDS LEFT AFTER BLT
	JUMPGE	PAKNAM,ACFIL		;PAKFRE IS = OR LESS THAN
					;PAKNAM, THEREFORE
					;PAFKRE (DISK FILE) RAN OUT FIRST
	MOVNM	PAKNAM,FILHED+2		;YOU SUBTRACTED
					;SMALLER FROM LARGER.... OH WELL,
					;MOVE THE NEGATIVE OF THE - NUMBER
					;INTO WORD COUNT FOR BUFFER
					;HEADER
	SETZM	TAPHED+2		;WE USED ALL  WORD COUNT
	ADDM	WASTE,FILHED+1		;REPOINT FILE HEADER TO
					;REFLECT BLT

ACTAP2:	PUSHJ	P,TAPOUT		;OUT TO TAPE
	SKIPN	PAKFRE,FILHED+2		;SAY, DID THE DISK RUN DRY JUST
					;AS THE TAPE FILLED UP
	JRST	ACFIL2			;YEP
	HRRZ	PAKNAM,TAPHED+2
	JRST	FASTAC
ACFIL:	HRRZM	PAKNAM,TAPHED+2		;AND SAVE IT
	ADDM	WASTE,TAPHED+1		;REPOINT TAPHED TO REFLECT BLT
ACFIL2:	PUSHJ	P,FILIN
	SKIPN	PAKNAM,TAPHED+2		;DID THE  TAPE FILL UP JUST
					;AS THE DISK RAN DRY ?
	JRST	ACTAP2			;YEP!
	HRRZ	PAKFRE,FILHED+2		;GET REFRESHED DISK WORD COUNT
	JRST	FASTAC
;**********************_____________*********************
KINCOR:	MOVE	A,[XWD	FILDIR+2,DGADIR]	;COPY INFORMATION FROM FILDIR
				;(EXTENDED LOOKUP) TO DGADIR (4-WORD LOOKUP)
				;
	BLT	A,DGADIR+2
	MOVE	A,FILDIR+1	;GET PPN
	MOVEM	A,DGADIR+3
				;NOW INIT THE DEVICE
	INIT	DGA,DUMP
MORE72:	SIXBIT	/DSK/		;STUFF DEVICE NAME

	XWD	0,DGAHED	;INPUT ONLY
	POPJ	P,		;SUSPECT THAT THERE MIGHT BE
				;TROUBLE HERE, SINCE WE JUST DID A
				;SUCCESSFUL EXTENDED LOOKUP (FOLLOWING
				;A SUCCESSFUL INIT)
				;ON THIS DEVICE....
	LOOKUP	DGA,DGADIR
	POPJ	P,			;OK, ON RESTORE & NO 1ST FILE
					;THIS LOOKUP WILL FAIL IN AREA
					;IS EMPTY AT START... SO TRY AGAIN NEXT 'ROUND
					;TO HELP FILSER
	SETOM	ONEFIL
	POPJ	P,		;CLOSE SWITCH AND RETURN

;READ MFD

MFD3:	PUSHJ	P,GETMFD	;INCREMENT TO FIRST OF NEXT PAIR
MFD2:	PUSHJ	P,GETMFD	;GET THE FIRST WORD
	SKIPN	U,W		;SKIP TO NEXT NON-ZERO
	JRST	MFD3
GETMFD:	TRO	F,MFDI
	SOSG	MFDHED+2	;ANY MORE WORDS IN BUFFER
	PUSHJ	P,MFDIN		;NO, GET ANOTHER BUFFER
	ILDB	W,MFDHED+1	;NEXT WORD INTO W
	TRZ	F,MFDI
	POPJ	P,

MFDIN:	IN	MFD,		;READ ANOTHER BUFFER
	POPJ	P,		;HAPPY, RETURN
	STATO	MFD,IOBAD	;END OF BUFFER?
	JRST	ENDMFD		;GO DO WRAPUP
	STATZ	MFD,BTL		;IS BLOCK TOO LARGE
	PUSHJ	P,BLOCKT	;BLOCK TOO LARGE MESSAGE
RMFDIN:	PRLIN1	<ERROR READING MFD@>
	SKIPLE	TAPHED			;IF BUFFERS ACTIVE, CLOSE TAPE
	CLOSE	TAP,0			;DUMP WHAT YOU HAVE
	JRST	ENDMFD			;STRUGGLE ONWARD AND UPWARD
;READ UFD

UFD3:	PUSHJ	P,GETUFD	;INCREMENT TO FIRST OF NEXT PAIR
UFD2:	PUSHJ	P,GETUFD	;GET THE FIRST WORD
	SKIPN	U,W		;PLACE IN FIRST WORD REGISTER
	JRST	UFD3
GETUFD:	TRO	F,UFDI
	SOSG	UFDHED+2	;ANY MORE WORDS IN BUFFER?
	PUSHJ	P,UFDIN		;NO, GET SOME
	ILDB	W,UFDHED+1	;NEXT WORD
	TRZ	F,UFDI
	POPJ	P,

UFDIN:	IN	UFD,		;READ ANOTHER BUFFER
	POPJ	P,		;HAPPY, RETURN
	STATO	UFD,IOBAD	;END OF FILE?
	JRST	ENDUFD		;YES, GO DO WRAPUP
	STATZ	UFD,BTL		;BLOCK TOO LARGE?
	PUSHJ	P,BLOCKT	;BLOCK TOO LARGE MESSAGE
RUFDIN:	PRLIN1	<ERROR READING UFD FOR#>
	PUSHJ	P,PRPP		;PRINT UFD NUMBER
	JRST	ENDUFD		;SEE IF THERE IS ANYTHING TO DUMP
				;RESET P,
				;AND TRY MORE UFD'S
BLOCKT:	PRLIN1	<BLOCK TOO LARGE#>
	POPJ	P,

;DISK FILE INPUT

FILIN:	TRO	F,FILI
	IN	FIL,		;GET NEXT BUFFER
	JRST	FILIN2		;HAPPY, RETURN
	TRZ	F,FILI
	STATZ	FIL,IOBAD	;END OF FILE? SKIP IF NO ERRORS(WHICH =EOF CONDITION)
	PUSHJ	P,UFLERR	;PRINT ERROR MESSAGE AND FILE NAME
RFLAIN:	JRST	ENDFIL

FILIN2:	TRZ	F,FILI		;SUCCESSFUL INPUTS
	POPJ	P,

;MAG TAPE OUTPUT

TAPOUT:	TRO	F,TAPO
	MOVEI	A,TAPLEN-4	;DATA WORDS/BUFFER
	SUBB	A,TAPHED+2	;COMPUTE # WORDS USED
	JUMPLE	A,NULTAP	;NONE USED, DONT OUTPUT
	AOS	CH,TAPHED+2	;TOTAL # WORDS IN BUFFER =
				;# WORDS FOLLOWING 1ST (CHECK)
				;WORD IN BUFFER + THE HEADER (CHECK) WORD
				;ITSELF
	HRRZ	B,TAPHED	;ADDR OF BUFFER CURRENTLY IN USE
	HRRZM	CH,1(B)		;UPDATE BUFFER
				;WORD COUNT
	HRRM	A,2(B)		;INTERNAL WORD COUNT INTO HEADER WORD
TAPOU1:	OUT	TAP,		;WRITE ANOTHER RECORD
	JRST	TAPO33		;SUCCESSFUL OUTPUT: NO ERRORS, NO EOT

	STATZ	TAP,100000+40000;SKIP IF
				;NO DATA ERRORS OR BLOCK NOT TOO LARGE
	JRST	FINTPO		;BAD NEWS ... CHECK FOR EOT;
				;IF EOT IS ON, WE CANNOT ERASE
				;TAPE, HAVE TO BACK UP TO
				;LAST BEGINNING OF RECORD
				;TRY NOT TO RUN OFF END
				;OF TAPE

	STATZ	TAP,IOTEND	;END OF TAPE?
	JRST	ENDTAP		;YES, DO WRAPUP
	STATZ	TAP,400000	;NO, WRITE-LOCKED TAPE?
	JRST	WRLOK		;YES, PRINT MESSAGE & WAIT 'TIL /C
	STATZ	TAP,200000	;NO, PHYSICAL DEVICE ERROR?
	JRST	DEVERR		;YES, TELL OPERATOR
RTAPOU:	GETSTS	TAP,A		;SEE WHERE YOU ARE
	TRZE	A,IOTEND		;EOT UP ?
	JRST	RRNTPO		;AT EOT!

					;(IF EOT IS UP [WE TOOK THE JUMP]
					;...DON'T TRY TO WRITE 3"
					;OF BLANK TAPE, YOU MAY RUN OFF THE
					;END OF THE REEL
					;SO, IF EOT IS UP FORGET 3" OF BLANK TAPE
				;BESIDES:
				;YOU WON'T BE WRITING AS MUCH INFORMATION
				;WITH THE TRAILER, SO YOU WON'T
				;FIND THIS AREA AFTER BACKSPACING
RRTAPO:	PRLIN1	<TAPE WRITE ERROR ON#>
	PUSHJ	P,PRUFL
	PR1	<ATTEMPTING RECOVERY@>
	PUSHJ	P,CRLF
				;DO NOT(!) WRITE 3" BLANK TAPE
				;SINCE YOU DON'T KNOW
				;WHERE YOU ARE AT THIS TIME


				;CONIDER:
				;MAG TAPE SERVICE HAS ATTEMPTED
				;TO WRITE THIS RECORD
				;BUT HAS FAILED
				;IT HAS ATTEMPTED TO WRITE ENOUGH
				;BLANK TAPE
				;TO COVER THE OFFENDING AREA
				;AND RETRIED SEVERAL TIME TO PUT
				;THE RECORD CORRECTLY ON TAPE
				;LET MTASRX
				;DO THE WORK
				;AND DON'T TRY TO OUTSMART
				;IT

	GETSTS	TAP,B		;CLEAR ERROR BITS
	ANDCMI	B,760000
	SETSTS	TAP,(B)

	JRST	NULTAP		;RESET BUFFER WORD COUNT
				;IT IS BETTER TO BE TOO SHORT ON
				;RECORD COUNTS THAN TOO LONG AS WE BACK UP
				;WHEN CONFUSED

FINTPO:	STATO	TAP,IOTEND		;END OF TAPE?
				;BAD WRITE _
				;CHECK FOR END OF TAPE
	JRST	RRTAPO		;ADVISE & TRY FIX
				;AND WRAP UP
RRNTPO:	TLOE	F,TENDF		;LITE THE EOT SWITCH
				;IN THE AC
	POPJ	P,		;RESET AND RETURN TO CALLER VIA POPJ P,

	PRLIN1	<"CAUTION! END OF TAPE HAS BAD SPOTS@>
	JRST	ERRENT		;ENTER WRAP-UP ROUTINES
				;NOTE THAT RECORD COUNT MAY BE 1 TOO GREAT
				;AT THIS POINT SINCE
				;ERRENT WILL BUMP RECORD COUNT BY 1... TO
				;"ACCOUNT FOR THIS SUPPOSEDLY 'GOOD' RECORD
				;OOUTPUT.  THIS WILL CAUSE US
				;TO BACK UP 1 TOO MANY, BUT IF MAGTAPE
				;SERVICE HAS BECOME CONFUSED, WE MAY
				;BACK UP JUST ENOUGH....
;WRITE HEADER OR TRAILER ON TAPE

LABBLT:	MOVSI	A,FIRBLK	;ADDR OF HEADER
	HRR	A,TAPHED+1	;GET BUFFER DATA ADDR FROM BYTE PTR
				;OF INCREMENT AND LOAD BYTE
	MOVEI	B,4(A)		;SET STOP AT 5TH DATA WORD
	BLT	A,(B)		;BLT HEADER INTO BUFFER

	HRRM	B,TAPHED+1	;RESET BYTE POINTER
	HRROI	A,-4		;RESET COUNT
				;WORDS XFERRED =
				;E - AC(RIGHT) + 1
				;DON'T HAVE TO COMPENSATE FOR COUNT
				;'CAUSE IT IS NOT "COMPENSATED FOR" LATER ON
				;AS PER NUMBER OF IDPB'S AND SOSG'S SIMULATED
	ADDM	A,TAPHED+2
CLSUSR:	PUSHJ	P,TAPOUT	;WRITE ONE RECORD
	TLNE	F,TENDF		;EOT MODE ?
	JRST	EOTMOD		;YEP!
	SKIPLE	RECCNT		;HAS ANYONE WRITTEN(!!) ANYTHING THIS TIME AROUND
	SKIPG	TAPHED		;OR DO WE HAVE A LIVE , USED BUFFER RING
	JRST	NULTAP		;NOPE NULL TAPE.. SKIP FLUSH & EOF
				;NOW
				;SCRAMBLE AROUND THE BUFFER RING AND
				;AS MANY TIMES AS YOU HAVE BUFFERS,
				;SEE WHAT YOU CAN DUMP
	MOVEI	A,TAPN-1	;NUMBER OF TRIES
BUFCKR:	OUTPUT	TAP,0
	SOJG	A,BUFCKR	;ANY MORE ?

	MTAPE	TAP,3		;MARK 1 EOF
	SETZM	RECCNT		;# OF OUTSTANDING RECORDS SINCE LAST EOF
				;OR DIRECTORY RECORD IS 0
	JRST	NULTAP		;BEFORE YOU

TAPO33:	AOSA	RECCNT		;ACCOUNT FOR ANOTHER GOOD RECORD OUTPUT
NNLTAP:	OUTPUT	TAP,		;DUMMY OUTPUT
NULTAP:	MOVSI	B,400000	;RESET VIRGIN BIT
	ANDCAB	B,TAPHED
	MOVEI	A,2(B)		;SET BYTE POINTER TO BEGINNING OF BUFFER
	HRRM	A,TAPHED+1	;BYTE POINTER POINTS TO PRESENT BUFFER

TAPOU3:	MOVEI	A,TAPLEN-4	;DATA WORDS/BUFFER -1
	MOVEM	A,TAPHED+2	;BUFFER COUNT
	TRZ	F,TAPO
TAPPOP:	POPJ	P,		;RETURN

EOTMOD:	AOS	TAPHED+2		;SHOW MONITOR WE HAVE 0 WORDS
					;TO GO OUT
					;IN THE LAST BUFFER OF THAT
	CLOSE	TAP,0			;CLOSE UP OUR TAPE
	POPJ	P,
;BLT HEADERS INTO TAPE BUFFER

DIRBLT:	MOVSI	A,FILMRK	;HEADER WORD FOR DIRECTORY
	HRR	A,TAPHED+1	;GET BUFFER DATA ADDR FROM BYTE PTR
	MOVEI	B,XLOOKN+2(A)	;SET STOP AT LAST RETRIVAL WORD
	BLT	A,(B)		;STUFF TAPE
				;WITH WHAT YOU FOUND ON DISK
	HRRM	B,TAPHED+1	;RESET BYTE POINTER
				;NOW RESET DISK INFO
				;FOR TAPE
	SETZM	.RBPOS+2-XLOOKN-2(B)	;LOGICAL BLOCK # OF FIRST BLOCK TO
				;ALLOCATE WITHIN FILE STRUCTURE _ 0

	MOVE	A,.RBSIZ+2-XLOOKN-2(B)	;CH _ # WORDS WRITTEN
	LSH	A,-^D7		;WORDS / 200(OCTAL) = BLOCKS
	CAMGE	A,.RBALC+2-XLOOKN-2(B)	;WHICH IS LARGER
				;#WRITTEN
				;OR ESTIMATED LENGTH (BOTH IN BLOCKS NOW)
	MOVE	A,.RBALC+2-XLOOKN-2(B)
	MOVEM	A,.RBEST+2-XLOOKN-2(B)
	SETZM	.RBALC+2-XLOOKN-2(B)	;AND ZERO OUT # BLOCKS ALLOCATED

	MOVSI	A,URBLGI!RIPSCE!RIPHWE!RIPHRE!RIPBFA!RIPCRH!RIPBDA
				;RESET LOGGED IN BIT, IF ON
				;AND ERROR BITS IF THEY ARE ON
				;KEEP OFF IF OFF
				;PREVENTATIVE MEASURE IN CASE SYSTEM
				;CRASHED DURING RESTORE
				;OF THIS USER'S FILES
	ANDCAM	A,.RBSTS+2-XLOOKN-2(B)



	HRROI	A,-XLOOKN-2-1+1	;RESET COUNT
				;NORMALLY, THE NUMBER
				;OF WORDS BLT-ED IS THE NUMBER OF SOSG'S
				;YOU HAVE TO SIMULATE, HOWEVER, IN THIS
				;CASE, THE FIRST WORD IS ALREADY COUNTED
				;-1,777 OVERLAYS 1ST WORD IN BUFFER**
				;THEREFORE, # WORDS BLT'ED =
				;EFFECTIVE ADDRESS - AC(RIGHT) + 1
				;OR 42 + 1
				;BUT ONE OF THOSE DOESN'T COUNT IF YOU
				;ARE GOING TO KEEP FROM COUNTING IT TWICE
				;ERGO: BUMP BYTE POINTER BY 42 BY
				;GETTING (TAPHED+1) + 42 INTO B
				;THESE 42 PLUS THE SIMULATED IDPB
				;THE NECESSARY 43


	ADDM	A,TAPHED+2	;FINALLY, BUMP THAT POINTER


	MOVE	A,FILDIR+1	;OK, SEE IF THIS IS 1,1
	CAMN	A,SYSPP		;REALLY?
	MOVEI	B,1(B)		;MOVE POINTER TO FILE NAME IFF 1,1
				;SINCE WE WILL BE CHANGING
				;THE FILE'S NAME
				;NOT THE OWNER'S
SWAPO:	MOVE	A,.RBPPN+2-XLOOKN-2(B)	;GET GUY YOU ARE LOOKING FOR
	CAMN	A,SLGPPN		;SAME?
	MOVE	A,SLOPPN		;YES, PREFORM SWAP
	MOVEM	A,.RBPPN+2-XLOOKN-2(B)	;OR REPLACE USER PPN WITH ITSELF
	POPJ	P,

				;OWNER		_ FILDIR +1
				;FILNAME	_ FILDIR +2
				;EXT		_ FILDIR + 3
				;WHEN IT'S 1,1, LOOK AT FILE NAME
				;WHICH IS THE UFD NUMBER FOR THE PPPN
				;IN QUESTION
				;WHEN OWNER IS NOT 1,1
				;LOOK AT OWNER AND SWITCH/SWAP
				;OWNER TO DESIRED #
ENDFLA:	MOVE	B,TAPHED+1
				;GET POINTER TO TAPE INFO
				;WHICH IS SET TO NEXT INSERTION

	SKIPG	.RBSIZ+2-XLOOKN-2(B)		;ANY WORDS ?
					;EITHER ESTIMATED OR ACTUALLY
					;USED
				;SPR 10-5520
	JRST	[PUSHJ	P,NULTAP	;RESET TAPE BUFFER & POINTERS
		JRST	ENDFI1		;CONTINUE
			]

			;NO WORDS, SKIP SAVING THIS UFD
	TLO	F,FILFND	;UFD OK FOUND & SAVED
ENDFIL:	PUSHJ	P,TAPOUT	;OUTPUT LAST BUFFER
	CAIN	W,(SIXBIT /UFD/)	;SKIP KILL IF UFD
	JRST	ENDFI1
	TLNN	F,KILLSW	;DO WE KILL DISK FILES SAVED ON TAPE?
	JRST	ENDFI1		;NO
	CLOSE	FIL,DNC		;CLOSE FOR RENAME
	SETZM	FILDIR			;IST WORD ZONKED
	MOVE	A,[XWD FILDIR,FILDIR+1]	;ZERO TO KILL FILE
	BLT	A,FILDIR+XLOOKN
	RENAME	FIL,FILDIR	;KILL FILE
	PUSHJ	P,RENERR	;WE FAILED SOMEHOW
ENDFI1:	CLOSE	FIL,DNC
	IFN	MINREL,<
	RELEASE	FIL,		;GIVE UP USER FILE DDB
	>
	TRNE	F,CONTSW	;ARE WE IN CONTINUATION PROCESS?
	JRST	APOPJ		;YES, RETURN TO RESAVE
	MOVE	P,SAVFIL	;RESET PDP
	JRST	MORE2		;GO READ NEXT USER FILE

ENDUFD:	TRZ	F,UFDI
	TLZN	F,FILFND	;ANY FILES FOR THIS USER?
	JRST	NULFIL		;NOPE
ENUFD1:	PUSHJ	P,CLSUSR	;WRITE EOFS ON TAPE
	MOVE	U,UFDDIR+2
	TRNE	F,USRSW
	CAME	U,SYSPP
	PUSHJ	P,PRPP		;PRINT PROJ-PROG #
CLOSER:	CLOSE	UFD,DNC
	IFN	MINREL,<
	RELEASE	UFD,		;GIVE UP UFD DDB
	>

	CLOSE	DGA,DNC
	IFN	MINREL,<
	RELEASE	DGA,
		>
				;CLOSE ON PHANTOM CHANNEL
	TRNE	F,CONTSW	;WE IN CONTINUATION PROCESS?
	POPJ	P,		;YES, RETURN
	MOVE	P,SAVUFD	;RESET PDP
	JRST	MORE1		;GO READ NEXT UFD


NULFIL:	CLOSE	FIL,DNC		;CLOSE THE DSK	[45]
	TRNN	F,USRSW		;IS THIS A SINGLE USER SAVE ?
	JRST	CLOSER		;NOPE, /S SAVE, DON'T SWEAT THE
				;NULL USER AREA IN THIS CASE
	MOVE	A,UFDDIR+2
	CAMN	A,SYSPP
	JRST	ENUFD1
	PR1	<NO FILES SAVED FOR#>
	MOVE	TMP,SLGPPN
	PUSHJ	P,PRPPN1
	PUSHJ	P,SPACE
	MOVE	B,CURSTR	;GET STRUCTURE
	PUSHJ	P,FIXSPA	;RIGHT JUSTIFY SIXBIT ITEM IN "B"
	PUSHJ	P,PRNAME	;PRINT OUT
	PUSHJ	P,CRLF

				;<CR>
				;LF
	JRST	CLOSER
ENDMF0:	TRZ	F,MFDI		;FREE UP MFD
	CLOSE	MFD,DNC

	IFN	MINREL,<
	RELEASE	MFD,
		>
	TLO	F,MFDDNE	;INDICATE FINISHED WITH MFD
	PUSHJ	P,LOOKDT		;LOOKUP THE DATE AND TIME
	TLZ	A,400000		;SHUT OFF THE CONTINUED BIT
					;THIS IS THE LAST TAPE
	MOVEM	A,TIMOUT
	MOVEM	A,FIRBLK+3	;AND PUT IT ON TAPE AS WELL
				;AS ON TTY
	MOVN	A,TAPNUM	;NEGATE TAPE #
	HRRM	A,FIRBLK+2
	MTAPE	TAP,7		;BAKSP OVER EOF
	TLO	F,TENDF		;INSURE THAT YOU DON'T GO THROUGH
				;END-OF-TAPE PROCEDURES TWICE
				;FORCE THIS TRAILER
				;OUT!
	PUSHJ	P,LABBLT	;WRITE TRAILER RECORD
ENDMF2:	HLRZ	A,FIRBLK		;GET VERSION NUMBER
	HRRZM	A,VERNO#			;AND SAVE IT!

	IFN	REWIND,<	EMTAPE	1		;REWIND IT
	>
	PRLIN1	<$SAVE COMPLETED WITH#>
	PUSHJ	P,ENDMES
	PUSHJ	P,TUNREL		;RELEASE TAP (& UNLOCK IF LOCK ASSEMBLED IN)
	IFE	NONSTP,
	<
	MOVE	P,SAVMFD	;RETURN
	>

	IFN	NONSTP,
	<
	JRST	START		;RETURN FOR MORE PASSES
	>
	AOS	(P)
	JRST	LFCRLF
;ROUTINE TO CONTINUE A SINGLE USER SAVE OR 
;ENTIRE DISK SAVE WHEN EOT IS REACHED

;IF WE BELIEVE WE HAVE JUST FINISHED OUTPUTTING A
;USER AREA, ENTER AT ENDTP1
;IF WE REACH EOT IN THE PROCESS OF FILE OUTPUT
;WE ENTER AT ENDTAP


ENDTAP:	TLOE	F,TENDF		;IF WE HAVE JUST OUTPUT TRAILER,
	POPJ	P,		;EVENTAULLY POPJ P, BACK TO CLSUSR + 1
				;WHAT HAPPENED WAS AS FOLLOWS...
				;YOU TRIED TO WRITE A TRAILER BLOCK
				;WITH EOT FLAG STILL UP
				;(OR EOT CAME UP WHILE WRITING TRAILER BLOCK)
				;AND EOT GAVE THE ERROR RETURN
				;FROM THE OUT UUO AT TAPOU1:.....
				;

				;WHICH TRANSFERRED YOU TO ENDTAP:
				;THE CLOSE AT CLSUSR WILL FINISH UP THE
				;TRAILER BLOCK AND THE POPJ P,0 AT TAPPOP: WILL
				;RETURN YOU TO
				;ENDTP2:
				;
				;
ERRENT:	TLZE	F,MFDDNE	;OTHERWISE PREPARE TO SWITCH TO NEW TAPE
	JRST	ENDMF2		;WE WERE WRITING LAST TRAILER - MERELY FINISH

				;SAVE DIRECTORY
	MOVE	A,[FILDIR-1,,WATBUF]
	BLT	A,WATBUF+XLOOKN+2-1
	PUSHJ	P,TAPFIL	;FIND FILE ON TAPE AND POSITION FOR TRAILER OUTPUT

	PUSHJ	P,TRLOUT	;SET UP TRAILER AND
ENDTP2:	PUSHJ	P,MESOUT	;OUTPUT MESSAGES AND REWIND
	IFE	NONSTP,
	<
RELINK:	PUSHJ	P,CWAIT		;WAIT FOR /C TO CONTINUE
	>

	IFN	NONSTP,
	<
RELINK:
	>
	JRST	RESAVE		;RESAVE WATCH RING FILES AND CONTINUE

;ROUTINE TO POINT B TO WATCH BLOCK OF FILE WHICH
;WILL BEGIN NEXT TAPE
;
;ROUTINE TO FIND FILE ON TAPE AND POSITION
;TAPE FOR TRAILER OUPUT
;T BACKSPACES FOR RECORDS OUTPUT
;EOF MARKS COUNT AS RECORDS
TAPFIL:	CLOSE	FIL,DNC		;CLOSE UP THE FILE
	SETZM	ONEFIL		;SAY THAT YOU REALLY HAVEN'T GO THE
				;SHADOW CHANNEL OPEN
	CLOSE	DGA,DNC		;'CAUSE YOU'VE JUST CLOSE IT UP
				;
				;THE REASON IS TO ALLOW A SWITCH IN THE
				;SEQUENCING OF TAPES (E.G.,
				;TAPE1 , TAPE 3, TAPE 7, TAPE 2)
				;FROM THE "NORMAL," AND THAT THE
				;SHADOW CHANNELS OPEN FOR EACH REEL WILL BE #RIGHT#
				;SINCE  THE SHADOW CHANNEL WILL BE
				;OPENED ON THE APPROPRIATE UFD FOR EACH REEL

	CLOSE	TAP,0		;CLOSER UP, BOSS
	AOS	T,RECCNT	;BUMP RECORD COUNT TO ACCOUNT
				;FOR EOF MARK
TAPFL2:	MTAPE	TAP,7		;BACKSPACE A RECORD
	SOJGE	T,TAPFL2	;UNTIL T RECORDS BACKSPACED... NOTE
				;THAT WE ARE POINTING IN FRONT OF
				;THE LAST DIRECTORY RECORD
	MTAPE	TAP,7		;GET TO JUST IN FRONT OF THE PLACE WHERE
				;YOU STOPPED WITH ALL O.K.
	PUSHJ	P,SETSYN		;SET SYN INPUT

	SETOM	FNDBEG		;AND SET SWITCH THAT SAYS YOU HAVE
				;FOUND THE HEADER RECORD

	TRO	F,TAPI!LISTSW!DOINGJ		;NOW YOU ARE DOING TAPE INPUT
					;AND DUMMY UP A REQUEST FOR LIST
					;AND LIKEWISE DUMMY UP A DOINGJ
					;SO THE TAPE INPUT ROUTINE WILL
					;READ TAPE INSPITE OF ERRORS,
					;NOW IS NOT THE TIME TO GET PICKY
					;ABOUT READING
					;TO DEFEAT /G _/O SWAPPING IN READING
	TRZ	F,TAPO		;NO LONGER DOING TAPE OUTPUT
				;OR SAVING.. TEMPORARILY JUST READIN'

TAPFL3:	TLZ	F,TENDF		;TURN OFF THE EOT FLAG
					;WE WANT TO  READ REGUARDLESS OF
					;EOT CONDITION
					;WHICH MAY SUPRIOUSLY BE UP IF 
					;THIS IS A
					;UN-ECO-ED TU/30
	PUSHJ	P,TAPIN		;GET 1 ROUND OF INPUT
	JRST	EOFIN		;O.K, THEN ADSORB THE EOF
				;FROM THE GUY IN FRONT OF YOU
				;ON THE TAPE
				;AND APPEND THE TRAILER RECORD TO HIS AREA

				;MEANS EOF CAME UP WHILE
				;WRITING AN EOF
				;WHICH COULD HAPPEN, BUT WE DON'T GET
				;STSTUS UNTIL WE DO OUT'S
				;THEREFORE CANNOT  SEE  HOW WE CAN
				;HAVE EOF COMING UP, UNLESS
				;TU-30 IS DOING US IN (9-TRACK?)

TPFL4A:	SKIPA	T,[XWD	FILDIR-1,WATBUF]	;RESTORE WATCH-BLOCK POINTER
				;USE ALREADY GENERATED LITERAL FOR ITS RIGHT HALF
	JRST	TPFL3A		;OOOPS, NO GO!
				;WE HAVE GOT THE DATA FROM PREVIOUS
				;FILE ?


	MOVEI	B,1(T)		;BUMP POINTER, SAVE ORIGINAL VALUE
TAPFL4:	ILDB	S,TAPHED+1	;GET DATA WORD
	CAME	S,-1(B)		;ARE DATA WORDS =?
	JRST	SWAPQ		;COULD THIS BE
						;DIFFERENT
						;BECAUSE OF SWAPPED PPN'S
TAPFL5:	CAIGE	B,6(T)			;ALL WORDS COMPARED?	[43]
	AOJA	B,TAPFL4		;OK SO FAR, TRY SOME MORE
				;JUMP IF NOT COMPLETELY DONE LOOKING
	CLOSE	TAP,0		;CLOSE TAPE UP
	MTAPE	TAP,7		;BACKSPACE OVER RECORD WHEN THROUGH COMPARING
	MOVE	B,-4(B)		;GET PPN
	MOVEM	B,UFDDIR+2	;YES
	PUSHJ	P,PRPP		;PRINT PROJ-PROG #
	TYPES	(&)		;&+SPACE

EOFPRT:	PR1	<THOSE FOLLOWING ARE ON THE NEXT TAPES.#>
	TDO	F,[XWD	TENDF,CONTSW!TAPO]	;SET CONTINUATION FLAG
				;AND TAPE OUT SWITCH
				;AND END OF TAPE SWITCH
	TRZ	F,TAPI!LISTSW!DOINGJ		;NO LONGER DOING INPUT
					;OR DUMMY-ING UP A LIST
						;OR DUMMY-ING UP A /J
	SETZM	SYNCIN		;BACK TO BUFFERED MODE, PLEASE
SETITO:	JRST	SETOU		;RE-INIT TAPE & SET VIRGIN HEADER
				;AFTER DOING A DUMMY OUTPUT


EOFIN:	MTAPE	TAP,17		;ADSORB THAT EOF
	JRST	EOFPRT			;AND PRINT IT OUT


BADIN:	MTAPE	TAP,7		;BACK UP A RECORD
	MTAPE	TAP,7		;BACK UP TO THE ONE IN FRONT OF THE BAD ONE
	JRST	EOFPRT		;YOU ARE SLIGHTLY CONFUSED, GET OUT WHILE
				;THE GETTIN'S GOOD
TPFL3A:	PUSHJ	P,TAPIN		;WE NEED A DIRECTORY
					;NOT AN EOF
	JRST	BADIN			; _ EOF
	JRST	TPFL4A			;DIRECTORY
					;NOT A BUNCH OF DATA
	JRST	BADIN			; _ DATA

SWAPQ:	MOVE	A,SLGPPN		;GET SOURCE PPN
	CAMN	S,SLOPPN
	CAME	A,-1(B)				;SEE WHETHER
	JRST	TPFL3A				;SEE IF ANY MORE DIRECTORIES..
						;DIRECTORIES ARE A POINT OF REFERENCE
						;WE SPOOL DOWN THE TAPE UNTIL
						;WE RUN OUT OF DIRECTORIES
						;THEN WE BACK PEDDEL
						;UNTIL WE FIND DIRECTORIES
						;IN FRONT OF THE STARTING
						;PLACE.
						;WE THEN MOVE
						;FOWARD UNTIL WE EITHER
						;BOMB OUT COMPLETELY
						;OR UNTIL WE
						;BACK INTO
						;A DIRECTORY THAT
						;MATCHES
	JRST	TAPFL5				;/G AND /O	[43]
;OUTPUT TRAILER BLOCK

TRLOUT:	PUSHJ	P,LOOKDT	;GET DATE & TIME
	TRNE	F,CONTSW	; CONTINUATION FLAG IS ON
	TLO	A,400000
	MOVEM	A,FIRBLK+3
	MOVEM	A,TIMOUT#	;SAVE ENDING TIME FOR THIS TAPE
				;TO BE SAVED, (TEMPORARILY
				;FORGETTING ABOUT /E AND /F), A
				;FILE MUST HAVE BEEN CREATED BEFORE
				;STARTING TIME <AS NOTED IN THE
				;HEADER TEXT
				;OR
				;THERE IS STILL A CHANCE
				;IF IT HAD BEEN CREATED DURING THE
				;FIRST FEW MOMENTS OF FAILSAFE-RUN
				;
				;IT CANNOT BE ON THE TAPE IF IT HAS A
				;CREATION TIME OF LATER
				;THAN THE TIME IN TIMOUT
				;BEFORE START TIME ... YEP, IT'S ON TAPE
				;AFTER START TIME BUT BEFORE END TIME ...
				; YEP, THEN MAYBE IT'S ON TAPE
				;AFTER END TIME ... YEP, THEN IT IS NOT ON THE TAPE


	MOVN	A,TAPNUM	;NEGATE TAPE #
	HRRM	A,FIRBLK+2	;RESET TRAILER
	PUSHJ	P,LABBLT	;WRITE TRAILER, EOFS, RETURN
	HLRZ	A,FIRBLK		;GET THE VERSION NUMBER
	HRRZM	A,VERNO			;SAVE IT
	POPJ	P,		;AND RESET FOR OUTPUTS AFTER CLOSING
;OUTPUT MESSAGES AND REWIND TAPE

MESOUT:	TLZ	F,TENDF		;CLEAR EOT BIT
	IFDEF	UNLOAD,<
	MTAPE	TAP,11		;START REWIND AND UN-LOAD PROCEDURE
	>
	IFNDEF	UNLOAD,<
	MTAPE	TAP,1		;OR JUST REWIND PROCEDURE
	>
	PUSHJ	P,TUNREL	;UNLOCK ??
				;RELEASE TAP, ANWWAY

	PRLIN1	<$COMPLETED FAILSAFE#>
	PUSHJ	P,ENDMES	;CR & LF BEFORE YOU RETURN HERE
REMESS:	PR1	<TO CONTINUE, REASSIGN LOGICAL DEVICE FAILSA (IF YOU WISH)@>
	PR1	<& TYPE /C@>
	JRST	ASTRSK		;TYPE "*" THEN POPJ

TUNREL:	RELEAS	TAP,			;GIVE UP DDB SO REASSIGN CAN
					;BE DONE SO TAPES CAN BE MADE ON
					;VARIOUS DRIVES
	IFN	LOCK,<
TUNLOC:	MOVEI	TMP,1			;LOW SEG OUT OUT & AWAY
					;SKIP TEMPORARY UNLOCK
	TLNE	F,LOCKER		;IF NOT LOCKED
	CALLI	TMP,UNLOCK		;TRY IT
	POPJ	P,			;WELL, YOU TRIED & LOST
	>
	POPJ	P,			;WELL, YOU TRIED & WON

ENDMES:	PUSHJ	P,TAPNO		;"TAPE #"
	MOVE	A,TAPNUM	;GET OUR REEL NUMBER
	PUSHJ	P,PRNUM		;OUTPUT DECOMAIL #
	PUSHJ	P,CRLF		;KEEP THE LINES SHORT
				;SINCE MUCH
				;OF THE RIGHT HAND HALF
				;MAY BE CUT OFF IF THE
				;OPERATOR KEEPS THE OUTPUT INSIDE
				;THE TAPE CANISTER
	MOVE	A,TIMOUT	;GET WRAPUP TIME
	HRRZ	B,VERNO		;GET THAT VERSION NUMBER!
	CAIGE	B,SECVER	;YOU HAVE SECONDS & MINUTES IN TIME
	JRST	DATIME		;NOPE! JUST MINUTES
	JRST	DAYTIM		;YEP!! BOTH
				;SECONDS AND MINUTES
				;CR + LF AND THEN POPJ AFTER
				;PRINTING WRAPUP TIME AND DATE
;CHECK FOR SPECIAL /C
;IF NOT, PROCESS AS USUAL

CWAIT:	INPUT	TTI,		;GET COMMAND
	PUSH	P,TTYI+1	;SAVE JUST IN CASE
	ILDB	CH,TTYI+1	;GET FIRST CHAR
	CAIE	CH,"/"		;IS IT A SLASH?
	JRST	RUSURE		;ARE YOU SURE ? /C NOT RECEIVED... CHECK
	ILDB	CH,TTYI+1	;YES
	CAIE	CH,"C"		;IS IT A C?
	JRST	RUSURE		;NOT "C"... CHECK!
	JRST	APOPJ		;RETURN
POPBAK:	POP	P,TTYI+1
	POP	P,TMP		;SLUFF PUSHJ P, RETURN
	JRST	FS1B		;GO PROCESS USUAL COMMAND

	;RESAVE FILES WE THOUGHT WE HAD SAVED
RUSURE:	CAIN	CH,"C"		;FORGET THE / ?
	JRST	APOPJ			;YEP
	POP	P,TMP		;FORGET SAVED BYTE POINTER
	POP	P,TMP			;FORGET RETURN ADDRESS
	CAIN	CH,"V"			;/V IS ALLOWED DURING BREAK
						;BETWEEN TAPES
	JRST	[PUSHJ	P,LOC			;TRY TO TOGGLE LOC SWITCH REQUEST
		PUSHJ	P,ASTRSK		;*
		JRST	RELINK
			]		;RETURN FOR MORE INPUT
	PRLIN1	<$ARE YOU SURE ?  "Y" STOPS SAVE ; ANY OTHER CHARACTER ALLOWS RESCAN@>
	INPUT	TTI,		;GET HIS ANSWER
	ILDB	CH,TTYI+1	;TERMINAL CHARACTER?
	CAIN	CH,"Y"		;DID HE SAY, "YES, ABORT SAVE?"
	JRST	FS1B		;YES, ABORT
	MOVEI	CH,044		;"$"
	PUSHJ	P,TYPEA
					;SET UP FOR POPJ FROM ASTERISK
	PUSH	P,[RELINK]		;ON TO PUSHDOWN LIST IT GOES
	JRST	REMESS		;AND LOOP UNTIL HE GIVES DEFINITIVE ANSWER

RESAVE:	MOVE	P,SAVMFD	;RESTORE PDP
	TLZ	F,FIRSW		;NOT FIRST TAPE ANYMORE
	PUSHJ	P,OTHERS		;WRITE OUT NEW HEADER
					;NO NEED TO SETUP FOR OUTPUT
					;OR DO DUMMY OUTPUT
					;SINCE TRLOUT: LEFT YOU SET UP

RESAV1:	TRZ	F,CONTSW		;TURN CONTSW OFF SO YOU WON'T POP P,A
					; THEN POPJ P,... RETURN 1 LEVEL TOO HIGH
RESAV2:	MOVE	U,WATBUF+2	;RESTORE PPN
	MOVS	S,[FILDIR-1,,WATBUF]
	BLT	S,FILDIR-1+XLOOKN+2-1
	JRST	MORE7

SUBTTL ***RESTORE CODE***
;"/R" SWITCH - RESTORE COMMAND EXECUTION

UNSAVE:	CALLI	A,GETPPN
	  JFCL			;BE DEFENSIVE
	CAME	A,FSPP		;LOGGED IN AS 1,2?
	JRST	NOTFS		;NO,NOTIFY USER AND EXIT
	TRO	F,RESTSW	;/R IN PROGRESS
	TRZ	F,SAVSW		;TURN OFF IN CASE OF /C
	PUSHJ	P,LOOKDT	;GO GET CURRENT DATE/TIME
	PUSHJ	P,DAYTIM	;  THEN TYPE IT FOR OPR
UNSAV2:	PUSHJ	P,SETIN		;INSURE BUFFERS
UNSAV3:	TRZ	F,CONTSW	;CLR CONTINUATION TAPE FLAG
IFN	REWIND,<	EMTAPE	1		;BEGINNING OF TAPE
	>
	PUSHJ	P,TAPIN		;READ FIRST RECORD
	JRST		[	PUSHJ	P,ILLFMT		;NOT FAILSAFE FORMAT
								;1ST REORD WAS EOF
				JRST	FORGIV
				JRST	FORGIV		;BUT WE'LL FORGIVE THE ERROR
						]

	JRST	DROK1			;DIRECTORY RECORD 1ST = AOK
	JRST		[	PUSHJ	P,ILLFMT
								;1ST RECORD WAS DATA RECORD
				JRST	FORGIV
				JRST	FORGIV]
DROK1:	MOVE	D,TAPHED		;GET ADDRESS OF BYTEPOINTER
	HLRZ	A,2(D)			;GET FORMAT CODE
	CAIN	A,-6			;CURRENT VERSION?
	JRST	FAILSC			;OLD FORMAT, BYE!
					;CONTINUE, IT'S A CURRENT FORMAT TAPE
	HLRE	A,2(D)		;XWD HEADER FLAG,INTERNAL WORD COUNT
	JUMPLE	A,	[	PUSHJ	P,ILLFMT	;INSIST ON HEADER FLAG (VERSION #)
				JRST	FORGIV
				JRST	FORGIV]		;FORGET CHECKING FAILSA PPN SINCE TAPIN
				;ROUTINE
				;CHECKS 1ST THREE WORDS FOR A MATCH
				;AND ACKNOWLWDGES APPROVAL
				;WITH 3 OUT OR 4, SO DON'T BOMB THE GUY
				;OUT IF HIS FIRST RECORD IS A LITTLE FLAKEY
				;ON THE 4TH HERE IF 3 OUT OF 4 WAS OK
				;AT TAPIN:
				;
	CAIGE	A,FST5S		;SAY, COULD THIS BE A LEGIT. 5-SERIES TAPE
				;?
	JRST	WRONGV		;WRONG VERSION OF FAILSAFE IS READ
				;OR THE WRONG ONE WROTE IT... AT ANY RATE
				;YOU ARE MIXING APPLES AND ORAGES AND GETTING
				;FRUIT SALAD.
	PRLIN1	<5-SERIES FAILSAFE TAPE RECORDED BY VERSION@>
	HLRZ	A,2(D)		;GET VERSION # THAT RECORDED YOU
	PUSHJ	P,PRNUM8	;OUT PUT THE OCTAL #

	PR1	< AT#>
	PUSHJ	P,PRTIME		;PRINT TIME AS HRS:MIN
					;OR HR:MIN:SEC, DEPENDING ON VERSION
					;WHICH AUTHORED THIS TAPE
	MOVEI	CH,042			;"
	PUSHJ	P,TYPEA
					;PRINT A "
					;TO QUEUE BATCH TO PUT MESSAGES
					;ON CONTROLLING TTY
	PUSHJ	P,TAPNO
	HRRE	A,4(D)		;GET TAPE NUMBER
	MOVM	A,A		;MAGNITUDE ONLY, PLEASE


	PUSHJ	P,PRNUM
	XLIST
	IFN	LEVELC,
	<
	LIST
	TRNE	F,LEVELC		;ARE WE LEVEL C ?
	PUSHJ	P,[
		PRLIN1	(OUTPUT MODE IS 4-SERIES@)
	POPJ	P,
	]
	>
	LIST


	SKIPGE	5(D)		;A CONTINUATION TAPE?
	TRO	F,CONTSW	;YES, SET FLAG

	PUSHJ	P,LFCRLF	;2 LINES SKIPED PLEASE
FORGIV:	TRNE	F,PRNTSW!LISTSW!SLRESW	;PRINTING?
					;OR LISTING
					;OR SELECTIVE RESTORING
	POPJ	P,			;YES, RETURN



	PRLIN1	<IF YOU WISH TO CONTINUE WITH THIS TAPE, TYPE "/C"@>
	SETZM	TTYI+2		;CLEAR ALL PREVIOUS INPUTS
	PUSHJ	P,ASTRSK
	POP	P,T		;RESTORE STACK LEVEL
	JRST	FS2		;GET NEXT COMMAND


;"/C" SWITCH - CONTINUE RECEIVED

CONTIN:	TRNN	F,RESTSW	;RESTORE?
	JRST	FS1.2		;NO, RESTART
	PUSHJ	P,CRLF		;YES,CONTINUE ENTIRE DISK RESTORE - FORMAT OUTPUT


	SKIPG	TAPHED		;TAPE NEED INIT-ING ?
	PUSHJ	P,SETIN		;YES!


	TRNE	F,CONTSW	;A CONTINUATION TAPE?
	JRST	UNSLPJ		;YES LEAVE SWITCH ON TO PREVENT DOUBLE OUTPUT OF PPN ON /C
ONEMOR:	PUSHJ	P,ITAPIN	;READ THE HEADER RECORD EOF
	JRST	SETSTR		;READ FIRST STRUCTURE'S FIRST FILES
	PUSHJ	P,ILLFMT		;BAD FORMAT
	JRST	SETSTR
	JRST	SETST1		;YOU ARE AT A DIRECTORY RECORD, NO NEED TO MOVE TAPE


;SET UP NEXT STRUCTURE

SETSTR:	PUSHJ	P,TAPIN		;SEE WHAT'S NEXT
					;WE NEED A DIRECTORY
					;+1 =EOF
					;+2 =DIRECTORY
					;+3 =DATA
	JRST	[	PUSHJ	P,ILLFMT		;BAD SHOW (EOF)
			JRST	SETSTR			;EOF RETURN
			JRST	SETST1			;DIRECTORY RETURN
			]

	JRST	SETST1			;DIRECTORY RECORD FOUND

	JRST	[	PUSHJ	P,ILLFMT
			JRST	SETSTR
			JRST	SETST1]

SETST1:	TRZ	F,TAPI
	MOVE	D,TAPHED		;GET STARTING POINT FOR BUFFER HEADER
	MOVE	A,3(D)			;GET STRUCTURE NAME
	MOVEM	A,CURSTR
	MOVEM	A,READPP
	MOVE	A,5(D)			;SEE WHO IT IS
	CAME	A,SYSPP			;SEE IF 1,1...IF NOT FORGET UFD'S
	JRST	UNSLUU			;NOT 1,1...
	MOVEM	A,UFDDIR+1

	FIXDEV				;FIX UP DEVICE
					;IF NECESSARY
	INIT	UFD,BUFBIN
READPP:	0			;SIXBIT /STRNAM/
	XWD	0,UFDHED	;LOOKUPS ONLY
	JRST	GETSTR		;THIS STR NOT AROUND ANYMORE
	PUSHJ	P,MKUFBF	;GET BUFS
	MOVEI	A,XLOOKN	;SET SPECS FOR LOOKUP
	MOVEM	A,UFDDIR
	MOVE	A,6(D)		;UFD NAME
	MOVEM	A,UFDDIR+2
	HLLZ	A,7(D)		;EXT="UFD"
	MOVEM	A,UFDDIR+3
	FIX	UFDDIR		;FIX UP UFDS

	LOOKUP	UFD,UFDDIR	;IS THIS UFD ON THIS STRUCTURE?
	JRST	FIXUFD		;NO, MAKE ONE LIKE THE ORIGINAL

;MOVE TO NEXT UFD

SETST2:	PUSHJ	P,FTAPIN	;IGNORE DATA RECORDS
	JRST	CHKTRL		;REAL EOF/ OR TRAILER ?
	JRST	SETST1		;NO, PROCESS NEXT UFD
FIXSET:	CLOSE	UFD,DNC		;GOT TRAILER - FINISH UP
	JRST	SYPPFS

CHKTRL:	TLNN	F,TENDF		;FLAG ON
	JRST	FIXSET		;NOPE, MUST BE REAL EOF
	JRST	SYPPFS		;GOT A TRAILER
;MAKE A UFD ON THIS STR WITH QUOTA FROM THE TAPE

FIXUFD:	MOVE	A,CURSTR
	MOVEM	A,FIX2
	FIXDEV			;FIX UP STRUCTURE NAME
				;IF NECESSARY
	INIT	MFD,BUFBIN
FIX2:	0			;SIXBIT/STRNAM/
	XWD	MFDHED,0
	JRST	GETSTR		;TRY ELSEWHERE
	PUSHJ	P,UFDSPK		;SET UP HEADER AGAIN
	FIX	MFDDIR		;FIX TO 4-SERIES IF NECESSARY
	ENTER	MFD,UFDDIR	;CREATE THIS UFD
	PUSHJ	P,MAYBE1	;CAN'T UNLESS THIS IS A FRAGMENTATION
				;ERROR, CHECK IT OUT
	PUSHJ	P,MAKU2		;RELEASE MFD
	JRST	SETST2

;SET UP SPECS TO CREATE A UFD

UFDSPK:	MOVSI	A,4(D)		;START OF SPECS IN TAPBUF
	HRRI	A,UFDDIR	;SPEC AREA
	BLT	A,UFDDIR+XLOOKN
	SETZM	URBPOS		;CLR SPECIAL ITEMS
	SETZM	URBNXT
	SETZM	URBPRD
	SETZM	URBUFD
	SETZM	URBELB
	SETZM	URBEUN
	SETZM	UFDDIR+.RBUSD	;SPR #10- 4398
				;SPR #10- 4275
	MOVEI	A,.RPDIR		;DIRECTORY BIT ON
	MOVEM	A,UFDDIR+.RBSTS	;SET UFD STATUS BITS
				;
				;BLOCK USED COUNT IS RESTORED SET
				;TO LAST ACCOUNT OF # BLOCKS
				;USED AT LAST LOGOUT
				;
	POPJ	P,

MAYBE1:	GETBAD	(A)		;POPJ BACK IF FRAGMENTATION ERROR,
				;POP OFF & FALL INTO GETSTR OTHERWISE
;CREATE A UFD ON SOME OTHER STRUCTURE IF POSSIBLE

GETSTR:	INIT	UFD,BUFBIN	;LOOK FOR UFD ANYWHERE
	SIXBIT	/DSK/
	XWD	0,UFDHED
	JRST	DNTAVL		;NO DISK
	MOVSI	A,(SIXBIT /DSK/)
	MOVEM	A,CURSTR	;NOW DSK IS CURRENT STRUCTURE
	PUSHJ	P,UFDSPK	;GET SPECS
	PUSHJ	P,MKUFBF	;GET BUFRS
	FIX	UFDDIR
	LOOKUP	UFD,UFDDIR
	PUSHJ	P,MAKUFD	;NOT AROUND - HAVE TO MAKE ONE
	JRST	SETST2		;FOUND ONE

;GET UFD BUFFERS

MKUFBF:	MOVEI	A,UFDBUF	;ALLOW THE LOOKUP SOME BUFFERS
	MOVEM	A,.JBFF
	INBUF	UFD,UFDN
	POPJ	P,

SYPPFS:	PUSHJ	P,TAB			;TAB OVER TO HELP SEPARATE
					;1 STRUCTURE FROM ANOTHER
UNSLU5:	MOVE	B,FILDIR+1
	MOVEM	B,UFDDIR+2
	TRZN	F,CONTSW	;SKIP 1ST PR-PPN OUTPUT ON /C
	PUSHJ	P,PRPP		;PRINT LAST USER RESTORED
	TRO	F,TAPI		;LITE THE TAPE INPUT FLAG
	SETZM	ONEFIL		;RESET THE "YOU HAVE A FOOT ON A FILE" FLAG
	TLZE	F,TENDF		;FOUND TRAILER YET ?
	JRST	TAPEND		;YEP!
				;CHECK BEFORE YOU GO,
	PUSHJ	P,ITAP		;GET INFORMATION (SKIP EOF'S UNTIL DIRECTORY OR TRAILER/HEADER)
				;AND AFTER YOU COME BACK, CHECK TRAILER
UNSLUU:	TLZE	F,TENDF		;FIND EOT (TRAILER RECORD ?)
	JRST	TAPEND
	TRZ	F,TAPI
	MOVE	D,TAPHED
	MOVE	A,3(D)		;GET 1ST STRUCTURE
					;MENTIONED ON THIS TAPE
	MOVEM	A,CURSTR
UNSLU3:	MOVE	D,TAPHED		;INSURE INDEX IS LOADED
	MOVE	A,5(D)		;GET PP#
	CAMN	A,SYSPP		;1,1?
	JRST	SETST1		;YES
	TRO	F,TAPI		;SET FOR RENTER
				;@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
	PUSHJ	P,USRUFD	;MAKE SURE USER HAS A HOME
				;THIS IS THE  GUTS OF THE /R SYSTEM
UNSLU1:	PUSHJ	P,XFER		;MOVE A USER FILE FROM TAPE TO DISK
	JRST	UNSLU5		;GOT AN EOF (OR TRAILER RECORD)
				;AT ANY RATE, FINISH THIS USERS AREA
RETRN:	TRZ	F,TAPI		;CLEAR AFTER XFER
	JRST	UNSLU1		;EXCELSIOR
UNSLPJ:	PUSHJ	P,FTAPIN	;MOVE TAPE FORWARD
	JRST	UNSLU5		;EOF OR TRAILER FOUND
	JRST	UNSLU1		;DIRECTORY-NEXT FILE

;MAKE A UFD WITH INFINITE QUOTA

MAKUFD:	PUSHJ	P,GETPAK	;INIT MFD FOR NEW UFD'S
	PUSHJ	P,UFDSPK
	HRLOI	A,377777	;LARGEST POSITIVE #
	MOVEM	A,URBQTO	;TO LOGGED-OUT QUOTA WORD
	MOVEM	A,URBQTI	;& LOGGED-IN QUOTA
	MOVEI	A,.RPDIR		;DIRECTORY BIT
	MOVEM	A,URBSTS
MAKU1:	TRO	F,UFDO
	MOVEI	A,MFDBUF	;ROOM FOR ENTER
	MOVEM	A,.JBFF
	OUTBUF	MFD,MFDN
	FIX	UFDDIR
	ENTER	MFD,UFDDIR	;CREATE A UFD
	PUSHJ	P,MAYBE2	;CAN'T UNLESS THIS IS A FRAGMENTATION
				;ERROR, CHECK IT OUT

MAKU2:	IFN	LEVELC,<
	TRNE	F,LEVELC		;IS IT LEVEL-C TIME ?
	JRST	[	OUTPUT	MFD,
		JRST	MAKU3			;YES
		]
	>

	USETO	MFD,2
MAKU3:	IFE	COMUFD,<	CLOSE	MFD,DNC!DONDAL>
	IFN	COMUFD,<	CLOSE	MFD,DNC>

	IFN	MINREL,<
	RELEAS	MFD,		;
		>
	TRZ	F,UFDO
	POPJ	P,
TAPEND:	CLOSE	TAP,		;CLEAR UP TAPE BUFFERS
	IFN	REWIND,<
	MTAPE	TAP,1		;START THE REWIND
	>
	PRLIN1	<$END OF FAILSAFE TAPE#>
	MOVE	D,TAPHED
	HRRE	A,4(D)		;GET TAPE NUMBER
	MOVM	A,A		;MAGNITUDE
	PUSHJ	P,PRNUM		;PRINT IT
	PR1	< FOR#>
	PUSHJ	P,PRTIME
	SETZM	FNDBEG		;NO LONGER KNOW ABOUT FIRST RECORD
	PUSHJ	P,LOOKDT	;GO GET CURRENT TIME/DATE
	PUSHJ	P,DAYTIM	;  & TELL IT TO THE OPR
	SKIPL	5(D)		;CONTINUED?
	JRST	FINTAP		;NO
IFE	REWIND,<
	IFDEF	UNLOAD,<
	MTAPE	TAP,11
	>
	IFNDEF	UNLOAD,<
	MTAPE	TAP,1		;REWIND
	>
	>
	PRLIN1	<TO CONTINUE RESTORING, MOUNT A NEW TAPE ON THE SAME NUMBERED DRIVE & TYPE /R@>
	JRST	FS1AA		;* AND WAIT FOR NEXT COMMAND
FINTAP:	CLOSE	FIL,DNC
	IFN	MINREL,<
	RELEASE	FIL,
		>
	CLOSE	DGA,DNC		;SHADOW TOO
	IFN	MINREL,<
	RELEAS	DGA,
		>

	CLOSE	UFD,DNC
	IFN	MINREL,<
	RELEASE	UFD,
		>


	RELEAS	TAP,			;AND TAPE

	PRLIN1	<THIS IS THE FINAL TAPE.@>
	PUSHJ	P,LFCRLF
	JRST	FS1AA

UFDFA2:	POP	P,A		;SET TO PROPER LEVEL
	PRLIN1	<CANNOT WRITE UFD:#>
	PUSHJ	P,PRPP
UNSLU4:	PUSHJ	P,FTAPIN	;MOVE TAPE FORWARD(NO INPUT)
	JRST	[	TLNN	F,TENDF
			JRST	UNSLU5		;REAL EOF
			JRST	TAPEND	;TRAILER
		]
	JRST	UNSLU4		;IGNOR INDIVIDUAL USERS' FILES

XFER:	MOVE	B,TAPHED	;WHERE TAPE BUFFER IS
	XLIST
	IFG	ALFLEX,<
	LIST
	HRRZ	A,11(B)		;GET # WORDS WRITTEN
	CAIG	A,ALFLEX		;LE TO TOLERENCE ?
	JRST	SKPCHK			;YEP!
	>
	LIST
	XLIST
	IFN	ALPJ1R,<
	LIST
	HLRZ	A,5(B)		;GET PPN
	SOJE	A,SKPCHK		;IS IT PROJECT 1 ?
		>

	LIST
	LDB	S,[POINT 3,CRDATE,23]	;INIT R,S,U + W FOR CHKCRE
	LDB	W,[POINT 3,7(B),20]
	MOVE	U,10(B)			;GET TIME AND DATE OF TAPE FILE
	MOVE	R,CRDATE		;GET TYPED IN TIME AND DATE
	PUSHJ	P,CHKCRE		;WHO IS OLDER
	JRST	[PUSHJ P,FNR		;[47] DONT RESTORE THIS FILE
		JRST FTAPIN]		;[47]
	JFCL
	LDB	A,[POINT	15,7(B),35]		;CHECK ACCESS DATE ON TAPE
	CAMGE	A,ACCDAT	;PRIOR TO SET DATE?
	JRST	[PUSHJ P,FNR1		;[47] YES, DON'T RESTORE THIS FILE
		JRST FTAPIN]	;[47]
SKPCHK:	MOVE	U,5(B)		;GET THIS GUY'S PPN
	CAMN	U,SLGPPN		;IS THIS THE ONE WE ARE GETTING ?
	MOVE	U,SLOPPN	;YOU BET!
	MOVEM	U,5(B)		;SETUP/ OR STAY SAME, DEPENDING ON CAMN
				;TRANSFER THE USER SELECTED
	MOVSI	U,4(B)		;FROM PART OF FROM ,, TO BLT POINTER
	HRRI	U,FILDIR	;TO 1)
	BLT	U,FILDIR+XLOOKN

	TLNE	F,NEWRSW	;IS N SWITCH ON
	JRST	XFER1		;YES, DON'T CHECK DISK FILE DATE
					;WILL NOT BE WHERE
					;IT IS EXPECTED
	MOVE	U,CURSTR	;GET WHERE WE HAVE RESOLVED THIS GUY
				;TO BE GOING
	MOVEM	U,CHKSTR	;SET UP FOR ACCESS/ CREATION CHECK
	FIXDEV
	INIT	CHK,DUMP		;INIT FOR DISK FILE DATE CHECK
CHKSTR:	SIXBIT	/DSK/
	XWD	0,CHKHED	;=UFDHED
	JRST	NODSK		;CAN'T INIT
	FIX	FILDIR
	LOOKUP	CHK,FILDIR	;CHECK CURRENT DISK FILE
	JRST	XFER3		;RESTORE FILE IF LOOKUP FAILS
	IFN	LEVELC,
	<
	TRNE	F,LEVELC
	SKIPA	R,FILDIR+2
	>
	LDB	S,[POINT 3,FILDIR+3,20]	;INIT R,S,U + W FOR CHKCRE
	LDB	W,[POINT 3,7(B),20]
	MOVE	R,FILDIR+4	;GET DISK DAT
	MOVE	U,10(B)		;GET TAPE DAT
	PUSHJ	P,CHKCRE	;TAPE FILE OLDER?
	JFCL			;YES, CLOSE CHK AND GET NEXT FILE
	JRST	[PUSHJ P,FNR	;[47] =, "FILE NOT RESTORED"
		JRST FTPIN1]	;[47]
	CLOSE	CHK,DNC		;NO, CLOSE DISK FILE
	IFN	MINREL,<
	RELEASE	CHK,		;GIVE UP DDB
		>
XFER3:	PUSHJ	P,RSTHDR	;RESTORE LOOKUP HEADER
XFER1:	MOVEI	A,XLOOKN+2	;REMOVE HEADER WORDS FROM BEGINNING OF FILE
				;REMEMBER, THERE WAS AN ILDB AT TAPIN2+1
				;SO THAT TO ACCOUNT FOR 42 OCTAL WORDS IN THE
				;DIRECTORY BLOCK REMAINING FROM THE ORIGINAL 43,
				;ONLY 42 NEED BE ACCOUNTED FOR
	ADDM	A,TAPHED+1


	HRROI	A,-XLOOKN-2	;NOW
	ADDM	A,TAPHED+2	;DECREMENT WORD COUNT

	MOVE	A,CURSTR	;INIT STR IT CAME FROM
	MOVEM	A,XFSTR
	FIXDEV			;FIX UP DEVICE NAME
MODDER:	INIT	FIL,BUFBIN
XFSTR:	0			;SIXBIT /STRNAM/
	XWD	FILHED,0
	JRST	XXFER		;HAVE TO PUT IT ELSEWHERE
	TRO	F,FILO
	PUSHJ	P,GETFBF	;GET BUFFERS FOR FILE
	OUTBUF	FIL,(CH)	;NUMBER OF BUF'S RETURNED IN CH
	FIX	FILDIR
	IFE	LEVELC,
	<
	LDB	A,[POINT 4,FILDIR+.RBPRV,12]
	

	SETSTS	FIL,(A)		;AND SET THAT MODE
	>
	ENTER	FIL,FILDIR
	PUSHJ	P,MAYBE3	;NOT AVAIL. - UNLESS THIS IS A FRAGMENTA-
				;TION ERROR RETURN.
				;IF NOT FRAGMENTATION, PUT FILE ELSEWHERE.


				;RESTORE STATUS & THEN
	JRST	XFER0		;BEGIN RESTORE
MAYBE3:	GETBAD	(A)		;SEE IF FRAGMENTATION OR NOT
XXFER:	PUSHJ	P,RSTHDR	;RESTORE FILE HEADER INFO FOR ENTER
	FIXDEV
MODDR:	INIT	FIL,BUFBIN	;TRY TO PUT IT ANYWHERE
	SIXBIT	/DSK/
	XWD	FILHED,0
	JRST	DNTAVL			;NO DISK
	MOVSI	A,(SIXBIT /DSK/)	;OK, DSK IS ACCEPTABLE
	MOVEM	A,CURSTR		;REMEMBER IT!!

	TRO	F,FILO		;FILE OUT FLAG ON
	PUSHJ	P,GETFBF	;GET BUFFERS
	OUTBUF	FIL,(CH)	;OUTPUT BUFFER SET UP
	FIX	FILDIR


	IFE	LEVELC,<
	LDB	A,[POINT 4,FILDIR+.RBPRV,12]
	SETSTS	FIL,(A)
	>
	ENTER	FIL,FILDIR
	PUSHJ	P,MAYBE4		;FAILURE - CONTINUE ON NEXT FILE
				;UNLESS THIS IS A FRAGMENTATION RETURN
;THE FOLLOWING SECTION OF CODE TRANSFERS A SINGLE DISK-ORIENTED FILE
;FROM TAPE TO THE DISK.

					;COMMUNICATE TO
					;USER THAT SOMETHING IS
					;HAPPENING
XFER0:
	IFE	LEVELC,<
	SETSTS	FIL,BUFBIN		;BUFFER BINARY MODE
	>


	TRNE	F,RESTSW	;IF /R IS ON
				;SKIP INFORMING USER
	JRST	QUIET		;OOPS, KEEP INFORMATION TO YOURSELF


	SKIPN	TALKER		;IF TALK SWITCH IS SET, ALLOW
				;< TO BE PRINTED
	JRST	QUIET		;OTHERWISE, FORGET INFORMING USER


	MOVEI	CH,74			;ASCII <
	PUSHJ	P,TYPEA		;AND DUMP INTO OUTPUT BUFFER
	SKIPN	LSTING		;TEST FOR TTY OUTPUT OF <>
	OUTPUT	TTO,		;  YES, FORCE 1ST BRACKET NOW
QUIET:	TRZ	F,FILO
	MOVE	A,CURSTR
	MOVEM	A,MORE72	;INSURE THE PROPER DEVICE IS SHADOWED


	SKIPN	ONEFIL		;SHADOW CHANNEL OPENED YET ?
	PUSHJ	P,KINCOR	;NOPE! OPEN IT!



	SKIPN	PAKFRE,TAPHED+2		;GET INPUT FILE'S WORD COUNT
	JRST	ACFIL6			;OOOOPS, NO WORDS LEFT
	SKIPN	PAKNAM,FILHED+2		;LIKEWISE FOR OUTPUT FILE
	JRST	ACTAP6			;OOOPS, NO MORE ROOM LEFT IN OUTPUT
					;BUFFER

;______________________*****************_________________________
SETUP2:	HRLZ	S,TAPHED+1		;FROM TAPE TO DISK
	HRR	S,FILHED+1		;FROM,,TO
FASTER:	CAILE	PAKNAM,(PAKFRE)		;
	SKIPA	WASTE,PAKFRE		;TAPE RUNS OUT AND LIMITS BLT
	MOVEI	WASTE,(PAKNAM)		;OUTPUT FILE BUFFER RUNS OUT FIRST
					;DISK LIMITING WORD COUNT
	HRRM	S,TSAF			;DESTINATION ADDRESS
				;SEE EXPLANATION AT "FAST:"
	AOBJP	S,TSAF			;
TSAF:	BLT	S,0(WASTE)




	SUBI	PAKNAM,(PAKFRE)		;FIND OUT WHICH [INPUT OR OUTPUT]
					;OR BOTH THAT YOU NEED TO DO

	JUMPGE	PAKNAM,ACFIL3		;OK, WE SUBTRACTED RIGHT (I.E.,
					;SMALLER SUBTRACTED FROM LASRGER)



	ADDM	WASTE,TAPHED+1		;REPOINT TAPE BUFFER TO REFLECT BLT


					;DISK BUFFER IS FULL
	MOVNM	PAKNAM,TAPHED+2		;UPDATE WORD COUNT
					;TO DISK
					;AND PUT IN BUFFER HEADER
					;SETTING DISK BUFFER TO 0(FULL)

ACTAP6:	PUSHJ	P,FILOUT		;DISK BUFFER FULL

	SKIPN	PAKFRE,TAPHED+2		;SEE IF TAPE BUFFER STILL HAS INFO IN IT
	JRST	ACFIL6			;TAPE RAN OUT CONCURRENTLY WITH
					;DISK'S FILLING UP
	HRRZ	PAKNAM,FILHED+2		;RESTORE THE REFRESHED COUNT TO AC
	JRST	SETUP2
					;TAPE BUFFER IS EMPTY....
ACFIL3:	HRRZM	PAKNAM,FILHED+2		;REMEMBER HOW MUCH ROOM LEFT FOR DISK
	ADDM	WASTE,FILHED+1		;REPOINT TAPE BUFFER TO REFLECT
					;THE BLT

ACFIL6:	PUSHJ	P,TAPIN			;TAPE BUFFER IS EMPTY, PLEASE REFILL
	JRST	TESTQ1			;FILE WE HAD BEEN TRANSFERRING
					;HAS BEEN CLOSED
	JRST	TESTQ2			;DIRECTORY RECORD FOUND
					;LIKEWISE, FILE PREVIOUSLY
					;BEING WRITTEN ON DISK HAS
					;BEEN CLOSED
	SKIPN	PAKNAM,FILHED+2		;MORE DATA TO TRANSFER, DATA RECORD FOUND
	JRST	ACTAP6			;PULL FILE IN FROM TAPE
					;AND CONTINUE PUTTING IT ON DISK
	HRRZ	PAKFRE,TAPHED+2		;REFRESH COUNTER
	JRST	SETUP2

TESTQ1:	TRNE	F,RESTSW
	POPJ	P,		;SKIP IMING USER FOR
	SKIPN	TALKER
	POPJ	P,		;IF DOING /R OR /T IS NOT ON
				;NOTE THAT /T DOES NOT OVERRIDE /R
				;THE SAME REASONS AT XFER0:

FILING:	MOVEI	CH,76		;RIGHT-ANGLE-BRKT
	PUSHJ	P,TYPEA			;OUTPUT
	JRST	CRLF			;RIGHT-ANGLE-BRKT FOLLOWED BY CR-LF

TESTQ2:	TRNE	F,RESTSW
	JRST	CPOPJ1
	SKIPN	TALKER
	JRST	CPOPJ1		;LIKEWISE, SKIP ONFORMING IF /R
				;OR IF /T IS NOT ON IN OTHER CASES

	AOS	(P)			;SET UP FOR SKIP RETURN
	JRST	FILING			;AND OUTPUT A RIGHT-ANGLE-BRKT

CGETDR:	SKIPLE	FILHED		;TRY TO CLOSE DISK OUTPUT FILE
				;BUT FORGET IT, IF FILE NOT OPEN
	CLOSE	FIL,DNC		;CLOSE UP ABORTED DISK FILE
	JRST	FTAPIN		;GET A DELILITER

ITAPIN:	PUSHJ	P,TAPIN		;DIRECTORY OR EOF MUST BE NEXT
	POPJ	P,			;EOF
	JRST	CPOPJ1			;DIRECTORY
	PUSHJ	P,ILLFMT		;IF DATA RECORD, BAD FORMAT
	JRST	ITAPIN

FTPIN1:	CLOSE	CHK,DNC		;CLOSE UP TIME CHECK CHANNEL
	IFN	MINREL,<
	RELEAS	CHK,		;AND GIVE UP DDB
		>
FTAPIN:	PUSHJ	P,TAPIN			;IGNORE DATA RECORDS
	POPJ	P,			;EOF
	JRST	CPOPJ1			;DIRECTORY
	JRST	FTAPIN			;IGNORE DATA RECORDS
SKPTAP:	PUSHJ	P,TAPIN		;GET SOME TAPE
	JRST	ISITHD			;IGNORE EOF'S
					;BUT EOF RETURN IS THE
					;TRAILER RETURN TOO
					;SO SEE WHICH IT IS
	JRST	SKPTAP			;DIRECTORY RECORD
	JRST	SKPTAP			;YOU FOUND DATA, FLUSH IT
ISITHD:	SKIPG	A,TAPHED		;REAL EOF
	JRST	SKPTAP			;YES!
	HRRZ	B,2(A)
	CAIE	B,FSPP-FIRBLK		;IS THE WORD COUNT RIGHT ?
	JRST	SKPTAP			;NOPE
	MOVE	B,3(A)			;IS DATA RIGHT ?
	CAME	B,STARFS		;*FAILS   ??????
	JRST	SKPTAP			;NOPE
	POPJ	P,			;YEP

GETEOF:	SKIPLE	TAPHED			;WE SAW SOMETHING WE DIDN'T LIKE
					;SKIP TO SOMETHING WE DO LIKE
					;DID WE JUST HAPPEN TO LAND ON
					;AN EOF ?
GETEF:	PUSHJ	P,TAPIN			;GET SOME INPUT
	POPJ	P,			;GOT WHAT WAS SOUGHT, EOF
	JRST	GETEF			;FLUSH DIRECTORIES
	JRST	GETEF			;FLUSH DATA

GETDIR:	PUSHJ	P,TAPIN
	JRST	CHKEND			;EOF OR TRAILER FOUND
					;TRAILER RECORDS (RETURN AT EOF)
	POPJ	P,			;GOT A DIRECTORY RECORD
	JRST	GETDIR

CHKEND:	TLNN	F,TENDF			;TRAILER SIGHTED ?
					;TRY RECIRCULATING TAPE
	POPJ	P,
	CLOSE	TAP,
	LOADPT
	POPJ	P,
;GET FIRST RECORD OF A FILE

ITAP:	PUSHJ	P,ITAPIN	;1ST REC. SHOULD BE DIRECTORY
				;BUT IT TAPE ERROR, MAY NOT BE, SKIP
				;UNTIL YOU FIND SOMETHING
				;YOU UNDERSTAND
	JRST	[	TLNN	F,TENDF
			JRST	ITAP		;REAL EOF
			POPJ	P,		;GOT THE TRAILER
		]
	POPJ	P,		;GOT A DIRECTORY

;CLR KEY ARGS IN EXTENDED LOOKUP/ENTER SPECS

FILSPK:	SETZM	FRBPOS
	SETZM	FRBNXT
	SETZM	FRBPRD
	SETZM	FRBUFD
	SETZM	FRBELB
	SETZM	FRBEUN
	POPJ	P,

;RESTORE LOOKUP/ENTER FILE SPECS

RSTHDR:	MOVSI	A,4(B)		;RESTORE LOOKUP HEADER
	HRRI	A,FILDIR
	BLT	A,FILDIR+XLOOKN
	JRST	FILSPK		;CLEAR OUT ENTRIES NOT USED
				;AND RETURN

;SETUP BUFFERS FOR FILE ENTER

GETFBF:	MOVEI	A,FILBUF	;SETUP BUFFERS FOR USER FILE
	MOVEM	A,.JBFF
	MOVE	A,USRPPN	;IF THIS IS 1,2 GIVE HIM ALL WE GOT
	MOVEI	CH,FILN		;PRESET TO LARGER NUMBER OF BUFFERS

	IFG	LOCK,<
	TLNE	F,LOCKER	;LOCKED ?
	POPJ	P,		;YES
		>
				;NOT LOCKED, WELL ARE WE
	CAME	A,FSPP		;1,2 ?
	MOVEI	CH,ALTFLN	;SMALLER NUMBER OF BUFFERS FOR NON 1,2'S
				;WHO AREN'T LOCKED IN CORE
	POPJ	P,

NOCORE:	PRLIN1	<?NOT ENOUGH CORE@>
	JRST	REINFO
;	TAPIN USUALLY RETURNS TO CALL +3
;	IT HAS TWO EXCEPTIONAL RETURNS WHICH SKIP ZERO OR ONE
;	AND THEN RETURN: END OF FILE
;			 DIRECTORY RECORD
;			 DATA RECORD
				;NOTE WELL*
				;TAPHED + 2
				;WILL CONTAIN # OF WORDS READ-1
				;UPON SUCCESSFUL RETURN
				;FROM TAPIN, I.E.,
				;NUMBER OF WORDS IN BUFFER & NUMBER
				;IN RIGHT HAND HALF OF 1ST WORD
				;OF BUFFER AGREE!

TAPIN:	TLZE	F,TENDF		;HAVE WE ALREADY REACHED TRAILER?
	JRST	CPOPJ1		;YES, SIMULATE DIRECTORY RECORD READ(CALL+2)
	TRO	F,TAPI
INN:	IN	TAP,		;READ ANOTHER BUFFER
	JRST	TAPIN2		;READ OK
				;READ NOT SO GOOD, WHAT'S THE MATTER
	STATZ	TAP,740000	;I/O ERROR BITS ON?
	JRST	RTAPIN		;SOMETHING IS WRONG, NOT JUST DIFFERENT
	STATZ	TAP,IOEND	;END OF FILE?
	JRST	TAPIN4		;YES, END USER FILE

RTAPIN:	TRNE	F,DOINGJ	;SOMETHING WAS NOT 100% AOK WITH THE READ
				;BUT THEN WE WERE DOING A /J
				;JUST JUMPING OVER THE SAVE SETS... SO
				;FORGET IT
	JRST	TAPIN3		;SAY IT WAS A GOOD READ
	TRO	F,TAPI		;SET FOR RETURN FROM FORMAT ERROR BELOW
	HRRZ	A,LASTWC#	;SEE IF LAST WORD COUNT = FULL BUFFER
				;IF NOT FULL BUFFER, IT TERMINATED A
				;FILE
	CAIE	A,TAPLEN-4	;FULL BUFFER, THEN IT WAS PROBABLY
				;A DATA RECORD
	JRST	CHKMOR		;WELL, WE FINISHED DEALING WITH
				;THE LAST FILE, SO WE REALLY DON'T KNOW
				;THE NAME OF THIS "NEW" FILE YET
WHONAM:	SKIPN	FNDBEG		;DON'T SAY THE NAME IF WE HAVEN'T SEEN
				;A HEADER RECORD
KNONAM:	PUSHJ	P,TFRERR	;NO, PRINT ERROR MESSAGE & FILE NAME
TAPRES:	PUSHJ	P,CLOFIL		;CLOSE BUT DO NOT TRANSFER FILE
					;CURRENTLY IN HAND
	GETSTS	TAP,B		;GET ERROR BITS
				;AND TRY TO RESCUE
	TRZ	B,760000	;CLEAR ERROR BITS
	SETSTS	TAP,(B)		;SET NEW STATUS
				;? DO WE WANT TO CLOSE TAP, HERE ?
	JRST	ILLTAP		;LOOK FOR SOME LANDMARK
CHKMOR:	MOVE	A,TAPHED	;SEE IF THIS MIGHT NOT
	HLRE	B,2(A)		;BE A DIRECTORY RECORD ITSELF
	AOJE	B,GETNAM	;IF THIS WAS A DIRECTORY RECORD
				;LEFT HALF = -1, WHICH PROPOGATES
				;TO ALL 7'S.
				;IF ADD 1 BRINGS TO = 0, THEN IT WAS A
				;DIRECTORY RECORD
				;THEN I KNOW THE FILE'S NAME
				;ALL I HAVE TO DO IS TO GET IT
	SOJE	B,WHONAM	;HAVE DATA RECORD, BUT DO WE HAVE FILE NAME
				;LAST RECORD WAS NOT FULL, I.E., IT
				;LOOKS AS IF WE HAD JUST READ A TERMINATION RECORD
				;AND THIS GUY SHOWS UP NEXT, BUT HE IS
				;NOT A DIRECTORY RECORD... HMM, SOMETHING IS
				;ROTTEN IN THE STATE OF DENMARK, I
				;WONDER WHAT ELSE WE MIGHT HAVE HERE:

				;WELL, THERE IS THE POSSIBILITY OF A TRAILER
				;OR HEADER RECORD BEING BAD
	MOVE	B,3(A)		;GET FIRST WORD OF RECORD
	CAME	B,STARFS	;SEE IF THIS IS *FAILS
	JRST	NOKNON		;NOPE! DON'T KNOW WHAT THE DEVIL THIS RECORD IS
	HLRZ	B,4(A)			;GET AFE/TAPE #
	CAIE	B,(SIXBIT /AFE/)	;IS IT "AFE" ?
	JRST	NOKNON		;WELL, THEN WE DON'T KNOW WHO IT IS

	HRRE	B,4(A)		;______________HEADER OR TRAILER/
				;FIND OUT WHICH
	JUMPL	B,BADTRA	;POSITIVE # = HEADER
				;NEG = TRAILER

BADHAD:	PRLIN1	<TAPE ERROR READING HEADER; RECORD ACCEPTED@>
	SETOM	FNDBEG		;SET SWITCH SAYING YOU'VE FOUND HEADER
	JRST	TAPIN6

BADTRA:	PRLIN1	<TAPE ERROR READING TRAILER; RECORD ACCEPTED@>
	JRST	TAPIN6		;BAD READ.. WELL, YES, BUT DON'T SHHOT
				;THE OPERATION DOWN, IT MAY NOT
				;BE ABSOLUTELY 100% GOOD DATA, BUT
				;IT IS GOOD ENOUGH TO CONTINUE ON


NOKNON:	SKIPN	FNDBEG			;HAVE WE FOUND THE FIRST RECORD YET ?
	JRST	TAPRES			;NO, DON'T OUTPUT DOUBLE ERROR MESSAGES

	PRLIN1	<TAPE ERROR READING IRRELEVANT RECORD; RECORD IGNORED@>
	STATO	TAP,IOTEND		;OOPS, IS EOT UP ?
	JRST	TAPRES
	JRST	CLOFIL		;CLOSE DISK FILE JUST IN CASE SOME
				;TRANSFER WAS GOING TO DISK


GETNAM:	PUSHJ	P,SETNAM	;SET UP NAME AND POISTIONING
	JRST	KNONAM		;GIVE THE USER NAME OF FILE SINCE
				;IT LOOKED AS IF THE READ ERROR WAS NOT
				;SO DEGRADING AS TO RETURN COMPLETE GARBAGE

TAPIN4:	TRZ	F,TAPI
	CLOSE	TAP,		;CLEAR END BIT
TAPIN5:	SETZM	LASTWC		;SET WORD COUNT TO NOT-FULL
				;WE HAVE PUT FLAG UP
				;SAYING "NAME OF INPUT FILE NOT KNOWN"
				;WHEN (IF) A TAPE ERROR OCCURS
				;ON NEXT IN UUO

	SETZM	ONEFIL		;SET UP FOR SHADOW CHANNEL INITIALIZATION
	TRNE	F,LISTSW!PRNTSW	;LISTING OR PRINTING ?
	POPJ	P,		;RETURN CALL+1 (EOF)
				;IF NOT LISTING OR PRINTING, THEN CLOSE UP
				;FILES YOU WERE WRITING ON THEPDISK


	IFE	COMFIL,<CLOSE	FIL,DNC!DONDAL>
	IFN	COMFIL,<CLOSE	FIL,DNC>
	CLOSE	DGA,DNC
	POPJ	P,

TAPIN3:	STATZ	TAP,IOEND		;DOING /J... AND AN ERROR
					;WELLL, WAS EOF ON ?
	JRST	TAPIN4			;YES
TAPIN2:	TRZ	F,TAPI		;RESET INPUT FLAG

	ILDB	B,TAPHED+1	;PICKUP WORD COUNT
				;SEE.

				;HOW MANY WORDS CAME IN ON THIS BUFFER
	SOS	CH,TAPHED+2	;PAY UP FOR WORD
	CAIE	CH,(B)		;DO MONITOR AND FAILSAFE AGREE ON RECORD LENGTHS ?
	PUSHJ	P,DISCRP		;ARG! NO!!


	HRRZM	B,LASTWC	;IN EITHER EVENT, REMEMBER WHAT WORD
				;COUNT MOST PROBABLY IS
	HLRE	A,B		;GET LEFT HALF
	JUMPE	A,CPOPJ2	;JUMP IF DATA RECORD
	JUMPG	A,TAPIN6	;HEADER/TRAILER
	TRNE	F,DOINGJ		;ARE WE LIABLE TO BE SEEING
					;FUNNY FILES<BOOTSTRAPING/>
					;IF SO,  DON'T WORRY ABOUT
					;NEGATIVE COUNTS<JRST	CPOPJ1>
	JRST	CPOPJ1
					;BE WORRIED.
	CAMN	A,[-6]		;OLD FORMAT?
	JRST	FAILSC		;OLD STYLE TAPE!
	AOJN	A,CHKNEG		;CHECK TO SEE IF NEGATIVE LEFT HALD
					;IS = -1 (IF SO, = FAILSA
					;DIRECTORY RECORD)
					;OR
					;IF JUST NEGATIVE
					;OTHER THAN -6 = PROBABLY
					;A MAGRIM OR SAVE FORMAT

	TRNN	F,LISTSW!PRNTSW		;IF PRINTING OR LISTING
				;DON'T CLOSE WHAT YOU HAVE^7T OPENED
	IFE	COMFIL,<CLOSE	FIL,DNC!DONDAL>
	IFN	COMFIL,<CLOSE	FIL,DNC>

			;DIRECTORY RECORD FOUND!
			;_______________________
	PUSHJ	P,SETNAM		;GET NAME
				;TO WHICHEVER DIRECTORY OUGHT TO GET IT
	TRNE	F,PRNTSW!LISTSW	;DON'T FLIP RPOJ-PROG #'S AROUNG;D
				;IF LISTING OR PRINTING
	JRST	CPOPJ1
				;CHANGES FOR /G AND /O
				;/O********/G
				;/G________/O
				;CHANGES
	MOVE	B,TAPHED
	MOVE	A,5(B)		;GET PROJECT-PROG # WHO OWNS THIS FILE
	CAMN	A,SYSPP		;IS IT 1,1
	MOVEI	B,1(B)		;IT IS 1,1   .. BUMP POINTER TO LOOK AT
				;FILE NAME, NOT OWNER
				;NOT OWNER OF FILE FOT THIS FILE
				;POINTER SET UP
SWAPI:	MOVE	U,5(B)		;DO WE, OR DON'T WE, SWAP
	MOVE	A,SLOPPN	;IS THIS THE FELLOW
				;WE ARE GOING TO CREATE OUT OF THE /G FELLOW ?
	CAME	A,SLGPPN	;FIRST, THOUGH .. ARE /G AND /O THE SAME
				;IF SO, CANNOT CREATE TWO UFDS.. TWO
				;FILE AREAS (ONLY LAST NE WOULD "WIN").
	CAME	U,A		;HMMM, NOT THE SAME...
				;WELL, IS THE GUY IN HAND
				;THE GUY WE WILL CREATE?

	JRST	CPOPJ1		;EITHER THE /O PPN = /G PPN
				;OR THEY ARE NOT EQUAL, BUT THIS IS NOT THE
				;/O FELLOW
				;DUMP THIS GUY,
				;HE IS THE /O FELLOW, AND IF WE DON' DUCK HIM
				;THERE WILL SURELY BE TWO
				;/O UFDS AND TWO AREAS WE TRY TO CREATE
				;LOOK FOR NEXT DIRECTORY !
	JRST	INN		;RETURN
				;WHEN THIS FELLOW IS BY-PASSED




DISCRP:	TRNE	F,DOINGJ		;IF SKIPPING
					;DON'T SWEAT THE INCONSISTENCY
	POPJ	P,
	SKIPN	FNDBEG			;HAVE WE VERIFIED THIS AS A FAILSA TAPE ?
	POPJ	P,			;NOPE, TAKE MONITOR'S WORD THAT
					;RECORD LENGTH IS OK

	PRLIN1	<RECORD LENGTH INCONSISTENCY IN#>
	HLRZ	A,B		;IS THIS WHAT LOOKS LIKE A DIRECTORY RECORD ?
	CAIN	A,-1			;DIRECTORY RECORD ?
	PUSHJ	P,SETNAM		;SET UP NEWLY FOUND NAME
	PUSHJ	P,PRUFL			;WITH NAME SET UP, WRITE IT OUT
					;OFFENDER
					;THEN,
	POP	P,T			;RESTORE LEVEL
	JRST	SEARCH			;SKIP TAPE TIL YOU RECOGNIZE SOMETHING

CHKNEG:	SKIPE	FNDBEG		;FOUND FIRST FILE YET ?
	JRST	FROG		;YES

	PRLIN1	<SKIPPING WHAT APPEARS TO BE A SAVE OR MAGRIM FORMAT FILE.@>
FROG:	CLOSE	TAP,0		;CLOSE UP TAPE
	MTAPE	TAP,7			;BACK UP OVER POSSIBLE EOF
	MTAPE	TAP,16			;FOWARD TO EOF
	JRST	INN			;READ ANOTHER TIME
SETNAM:	MOVE	B,TAPHED		;FIND WHERE YOU ARE
	MOVSI	A,4(B)		;AND WHERE YOU WANT TO
				;START BLT FROM
	HRRI	A,FILDIR	;TO FILDIR AND POSSIBLY SOME ONE ELSE
	BLT	A,FILDIR+1+3		;AND XFER
				;NOW....

	MOVE	A,TAPHED
	MOVE	B,5(A)		;GET PPN AGAIN
	CAME	B,SYSPP		;OUR FRIEND 1,1 AGAIN ?
	POPJ	P,		;NOT 1,1.. THEN NOT A UFD
	MOVSI	A,4(A)		;FROM,,TO
	HRRI	A,UFDDIR	; _ TO
	BLT	A,UFDDIR+1+3	;SET FILE DIRECTORY TOO

GOT11:	POPJ	P,		;RETURN
				;NOTE THAT THE  BLT-ED "DIRECTORY" REFLECTS
				;THE REAL USER
				;BUT WE ARE TRANSFERRING FOR THE SWAPPED
				;PROJECT-PROG #
CPOPJ2:	AOS	0(P)		;RETURN TWO SKIPS
CPOPJ1:	AOSA	0(P)		;RETURN +1
APOPJ:	POP	P,A		;RETURN ONE LEVEL UP
CPOPJ:	POPJ	P,		;RETURN

FILOUT:	TRO	F,FILO
	OUT	FIL,		;OUTPUT THE FILE
	JRST	FILOU3		;WRITTEN OK
RFILOU:	PRLIN1	<ERROR WHILE WRITING USER FILE@>
	PUSHJ	P,PRUFL		;PRINT USER'S FILE NAME
	PUSHJ	P,CLOFIL
				;CLOSE FILE CHANNELS
				;
	POP	P,A		;RETURN TO +1 LEVEL

FILOU3:	TRZ	F,FILO
	POPJ	P,
CLOFIL:	CLOSE	FIL,DONXFR!DNC
	CLOSE	DGA,	DNC
	POPJ	P,
				;FOUND A TRAILER OR A HEADER

TAPIN6:	MOVE	B,TAPHED	;GET TAPE INFORMATION
	MOVE	A,3(B)		;THIS WORD SHOULD SAY
	CAME	A,STARFS	;"*FAILS"
	JRST	INN		;NO???, IRRELEVANT RECORD
				;TRY TO FIND SOMETHING YOU UNDERSTAND
	HLRZ	A,2(B)		;GET VERSION NUMBER
	HRRZM	A,VERNO		;SAVE IT
	HRRE	A,4(B)		;SEE WHETHER HEADER OR TRAILER
	JUMPG	A,HDRREC	;FOUND A HEADER ...TREAT LIKE DIRECTORY
TRLR:	TLO	F,TENDF		;LOGICAL EOT FOUND, OR REAL EOT
				;TREAT LIKE EOT
				;THIS IS A TRAILER RECORD (PREMATURE LOGICAL EOT)
				;CLOSE UP FIL
				;BUT! EOT FOR US ANYWAY
	JRST	TAPIN5		;TRAILER READ, NOW SIMULATE EOF READ



HDRREC:	SETOM	FNDBEG		;YOU'VE FOUND THE  HEADER RECORD!!
	SKIPG	FILHED		;DID WE RUN INTO A HEADER RECORD
				;WHILE READING TAPE ?
				;IF SO, THEN WE HAVE A NEW STARTING POINT
				;CLOSE WHAT WE HAVE AND START AGAIN

	JRST	CPOPJ1


STRSTP:	PRLIN1	<UNEXPECTED HEADER RECORD ENCOUNTERED@>
	PUSHJ	P,SFEODR
	TRNN	F,LISTSW!PRNTSW
	PUSHJ	P,CLOFIL		;CLOSE UPON ERROR
	JRST	FTAPIN		;TRY TO FIND SOMETHINF YOU UNDERSTAND




SFEODR:	PR1	<SEARCHING FOR EOF OR DIRECTORY RECORD@>
	POPJ	P,

;SELECTIVE RESTORE COMMAND

;ACCEPT LETTER OR DIGIT, AND BUILD IDENTIFIER

NLETTR:	AOJG	R,FS2		;IGNORE CHARACTERS AFTER SIXTH
	MOVEI	CH,-40(CH)	;CONVERT TO SIXBIT
	IDPB	CH,S		;STASH INTO IDENT
	TLO	F,CSSW!ETWASW	;INDICATE CHAR SEEN
	JRST	FS2		;GET ANOTHER CHARACTER

;FILE DELIMITER

EXTDLM:	TLOE	F,PERSW		;PERIOD SEEN?
	JRST	FILDL1		;YES, THAT MAKES TWO
	TLZN	F,CSSW		;ANYTHING SEEN?
	TDZA	A,A		;BLANK FILENAME
	MOVE	A,IDENT		;YES, STORE IDENT AS FILNAME
	MOVEM	A,NAME
EXDLM1:	TLZ	F,CSSW		;START WITH A CLEAN SLATE
	HRROI	R,-3		;BUT ONLY GET 3 LETTERS NEXT TIME
	JRST	FS1.7		;GET EXTENSION (OR DELIMITER)

;ALL FILES CHARACTER

ALLFIL:	TLZE	F,CSSW		;PART OF A NAME?
	JRST	ALLFI1		;YES, * IN NAME ILLEGAL
	TLNE	F,PERSW		;PERIOD SEEN?
	TLOA	F,EXTSW!ALLFSW!ETWASW	;INDICATE EXT WILD
	TLO	F,NAMESW!ALLFSW!ETWASW	;INDICATE NAME WILD
	JRST	EXDLM1

;OUTPUT SPEC DELIMITER

COMMA:	PUSHJ	P,DO		;PROCESS FILE
	JRST	FS1.5		;GET NEXT IDENT

;LINE TERMINATOR

LINTER:	PUSHJ	P,DO		;PROCESS LAST FILE
	JRST	FS1A		;GET NEXT COMMAND
;SELECTIVE RESTORE ROUTINE
;PROCESSES ONE FILE SPECIFICATION

DO:	TRO	F,SLRESW	;SELECTIVE RESTORE IN PROGRESS
	TLZN	F,ETWASW	;ANYTHING ON THIS LINE SO FAR?
	POPJ	P,		;NO
	SETZM	STARPT#			;STARTING POINT NOT YET FLAGGED
	SETZB	A,ANYFIL#		;LIKEWISE,
					;RESET SWITCH THAT SAYS THERE HAVE
					;BEEN SOME FILES FOUND FOR THE PERSON
					;NAMED BY /G

	TLNE	F,PPFSW			;GOT SOMEWHERE ? LIKE TO JOB'S
					;PLACE ON TAPE ?
					;AND SKIP
	SETOI	A,			;-1 _ A
	MOVEM	A,ANYPPN#		;RESULT INTO CORE

					;WHENEVER STARPT = 0
					;WE SHALL GET THE DEVICE
					;PPN
					;FILENAME
					;AND EXTENSION OF OUT STARTING
					;POINT ON THE TAPE
					;IF WE DON'T FIND PROJ-PPN
					;SOUGHT BEFORE WE FIND OUR
					;STARTING POINT, WE HAVE
					;COMPLETELY CIRCLED THE TAPE
					;SO
					;THE GUY SOUGHT 'TAINT THERE.
					;
	MOVE	A,IDENT#	;STASH IDENTIFIER AWAY
	TLNN	F,PERSW		;HAS A PERIOD BEEN TYPED?
	MOVEM	A,NAME		;NO, IDENT WAS NAME
	MOVEM	A,EXT		;(YES) STORE AS EXTENSION
	TLZN	F,PERSW		;DO WE HAVE AN EXTENSION?
	SETZM	EXT		;NO, MAKE NULL EXTENSION
	TLNE	F,ALLFSW	;ANY * TYPED?
	JRST	DOALL1		;YES, PROCESS THEM
	TLNE	F,PPFSW		;ARE WE POSITIONED?
IFN	REWIND,<
	JRST	[
		SKIPG	B,TAPHED
		PUSHJ	P,SETIN
		MTAPE	TAP,1
		JRST	DO2A]		;DON'T INIT A TAPE THAT'S ALREADY INIT-ED
					;IF REWINDING, YOU MUST RE-FIND PPN

	>
	IFE	REWIND,<
	JRST	[SKIPG	B,TAPHED
			JRST[
			PUSHJ	P,SETIN
			JRST	DO2A]
		HLRE	A,2(B)
		AOJE	A,DO1
		PUSHJ	P,GETDIR
		PUSHJ	P,GSTRPT		;GET A STARTING POINT
		MOVE	B,TAPHED
		MOVE	A,5(B)		;SAME PPN
		CAME	A,SLGPPN
		JRST	NOTME2		;NOPE
		JRST	DO1		;YEP
		]
	>
	SKIPG	TAPHED
	PUSHJ	P,SETIN
DO2A:	SKIPE	FNDBEG			;WAIT... HAVE WE FOUND THE FIRST
					;RECORD (HEADER RECORD)
					;THUS IDENTIFIYING THIS AS A FAILSA
					;TAPE ?  IF SO, 
					;FORGET GOING THROUGH THE IDENTIFICATION
					;SEQUENCE
	JRST	DO2B
	PUSHJ	P,UNSAV2		;INSURE BUFFERS,
	PUSHJ	P,GETEOF		;SKIP TO EOF
					;VERIFY AS 5-SERIES TAPE
					;PUBLISH INFO
					;AND COME BACK
DO2B:	PUSHJ	P,XPLUSR		;EXPLANE TO THE USER WHAT IS HAPPENING
				;WHOM WE ARE LOOKING FOR
DO2:	PUSHJ	P,FINDPP	;MOVE TO NEXT AREA FOR THIS USER
NDPP:	JRST	HITEOT		;HIT EOT, EOF
				;OR RETURNED TO STARTING PLACE ON THE TAPE
DO1:	PUSHJ	P,THSFIL	;SHOULD WE COPY THIS FILE?
	JRST	NOTME3		;NOT ME
				;BUT CHECK TO SEE IF THIS MIGHT BE THE
				;STARTING PLACE ON THE TAPE
	PUSHJ	P,USRUFD	;GET A UFD IF HE NEEDS IT
	TDO	F,[XWD	PPFSW,TAPI]		;SET POSITION SWITCH FOR
						;A STOP HERE & FOR REEENTER
	PUSHJ	P,XFER		;COPY IT
	TLZ	F,PPFSW		;ON HITTING EOF OR EOT, WE NO LONGER
				;KNOW WE ARE WITHIN THE BOUNDS OF A
				;USER AREA
				;TAPE
	TRZ	F,TAPI		;CLEAR AFTER XFER
	TLNN	F,TENDF		;DO WE HAVE EOT ?
	POPJ	P,		;RETURN

HITEOT:	SKIPG	Q,TAPHED
	JRST	NOTME2		;WE HIT EOF, SINCE TAPE HAS BEEN CLOSE'D
	TLZN	F,TENDF		;IS IT EOT
	JRST	NOTME1		;NO! WE ARE WHERE WE STARTED
				;TAPE AT TRAILER RECORD = LOGICAL EOT
				;CLOSE UP AND GET  TO  BEGINNING OF SAVE SET
WINDER:	CLOSE	TAP,0
	LOADPT
	JRST	NOTME2		;SET UP TO FIND OUR PPN AGAIN

NOTME1:	SKIPN	ANYPPN
	JRST	NOPROJ		;NO PROJECT NN,MMM SEEN
	SKIPE	ANYFIL
	POPJ	P,
NOPPNF:	PRLIN1	<CANNOT FIND#>
	MOVE	B,NAME

	PUSHJ	P,PRNAME
	MOVE	B,EXT
	PUSHJ	P,PREXT
ONTHTP:	PR1	< ON THIS TAPE.@>
	POPJ	P,		;ASK WHAT NEXT

NOTME2:	TLZ	F,PPFSW		;EOF FOUND,LEAVING A KNOWN AREA
NOTME3:	PUSH	P,[NDPP]
	JRST	FINDP1

IFE	REWIND,<
;	REWIND TAPE & THEN /J BACK TO SAVE SET WE WERE ON
REWJMP:	SKIPE	RECIRC		;IF WE CAN, RECIRCULATE (REWIND AND ADVANCE THROUGH)
				;THE TAPE
	JRST	BKBKSP		;REPOSITION THE TAPE TO THE BEGINNING OF THE CURRENT USER
	MTAPE	TAP,1		;REWIND
	SETZB	A,FNDBEG	;REFRESH J COUNTER & RESET FLAG
				;SAYING I'VE FOUND BEGINNING RECORD

	EXCH	A,JFLAG		;
	MOVEM	A,JCTR#		;TEMP STORE
REW1:	SOSGE	JCTR		;LOOP TO DO AUTO /J'S
	POPJ	P,		;RETURN
	PUSHJ	P,JMPSAV	;MORE TO NEXT SAVE SET
	JRST	REW1		;ALWAYS SKIPS
	JRST	REW1		;ANY MORE?

>
	;SELECTIVE RESTORE
;PROCESSES FILE SPECIFICATIONS WITH *'S

DOALL1:	TLNE	F,PPFSW		;DO WE HAVE THE PPN DESIRED ?
	IFE	REWIND,<
	JRST	[	SKIPG	B,TAPHED
			JRST	[	PUSHJ	P,SETIN
			JRST	DOALL0
			]
			HLRE	A,2(B)
			AOJE	A,DOALL5
			PUSHJ	P,GETDIR
			MOVE	B,TAPHED
			MOVE	A,5(B)
			CAME	A,SLGPPN
			JRST	DOALL7
			JRST	DOALL5
			]

		>
	IFN	REWIND,<
	JRST		[SKIPG	B,TAPHED
			PUSHJ	P,SETIN
			MTAPE TAP,1
			JRST	DOALL0
			]
	>
	SKIPG	TAPHED
	PUSHJ	P,SETIN
DOALL0:	SKIPE	FNDBEG
	JRST	DOALL9

				;IF TAPE NOT  ALREADY IDENTIFIED
	PUSHJ	P,UNSAV3	;VERIFY AS 5-SERIES TAPE
				;SAME AS @ UNSAV2, EXCEPT DON'T
				;INIT THE TAPE
	PUSHJ	P,GETEOF	;CLOSE UP TAPE
DOALL9:	PUSHJ	P,XPLUSR	;EXPLAIN TO USER WANT
				;WE ARE LOOKING FOR IN THE [PP,NO]
				;LINE
DOALL4:	PUSHJ	P,FINDPP	;MOVE TO NEXT AREA FOR THIS USER
NDPP1:	JRST	EOTHIT		;HIT TRAILER RECORD (LOGICAL EOT)
					;EOF, OR STARTING PLACE ON THE TAPE
DOALL5:	PUSHJ	P,THSFIL	;LOOK FOR OTHER HALF OF SPEC
	JRST	DOALL8		;DON'T TRANSFER THIS GUY
				;BUT THIS FILE
				;MIGHT BE STARTING PLACE ON THE TAPE
	PUSHJ	P,USRUFD	;GET A UFD IF NEED BE
	PUSHJ	P,XFER		;FOUND, COPY IF DATE OK
	JRST	DOALL7		;EOF, TRY NEXT AREA
	JRST	DOALL5		;TRANSFERRED THE GUY WANTED
				;SEE IF THERE ARE MORE





DOALL7:	TLZ	F,PPFSW		;LEAVING A KNOWN AREA
DOALL8:	TLNE	F,TENDF		;DO WE HAVE TRAILER RECORD
	JRST	EOTHIT		;GOT IT!
	PUSH	P,[NDPP1]
	JRST	FINDP1



EOTHIT:	SKIPG	Q,TAPHED
	JRST	DOALL7		;WE HAVE A REAL EOF
	TLZN	F,TENDF		;AT LOGICAL EOT (TRAILER RECORD SEEN ?)
	JRST	NOPROJ
	CLOSE	TAP,0		;TRAILER RECORD FOUND

	LOADPT
	JRST	DOALL7		;GET TO START OF SAVE SET
				;AND LOOK FOR A MATCH ON PPN
;MISCELLANEOUS MOVEMENTS

BKBKSP:	PUSHJ	P,BKSP		;RETURN TO FRONT OF THIS SAVE SET
BKSP:	TRZ	F,TAPI		;CLEAR AFTER XFER
	SKIPL	TAPHED		;SHUT DOWN FILE
	CLOSE	TAP,0		;IFF IT NEEDS IT
	MTAPE	TAP,7		;BACK ONE RECORD
	MTAPE	TAP,17		;ONE OTHERWISE
	POPJ	P,		;RETURN


;POSITION TAPE FOR USER
;CALL:	PUSHJ P,FINDPP
;	EOT RETURN
;	FOUND AREA RETURN

FINDPP:	PUSHJ	P,BKSP		;BACKSPACE FILE
	MTAPE	TAP,6		;ADVANCE FILE
				;BY ADVANCING A RECORD OVER FILE MARK
FINDP1:	PUSHJ	P,FTAPIN	;IGNORE DATA
	 POPJ	P,		;HAVE REACHED LOGICAL EOT
	MOVE	B,TAPHED	;WHERE THE DATA IS
	HLRE	A,2(B)		; HEADER?
	JUMPG	A,ADAFHD	;SEE WHICHEVER
	SKIPN	STARPT		;GOT STARTING POINT ?
	JRST	[
		PUSHJ	P,GSTRPT
		JRST	NOTSAM
		]
	MOVE	B,TAPHED
	MOVE	A,6(B)
CHKLEE:	CAMN	A,FIRFIL		;SEE IF WE HAVE COME FULL CIRCLE
	JRST	SEEM1					;MAYBE


NOTSAM:	MOVE	A,5(B)		;GET DIRECTORY'S PPN
	CAMN	A,SLGPPN		;SAME AS USER'S
	JRST	ESTBL1			;THEN SAY SO
	JRST	FINDP1

ADAFHD:	PUSHJ	P,GETEOF	;ADVANCE TO BEGINNING OF NEXT USER
	TLNE	F,TENDF		;CHECK TO SEE IF TRAILER SPOTTED
	POPJ	P,		;GOT ONE!
SEEM1:	HLLZ	A,7(B)
	CAME	A,FIREXT
	JRST	NOTSAM
	MOVE	A,FIRPPN
	CAME	A,5(B)
	JRST	NOTSAM
	MOVE	A,FIRSTR
	CAME	A,3(B)
	JRST	NOTSAM
	POPJ	P,		;MATCH FOUND , GIVE POJ RETURN

NOPROJ:	SKIPE	ANYPPN			;FIND OUR GUY ?
	JRST	FILES			;YEP, NOW DID WE GET
					;ANY OF THE FILES SELECTED
	PRLIN1	(CANNOT FIND#)		;OOOPS, NO FILES

	MOVE	TMP,SLGPPN
	PUSHJ	P,PRPPN1
				;SIGNAL THAT YOU WANT A NEW STARTING POINT
	JRST	ONTHTP		;CANNOT FIND [PROJ-PROG] ON THIS TAPE
				;AND POPJ BACK
FILES:	SKIPE	ANYFIL		;IF  NO FILES, TELL HIM ABOUT IT
	POPJ	P,

TEOFS:	PRLIN1	<TAPE EMPTY OF FILES SPECIFIED@>
	POPJ	P,

GSTRPT:	MOVE	A,3(B)		;GET STARTING STRUCTURE
	MOVEM	A,FIRSTR#

	MOVE	A,6(B)
	MOVEM	A,FIRFIL#		;STARTING FILE
	HLLZ	A,7(B)			;AND EXT
	MOVEM	A,FIREXT#

	MOVE	A,5(B)
	MOVEM	A,FIRPPN#
	SETOM	STARPT		;SET FLAG SAYING YOU KNOW WHERE YOU STARTED
	POPJ	P,
;COMPARE SPECIFIED NAME WITH NAME ON TAPE

;CALL:	PUSHJ P,THSFIL
;	UNSUCCESSFUL RETURN
;	SUCCESSFUL RETURN

THSFIL:	MOVE	B,TAPHED	;FIND BEG OF BUFFER
	TLNE	F,NAMESW	;LOOK AT NAME?
	JRST	THSFI2		;IGNORE
	MOVE	A,NAME		;CHECK EQUALITY
	CAME	A,6(B)
	POPJ	P,		;UNSUCCESSFUL RETURN
THSFI2:	TLNE	F,EXTSW		;LOOK AT EXTENSION?
	JRST	ESTBL2		;NO - SUCCESSFUL ..EVERY FILE WINS
	HLLZ	A,7(B)		;GET EXTENSION
	CAMN	A,EXT
	JRST	ESTBL2		;RETURN TO CALL + 2
				;HAVE FOUND HIM FIRST
	POPJ	P,		;UNSUCCESSFUL

;ESTABLISH YOU HAVE FOUND A USER.. DON'T LET HIM STAY AT TTY FOREVER
;WITHOUT SOME IDEA OF WHAT IS HAPPENING
ESTBL1:	SETOM	ANYPPN			;YOU HAVE ESTABLISHED CONTACT WITH A
	TLON	F,PPFSW			;AT LEAST 1 AREA (ANYPPN SET)
					;AND ARE NOW INSIDE AN AREA
					;PPFSW SET
	TRNE	F,LISTSW!PRNTSW!RESTSW	;SEE IF YOU ARE PRINTING
					;OR LISTING
					;OR /R - ING
					;IF SO, SKIP ESTABLISHING CONTACT
	JRST	CPOPJ1
ESTPR1:	PRLIN1	<FOUND ON TAPE#>
	MOVE	A,TAPHED		;GO AFTER STRUCTURE
	MOVE	B,3(A)			;THEN
	PUSHJ	P,FIXSPA		;RIGHT JUSTIFY THE DEVICE NAME
	PUSHJ	P,PRNAME
	PUSHJ	P,SPACE			;OUTPUT A SPACE
	MOVE	A,TAPHED
	MOVE	TMP,5(A)		;NOW PROJ-PROG NUMBER
	PUSHJ	P,PRPPN1		;FOUND DSKXXX<TAB>[PROJ-PROG]
					;NOW TYPED OUT
	PUSHJ	P,CRLF
	JRST	CPOPJ1			;RETURN TO CALL + 2
ESTBL2:	SETOM	ANYFIL		;ESTABLISH CONTACT WITH AT LEAST 1 FILE
	SETOM	ANYPPN		;FILE FOUND IMPLIES PPN FOUND
					;AND
	TLO	F,PPFSW		;ALSO IMPLIES WE ARE WITHIN PPN AREA
	TRNE	F,LISTSW!PRNTSW!RESTSW	;DONT PUBLISH
				;IF /RESTORING /PRINTING OR /LISTING
	JRST	CPOPJ1
	SKIPN	TALKER		;HMM, IS TALKER SWITCH ON ?
	JRST	CPOPJ1		;NOPE!

ESTPR2:	PRLIN1	<LOCATED ON TAPE#>

ESTPR3:	MOVE	A,TAPHED		;[47] GET CURRENT STRUCTURE
	MOVE	B,3(A)	;
	PUSHJ	P,FIXSPA		;RIGHT JUSTIFY THE DEVICE NAME
	PUSHJ	P,PRNAME
	MOVEI	CH,72			;AN ASCII :
	PUSHJ	P,TYPEA
	PUSHJ	P,SPACE			;OUTPUT A SPACE
	MOVE	A,TAPHED
	MOVE	B,6(A)
	PUSHJ	P,PRNAME		;SIX SIXBIT
					;OF FILE NAME
	MOVE	A,TAPHED
	HLLZ	B,7(A)
	PUSHJ	P,PREXT
	PUSHJ	P,CRLF		;A CR AND LF
	JRST	CPOPJ1		;FINIS

	;RIGHT JUSTIFY THE SIXBIT THING IN "B"
FIXSPA:	TRNE	B,77		;RIGHT MOST CHARACTER A SPACE?
	POPJ	P,		;NO SO EXIT
	LSH	B,-6		;ROTATE TO RIGHT 6
	JRST	FIXSPA		;LOOP TIL DONE

FNR:	LDB	A,[POINT 3,7(B),20]	;[47] GET TOGETHER
	LDB	U,[POINT 12,10(B),35]	;[47] A CREATION
	LSH	A,14			;[47] DATE
	IOR	A,U			;[47]
FNR1:	CAIE	A,10000			;[47] IF DATE = 1/5/75 OR
	CAIGE	A,2134			;[47] LESS-THAN 1/1/67
	CAIA				;[47] TELL USER FILE NOT RESTORED
	POPJ	P,			;[47] ELSE GET NEXT FILE
	LDB	A,[POINT 15,7(B),35]	;[47] GET ACCESS DATE
	PUSH	P,A			;[47] SAVE IT
	LDB	A,[POINT 3,7(B),20]	;[47] GET CREATION DATE
	LDB	U,[POINT 12,10(B),35]	;[47]
	LSH	A,14			;[47]
	IOR	A,U			;[47]
	PUSH	P,A			;[47] SAVE IT
	PRLIN1	<FILE NOT RESTORED#>
	PUSHJ	P,ESTPR3		;[47] PRINT FILE DESCRIPTOR
	 JFCL				;[47]
	PR1	<CREATE DATE:#>
	POP	P,Q			;[47] RESTORE CREATE DATE
	PUSHJ	P,YRSMOS		;[47] PRINT IT
	PR1	<ACCESS DATE:#>
	POP	P,Q			;[47] GET ACCESS DATE
	JRST	YRSMOS			;[47] PRINT AND RETURN
;CREATE AN INFINITE UFD FOR THE USER IF HE NEEDS IT

USRUFD:	MOVE	D,TAPHED	;WHERE DATA IS
	MOVE	A,3(D)		;GET THE STRUCTURE
	MOVEM	A,USRPP		;THREE PLACES TO LOOK FOR STRUCTURES
	MOVEM	A,CURSTR
	MOVEM	A,FIXU2		;SET UP STRUCTURES FROM THAT SIGNALED BY TPE
	PUSHJ	P,DOUFD		;SET UP UFD FROM INFORMATION ON TAPE
				;SWITCHING /G & /O AS REQUIRED
	FIXDEV
	INIT	UFD,BUFBIN	;LOOKUP ONLY
USRPP:	0
	XWD	0,UFDHED
	JRST	GETUSR		;TRY ELSEWHERE
	PUSHJ	P,MKUFBF

	FIX	UFDDIR
	LOOKUP	UFD,UFDDIR
	JRST	FIXUSR		;NO UFD -  HAVE TO MAKE ONE
UFCL:	CLOSE	UFD,DNC
	IFN	MINREL,<
	RELEAS	UFD,
		>
	POPJ	P,

FIXUSR:	CLOSE	UFD,DNC
	IFN	MINREL,<
	RELEASE	UFD,
		>
	FIXDEV
	INIT	MFD,BUFBIN	;CREATE UFD ON DESIRED STR
FIXU2:	0
	XWD	MFDHED,0
	JRST	GETUSR
	PUSHJ	P,DOUFD		;SET UP SPEC AND CLEAN UPS
	OUTBUF	MFD,MFDN
	FIX	UFDDIR
	ENTER	MFD,UFDDIR
	PUSHJ	P,MAYBE5	;IF NOT ERROR 17, TRY ELSEWHERE.
				;SEE IF ERROR 17 ON EXTENDED ENTER
	JRST	MAKU2		;CLOSE MFD & RET

MAYBE5:	GETBAD	(A)	;SEE IF 17 ERROR CODE
				;POPJ BACK IF SO, POP OFF AND FALL INTO
				;GETUSR IF NOT
GETUSR:	INIT	UFD,BUFBIN	;UFD ANYWHERE?
	SIXBIT	/DSK/
	XWD	0,UFDHED
	JRST	DNTAVL		;BAD NEWS
	MOVSI	A,(SIXBIT /DSK/)
	MOVEM	A,CURSTR
	PUSHJ	P,DOUFD		;SET SPECS
	PUSHJ	P,MKUFBF
	LOOKUP	UFD,UFDDIR
	CAIA
				;SPR # 10-5298
				;THANKS! JOHN EDGECOMBE!!
	JRST	UFCL		;FOUND
	PUSHJ	P,GETPAK	;NO UFD - MAKE ONE ANYWHERE
	PUSHJ	P,DOUFD
	JRST	MAKU1		;ENTER & RET

DOUFD:	MOVE	A,[XWD UFDDIR+4,UFDDIR+5]
	SETZM	UFDDIR+4
	BLT	A,UFDDIR+XLOOKN
	MOVE	A,SYSPP		;1,1 HAS THE UFD'S
	MOVEM	A,UFDDIR+1
	MOVEI	A,XLOOKN	;40 WORDS OF LOOKUP INFO
	MOVEM	A,UFDDIR


	MOVE	A,5(D)		;GET PPN
	CAMN	A,SLGPPN		;IS THIS THE /G FELLOW
	MOVE	A,SLOPPN		;YES
	MOVEM	A,UFDDIR+2		;UPDATE OR KEEP THE SAME


	MOVSI	A,(SIXBIT /UFD/)
	MOVEM	A,UFDDIR+3
	HRLOI	A,377777	;LARGEST POSITIVE #
	MOVEM	A,URBQTI
	MOVEM	A,URBQTO
	MOVEI	A,.RPDIR		;DIRECTORY BIT
	MOVEM	A,URBSTS
	POPJ	P,
;DATE CHECK
;CALL:	PUSHJ	P,CHKCRE
;RETURNS:	R .GT. U
;		R .EQ. U
;		R .LT. U

CHKCRE:	TRNN	F,RESTSW!SLRESW	;[41];IF SAVING DONT CHECK VERNO
	JRST	CHKCR1		;[41];SKIP THE VERSION CHECK
	MOVE	A,VERNO		;WHICH FAILSA WROTE THIS TAPE?
	CAIGE	A,100		;VERSION 100 HAS 15 BIT DATE FIELD
	JRST	CHKCR2		;[41];JUMP -- MUST BE 12 BIT FIELD
CHKCR1:	CAILE	S,(W)		;[41];COMPARE THE 3 HI-ORDER CREATION BITS
	POPJ	P,		;S IS GREATER
	CAIE	S,(W)		;CRDATE = FILE DATE?	[44]
	JRST	CPOPJ2		;NO .LT.		[44]
CHKCR2:	LDB	S,[POINT 12,R,35] ;[41];CHECK DATES
	LDB	W,[POINT 12,U,35]
	CAILE	S,(W)		;COMPARE
	POPJ	P,		;S IS GREATER
	CAIE	S,(W)		;AGAIN
	JRST	CPOPJ2		;W IS GREATER THAN S
	LDB	R,[POINT 12,R,20]	;RIGHT JUSTIFY THE	[44]
	LDB	U,[POINT 12,U,23]	;  TIME FIELDS		[44]
	CAMLE	R,U		;R .LE. U?
	POPJ	P,		;NO
	CAML	R,U		;=?
	JRST	CPOPJ1		;YES, SKIP
	JRST	CPOPJ2		;.LT. SO SKIP 2

;INITIALIZE MAGNETIC TAPE
SETSYN:	MOVEI	A,SYNCH		;SETUP SYNCHRONOUS INPUT
	MOVEM	A,SYNCIN	;AND FALL INTO INIT
	PUSHJ	P,SETINA	;SKIP UNCONDITIONAL ASYNCHRONOUS MODE
	JRST	GMTABF		;SET MTA BUF'S UP

SETIN:	PUSHJ	P,SETI		;SET FOR IN PUT
	PUSHJ	P,GETCOR	;GET CORE
	JRST	GMTABF		;SET BUF'S UP

SETI:	SETZM	SYNCIN		;INSURE THAT ASYNCHROUNOUS INPUT IS DONE
SETINA:	SETZB	A,LASTWC		;SET LAST WORD COUNT READ = 0
					;TO AID IN FINDING IRRELAVENT
					;RECORDS
	TROA	A,TAPHED		;BUFFER HEADER ADDRESS
SETO:	MOVSI	A,TAPHED		;DITTO FOR OUTPUT

	MOVEM	A,INOUT		;SET HEADER
	SETZM	RECCNT#		;RESET # OF RECORDS WRITTEN SINCE LAST EOF
				;OR DIRECTORY RECORD
IFE	REWIND,<	MOVE	A,INIT1	;GET INIT FUNCTION
	TRZ	A,SYNCH		;CLR SYNC INPUT BIT
	XOR	A,SYNCIN#	;GET CURRENT SYNCH IN
	MOVEM	A,INIT1		;RESET
	>
	MOVE	A,FS6BIT	;DOES LOGICAL DEVICE FAILSA EXIST
	CALLI	A,DEVCHR
	TLNE	A,20		;IS DEVICE A MAGTAPE?
	TLNN	A,40		;IS IT AVAILABLE?
	JRST	NOTAP		;NO TO EITHER: COMPLAIN
INIT1:	INIT	TAP,BUFBIN!NOCNT	;ALLOW PRIVATELY-BUFFERED MTAPES
FS6BIT:	SIXBIT	/FAILSA/
INOUT:	XWD	TAPHED,TAPHED	;BUFR HDR FOR INPUT OR OUTPUT (SET BY ABOVE)
	JRST	NOTAP		;UNLIKELY
	MOVE	A,[XWD 400000,TAPBUF+1]	;INIT 1ST WORD OF HEADER
	MOVEM	A,TAPHED
	POPJ	P,

GETCOR:	MOVEI	A,MFDBUF		;NOW LAST USED CORE LOC
	MOVEM	A,.JBFF
	IFN	LOCK,<
	TLNE	F,LOCKER
	POPJ	P,
	>
	IFE	DEBUG,<
	CALLI	A,CORE			;NOW!
	>
	IFN	DEBUG,
	<
	CAIA
	>
	JRST	NOCORE
	POPJ	P,		;RETURN

GMTABF:	SETBUF	TAP
	POPJ	P,
				;SET UP MAGTAPE BUFFERS

				;MUST HAVE CORE ALLOCATED BEFORE YOU COME HERE
SETOU:	PUSHJ	P,SETO		;THEN SET FOR OUTPUT
	PUSHJ	P,GMTABF	;SET UP THE MAGTAPE BUFFERS
	JRST	NNLTAP		;DO A DUMMY OUTPUT

;INIT THE DISK STRUCTURE WITH THE MOST ROOM LEFT ON IT
;IN ORDER TO CREATE A UFD FOR THIS PROJ-PROG #

GETPAK:	IFN	LEVELC,
	<
	TRNE	F,LEVELC			;ARE WE IN LEVEL-D MODE
	POPJ	P,				;NO!
	>
	MOVSI	PAKNAM,(SIXBIT /DSK/)
	MOVEM	PAKNAM,DEVICE

	SETOI	W,			;1ST, THEN SUBSEQUENT FILES
					;FOR GOBSTR AND JOBSTR... 0
	SETZB	R,CH			;WILL BE REQUIRED IF SYSSTR
	MOVE	B,TAPHED		;GET # BLOCKS IN FILE TO USE AS CRITERIA
	MOVE	B,11(B)		;FOR MINIMUM SPACE REQUIREMENT
	LSH	B,-^D7



GETP1:	MOVE	U,TAPHED
	MOVE	U,5(U)			;GET PROJECT PROGRAMMER #
	CAMN	U,SLGPPN		;IS THE ONE WE HAVE THE SAME
					;AS THE ONE WE ARE
					;SWAPPING ?
	MOVE	U,SLOPPN		;YES, SWAP

	CAMN	U,USRPPN		;IS THE GUY FINALLY SELECTED FOR
					;THE OUTPUT PPN THE SAME AS THE
					;USER PPN RUNNING THIS JOB ?
					;IF SO, USE JOBSTR, OTHERWISE, USE
					;GOBSTR
	JRST	CHKJOB			;OK, USE JOBSTR


	MOVE	U,USRPPN		;SEE PPN #
	CAME	U,FSPP			;/O NOT = PPN RUNNING THIS SHOW
					;ARE WE 1,,2 ?
	JRST	CHKSYS			;NOPE, MUST USE SYSSTR UUO TO GET UNITS






	MOVE	U,[1,,4]
	MOVEI	D,0

	MOVE	CH,[3,,D]		;POINT TO AC WHICH ARE THE ARGUMENT
					;LIST
					;GO!

	CALLI	CH,GOBSTR	;GET NEXT STRUCTURE
	  JRST	GETP2		;ERROR OR THROUGH
JUMPIN:	SKIPN	PAKNAM,W	;END OF LIST ?
	JRST	GETP2		;YEP

	MOVE	A,[XWD 3,PAKNAM]	;WANT 1ST THREE ARGS RETURNED
	CALLI	A,DSKCHR
	JRST	GETP2
	CAMLE	PAKFRE,B	;MORE ROOM HERE THAN ON LAST?
	TLNE	A,.UPOFL!.UPHWP!.UPSWP!.UPSAF!.UPNNA!.UNIAWL

				;YES, THIS DRIVE USABLE?
	JRST	GETP1		;NO, LOOK AT NEXT PACK
	MOVEM	PAKNAM,DEVICE	;YES, SAVE BEST SO FAR
	MOVE	B,PAKFRE		;SAVE FREE COUNT ASSOCIATED WITH STR NAME
					;HELD IN DEVICE:
	JRST	GETP1		;CONSIDER NEXT PACK
GETP2:	INIT	MFD,BUFBIN	;INIT SELECTED DEVICE MFD
DEVICE:	SIXBIT	/DSK/		;SIXBIT /STRNAM/
	XWD	MFDHED,0
	JRST	DNTAVL		;NOT AVAILABLE
	MOVE	A,DEVICE	;OK, WHO DONE IT
	MOVEM	A,CURSTR	;HE DID IT!
	POPJ	P,


CHKJOB:	MOVEI	R,-SYSSTR+JOBSTR
	MOVE	CH,[1,,W]
CHKSYS:	CALLI	CH,SYSSTR(R)		;SYSSTR OR JOBSTR
	JRST	GETP2			;THROUGH SEARCHING
	JUMPN	R,JUMPIN			;GOT A PACK,  IN W, CONTINUE
	MOVE	W,CH			;GOT A PCK, IN CH... NOW IN W
	JRST	JUMPIN
SUBTTL 
;PRINT A DIRECTORY OF AN ENTIRE FAILSAFE TAPE ON LOGICAL DEVICE LST
					;FLAGS SET**********
					;/X HAS SET
					;XSWITC!PRNTSW!LISTSW
					;/P HAS SET
					;PRNTSW!LISTSW
					;/L HAS SET
					;LISTSW
;"/X" SWITCH
GOTANX:	TRO	F,XSWITC		;FOUND AN X

;"/P" SWITCH
PRINT:	AOS	JFLAG		;WE ARE ADVANCING OVER A SAVE SET
				;BY PRINTING IT

	TRO	F,PRNTSW!LISTSW
	SKIPG	TAPHED			;ANY NEED TO INIT THE DEVICE ?
	PUSHJ	P,SETIN			;YEP!
	IFN	REWIND,<
	MTAPE	TAP,1		;INIT + START REWIND
	>
	INIT	TTO,AL		;INIT A LISTING DEVICE
	SIXBIT	/LST/		;LOGICAL NAME LST
	XWD	TTYO,0
	JRST	NOLIST
	MOVEI	A,MFDBUF	;USE DSK BUFFERS
	MOVEM	A,.JBFF
	MOVSI	A,(SIXBIT	/LST/)
	CALLI	A,DEVCHR
	MOVEI	B,MFDBUF
	IORI	B,1777
				;SET TO NEXT HIGHER K
	SUBI	B,MFDBUF	;SUBTRACT OFF BASE ADDRESS


	MOVEI	CH,DSKSIZ		;START BY ASSUMING DSK
	TLNE	A,LPT			;BUT IS IT AN LPT?
	MOVEI	CH,LPTSIZ
	TLNE	A,ITSTTY
	MOVEI	CH,TTYSIZ
				;# BUFFRS
	IDIVI	B,(CH)		;DIVIDE HOW MUCH CORE YOU HAVE BY
				;AMOUNT OF CORE PER BUFFER TO GIVE YOU
	OUTBUF	TTO,(B)
				;NUMBER OF BUFFERS
				;IF NOT AN LPT OR TTY, TAKE DSK AS DEFAULT
	MOVE	A,FS6BIT	;ENTER A FILE NAME FOR LIST
	MOVEM	A,LSTDIR
	MOVSI	A,(SIXBIT /DIR/)
	MOVEM	A,LSTDIR+1
;[40] PRINT+32 30JUL74
	SETZM	LSTDIR+2	;[40];ZERO THE PROTECTION FIELD
	SETZM	LSTDIR+3
	ENTER	TTO,LSTDIR
;PAGE 5-30 OF VERSION 77   [EDIT#34]
	JRST	[PUSHJ	P,TTYINI
	PRLIN1	<? CANNOT ENTER OUTPUT FILE FOR /P@>
		JRST	REINFO
			]

	OUTPUT	TTO,

	PUSHJ	P,UNSAV3	;VERIFY & PRINT HEADER

	PUSHJ	P,GETEOF	;CLOSE UP TAPE


ALRIDN:	MOVSI	A,(SIXBIT "LST")
	CALLI	A,DEVCHR	;GET CHARACTERISTICS OF
				;THIS DEVICE (I.E., "LST")
	TLNN	A,ITSTTY	;IF IT'S A TTY, PUSH OUTPUT
				;OUT EVERY END OF LINE, LET
				;THE LADS SEE THE STATUS OF THE TAPE
				;EVERY TIME IT CHANGES (I.E., NEW
				;USER AREA READ)
				;
	SETOM	LSTING#		;SET FLAG
				;WHICH SAYS THAT THIS IS NOT A TTY AS FAR
				;AS WE ARE CONCERNED
				;OUTPUTS AT END OF LINE
				;ARE TO BE SUPPRESSED, AND
				;WE SHALL DO AN OUTPUT ONLY AS
				;THE BUFFER COUNT GOES
				;TO 0.
				;
				;THIS IS TO HELP KEEP THE SPACE REQUIRED
				;FOR A DIRECTORY ON DISK DOWN
				;SINCE IF WE DO AN OUTPUT EVERY
				;TIME WE SEE AN EOL (12) WE SHALL
				;BE DONING AN OUTPUT ABOUT EVERY 60
				;CHARACTERS OR EVERY 12
				;WORDS (DECIMAL) INSTEAD OF EVERY
				;128 WORDS
	TRNE	F,XSWITC	;ARE WE JUST RECREATING THE TTY OUTPUT?

	JRST	YESXSW		;YEP!

	PRLIN1	<NAME   EXT@>
	PR1 <ALLOCATED_THIS_ALL_   ACCESS__ CREATION@>


YESXSW:
PRINT2:	PUSHJ	P,FTAPIN
	JRST	CHKFMT		;EOF. LOGICAL EOT
				;MAYBE, BUT ALSO COULD BE
				;A TRAILER RECORD CHECK IT OUT

	PUSHJ	P,LIST3		;PRINT USER DIRECTORY
	JRST	PRINT2		;GO DO NEXT USER
PRINT3:	PRLIN1	<$END OF#>
	HRRE	A,4(Q)		;GET SEQUENCE #
				;REMEMBER, REEL NUMBER IS NEGATIVE FOR TRAILER BLOCKS
	MOVNM	A,TAPNUM	;LEAVE IT WHERE IT IS EXPECTED
	MOVE	A,5(Q)		;GET WRAPUP TIME AND DATE
	MOVEM	A,TIMOUT
	PUSHJ	P,ENDMES	;OUTPUT WRAPUP INFO
				;REMEMBER, THIS
				;MESSAGE WILL BE THE ONLY
				;PROOF ON DEVICE "LST" THAT THE
				;TAPE RAN SUCCESSFULLY TO THE TRAILER
				;BLOCK.!!!!!!
				;ALSO
				;WRAP UP TIME GIVES A DEFINATIVE
				;TERMINATION POINT FOR THE SAVING
				;OF FILES. THAT IS, THERE IS NO FILE ON
				;THIS TAPE JUST PRINTED WHICH HAS A
				;CREATION TIME/DATE AFTER THE TERMINAL DATE AND
				;TIME JUST GIVEN.

	PUSHJ	P,GETEOF		;ADSORB THE EOF FOLLOWING THE
					;TRAILER RECORD
	PUSHJ	P,TTYINI		;GO FIX TTY
IFN	REWIND,<	MTAPE	TAP,1		;REWIND
	>
	JRST	FS1AA		;GO RESTART
;"/L" SWITCH - LIST FILES ON TAPE UNDER USER PROJ-PROG # ON TTY

LIST:	IFN	REWIND,<
	PUSHJ	P,SETIN		;INIT
	MTAPE	TAP,1
	>
	TRO	F,LISTSW		;WE ARE LISTING
	XLIST
	IFE	REWIND,<
	LIST
	SKIPE	FNDBEG				;GOT HEADER RECORD ?
	JRST	[SKIPG	B,TAPHED
		JRST	[	PUSHJ	P,SETIN
				JRST	LIST4
			]
		TLNN	F,PPFSW		;OK
					;WE HAVE FOUND 1ST
					;RECORD
					;WE HAVE AN OPEN BUFFER
					;NOW* DO WE HAVE
					;THE  PPN AREA ?
		JRST	LIST4		;NOPE!
		PUSHJ	P,GETDIR		;GET A DIRECTORY
		MOVE	B,TAPHED
		MOVE	A,5(B)
		CAME	A,SLGPPN
		JRST	.-4
		PUSHJ	P,GSTRPT
		JRST	LIST3
		]
	PUSHJ	P,UNSAV2			;WE NEED MTA & BUFFERS
						;AND TO BE SURE
	>
	LIST
	XLIST
	IFN	REWIND,<
	LIST
	PUSHJ	P,UNSAV3
	>
	LIST

						;THIS IS A 5-SERIES TAPE
						;AND TO NOTIFY AS TO
						;SAME & GIVE TAPE #

	PUSHJ	P,GETEOF		;SHUT OFF EOF WHEN YOU FIND IT
LIST4:	PUSHJ	P,XPLUSR		;EXPLAIN TO USER WHOM YOU SEEK
LIST4B:	SETZM	STARPT		;INSURE THAT ON THE FIRST PASS WITH A
				;/L THAT YOU HAVE NO STARTING POINT
	SETZM	ANYFIL		;SET SWITCH SAYING THAT FOR THIS /L
				;PASS YOU HAVE NOT FOUND ANY FILES
				;FOR THE USER SPECIFIED BY /G
	SETZM	ANYPPN		;ALSO RESET PPN FOUND SWITCH
LIST4A:	PUSHJ	P,FINDP1		;GET PPN
	JRST	GOTEOT		;WELL, WE HAVE EOT, EOF OR MAYBE THE
				;STARTING PLACE ON THE 
				;TAPE


LIST3:	TRNE	F,XSWITC	;ARE WE JUST RECREATING THE TTY OUTPUT ?
	JRST	NLIST3		;YEP!
	PUSHJ	P,CRLF		;SPACE DOWN SOME

	PRLIN1	<DIRECTORY FOR#>
	SETOM	ANYFIL		;BUT YOU HAVE FOUND A DIRECTORY ENTRY
				;AND HENCE FILES FOR THE PERSON
				;NAMED BY /G
NLIST3:	MOVE	Q,TAPHED	;WHERE THE DIRECTORY IS
	MOVE	B,3(Q)		;GET STRUCTURE NAME
	MOVEM	B,CURSTR
	MOVE	B,5(Q)		;PROJ-PROG NUMBER
	MOVEM	B,UFDDIR+2
	PUSHJ	P,PRPP		;GIVE NUMBER OF USER
	SETZM	TOTAL#		;ZONK RUNNING TOTAL
	TRNN	F,XSWITC		;KEEP /X OUTPUT COMPACTED
	PUSHJ	P,LFCRLF	;SPACE DOWN A BIT MORE


LIST1:	TRNN	F,XSWITC	;JUST DOING THE TTY OUTPUT ?
	PUSHJ	P,PRFIL		;PRINT NAME OF FILE, WE ARE DOING THE WHOLE THING
LIST1A:	PUSHJ	P,FTAPIN	;IGNORE DATA
LIST1B:	JRST	GOTEOT		;END OF FILE
LIST1C:	MOVE	B,TAPHED
	MOVE	A,6(B)
	CAME	A,FIRFIL
	JRST	LIST1
	HLLZ	A,7(B)
	CAME	A,FIREXT
	JRST	LIST1
	MOVE	A,FIRPPN
	CAME	A,5(B)
	JRST	LIST1
	MOVE	A,FIRSTR
	CAME	A,3(B)
	JRST	LIST1
PROJQ:	SKIPE	ANYPPN			;FIND OUR GUY ?

	POPJ	P,
	JRST	NOPROJ		;NO PROJECT-PROGRAMMER AREA FOUND

LIST2:	TRNE	F,PRNTSW	;PRINTING?
	POPJ	P,		;YES
	TLZE	F,TENDF		;ARE WE AT EOT (TRAILER RECORD SIGHTED ?)
	JRST	ENDOFM		;EOT UP, REWIND
	TLZ	F,PPFSW		;RESET FOUND PP SWITCH
				;WE HAVE FOUND A BONA FIDE EOF
	JRST	LIST4A		;YOU HAVE JUST FOUND THE NEXT USER OR AREA
				;SO  ADVANCING AND BACKSPACING IS
				;UNCALLED FOR






					;
GOTEOT:	SKIPG	Q,TAPHED
	JRST	LIST2		;GOT REAL EOF


	TRNE	F,PRNTSW		;ARE WE /P PRINTING
	JRST	PRINT3		;YEP
	CLOSE	TAP,		;SPR 10-9515 AVOID ADR CHECK AT REINFO
	TLZN	F,TENDF		;CHECK TRAILER FLAG
	JRST	NOPROJ		;TAPE IS OPEN _ MEANS AT BEGINNING POINT
ENDOFM:	CLOSE	TAP,
	LOADPT

	TLZ	F,PPFSW			;HAVEN'T GOT THIS PPN FOR SURE
					;ANY MORE
	JRST	LIST2			;AND CONTINUE



XPLUSR:	PRLIN1	<SEARCHING FOR#>;		;TELL WHO IS SOUGHT
	MOVE	TMP,SLGPPN
	JRST	PRPPN			;AND PRINT IT OUT
;PRINT FILE.EXT   ALLOCATED THIS ALLOCATED ALL ACCESS DATE   CREATION DATE & TIME

PRFIL:	MOVE	Q,TAPHED	;SET PTR TO DATA EVERY TIME
	MOVE	B,5(Q)		;GET PPN
	CAMN	B,SYSPP		;IS IT 1,1 ?
	JRST	PRUFD		;YES
	MOVE	B,6(Q)		;GET FILE NAME
	PUSHJ	P,PRNAME	;NO
PRFIL2:	HLLZ	B,7(Q)		;GET EXTENSION
	PUSHJ	P,PREXT


	TRNN	F,PRNTSW	;ARE WE PRINTING?
	JRST	CRLF		;ALL DONE ?  FINISH UP


	PUSHJ	P,TAB
	MOVE	A,14(Q)		;GET NUMBER OF BLOCKS ALLOCATED

	ADDM	A,TOTAL		;GET TOTAL
	PUSHJ	P,PRNUM		;PRINT IT

	PUSHJ	P,TAB		;AND A TAB

	MOVE	A,TOTAL
	PUSHJ	P,PRNUM		;RUNNING TOTAL
	TLO	F,POPGOT	;WITHOUT CR & LF

	HRRZ	Q,7(Q)		;GET ACCESS DATE
	PUSHJ	P,YRSMOS	;TAB FOLLOWED BY MOS AND YEARS


				;


	PUSHJ	P,SPACE
	PUSHJ	P,TAB

	MOVE	Q,TAPHED	;RESTORE POINTER
	MOVE	A,10(Q)		;CREATE DATE
	LDB	R,[POINT 3,7(Q),20] ;GET HI-ORDER CREATE BITS
	JRST	DATIME		;DATE AND TIME OF CREATION AND RETURN
CHKFMT:	TLZN	F,TENDF		;GOT TRAILER /
	JRST	PRINT2		;NOT YET !
	MOVE	Q,TAPHED	;SET UP
	JRST	PRINT3		;FOR ENDING MESSAGE
					;VERIFIED
PRUFD:	MOVE	TMP,6(Q)		;SETUP TMP
	PUSHJ	P,PRPPN1		;PRINT UFD
	JRST	PRFIL2		;NOW THE EXTENSION

;PRINT INFORMATION ON A GIVEN FILE IN CASE OF UUO FAILURE

PRNMEX:	PUSH	P,A		;PRINTS NAME & EXTENSION OF FILE
	UNFIX	FILDIR
	MOVE	B,FILDIR+1		;GET OWNER 'S PPN
	CAMN	B,SYSPP		;IS IT 1,1 ?
	JRST	NAMPP		;YES, NAME IS A BINARY PROJ-PROG NR.
	MOVE	B,FILDIR+2		;NO, NAME IS IN SIXBIT
	PUSHJ	P,PRNAME	;PRINT IT
EXTPP:	HLLZ	B,FILDIR+3		;GET EXTENSION
EXTPP1:	PUSHJ	P,PREXT		;PRINT EXT.
	JRST	APOPJ		;POP P,A + POPJ P,
NAMPP:	UNFIX	UFDDIR		;FIX UFDDIR
	MOVE	TMP,UFDDIR+2
	PUSHJ	P,PRPPN1	;PRINT THE FILE'S NAME
	HLLZ	B,UFDDIR+3		;AND THE EXTENSION
	JRST	EXTPP1			;AND THEN IT'S EXTENSION
					;WHICH MAY NOT BE ".UFD"

;PRINT PROJ#,PROG# BY WHICH FILE WAS REFERENCED

PRFLPP:	PUSH	P,A
	MOVE	TMP,FILDIR+1	;GET PP#
	PUSHJ	P,PRPPN		;PRINT
	JRST	APOPJ		;GET BACK A, THEN RETURN

;PRINT PROJ#,PROG# IN UFDDIR

PRPP:	HRROI	A,-6		;LIKE PRNAME, BUT WILL NOT PRINT SPACES
	MOVE	B,CURSTR	;PRINT CURRENT FILE STRUCTURE
PRPP1:	MOVEI	CH,0			;CLEAR
	ROTC	B,6			;SLIP AROUND
	CAIE	CH,0		;ELIMINATE BLANKS
	PUSHJ	P,TYPE
	AOJL	A,PRPP1

	PUSHJ	P,TAB		;OUTPUT A TAB
	MOVE	TMP,UFDDIR+2	;GET PP#

;CALL IS THUS	...MOVE		TMP,PPN
;		...PUSHJ	P,PRPPN

PRPPN:	PUSHJ	P,PRPPN1		;PUT OUT THE PPN
	JRST	CRLF			;THEN A CARR RET & LINE FEED

PRPPN1:	HLRZ	A,TMP		;PROJECT #
	PUSHJ	P,PRNUM8
	PRCHAR	<,>
	HRRZ	A,TMP		;PROGRAMMER #
	TRNN	F,LISTSW!PRNTSW		;ARE WE PRINTING ?
	CAME	TMP,SLGPPN				;OR AT A SWAP PPN
	JRST	PRNUM8
	CAMN	TMP,SLOPPN		;/G NOT = /O
	JRST	PRNUM8
	PUSHJ	P,PRNUM8
	PR1	< OUTPUT AS#>
	MOVE	TMP,SLOPPN		;GET THE NUMBER OUTPUT
	JRST	PRPPN1

PRTIME:	MOVE	A,5(D)		;GET CREATE-DATE/TIME INFO
	LDB	R,[POINT 3,4(D),20]	;HI-ORDER CREATE BITS
	HLRZ	B,2(D)			;VERSION #
	CAIGE	B,SECVER			;MIN & SEC OR JUST MIN ?
	JRST	DATIME
;PRINT THE DATE AND TIME FROM AC A
;DATE = ((Y-1964)*12+M-1)*31+D-1 IN BITS 21-35
;TIME IN SECONDS SINCE MIDNITE IN BITS 4-20
;ALTERNATE ENTRY POINT AT DATIME USES TIME IN MINUTES IN BITS 10-20, DATE THE SAME

;CALL:	PUSHJ	P,DATIME

DAYTIM:	TLZ	A,400000	;CLEAR ALL NON TIME AND DATE BITS
	SKIPE	Q,VERNO			;IF NEW VERSION (101)
	CAIL	Q,101			; WROTE THIS TAPE
	JRST	[LDB Q,[POINT 15,A,35]	; SETUP FOR NEW DATE75 FORMAT
		LSH A,-^D15		;DATE IS 15 BITS WIDE
		JRST DAYTI0	]
	LDB	Q,[POINT 12,A,35] ;PICKUP DATE
	LSH	A,-^D12		;OUTPUT TIME FIRST
DAYTI0:	IDIVI	A,^D60*^D60	;DIVIDE INTO HOURS AND SECONDS
	MOVE	R,A+1		;SAVE SECONDS
	PUSHJ	P,PRNUM		;PUBLISH HOURS
	PRCHAR	<:>
	MOVE	A,R		;PUBLISH MINUTES

PICKUP:	IDIVI	A,^D60
	MOVE	R,A+1		;SAVE SECONDS	[OR MINUTES IF JRST-ING HERE]
	PUSHJ	P,PRNUM
	PRCHAR	<:>
	MOVE	A,R		;GET SECONDS
	PUSHJ	P,PRNUM		;PUBLISH SECONDS
YRSMOS:	PUSHJ	P,TAB		;TAB OUT
;YRSMOS+1 INSERTED 1 INSTRUCTION [36]
	ANDI	Q,77777		;MASK TO 15 BITS [36]
	IDIVI	Q,^D31*^D12	;GET YEARS
	IDIVI	R,^D31		;GET MONTH AND DAY
	AOS	A,S		;PUBLISH DAY OF MONTH
	PUSHJ	P,PRNUM
	CAIGE	R,6		;LEFT OR RIGHT SIDE OF TABLE
	SKIPA	A,MONTAB(R)	;RIGHT
	HLRZ	A,MONTAB-6(R)	;LEFT
	DPB	A,[POINT 18,MONDPB,23]	;STASH INTO TEXT
	JSP	A,PR		;PUBLISH MONTH

	IFN	PAGING,	<	JFCL	MONDPB	>

	IFE	PAGING,	<
MONDPB:	SIXBIT	/ PDP#/	>

	MOVEI	A,^D64(Q)	;PUBLISH YEAR
	PUSHJ	P,PRNUM
	TLZE	F,POPGOT		;NEED A SPECIAL POPJ ?
	POPJ	P,			;YOU'VE GOT IT
SWPRET:	JRST	CRLF			;RETURN VIA CR - LF

	IFN	PAGING,	<
MONDPB:	SIXBIT	/ HOH#/	>
DATIME:	TLZ	A,777740	;ZERO ALL NON TIME/DATE BITS
	LDB	Q,[POINT 12,A,35] ;PICKUP DATE
	LSH	A,-^D12		;OUTPUT TIME FIRST
	MOVE	B,VERNO		;IF VERSION 101 WROTE THIS TAPE
	CAIL	B,101		;  R HAS THE HI-ORDER CREATE DATE BITS
	DPB	R,[POINT 3,Q,23] ; SO PUT THEM ALL TOGETHER
	JRST	PICKUP		;PICK UP REST OF PROCEDURE


MONTAB:	SIXBIT	/JULJAN/	;TABLE OF MONTH NAMES
	SIXBIT	/AUGFEB/
	SIXBIT	/SEPMAR/
	SIXBIT	/OCTAPR/
	SIXBIT	/NOVMAY/
	SIXBIT	/DECJUN/
;THE PRINT ROUTINES ARE CALLED BY
;	JSP	A,PRLIN		;BEGINS WITH CRLF
;	SIXBIT	/MESSAGE OF ANY LENGTH/
;OR
;	JSP	A,PR		;BEGINS IMMEDIATELY
;	SIXBIT	/MESSAGE OF ANY LENGTH/
;	OR!!!
;	JSP	A,PR <OR PRLIN>
;	JFCL	ADDRESS OF LITERAL SIXBIT MESSAGE

;WITH ANY CALL, CONTROL RETURNS TO THE LOCATION IMMEDIATELY
;FOLLOWING THE END OF THE MESSAGE ENTRY
;
;EACH MESSAGE MUST END WITH ONE OF THE FOLLOWING CHARACTERS:
;	@ AT THE END OF THE MESSAGE GIVES A CRLF
;	# AT THE END OF THE MESSAGE GIVES A SPACE

PRLIN:	PUSHJ	P,CRLF
	XLIST
	IFN PAGING,
	<
	LIST
PR:	MOVEI	B,@(A)		;GET POINTER
	>
	LIST
	XLIST
	IFE PAGING,
	<
	LIST
PR:	MOVEI	B,(A)
	>
	LIST
	TLOA	B,440600		;P AND S FOR BYTE POINTER
					;POINT 6,ADDRESS OF LITERAL
PRLUP:	PUSHJ	P,TYPEA		;TYPE IT OUT
	ILDB	CH,B		;PICKUP NEXT CHAR
	CAIN	CH,77		;IS IT A PSEUDO TAB ?
				; SIXBIT _
	TRCA	CH,000066	;MAKE HIM A REAL TAB
	MOVEI	CH,40(CH)	;TAB SKIPS THIS INSTRUCTION, BUT
				;ALL OTHER ARE ASCII-IZED
	CAIN	CH,100		;SIXBIT @
				;WHICH HAS BEEN ASCII-IZED
	JRST	PR6		;FINISH LINE
	CAIE	CH,43		;SIXBIT #
				;WHICH HAS BEEN ASCII-IZED
	JRST	PRLUP		;GET NEXT CHAR TO TYPE
	PUSHJ	P,SPACE		;OUTPUT FINAL SPACE
	IFE PAGING,
	<
	JRST	1(B)		;RETURN
	>
	IFN	PAGING,<
	JRST	1(A)
	>
PR6:	PUSHJ	P,CRLF		;OUTPUT CRLF
PRRET:
	IFN	PAGING,<
	JRST	1(A)
	>
	IFE	PAGING,
	<
	JRST	1(B)		;(A) + 1 GIVE VECTOR
	>
				;BACK TO AFTER THE JFCL
				;AOJA	B,@B
				;DOES NOT WORK BECAUSE EFFECTIVE ADDRESS
				;IS CALCULATED BEFORE THE ADDITION IS DONE

;PRINT AN ASTERISK IMMEDIATELY
ASTRSK:	XLIST
	IFN	BELL,
	<
	LIST
	MOVEI	CH,007			;^G = BELL
					;
	PUSHJ	P,TYPEA
	>
	LIST

JSTAST:	MOVEI	CH,52			;*
	PUSHJ	P,TYPEA
	OUTPUT	TTO,			;FORCE IT OUT NOW
	POPJ	P,

;PRINT A SPACE
;OR A TAB
TAB:	SKIPA	CH,[OCT	11]	;TAB
SPACE:	MOVEI	CH,40		;ASCII SPACE
	JRST	TYPEA		;TYPE IT OUT

;PRINT ONE OR TWO CRLF'S
LFCRLF:	MOVEI	CH,1012		;LINE FEED PLUS BIT TO PROHIBIT OUTPUT
	PUSHJ	P,TYPEA
CRLF:	MOVEI	CH,15		;ASCII CR
	PUSHJ	P,TYPEA		;TYPE IT OUT
	MOVEI	CH,12-40	;ASCII LF IN PSEUDO-SIXBIT

;PRINT ONE SIXBIT CHARACTER
TYPE:	MOVEI	CH,40(CH)	;CONVERT SIXBIT TO ASCII

;PRINT ONE ASCII CHARACTER
TYPEA:	SOSG	TTYO+2		;OUTPUT THE CHARACTER IN CH
	OUTPUT	TTO,
	IDPB	CH,TTYO+1
	SKIPE	LSTING		;IS THE DON'T FORCE OUTPUT EVERY E.O.L
				;CHARACTER FLAG UP ?
	POPJ	P,		;RETURN, FORGET WHAT CHARACTER IS, YOU
				;AREN'T SUPPOSED TO FORCE OUTPUTS AT EOL

	CAIN	CH,12		;END OF LINE?
	OUTPUT	TTO,0		;YEP, FORCE WHATEVER IT IS OUT
	POPJ	P,		;RETURN

;PRINT A CHARACTER - WITH UPARROW IF A CONTROL CHARACTER

PRCH:	MOVEM	CH,PRCH1#	;STASH CHAR AWAY SAFELY
	PUSHJ	P,CRLF		;START A LINE OF TEXT
	MOVE	CH,PRCH1	;UNSTASH THE CHAR
PRCHNL:	CAIL	CH,40		;NORMALLY PRINTING?
	JRST	TYPEA		;YES, PRINT AND POPJ
	PRCHAR	<^>
	MOVE	CH,PRCH1	;REGET CHAR
	MOVEI	CH,100(CH)	;CONVERT TO CONTROL MUMBLE
	JRST	TYPEA		;PRINT AND POPJ

;PUBLISH THE OCTAL NUMBER IN AC A
; CALL:	PUSHJ	P,PRNUM8
PRNUM8:	SKIPA	A+1,[10]		;RADIX 8.

;PUBLISH THE DECIMAL NUMBER IN AC A
;	ALWAYS PUBLISH AT LEAST TWO DIGITS
; CALL:	PUSHJ	P,PRNUM
PRNUM:	MOVEI	A+1,12		;RADIX 10.
PRNUMA:	MOVEI	CH,"0"		;INSURE AT LEAST TWO DIGITS
	CAIGE	A,(A+1)		;IS NUMBER BIGGER THAN RADIX
	PUSHJ	P,TYPEA		;NO, PABLISH A LEADING ZERO
	HRRM	A+1,PRN		;THIS MAY LOOK LIKE A CROCK, BUT IF YOU
					;LOOK CAREFULLY, ANY ATTEMPT TO
					;DO IDIVI A,0(A+1) DIES ON
					;THE SECOND DIGIT
PRN:	IDIVI	A,0		;REMAINDER IS LOW ORDER DIGIT
	HRLM	A+1,(P)		;STASH IN LEFT OF CURRENT PDL WORD
	JUMPE	A,MORDIG	;ANY MORE DIGITS?
	PUSHJ	P,PRN		;YES, PUT NEXT DIGIT IN NEXT PDL WORD
MORDIG:	HLRZ	CH,(P)		;UNSTASH DIGIT
	MOVEI	CH,60(CH)	;CONVERT TO ASCII
	JRST	TYPEA		;OUTPUT IT & POPJ TO .-2 FOR NXT DIGIT, OR RETURN

;PRINT A PERIOD FOLLOWED BY THE LEFTMOST THREE SIXBIT
;	CHARACTERS IN AC B
PREXT:	TLNN	B,-1		;ANY EXTENSION (LEFT HALF ONLY)
	JRST	NOPERD			;NO EXT
	PRCHAR	<.>
PR3CHR:	SKIPA	A,[-3]		;SET CHARACTER COUNT

;PRINT THE SIX SIXBIT CHARACTERS IN AC B
PRNAME:	HRROI	A,-6		;SET CHARACTER COUNT

;PRINT THE N SIXBIT CHARS IN AC B
;	ENTER WITH -N IN AC A
PRNAM1:	MOVEI	CH,0		;CLEAR CH(=B+1)
	ROTC	B,6		;ROTATE HIGH ORDER CHAR INTO CH
	PUSHJ	P,TYPE		;PUBLISH
	AOJL	A,PRNAM1	;GET NEXT CHAR
	POPJ	P,		;RETURN

NOPERD:	TRNN	F,PRNTSW	;PRINTING?
	POPJ	P,		;NOPE, JUST LISTING
				;IF LISTING, DON'T PAD OUT BLANK EXTENSIONS
	HRROI	A,-4		;FOUR (4) SPACES FOR NULL EXT
	JRST	PRNAM1		;PRINT IT (OR THEM)

;MISC TTY SUBRS

TTYINI:	INIT	TTI,AL		;INITIALIZE TTY INPUT
	SIXBIT	/TTY/
	XWD	0,TTYI
	CALLI	EXIT		;NO TTY IS FATAL
	MOVEI	A,TTYBFI	;SETUP TTY BUFFERS FOR INPUT
	MOVEM	A,.JBFF
	INBUF	TTI,TTYINN
	INIT	TTO,ASCII		;INITIALIZE TTY OUTPUT
	SIXBIT	/TTY/
	XWD	TTYO,0
	CALLI	EXIT

	IFN	LOCK,<
	TLNE	F,LOCKER
	JRST	GTTOBF		;IF LOCK IS ON, DON'T DO A CORE UUO
	>
	MOVEI	A,TAPBUF
	MOVEM	A,.JBFF

	IFE DEBUG,<
	CALLI	A,CORE
	>
	IFN	DEBUG,<
	CAIA
	>
	JRST	NOCORE
GTTOBF:	SETBUF	TTO;		;SET UP TELETYPE BUFFERS
				;NOTE THAT THE ; AFTER SETBUF TTO^
				;IS NECESSARY
				; I SHOULD HAVE REMEMBERED THIS FROM WORK ON
				;THE COBOL COMPILER!!!!!!!!!!!!




	MOVE	A,[400000,,TTOBUF+1]
	MOVEM	A,TTYO		;SET UP STATUS WORD
	SETZM	LSTING		;WE MAY BE LISTING, BUT THE DEVICE
				;WE ARE SPEAKING TO WANTS TO
				;HAVE AN OUTPUT FORCED WHENEVER
				;IT SEES AN EOL (12)

	OUTPUT	TTO,		;DUMMY OUTPUT
	POPJ	P,			;YES, RETURN

;TELETYPE INPUT
TYI:	SOSLE	TTYI+2
	JRST	TYIOK		;CHARS AVAILABLE
	INPUT	TTI,		;GET A BUFFER
	STATO	TTI,760000	;EOF OR ERR?
	JRST	TYIOK		;NO, OK.
	PUSHJ	P,TTYINI	;ASSUME EOF, GET TTY AGAIN
	TDZA	CH,CH
TYIOK:	ILDB	CH,TTYI+1	;GET A CHAR
	JUMPE	CH,TYI		;JUNK NULLS
	POPJ	P,
;MISCELLANEOUS ERROR MESSAGES

;COMPLAIN ABOUT AN ILLEGAL DIGIT
NILSW:	MOVEI	CH,60-133(CH)	;RESTORE ASCII CODE FOR NUMBER
ILSW:
;COMPLAIN ABOUT AN ILLEGAL CHAR
ILCH:	CAIN	CH,032		;IS IT CONTROL-Z	[EDIT#35]
	JRST	ZOUT		;YES			[EDIT#35]
	PUSH	P,CH		;SAVE CH
	TYPES	($)
	POP	P,CH		;RESTORE CH
	PUSHJ	P,PRCHNL		;PRINT OFFENDING CHAR
	PR1	< IS ILLEGAL@>
	JRST	FS1.1		;ASK WHAT NEXT


ZOUT:	CLOSE 	TTO,		;CONTROL-Z EXIT		[EDIT#35]
	CLOSE	TAP,		;			[EDIT#35]
	CLOSE	MFD,DNC		;			[EDIT#35]
	CLOSE	UFD,DNC		;			[EDIT#35]
	CLOSE	FIL,DNC		;			[EDIT#35]
	CLOSE	CHK,DNC		;			[EDIT#35]
	CLOSE	DGA,DNC		;			[EDIT#35]
	CALLI	EXIT		;			[EDIT#35]

;FILE NAME ERROR
FILDL1:	PRLIN1	<$TWO PERIODS#>
	JRST	ALLFI2
ALLFI1:	PRLIN1	<$ASTERISK#>
ALLFI2:	PR1	<IN NAME@>
	JRST	FS1.2

;COMMAND ERROR - RESTART
COMERR:	PRLIN1	<$COMMAND ERROR@>
	JRST 	START		;BACK TO BEGINNING

;COMMAND NOT YET IMPLEMENTED
NOTYET:	CAIN	CH,032		;CONTROL-Z?		[EDIT#35]
	JRST	ZOUT		;YES			[EDIT#35]
	PUSH	P,CH		;SAVE IT
	TYPES	($)
	POP	P,CH
	PUSHJ	P,PRCH		;PRINT FRUSTRATING CHAR
	PR1	< ISNT YET IMPLEMENTED@>
	JRST	FS1.1

;NUMBER OUT OF RANGE - RESTART
NUMOUT:	PRLIN1	<$NUMBER OUT OF RANGE@>
	JRST	START		;BACK TO BEGINNING

NOLIST:	PUSHJ	P,TTYINI	;GO FIX UP TTY
	PRLIN1	<?NO DEVICE "LST"?@>
	JRST	REINFO

ILLFMT:	PRLIN1	<ILL FORMAT ON TAPE@>
	SETOM	FNDBEG		;SIGNAL WE HAVE FOUND ENOUGH TO FAKE A BEGINNING
SEARCH:	PUSHJ	P,SFEODR
	JRST	CGETDR		;DON'T JUST GIVE UP... KEEP TRYING

NOTAP:	PUSHJ	P,TTYINI		;ERROR MESSAGE OUT TO TTY
	PRLIN1	<?NO MTA NAMED "FAILSA"?@>
REINFO:	CALLI	EXIT
BADMFD:	PRLIN1	<LOOKUP ERROR ON MFD FOR#>
	JRST	UGHMFD
NOMFD:	PRLIN1	<CANNOT INIT MFD FOR#>
UGHMFD:	MOVE	B,CURSTR	;PRINT STRUCTURE NAME
	PUSHJ	P,PRNAME
	PUSHJ	P,CRLF

	JRST	ENDMFD			;CONTINUE UNTIL MFD'S ARE EXHAUSTED




NOTFS:	PUSHJ	P,TTYINI	;INSURE OUTPUT TO TTY
	PRLIN1	<?NOT LOGGED IN UNDER 1,2!@>
	JRST	REINFO

MAYBE2:	GETBAD	(A)		;IF NOT FRAGMENTATION
				;ERROR, FALL INTO MESSAGE, OTHERWISE,
				;RETURN BY POPJ
NOUFD:	PRLIN1	<CANNOT RESTORE UFD#>
	JRST	PRPP

NODSK:	PUSHJ	P,TTYINI		;FIX UP TTY
	PRLIN1	<$CAN'T INIT DISK FOR DATE CHECK; TRY AGAIN@>
	JRST	START

TFRERR:	PRLIN1	<TAPE#>
	JRST	UFLER2
UFLERR:	PUSHJ	P,NULTAP		;RESET TAPE BUFFER TO TRY
					;TO STOP BAD FILE FROM BEING WRITTEN OUT ON TAPE
	PRLIN1	<DISK#>
UFLER2:	PR1	<ERROR READING#>
PRUFL:	MOVE	A,[XWD	ZONKER,SAVNAM]	;BLT DIRECTORY NAME
				;OF FILE SOUGHT TO SAFE PLACE WHILE YOU
	BLT	A,SAVNAM+4

	MOVE	A,[XWD FILDIR,ZONKER]	;BLT OFFENDING(ERROR) FILE
				;NAME INTO POSITION FOR PRINTING

	BLT	A,PROT
	PUSHJ	P,PRNMEX	;PRINT NAME & EXT OF FILE
	MOVS	A,[XWD ZONKER,SAVNAM]	;BLT SAVED NAME BACK INTO POSITION
	BLT	A,FILPP+4

	JRST	CRLF		;DO OUTPUT UUO

DNTAVL:	PUSHJ	P,TTYINI		;OUTPUT TO TTY
	PRLIN1	<$DISK NOT AVAILABLE@>
	CALLI	A,GETPPN	;IS THIS FAILSAFE PPN?
	  JFCL			;BE DEFENSIVE
	CAME	A,FSPP
	JRST	NOTFS		;NO, COMPLAIN
	JRST	FS1A

TFLWF:	PUSHJ	P,PRNMEX	;PRINT NAME & EXTENSION OF FILE
	PUSHJ	P,TAB		;AND A TAB

	JRST	PRFLPP		;PRINT PROJ-PROG NR. SPECIFIED IN FILE

WRLOK:	PRLIN1	<$MTA WRITE-LOCKED; INSERT RING & TYPE "/C"@>
	GETSTS	TAP,A		;GET CURRENT STATUS OF TAPE
	TRZ	A,400000	;TURN OFF WRITE-LOCK FLAG
				;AND THEN
	SETSTS	TAP,(A)		;RESTORE ALL OTHER FLAGS
SLASHW:	PUSHJ	P,ASTRSK	;PUT OUT 'READY FOR INPUT'
GETINP:	PUSHJ	P,TYI		;GET A CHARACTER FROM TTY
	CAIE	CH,12		;SKIP LN FEEDS AND
	CAIN	CH,15		;CARR RETS
	JRST	GETINP		;SKIP LF AND CR, GO BACK FOR GOOD STUFF
	CAIE	CH,"/"		;SLASH?
	JRST	GETINP		;WAIT TILL SLASH
	PUSHJ	P,TYI		;GET SOME MORE INPUT FROM TTY
	CAIE	CH,"C"		;WAIT FOR C TO FOLLOW
	JRST	SLASHW		;LOOP UNTIL /C OR ^C START
	JRST	TAPOU1		;HOORAY! THE IDIOT PUT A RING IN REEL


DEVERR:	PRLIN1	<$MTA OK? TYPE "/C" TO CONTINUE@>
	GETSTS	TAP,A		;GET ALL FLAGS
	TRZ	A,200000	;RESET PHYSICAL DEVICE ERROR
	SETSTS	TAP,(A)		;RESTORE ALL OTHER FLAGS
	JRST	SLASHW		;WAIT FOR / AND THEN C


TOOMNY:	PRLIN1	<$TOO MANY ARGS@>
	JRST	FS1.1

FAILSC:	PUSHJ	P,TTYINI			;INIT TTY SO OUTPUT FORCED TO TTY
	PRLIN1	<?OLD FORMAT TAPE. SUGGEST ".R FAILCD"@>
	JRST	REINFO


WRONGV:	PUSHJ	P,TTYINI			;INIT TTY SO OUTPUT FORCED TO TTY
	PRLIN1	<?TAPE APPEARS TO BE A 4-SERIES FAILSAFE TAPE.@>
	JRST	REINFO


ILLNAM:	PRLIN1	<ILLEGAL FILENAME:#>
	PUSHJ	P,TFLWF
	PR1	<ENCOUNTERED@>
	JRST	SEARCH


ILLTAP:	PRLIN1	<TAPE READ ERROR#>
	JRST	SEARCH			;LOOK FOR SOMETHING YOU CAN READ
FIXFRG:	HRRZ	A,(P)	;GO AFTER EFFECTIVE ADDRESS OF ENTER AGAIN
	MOVEI	A,@-2(A)
	IFN	LEVELC,
	<
	MOVE	B,(A)		;GET 1ST WORD
	TLNE	B,-1		;ARE WE 4-SERIES OR 5-SERIES
	POPJ	P,		;EXIT IF 4-SERIES
	>
	MOVEI	TMP,077777		;MASK FOR ERROR CODE
	ANDCAM	TMP,3(A)		;ZERO ALL BUT CREA-DATE BITS
	POPJ	P,

MAYBE4:	HRRZ	A,(P)		;GET ADDRESS OF PUSHJ
	LDB	A,[POINT 9,-2(A),8]		;GET LEFT HALF
						;STRIP OFF CHANNEL & INDEX
				;AND INDIRECT BITS <JUST LEAVE OP CODE>
	CAIE	A,(<ENTER>B44)	;DID YOU HAVE AN ENTER?
	JRST	LOOKER		;NOT AN ENTER...?? CAN'T BE ERROR 17
				;ERROR.. GO TO IT.
	HRRZ	B,(P)		;GET ADDRESS OF ENTER+1+1
	MOVEI	B,@-2(B)	;NOW GET EFFECTIVE ADDRESS OF ENTER
	IFN	LEVELC,
	<
	MOVE	A,(B)		;GET  1ST WORD
	TLNE	A,-1
	JRST	LOOKER		;SKIP OUTTA HERE IF 4-SERIES
	>
	HRRZ	A,3(B)		;GET RIGHT HALF OF UUO ADD +3 = ERROR RETURN
	CAIN	A,FRAGER	;FREGMENTATION ?
	JRST	FIXFRG		;GREAT! ONLY FRAGMENTATION ON ENTER
				;WE CAN CONTINUE (FIXFRG CLEARS ERROR CODE)

	CAIN	A,NOROOM	;NO MORE ROOM ?
	JRST	[PRLIN1	<NO MORE ROOM FOR#>
		PUSHJ	P,TFLWF
		POP	P,A		;POP OFF
		JRST	GETEOF		;TRY ANOTHER USER
		]
	JUMPE	A,ILLNAM		;ILLEGAL FILE NAME ON AN ENTER
;UUO ERROR CHECK ROUTINE(ENTER,LOOKUP, RENAME)
;CALL:	UUO	DSK,E
;	PUSHJ	P,UUOERR
;RETURN DEPENDS UPON UUO
;E OF THE UUO IS USED TO FIND FILENAME

RENERR:
LOOKER:
ENTERR:	MOVEI	A,RENTER	;RETURN IF ENTER OR RENAME ERROR
	EXCH	A,(P)		;GET CALL ADDRESS+1
	TRO	F,UUOERR	;SET UUO ERROR FLAG
	IFN LEVELC,
	<
	MOVEI	B,@-2(A)
	MOVE	U,1(B)		;GET ERROR # IF THIS IS A 4-WORD BLOCK

	MOVE	B,(B)		;GET FIRST WORD OF UUO SPEC
	TLNE	B,-1		;4 OR 5 SERIES FORMAT ?
	JRST	MISCER		;4 SERIES!!
	>

	MOVEI	B,@-2(A)	;GET ADDRESS
	HRRZ	U,3(B)		;SAVE ERROR CODE NUMBER
	MOVEI	TMP,077777		;MASK FOR ERROR CODE
	ANDCAM	TMP,3(B)		;RESET ERROR FLAGS IN DIRECTORY
	CAIGE	U,ERRTMX	;IS IT A KNOWN TYPE OF ERROR?
	JRST	@ERRTAB(U)	;DISPATCH TO ERROR PRINT ROUTINE

	JRST	MISCER		;UNKNOWN ERROR
ERRTAB:	EXP	FNF		;FILE NOT FOUND
	EXP	NSUCH		;NO SUCH UFD
	EXP	PROTF		;PROTECTION FAILURE
	EXP	FBMOD		;FILE BEING MODIFIED
	EXP	EXNAM		;TRIED RENAME TO EXISTING NAME
ERRTMX==.-ERRTAB
;INDIVIDUAL ERROR PRINT-OUT ROUTINES

FNF:	POP	P,A		;RESTORE PD-LEVEL
	TRNE	F,UFDI		;LOOKUP ON UFD ?
	JRST	MORE1		;YES, DO NEXT UFD, THIS ONE IS LOST
	JRST	MORE2		;GO AFTER MORE FILES

NSUCH:	PUSHJ	P,TFLWF
	PR1	<REFERENCES NON-EXISTENT USER AREA@>
	POPJ	P,

PROTF:	PR1	<PROTECTION FAILURE ON#>
MISCE1:	JRST	TFLWF

FBMOD:	PUSHJ	P,TFLWF
	PR1	<IS BEING MODIFIED@>
	POPJ	P,

EXNAM:	LDB	CH,[POINT 9,-2(A),8]		;GET UUO WHICH SET US HERE
						;GET RID OF XR, I AND AC BITS
	CAIE	CH,(<RENAME>B44)	;WAS IT A RENAME ?
				;(RENAME ERROR ON LOOKUP ???)
	JRST	REMOVE		;RENAME ERROR ON LOOKUP SOUNDS LIKE
				;THE STRUCTURE HAS BEEN DISMOUNTED

	PR1	<ATTEMPTED TO RENAME#>
	PUSHJ	P,TFLWF
	PR1	<TO AN EXISTING NAME@>
	POPJ	P,


REMOVE:	TRZE	F,FILI		;DOING FILE INPUT ?
	JRST	ENDFIL		;YES,,,, BUT THE FILE WENT AWAY
	TRZE	F,UFDI		;UFD INPUT ??
	JRST	ENDUFD		;IT WENT AWAY


;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

;IT WOULD APPEAR HERE THAT THE SRUCTURE HAS DISAPPEARED
	MOVEI	CH,042		;CH _ "
	PUSHJ	P,TYPEA
	MOVE	B,CURSTR		;"%STRUCTURE FOO
	PUSHJ	P,PRNAME
	PR1	< WAS REMOVED BEFORE SAVE WAS COMPLETED. THE TAPE IS@>
	PR1	<"INCOMPLETE FOR STRUCTURE#>
	MOVE	B,CURSTR
	PUSHJ	P,PRNAME
	PR1	<._CONTINUING WITH NEXT STRUCTURE.@>
	JRST	ENDMFD			;TRY NEXT STR



MISCER:	PR1 <LOOKUP/ENTER FAILURE#>
	MOVEI	CH,"("		;PRINT (ERR CODE)
	PUSHJ	P,TYPEA
	MOVEI	A,(U)			;GET ERROR NUMBER
	TRZ	A,777700	;SELECT LOW 6 BITS
	MOVEI	A+1,10		;OCTAL RADIX
	PUSHJ	P,PRNUMA
	MOVEI	CH,")"		;FINISH THE LINE
	PUSHJ	P,TYPEA
	PUSHJ	P,SPACE
	PUSHJ	P,PRNMEX
	JRST	CRLF		;IDENTIFY THE ERROR #, FILE NAME
				;ONE LF
				;EXIT BACK TO WHERE YOU ARE POPJ'ED TO
				;IN THE ERROR RECOVERY AND DETECTION SECTION,
				;CODE WILL TRANSFER CONTROL TO TFLWF:
				;OR LIKE PLACE WHERE OFFENDING FILE WILL
				;BE IDENTIFIED.  POPJ-ING RELIEVES
				;PROBLEM OF MULTIPLE ERROR MESSAGES FOR
				;A SINGLE FILE

;REENTER CODE
;START AT RENTER WHEN USER HAS TYPED "REENTER" TO MONITOR

RENTER:	TRNN	F,-1		;ANY OPERATIONS IN PROGRESS?
	JRST	START		;NO

	TRZE	F,UUOERR	;UUO ERROR?
	JRST	RENINT		;YES, SKIP I/O ERROR CHECKS
	TRNE	F,TAPI		;TAPE INPUT ERROR?
	JRST	RTAPIN		;YES, TELL USER
	TRNE	F,FILO		;FILE OUTPUT IN PROGRESS?
	JRST	RFILOU		;LET USER KNOW

RENINT:	MOVEI	B,17		;INTERNAL REENTER POINT
	ANDI	B,(F)		;GET ONLY MAJOR OPERATION BITS
	JUMPE	B,FS1A		;NO /S, /R, /L, OR SELECT. REST. IN PROGRESS
	LSH	B,-1		;REDUCE BITS TO QUANTITIES FOR INDEXING
	TRZ	B,4		;WAS /S IN PROGRESS?
				;IF SO, INSURE SWITCH IS OFF
	MOVEI	T,6		;NO
RENDSP:	HLRZ	A,RENTAB(T)	;PICK UP BITS
	TRZ	A,37		;MASK OUT IND AND XR FIELD
	TRZE	F,(A)		;MATCH?
	JRST	@RENTAB(T)	;YES, DISPATCH
	SOJGE	T,RENDSP	;NO, TRY AGAIN
NOREEN:	PRLIN1	<$NOT AN I/O FAILURE - CANNOT DETERMINE REENTRY POINT@>
	JRST	FS1.2

;REENTRY PROCESS DISPATCH

RENTAB:	XWD	TAPO,RTAPOU
	XWD	FILI,ENDFIL		;RFILIN JRST'S TO ENDFIL
	XWD	UFDI,ENDUFD		;RUFDIN JRSTS TO ENDUFD AFTER EXTRA
					;ERROR MESSAGES

	XWD	MFDI,RMFDIN
	XWD	FILO+B,RFILO
	XWD	TAPI+B,RTAPI
	XWD	UFDO+B,RUFDOU

RUFDOU:	JRST	UFDFA1		;SELECTIVE RESTORE IN PROGRESS
	JRST	UFDFA2		;/R IN PROGRESS
	JRST	FS1A		;/L IN PROGRESS

RFILO:	JRST	CGETDR		;SEL. REST. FILE OUTPUT TO DSK
				;CLOSE DISK OUTPUT AND SKIP TO NEXT EOF OR
				;FILE FOR THIS USER
	JRST	TAPIN4		;/R OUTPUT FILE TO DSK
	JRST	NOREEN		;/L OUTPT TO DSK SHOULDN'T HAPPEN

RTAPI:	POPJ	P,		;PROBABLY A PROTECTION FAILURE
				;QUIT NOW WHILE AHAEAD
	JRST	SELRES		;/R TAPE INPUT
	TRO	F,TAPI		;READ ERROR ON LISTING
				;SET FLAG IN CASE OF ANOTHER ERROR

SELRES:	SKIPN	FNDBEG		;FOUND BEGINNG RECORD ?
	PUSHJ	P,TRACKS	;TAPE ERROR AND YOU HAVEN'T FOUND 1ST RECORD
				;SOUND LIKE YOU MAY HAVE THE WRONG CHANNEL
				;TAPE ON THE RIGHT CHANNEL DRIVE....
	POP	P,A		;CORRECT TO PD-LEVEL
	JRST	-1(A)		;AND GO BACK TO FTAPIN OR WHOMSOEVER
				;CALLED YOU AND TRY AGAIN





UFDFA1:	PRLIN1	<$CANNOT WRITE UFD#>
	PUSHJ	P,PRPP
	JRST	FS1AA		;REINITIALIZE


TRACKS:	PRLIN1	<"TAPE ERROR ON 1ST RECORD; ARE TAPE & DRIVE COMPATIBLE WITH RESPECT TO:@>
	PR1	<"CHANNELS, DENSITY, PARITY, & PHASE ?@>
	POPJ	P,


;BUFFER HEADERS

TTYI:	BLOCK	3		;TTY INPUT BUFFER HEADER**2
TTYO:	BLOCK	3		;TTY OUTPUT BUFFER HEADER**2
TAPHED:	BLOCK	3		;MAGTAP INPUT OR OUTPUT BUFFER HEADER**2
MFDHED:	BLOCK	3		;DISK MFD BUFFER HEADER**2
UFDHED:	BLOCK	3		;DISK UFD BUFFER HEADER**2
DGAHED:	BLOCK	3		;PHANTOM CHANNEL
CHKHED:	BLOCK	3		;DATE CHECK FILE HEADER
FILHED:	BLOCK	3		;DISK USER FILE BUFFER HEADER**2

;MTA HEADER BLOCK
FIRBLK:	XWD	AARDVARK,FSPP-FIRBLK	;WD0=XWD HEADER FLAG,BLK WDCT
STARFS:	SIXBIT	/*FAILS/	;WD1
	SIXBIT	/AFE   /	;WD2=XWD SIXBIT "AFE",TAPE SEQ#
				;NEGATIVE TAPE SEQ# MEANS TRAILER
	EXP	0		;WD3=TAPCTD BIT (B0), USRCTD BIT (B1)
				;    CRTIME (B13-23), CRDATE (B24-35)
FSPP:	XWD	1,2		;WD4=FAILSAFE PROJ,PROG #


SYSPP: 1,,1
;LOOKUP & ENTER SPECS
				;EXT LOOKUP	-    OLD LOOKUP



				;NOTE THAT 4-WORD ENTERS/LOOKUPS ARE
				;THE ONLY KIND UTILIZED ON THE MFD AT
				;THIS TIME
HELPS:	400000,,0
	SIXBIT	/SYS   /
	EXP	HELPIT
HELPIT:
LSTDIR:
MFDDIR:	0			;0,XLOOKN	-     FILNAM
	0			;PPN		-     EXT.,ACC.DAT.
	0			;FILNAM		-     PROT,MODE,CREAT
	0			;EXT.,ACC.DAT.	 -    PPN
;	0			;PROT,MODE,CREAT
;	BLOCK	5		;--NEVER TOUCH--
;MRBPOS:	0			;--CLR BEFORE RESTORE--
;MRBNXT:	0			;   "    "	 "
;MRBPRD:	0			;   "    "	 "
;	BLOCK	1		;--NEVER TOUCH--
;MRBUFD:	0			;--CLR BEFORE RESTORE--
;MRBSTS:	0			;FILE STATUS WORD
;MRBELB:	0			;--CLR BEFORE RESTORE--
;MRBEUN:	0			;   "    "	 "
;	BLOCK	XLOOKN-21	;---NEVER TOUCH ON SAVE OR RESTORE--

UFDDIR:	0			;0,XLOOKN	-     FILNAM
	0			;PPN		-     EXT.,ACC.DAT.
	0			;FILNAM		-     PROT,MODE,CREAT
	0			;EXT.,ACC.DAT.	 -    PPN
	0			;PROT,MODE,CREAT
	BLOCK	5		;--NEVER TOUCH--
URBPOS:	0			;--CLR BEFORE RESTORE--
URBNXT:	0			;   "    "	 "
URBPRD:	0			;   "    "	 "
	BLOCK	1		;--NEVER TOUCH--
URBUFD:	0			;--CLR BEFORE RESTORE--
URBSTS:	0			;FILE STATUS WORD
URBELB:	0			;--CLR BEFORE RESTORE--
URBEUN:	0			;   "    "	 "
	BLOCK	XLOOKN-21	;---NEVER TOUCH ON SAVE OR RESTORE--
URBQTO=URBEUN+2			;LOGGED OUT QUOTA
URBQTI=URBQTO-1

FILMRK:	XWD	-1,XLOOKN+2	;FILE HEADER (MUST PRECEDE CURSTR)
CURSTR:	0			;CURRENT FILE STRUCTURE (MUST PRECEDE FILDIR)
FILDIR:	0			;0,XLOOKN	-     FILNAM
	0			;PPN		-     EXT.,ACC.DAT.
	0			;FILNAM		-     PROT,MODE,CREAT
	0			;EXT.,ACC.DAT.	 -    PPN
	0			;PROT,MODE,CREAT
	BLOCK	5		;--NEVER TOUCH--
FRBPOS:	0			;--CLR BEFORE RESTORE--
FRBNXT:	0			;   "    "	 "
FRBPRD:	0			;   "    "	 "
	BLOCK	1		;--NEVER TOUCH--
FRBUFD:	0			;--CLR BEFORE RESTORE--
FRBSTS:	0			;FILE STATUS WORD
FRBELB:	0			;--CLR BEFORE RESTORE--
FRBEUN:	0			;   "    "	 "
	BLOCK	XLOOKN-21	;---NEVER TOUCH ON SAVE OR RESTORE--
;MISCELLANEOUS DATA

ZONKER:		0
FILPP:	0			;E+3		LEAVE HERE, USED IN BLT
NAME:	0			;E FOR UUO ERRORS
EXT:	0			;E+1
PROT:	0			;E+2
DSKNAM:	BLOCK	NUMSTR		;FILE STRUCTURE LIST FOR /S,/U
DSKNME:	0			;END OF LIST MARKER - ALWAYS 0
MFDSPK:	BUFBIN
ACTSTR:	0			;SIXBIT /STRNAM/
	0			;OBUF,IBUF FOR MFD
DGADIR:	0
	0
	0
	0


	VAR			;MISC. VARIABLES
	LIT			;LITERAL TABLE
SAVNAM:	BLOCK	5		;SAVE NAME OF SOUGHT FILE HERE
WATBUF:	BLOCK	XLOOKN+2

PDL:	BLOCK	PDSIZ



;I/O BUFFERS

TTYBFI:	BLOCK	TTYINN*TTYSIZ	;BUFFERS FOR TTY INPUT
TTOBUF:	BLOCK	TTON*TTOLEN	;BUFFERS FOR TTY OUTPUT
TAPBUF=.				;BUFFER STARTING LOC FOR TAPE
MFDBUF=TAPBUF+TAPN*TAPLEN		;STARTING LOC FOR MFD
UFDBUF=MFDBUF+MFDN*DSKSIZ		;STARTING LOC FOR UFD
FILBUF==UFDBUF+UFDN*DSKSIZ		;CHECK FOR ACCESS AND CREATION
ENDIF1=FILBUF+ALTFLN*DSKSIZ		;END OF MODULE IF ALTN FILE
					;BUFFERS USED

ENDIF2=FILBUF+FILN*DSKSIZ		;END IF FILN # USED
	VSTBUF=3

	IFE	DEBUG,<
	BLOCK	VSTBUF		;LEAVE ROOM FOR INIT'ING MTA BUF HEADER
				;WHEN DOING  SPACING FUNCTIONS
	>
	IFN	DEBUG,
	<
	RELOC	ENDIF2
	>
TECOSTOP: END	START