Trailing-Edge
-
PDP-10 Archives
-
bb-m836d-bm
-
tools/alu/alu.mac
There are 6 other files named alu.mac in the archive. Click here to see a list.
;EDIT 240
;Reformat to TOPS20 coding conventions.
;Add FREEZE, UNFREEZE commands.
;Add STATUS USER command.
;EDIT 237
;Change default "till when" from "soon" to "one hour".
;EDIT 236
;Remove old SEARCH ALUPRM statement.
;EDIT 235
;Changed version number to 11
;-------
;This version shipped on tools tape with TOPS20 Release 5, although
;edit number had not been updated and was shipped as 233.
;EDIT 234
;Assemble ALUPRM as part of ALU rather than as universal.
;Put back default extension for CANCEL.
;Use ALU: instead of SYS: for second try for help file
;Give extension .RED for REDIT changes file.
;Type REDIT info in neater format
TITLE ALU - AUTOMATED LIBRARY UPDATING
SUBTTL DAVID WRIGHT JUL., 1979
;BASED ON ALU BY JACK KRUPANSKY
;USER-DEPENDENT THINGS ARE IN ALUPRM.MAC
SEARCH MONSYM,MACSYM
SALL
.REQUIRE SYS:MACREL
;SET DEFAULT F.T. SWITCHES
DEFINE ND (NAME,VALUE),<
IFNDEF NAME,<NAME==VALUE>>
ND FTFUID,0 ;DEFAULT IS NO UID IN SOURCE FILE
ND FTFCOM,0 ;DEFAULT IS NOT AUTOMATIC FILCOM AFTER REPLACE
ND FTCOPO,0 ;DEFAULT IS NO AUTOMATIC COPYING OF OUTPUT FILES
ND FTRUID,1 ;DEFAULT IS REPLACE UID (IF UID BEING USED)
ND FTBAKF,1 ;DEFAULT IS MAKE BACKUP FILE WITH RENAME
ND FTANYU,0 ;DEFAULT IS REGISTERED USERS ONLY
ND FTGCPY,1 ;DEFAULT IS ASK USER IF HE WANTS A COPY OF FILE
; EVEN THOUGH IT IS RESERVED BY SOMEONE ELSE.
ND FTREDT,1 ;DEFAULT IS RUN REDIT BEFORE REPLACE
ND FTCGET,1 ;DEFAULT IS TO COPY FILE WHEN IT'S RESERVED
;VERSION INFORMATION:
ALUMJR==11 ;MAJOR VERSION
ALUMNR==0 ;MINOR VERSION
ALUEDT==241 ;EDIT LEVEL
ALUWHO==0 ;WHO LAST EDITED
;EDIT HISTORY
;==================================
;EDIT# DATE WHO WHY !
;==================================
;
;233 6-Jul-81 /DAW If file is RENAME'd to the library, set the
; generation-retention-count to the default of the
; library.
;232 6-Jul-81 /DAW Implement /COPY and /NOCOPY switches on "GET" and
; "QGET" commands.
; FTCGET feature test switch: = 1 means the default
; is /COPY on GET and QGET, = 0 means default is /NOCOPY.
;231 6-Jul-81 /DAW Add "INFORMATION (ABOUT) VERSION" command,
; put out whole version number (including "minor"
; and "who" field) to FILUPD.HST.
; Don't depend on user defining LIB: the same way
; as is in ALU's table for REPLACE to work correctly.
; STATUS to print out "lib: = " before each library
; directory.
; Allow user to be on a different structure and
; REPLACE (until now this hasn't worked with all
; flavors of ALU).
; When replacing generated output files, do the same
; typeout as the EXEC when it does a COPY.
;
;*** VERSION 10 July 3,1981 ***
;
;230 2-Jul-81 /DAW Add another argument to LIB macro; to allow
; different libraries to have different FILUPD.HST's
; and places to put .DIF and .SCM files.
; Changed COMMENT command to ask which library's
; FILUPD.HST you want to put a comment in.
; Also ALUPRM files are now incompatible, so ALU is
; now version 10.
;227 2-Jul-81 /DAW Delete switch FTRCD (use connected directory
; on replaces); this is reasonable for all ALU's
; to do.
; Add DFLIB feature: If you define DFLIB in
; ALUPRM.MAC, it is used as the default library.
;226 1-Jul-81 /DLM RSCAN line handled.
; Get why text from new file if possible.
; CANCEL not fail if copy of file gone.
; Better handling of GTJFN failure on STATUS, etc.
; Allow any user if FTANYU.
; See if file already in connected directory before
; COPY'ing with GET.
; Handle busy on update of FILUPD.HST.
; Replace from connected directory.
; No default directory, code cleanup.
;225 8-Jun-81 /DAW Never set CM%RAI flag - it doesn't work well in
; COMND% JSYS unless you do it all the time. Convert
; the library field by hand to uppercase.
;224 4-JAN-80 /DAW Fix running of FILCOM to look nicer when it happens.
;223 3-DEC-79 /DAW Make DELETE work under TOPS20 V3A.
;222 30-NOV-79 /DAW Put user name in log entry.
;221 21-NOV-79 /DAW Fix problem in edit 220, where ALU no longer knew
; if you were connected to a library. Note: This change
; makes .MAZ files be incompatible (since the structure
; name is now included in them).
;220 20-NOV-79 /DLM Features for the TOPS20 project:
; function switches SWRUID and SWBAKF,
; allow .MAZ files to be in a subdirectory of the library,
; and fix ALU to be able to work across structures.
;217 30-OCT-79 /DAW In log file, say "Replaced LIB:file.ext" instead of
; just file.ext.
;216 21-OCT-79 /DAW ADD and DELETE commands implemented
;215 19-OCT-79 /DAW Created ALUPRM.MAC. Got rid of feature-tested code,
; and made them all run-time switches. Changed name
; of command "INFORMATION (about) FEATURE-TEST-SWITCHES"
; to "INFORMATION (about) FUNCTION-CONTROL-SWITCHES"
;214 18-OCT-79 /DAW Add option to STATUS command to just get the status
; of a particular file.
;213 17-OCT-79 /DAW Add another set of parsing routines for secondary
; command parsing. This improves the usefulness of "?"
; and control-U in certain places.
;212 16-OCT-79 /DAW Do RENAMEs instead of COPYs when built with FTFUID=0.
; Make ALU set date/times of files copied around
; just like EXEC copy. ALU only changes file date/times
; now when built with FTFUID=1.
;211 16-OCT-79 /DAW Improve error recovery when writing the MAZ file.
; Created a subroutine WRTMAZ to modularize the problem.
;
;*** VERSION 7 OCT 16,1979 ***
;
;210 16-OCT-79 /DAW Make several changes to make ALU incompatible
; with old versions. Therefore it is now version 7.
;207 15-OCT-79 /DAW Implement "INFORMATION (ABOUT) EXTENSIONS"
;206 15-OCT-79 /DAW Implement automatic copying of generated output
; files to the library along with the reserved
; file when it is replaced. This feature is controlled
; by switch "SWCOPO".
; Make "INFORMATION (ABOUT) FEA" tell about this.
;205 15-OCT-79 /DAW Implement "INFORMATION" command
; (about: USERS, LIBRARIES, FEATURE-TEST-SWITCHES)
;204 14-OCT-79 /DAW Implement feature test FTFUID - if 0, supresses
; changing the UID line in the updated file
;203 24-AUG-79 /DAW Fix STATUS command to 1) Print Library name
; when 1st reserved file on it found, and "no files
; reserved" otherwise; 2) Print actual file name
; that's reserved instead of "MAZ" name.
;202 23-AUG-79 /DAW Get rid of logical names, move EXTS definition
; up to top of file for easy editing.
;201 23-AUG-79 /DAW CHECK FOR "No such generation number" when
; doing a GTJFN for MAZ file.
;
;** VERSION 6 ** JUL 1, 1979
;
;200 1-JUL-79 /DAW INITIAL VERSION TAKEN FROM KRUPANSKY'S
;
;ABSTRACT:
; ALU is a program to aid developers of TOPS20 software products.
;It provides the following:
;
;1) An interlock mechanism on library files. Only one
; person can be editing a particular file at one time.
;
;2) A record of all changes to the library.
;
; The original version of this program was written in
;SNOBOL in 1978 by Jack Krupansky for the COBOL-79 project.
; It became version 6 in July, 1979 when David Wright rewrote
;it in MACRO for performance and maintainability.
; As more in-house developers started using it, feature-test
;switches were added and the formats of things changed, so in
;October, 1979 it became version 7.
; Dan Murphy (who represented the TOPS-20 monitor group)
;made several enhancements after that, and his source was
;merged in July, 1981 with David Wright's latest source to
;become ALU version 10. ALU was also made to work with REDIT
;in July, 1981 to make its capabilities rival those of STEP.
;AC DEFINITIONS
STDAC. ;STANDARD DEFINIIONS FROM MACSYM
;FLAGS
F.HUD==1B0 ;RESERVED FILE HAS A UID LINE
F.NUD==1B1 ;NEW FILE HAS A UID LINE
F.72C==1B2 ;NEW FILE'S UID LINE IS 72 CHARS LONG
F.TLN==1B3 ;TYPED A LIBRARY NAME IN "STATUS" COMMAND
F.FFL==1B4 ;FOUND A FILE IN "STATUS (OF) filespec"
F.QCMD==1B5 ;IN Q COMMAND (QGET)
F.EXIT==1B6 ;EXIT AFTER CURRENT COMMAND
F.SPCR==1B7 ;SPECIAL REPLACE FILESPEC
F.RCPY==1B8 ;Did a COPY vs RENAME when source file was
; REPLACE'd.
F.GCPY==1B9 ;/COPY option on "GET" or "QGET".
F.SUSR==1B10 ;DOING "STATUS USER" COMMAND
;DEFAULT PARAMETERS
PDLSIZ==100 ;SIZE OF PUSHDOWN STACK
TXTLEN==^D100 ;SIZE OF TEXT BUFFER
LOGLEN==^D2000 ;SIZE OF LOG BUFFER
LINLEN==^D80 ;SIZE OF A LINE OF .MAZ FILE
MAXLIN==^D140 ;SIZE OF (FIRST) TEXT LINE IN FILE
WHYLEN==^D100 ;LENGTH OF "WHY" TEXT
FILWDS==^D72 ;Max # words needed to hold a TOPS-20 filespec
CD.LEN==.CDRET+1 ;Number of words needed in a directory block
DEFINE AA(NAME,DATA,FLAGS),< ;MACRO FOR COMMAND TABLES
XWD [IFNB <FLAGS>,<EXP CM%FW!<FLAGS>>
ASCIZ/NAME/],DATA
>
;DECREMENT BYTE POINTER IN GIVEN LOCATION
DEFINE DBP. (LOC)<
MOVNI CX,1
IBP CX,LOC
MOVEM CX,LOC>
DEFINE TEXT (STRING),<
ASCIZ @STRING@
>
DEFINE TYPE (ADDRESS),<
HRROI T1,ADDRESS
PSOUT%>
CRLF==[ASCIZ/
/] ;ADDRESS OF A CRLF
TOINDI==[ASCIZ/ => /] ;Like EXEC "COPY"
SUBTTL START-UP
AENTRY: JRST ST ;FIRST TIME ENTRY
JRST ST1 ;REENTER
ALUVER: BYTE (3)ALUWHO(9)ALUMJR(6)ALUMNR(18)ALUEDT
BENTRY: JRST ST1 ;NORMAL ENTRY
JRST ST1 ;REENTER
BYTE (3)ALUWHO(9)ALUMJR(6)ALUMNR(18)ALUEDT
;HERE IS FIRST TIME ENTRY
ST: RESET%
TDZ F,F ;CLEAR ALL FLAGS
MOVEM F,SAVEF ;SAVE THEM
MOVE P,[IOWD PDLSIZ,PDL]
CALL SETPMP ;SETUP PAGE MAP
CALL WDFLIB ;Figure out which library is the
; default (if any). If none of them
; is, give error and abort.
CALL SETAVR ;Get ASCIZ ALU version number string
MOVEI T1,.FHSLF ;SET ALTERNATE ENTRY VECTOR
MOVE T2,[3,,BENTRY] ;ENTRY VECTOR WORD
SEVEC% ;SET IT
;Set up first-time defaults from assembly switches
MOVEI T1,FTFCOM ;GET FILCOM SWITCH SETTING
MOVEM T1,SWFCOM ;SET IT
MOVEI T1,FTCOPO ;GET COPY REL FILES SWITCH SETTING
MOVEM T1,SWCOPO ;SET IT
MOVEI T1,FTFUID ;UID IN SOURCE FILE SWITCH SETTING
MOVEM T1,SWFUID ;SAVE IT
MOVEI T1,FTRUID ;1= REPLACE UID IN SOURCE ON REPLACE
MOVEM T1,SWRUID
MOVEI T1,FTBAKF
MOVEM T1,SWBAKF
MOVEI T1,FTANYU
MOVEM T1,SWANYU
MOVEI T1,FTGCPY ;1= ASK USER IF HE WANTS A COPY OF FILE
; IF IT WAS RESERVED AND HE DID A "GET"
MOVEM T1,SWGCPY
MOVEI T1,FTREDT ;1= RUN REDIT before REPLACE
MOVEM T1,SWREDT
MOVEI T1,FTCGET ;1= /COPY is the default for GET
MOVEM T1,SWCGET
TYPE <[ASCIZ/[ALU: First-time Initialization complete]
[Type "EXIT" then save ALU to bypass the initialization from now on]
/]>
JRST ST2
;SECONDARY ENTRY POINT AND REENTER ADDRESS
;( ASSUME PAGE MAP AND SWITCHES ARE ALL SET UP)
ST1: MOVE P,[IOWD PDLSIZ,PDL]
MOVE F,SAVEF ;GET SAVED FLAGS
MOVEI T1,.RSINI
RSCAN% ;Get rescan line if any
IFJER.
SETZ T1,
ENDIF.
MOVEM T1,RSCANF ;Note RESCAN waiting
ST2: MOVE T1,[ZROST,,ZROST+1]
SETZM ZROST
BLT T1,ZROEND ;CLEAR ZEROED AREA
SETO T1, ;GET MY TERMINAL NUMBER
MOVE T2,[-1,,T4]
MOVEI T3,.JITNO ;JUST TERMINAL NUMBER
GETJI%
ERJMP SYSERR ;BAD ERROR
TRO T4,.TTDES ;MAKE A TTY DESIGNATOR
MOVEM T4,MYTTY ;SAVE IT
;SEE IF WE HAVE "PRIVS" TO DO ^E COMMANDS
CALL RGUCHK ;CHECK FOR REGISTERED USER
JRST DOSCAN ;NOT, THEN NO PRIVS
MOVE T2,USRBIT ;Get user flags
TXNE T2,E.BIT ;Is E.BIT on?
SETOM MEPRIV ;YES, HE HAS PRIVS TO DO ^E COMMANDS
JRST DOSCAN ;OK TO GO
SUBTTL SYSTEM ERRORS
SYSERR: TMSG <?JSYS ERROR: >
HRRZI T1,.PRIOU ;PRIMARY OUTPUT
HRLOI T2,400000
SETZ T3,
ERSTR%
JRST ERSTRE
JRST ERSTRE
HALTF%
JRST ST ;RESTART PROGRAM IF HE TYPES CONTINUE
ERSTRE: TMSG < ?Can't get JSYS error code!!>
HALTF%
JRST ST
IMPERR: TMSG <? "Impossible" JSYS error: >
CALL LSTFER
TMSG <
(Address of the ERCAL is in AC1)
>
POP P,T1
SUBI T1,1
HALTF%
JRST 1(T1) ;RETURN
SUBTTL COMMAND SCANNER
DOSCAN:
;HERE TO READ NEXT COMMAND
NEWCMD: MOVEI T1,.PRIOU ;Get usual place for command output
SKIPE RSCANF ;RESCAN waiting?
MOVEI T1,.NULIO ;Yes, no output from COMND
HRRM T1,CMDBLK+.CMIOJ
MOVEI T1,CMDBLK ;POINT TO COMMAND BLOCK
MOVEI T2,[FLDDB. (.CMINI)] ;INITIALIZATION FUNCTION
CALL COMMND ;GO DO IT
MOVEM P,SAVEP ;SAVE STACK FOR REPARSING
NEWPAR: MOVE P,SAVEP ;RESTORE THE STACK
SKIPN T1,PRSJFN ;ANY JFN?
JRST NEWPR1 ;NO
RLJFN% ;RELEASE IT
JFCL
SETZM PRSJFN ;CLEAR PARSED JFN
NEWPR1: TXZ F,F.QCMD!F.EXIT!F.SUSR ;Not a Q cmd.
MOVEI T1,CMDBLK ;POINT TO THE COMMAND BLOCK
SKIPN RSCANF ;RESCAN line here?
JRST NEWPR3 ;No
SETZM RSCANF ;Yes, once only
MOVEI T2,[FLDDB. (.CMKEY,,RSCNTB)] ;Yes, special table
COMND%
ERJMP LOSE
TXNE T1,CM%NOP ;Got our name?
JRST NEWCMD ;No, ignore the line quietly
HRRZ P1,0(T2) ;Save dispatch address
MOVEI T2,[FLDDB. (.CMCFM)]
COMND% ;See if line ends here
ERJMP LOSE
TXNN T1,CM%NOP
JRST NEWCMD ;It did, nothing to do
TXO F,F.EXIT ;Remember exit after command
JRST 0(P1) ;Dispatch to command
NEWPR3: SKIPE MEPRIV ;AM I PRIVILEDGED TO DO ^E COMMANDS?
JRST NEWP1A ;YES
MOVEI T2,[FLDDB. (.CMKEY,,CMDTAB)] ;POINT TO COMMAND TABLE
CALL COMMND ;READ THE COMMAND
NEWP1B: MOVE T2,(T2) ;GET ADDRESS OF ROUTINE
CALL (T2) ;CALL IT
TXNE F,F.EXIT ;EXIT after command?
HALTF% ;Yes, done
JRST NEWCMD ;GO GET A NEW COMMAND
NEWP1A: MOVEI T2,FLPR1 ;COMMANDS, AND ^E
CALL COMMND
HRRZ T3,T3 ;GET PARSE BLOCK USED
CAIN T3,FLPR1 ;NORMAL COMMAND?
JRST NEWP1B ;YES
;^E PARSED.. GO GET A ^E COMMAND
MOVEI T2,[FLDDB. (.CMKEY,,CMETAB)]
CALL COMMND
HRRZ T2,(T2)
CALL (T2) ;CALL A CONTROL-E COMMAND
JRST NEWCMD ;AND GET A NEW COMMAND
;PARSING TABLES FOR MAJOR COMMANDS
FLPR1: FLDDB. (.CMKEY,,CMDTAB,,,FLPR2)
FLPR2: FLDDB. (.CMTOK,,<POINT 7,ASCCTE>)
ASCCTE: BYTE (7)5,0 ;CONTROL-E
;TABLE OF COMMANDS
CMDTAB: CMDLEN,,CMDLEN ;HEADER
AA ADD,CMDADD ;ADD A FILE
AA CANCEL,CMDCAN ;CANCEL A GET
AA COMMENT,CMDCOM ;PUT COMMENT INTO FILE
AA DELETE,CMDDEL ;DELETE A FILE FROM A LIBRARY
AA EXIT,CMDEXT ;EXIT
AA FREEZE,CMDFRZ ;FREEZE
AA GET,CMDGET ;GET A FILE
AA HELP,CMDHLP ;HELP
AA INFORMATION,CMDINF ;INFORMATION
AA QGET,CMQGET ;Quick GET (no questions asked)
AA REPLACE,CMDREP ;REPLACE A FILE
AA STATUS,CMDSTT ;STATUS
AA UNFREEZE,CMDUNF ;UNFREEZE
CMDLEN==.-CMDTAB-1 ;NUMBER OF COMMANDS
;CONTROL-E COMMANDS
CMETAB: CMELEN,,CMELEN ;HEADER
AA DDT,CMEDDT
AA SET,CMESET
CMELEN==.-CMETAB-1 ;NUMBER OF ^E COMMANDS
;TABLE OF COMMANDS FOR RESCAN LINE
RSCNTB: RSTLEN,,RSTLEN
AA ALU,NEWPR3
RSTLEN==.-RSCNTB-1
SUBTTL ADD COMMAND
;ADD A NEW SOURCE FILE TO THE LIBRARY
CMDADD: MOVEI T2,[ASCIZ/file/]
CALL NOISE
SETZM JFNBLK ;NO DEFAULTS
MOVE T2,[JFNBLK,,JFNBLK+1]
BLT T2,JFNBLK+20
MOVX T2,GJ%OLD ;GET AN EXISTING FILE
MOVEM T2,JFNBLK+.GJGEN ;STORE FLAGS
MOVEI T2,[FLDDB. (.CMFIL,CM%SDH,,<existing file to put on library>)]
CALL COMMND
HRRZM T2,PRSJFN ;SAVE PARSED JFN
MOVEI T2,[ASCIZ/to/]
CALL NOISE
MOVE T3,[POINT 7,[ASCIZ/(Library to add file to)
/]] ;Get help text
CALL PRSLIB ;Parse library name
CALL BLDINM ;BUILD NAME IN IFINAM
CALL PRSWHY ;GET "WHY" TEXT
MOVX T1,GJ%SHT+GJ%OLD ;SEE IF FILE THERE ALREADY
HRROI T2,IFINAM ;PTR TO NAME
GTJFN%
ERJMP CMDAD1
RLJFN% ;ALREADY THERE, COMPLAIN
JFCL
TMSG <? File already exists on the library
>
RET ;DONE, RETURN
CMDAD1: ;ONE MIGHT CHECK TO MAKE SURE WE ARE GETTING ONE OF THE
;VALID ERROR CODES FROM GTJFN
MOVX T1,GJ%SHT+GJ%NEW ;WRITE FILE TO LIBRARY NOW
HRROI T2,IFINAM
GTJFN%
ERJMP ADDER1 ;ERROR-CAN'T WRITE
MOVEM T1,OJFN ;SAVE THIS JFN
MOVE T1,PRSJFN
MOVEM T1,IJFN ;SET "IJFN", "OJFN"
MOVE T1,IJFN ;READ DATE/TIME OF INPUT FILE
MOVEI T2,RFTAD1
MOVEI T3,2
RFTAD%
CALL OPENO ;GET READY TO WRITE NEW FILE
RET ;ERRORS, FORGET IT
CALL IOPEN ;OPEN FILE FOR READING
JRST [CALL RLOJFN ;ERROR, RELEASE OJFN
RET] ; AND RETURN
SKIPN SWFUID ;PUT UID IN FILE?
JRST ADDCM2 ;NO
;DO A "SLOW" COPY
CALL BLDNUI ;BUILD NEW UID LINE
RET ;ERRORS, RETURN
CALL OUT1ST ;OUTPUT 1ST LINE TO OUTPUT FILE
CALL BYTWRT ;USE BYTE I/O TO COPY THE FILE NOW
JRST ADDCM4 ; DON'T RESET DATE/TIMES
;DO A "FAST" COPY
ADDCM2: CALL PRELD0 ;GET SOME PAGES IN CORE
CALL PPCPY ;PAGE/PAGE COPY
CALL ALUUID ;GET A UID
;MAKE LOG ENTRY
ADDCM4: CALL ADDLOG ;DO A "ADD" LOG ENTRY
;RELEASE FILES
HRRZ T1,OJFN
RLJFN%
JFCL
HRRZ T1,IJFN
RLJFN%
JFCL
RET ;DONE, RETURN
ADDER1: TMSG <?GTJFN FAILED: >
CALL LSTFER
TYPE CRLF
HALTF%
RET
;Routine to parse a library name
; He can either type LIB: on this line or type CRLF here and
;is then prompted for a library name. It is required that he
;actually type the library name, and this routine returns when
;he has typed something.
;Input:
; T3/ help text
;Output:
; LIBNUM/ library number
PRSLIB: MOVEM T3,HPTXTP ;Save help text ptr
MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<library:>)]
CALL COMMND ;PARSE THE TEXT
LDB T1,[POINT 7,ATMBUF,6] ;ANYTHING TYPED?
JUMPE T1,GTLNM ;NO, MAKE HIM TYPE SOMETHING
MOVEI T1,ATMBUF ;Convert ATMBUF to uppercase
CALL CNVUPP
MOVE T1,[ATMBUF,,LIBHLD]
BLT T1,LIBHLD+17 ;COPY STRING TO HERE
MOVEI T1,CMDBLK ;String must be followed by CRLF
CALL CONFRM
JRST GOTLNM ;GO CHECK IT
;HERE TO ASK FOR HIM TO TYPE LIBNAM
GTLNM: MOVE T1,HPTXTP ;Get ptr to help text
CALL PR2SET
MOVEI T1,CM2BLK
MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<library:>)]
CALL COMMND
LDB T2,[POINT 7,ATM2BF,6] ;ANYTHING TYPED?
JUMPE T2,GTLNM ;NO, TRY AGAIN
MOVEI T1,ATM2BF ;Convert ATM2BF to uppercase
CALL CNVUPP
MOVE T1,[ATM2BF,,LIBHLD] ;COPY IT
BLT T1,LIBHLD+17
MOVEI T1,CM2BLK
CALL CONFRM ;String must end here
;HERE WHEN THERE WAS SOMETHING INPUT FOR LIBRARY NAME. SEE IF OK.
GOTLNM: CALL FNDLIB ;FIND THE LIBARY HE TYPED
JRST GTLNM ;NOT A LIBRARY, GO ASK AGAIN
RET ;Got it, return ok
;CALL: LIBNUM/ # of library
; PRSJFN/ TO GET FILE.EXT
; CALL BLDINM
; <RETURN HERE, WHOLE ASCIZ STRING IN IFINAM>
BLDINM: MOVE T1,[POINT 7,IFINAM] ;OUTPUT TO HERE
MOVE T2,LIBNUM
HRRZ T2,LIBLST(T2)
HRLI T2,(POINT 7,) ;<DIR>
CALL CPYNUL ;COPY TO NUL
HRRZ T2,PRSJFN ;GET JFN
MOVX T3,1B8+1B11+JS%PAF ;FILE.EXT
JFNS%
RET ;RETURN, DONE
;ROUTINE TO CHECK INPUT LIBRARY NAME IN LIBHLD
; IF IT IS A LIBARY, RETURNS .+2, library index in LIBNUM
; IF NOT, TYPES ERROR MESSAGE
FNDLIB: PUSH P,P4 ;Save an ac
MOVSI P4,-NMLIBS ;FIND THE LIBRARY HE TYPED
FNDLB1: HRRZ T1,LB1LST(P4) ;POINT TO A LIBRARY
HRLI T1,(POINT 7,) ;STRING
MOVE T2,[POINT 7,LIBHLD] ;POINT TO INPUT STRING
FNDLB2: ILDB T3,T1
ILDB T4,T2
JUMPE T3,[CALL FNBT4 ;GET FIRST NON-BLANK
JUMPE T4,FNDLB4 ;OK IF BOTH ENDED
JRST FNDLB3] ;TO AOBJN
CAIN T3,(T4) ;STILL THE SAME?
JRST FNDLB2 ;YES, LOOP
FNDLB3: AOBJN P4,FNDLB1 ;LOOP FOR ALL
TMSG <? >
TYPE LIBHLD ;TYPE HIS TEXT
TMSG < is not a library
>
POP P,P4 ;Restore ac
RET ;ERROR MESSAGE, POPJ
;HERE IF LIBRARY MATCHES
FNDLB4: HRRZM P4,LIBNUM ;SET INTERNAL LIBRARY NUMBER
POP P,P4 ;Restore ac
JRST RSKP ;SKIP RETURN
;LITTLE ROUTINE TO IGNORE TRAILING BLANKS
FNBT4: CAIE T4,.CHTAB
CAIN T4," "
CAIA
RET ;NON-BLANK, RETURN
ILDB T4,T2
JRST FNBT4
SUBTTL CANCEL COMMAND
CMDCAN: MOVEI T2,[ASCIZ/file/]
CALL NOISE
MOVE T2,DFLIBW ;GET DEFAULT LIBRARY (OR 0)
MOVEM T2,JFNBLK+.GJDEV
HRRO T2,EXTLST ;DEFAULT EXT - FIRST ONE IN THE LIST.
MOVEM T2,JFNBLK+.GJEXT
MOVX T2,GJ%OLD
MOVEM T2,JFNBLK ;STORE FLAGS
MOVEI T2,[FLDDB. (.CMFIL,CM%SDH,,<file on library you don't want reserved any more>)]
CALL COMMND
HRRZM T2,PRSJFN ;SAVE PARSED JFN
CALL CONFRM ;CONFIRM THE LINE
MOVE T1,PRSJFN
MOVEM T1,GTFJFN ;SAVE "GET" FILE JFN
CALL RGUSR ;GET USER NUMBER FOR ME
RET ;? NOT A REGISTERED USER!
CALL GTFINL ;GET LIBRARY
RET ;? NOT IN A LIBRARY
CALL FNDEXT ;FIND EXTENSION
RET ;CAN'T.. OOPS
;LOOK FOR .MAZ FILE
CALL GMAZNM ;GET MAZ FILENAME
RET ;ERRORS, RETURN
;TRY TO GTJFN IT
MOVX T1,GJ%SHT+GJ%OLD
HRROI T2,MAZNAM
GTJFN%
ERJMP CCANE2 ;NOT THERE -- GO COMPLAIN
MOVEM T1,MAZJFN ;YUP--SAVE JFN OF IT
CALL CHKRME ;MAKE SURE RESERVED BY ME!
RET ;NOT.. RETURN AFTER TYPING ERROR MSG
; FALL...
;DELETE THE RESERVED FILE FROM THE RESERVATION DIRECTORY IF IT IS THERE
MOVE T2,[POINT 7,RDIR]
MOVE T1,[POINT 7,RETJNM] ;MAKE JFN STRING FOR FILE IN AREA IT WAS
;RESERVED IN
CALL CPYNUL ;COPY TO NUL
;USE JFNS TO GET REST OF NAME
MOVE T2,GTFJFN
MOVX T3,1B8+1B11+JS%PAF ;FILENAME.EXT
JFNS%
SETZ T2,
IDPB T2,T1 ;;STORE NULL AT END OF STRING
MOVX T1,GJ%SHT!GJ%OLD
HRROI T2,RETJNM
GTJFN%
ERJMP CCAN1 ;Couldn't find it
PUSH P,T1
TMSG <(Delete >
TYPE RETJNM
TMSG < ?) >
CALL YESNO
JRST [ POP P,T1 ;Recover JFN
RLJFN%
NOP
JRST CCAN1]
POP P,T1 ;Recover JFN
MOVEI T2,0 ;Keep 0 generations
DELNF% ;Delete all generations
ERJMP CCAN1 ;OOPS.. CAN't
RLJFN% ;Release JFN
ERJMP .+1 ; Ah, well, tried
;THEN DELETE .MAZ FILE
CCAN1: HRRZ T1,MAZJFN
DELF%
ERJMP CCANE3 ;OOPS.. CAN'T
RET ;DONE, RETURN
; ERRORS DURING "CANCEL" COMMAND
;GTJFN FAILED FOR MAZ FILE -- PROBABLY NOT RESERVED
CCANE2: CAIE T1,GJFX19 ;NO SUCH FILE TYPE
CAIN T1,GJFX24 ;FILE NOT FOUND
JRST NOTRSV ;YEAH.. NOT RESERVED, YOU FOOL
CAIN T1,GJFX20 ;NO SUCH GENERATION NUMBER (TOPS20 FUNNY)
JRST NOTRSV
TMSG <?GTJFN failed for MAZ file: >
CALLRET LSTFRC ;Type JSYS error, CRLF, then return
NOTRSV: TMSG <% File >
MOVEI T1,.PRIOU ;PREPARE TO TYPE FILENAME
HRRZ T2,GTFJFN
MOVX T3,1B5+1B8+1B11+JS%PAF
JFNS%
TMSG < was not reserved
>
; JRST RLMAZP ;Release MAZJFN and POPJ
;Routine to release MAZJFN
; It must not be opened.
RLMAZP: MOVE T1,MAZJFN
RLJFN% ;RELEASE MAZ FILE
ERJMPS .+1 ;WHO CARES?
RET ;RETURN FROM "CANCEL" COMMAND
CCANE3: TMSG <?DELF failed for MAZ file: >
CALLRET LSTFRC
SUBTTL COMMENT COMMAND
CMDCOM: MOVEI T2,[ASCIZ/for library/]
CALL NOISE
MOVE T3,[POINT 7,[ASCIZ/(Library to comment about)
/]] ;Get help text
CALL PRSLIB ;Parse library name and confirm
CALL RGUSR ;GET USER NUMBER
RET ;HE'S NOT A REGISTERED USER
GETCMT: TMSG <(Type a one-line comment)
>
SETZ T1, ;NO CONTROL-R BUFFER
CALL PR2SET ;SETUP FOR 2ND PARSE
MOVEI T1,CM2BLK ;2ND PARSE BLOCK
MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<One-line comment to put in FILUPD.HST>)]
CALL COMMND ;READ THE COMMENT
MOVE T3,[POINT 7,ATM2BF]
ILDB T1,T3
JUMPE T1,GETCMT ;MAKE HIM TYPE SOMETHING
CALL ALUUID ;GET A UID
;DO LOG ENTRY
CALL STLOG ;START THE LOG
MOVE T2,[POINT 7,[ASCIZ/
[Comment by /]]
CALL LOGSTR
MOVE T2,[POINT 7,USRNAM]
CALL LOGSTR
MOVEI T2,"]"
IDPB T2,P1
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR
MOVE T2,[POINT 7,ATM2BF]
CALL LOGSTR ;OUTPUT COMMENT
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR ;AND CRLF
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR ;AND EXTRA CRLF
MOVEI T1,0
IDPB T1,P1 ;NULL TO END IT
CALL ALULOG ;OUTPUT TO LOG FILE
RET ;DONE, RETURN
SUBTTL DELETE COMMAND
CMDDEL: MOVEI T2,[ASCIZ/file/]
CALL NOISE
MOVE T2,DFLIBW ;GET DEFAULT LIBRARY (OR 0)
MOVEM T2,JFNBLK+.GJDEV
HRRO T2,EXTLST ;DEFAULT EXT - FIRST ONE IN THE LIST.
MOVEM T2,JFNBLK+.GJEXT
MOVX T2,GJ%OLD
MOVEM T2,JFNBLK+.GJGEN ;STORE FLAGS
MOVEI T2,[FLDDB. (.CMFIL,CM%SDH,,<existing file in a library>)]
CALL COMMND
HRRZM T2,PRSJFN ;SAVE PARSED JFN
CALL CONFRM ;CONFIRM THE LINE
MOVE T1,PRSJFN
MOVEM T1,GTFJFN ;SAVE "GET" FILE JFN
CALL GTFINL ;GET WHICH LIBRARY IT'S IN
RET ;ISN'T IN ANY, RETURN
CALL RGUSR ;GET MY USER NUMBER
RET ;? NOT A REGISTERED USER
CALL FNDEXT ;FIND EXTENSION
RET ;CAN'T.. RETURN
;MAKE SURE FILE ISN'T RESERVED BY SOMEONE
CALL SKPFRF ;SKIP IF LIBRARY FROZEN
IFSKP.
HRRZ P1,T1 ;SAVE JFN
TMSG <?Library is frozen.
>
JRST CDELE8
ENDIF.
CALL GMAZNM ;GET .MAZ FILENAME
RET ;ERRORS.. RETURN
MOVX T1,GJ%SHT+GJ%OLD
HRROI T2,MAZNAM
GTJFN%
ERJMP CDELE2 ;FAILED.. MIGHT BE OK
;FILE WAS THERE.. COMPLAIN TO HIM
CDELE7: HRRZ P1,T1 ;JFN IN P1
CDELE8: TMSG <?>
CALL TYPFIL ;TYPE THE .MAZ FILE OUT
HRRZ T1,P1 ;RELEASE .MAZ FILE
RLJFN%
JFCL ;ERRORS ARE BAD.
RET ;RETURN TO RELEASE PRSJFN (SOURCE FILE)
;GTJFN FAILED FOR .MAZ FILE.. HOPEFULLY FILE-NOT-FOUND
CDELE2: CAIE T1,GJFX24 ;FILE NOT FOUND
CAIN T1,GJFX19 ;NO SUCH FILE TYPE
JRST CDELT3 ;OK TO DELETE THE FILE
CAIN T1,GJFX20 ;NO SUCH GENERATION NUMBER
JRST CDELT3 ;IS OK TOO
JRST EGTMAZ ;GO COMPLAIN THAT GTJFN FAILED
;HERE IF NO .MAZ FILE EXISTS.. OK TO DELETE IT
CDELT3: CALL PRSWHY ;ASK HIM FOR ONE-LINE COMMENT
SKIPN SWBAKF ;USING BACKUP FILES?
JRST CDELT4 ;NO
;DELETE BACKUP TOO IF THERE
HRROI T1,RETJNM
HRRZ T2,GTFJFN
MOVX T3,1B2+1B5+1B8+JS%PAF ;<DIRECTORY>FILE
JFNS%
HRRZ T2,EXTNUM ;WHICH EXTENSION?
HRRZ T2,EXBLST(T2) ;GET A BACKUP EXTENSION
HRLI T2,(POINT 7,) ;POINT TO IT
MOVEI T3,"." ;APPEND A DOT FIRST
IDPB T3,T1
CALL CPYNUL ;COPY STRING
MOVX T1,GJ%SHT+GJ%OLD ;SEE IF WE CAN FIND BACKUP TOO
HRROI T2,RETJNM
GTJFN%
ERJMP CDELT4 ;NO, FORGET IT
;DELETE FILE, THEN BACKUP
MOVE P3,T1 ;SAVE JFN OF BACKUP TO DELETE
HRRZ T1,GTFJFN ;DELETE SOURCE
MOVEI T2,0 ;KEEP 0 GENERATIONS
DELNF% ;Delete it, keep JFN
ERJMP CDELE4 ;CAN'T
HRRZ T1,P3 ;DELETE BACKUP
MOVEI T2,0 ;KEEP 0 GENERATIONS
DELNF%
ERJMP CDELE5
RLJFN% ;Release backup JFN
ERJMP .+1 ; Tried..
TYPE <[ASCIZ/[Deleted /]>
TYPE RETJNM
TYPE <[ASCIZ/ also]
/]>
CDELT5: CALL ALUUID ;GO ALLOCATE A UID
CALL LOGDEL ;A DELETE LOG ENTRY
RET ;RETURN--DONE
;NO BACKUP.. JUST DELETE SOURCE FILE
CDELT4: HRRZ T1,GTFJFN
MOVEI T2,0 ;KEEP 0 GENERATIONS
DELNF% ;DELETE ALL GENERATIONS
ERJMP CDELE3 ;ERROR
JRST CDELT5 ;OK, FINISH
;DELETE ERRORS
CDELE3: TMSG <?Can't delete file: >
CALLRET LSTFRC ;Type why, CRLF and return to release PRSJFN
CDELE4: TMSG <?Can't delete file: >
CDELE6: CALL LSTFRC ;Type why
HRRZ T1,P3 ;RELEASE BACKUP JFN
RLJFN%
JFCL ;CAN'T
RET ;RETURN TO RELEASE PRSJFN
CDELE5: TMSG <?Can't delete >
TYPE RETJNM ;<DIR>FILE.EXT
TMSG <: >
JRST CDELE6 ;GO FINISH ERROR RECOVERY
SUBTTL EXIT COMMAND
CMDEXT: CALL CONFRM
;SEE IF ANY FUNCTION-SWITCHES HAVE BEEN CHANGED.. IF SO, TELL HIM TO
; SAVE A COPY TO RETAIN THESE CHANGES.
SKIPN CNFCOM
SKIPE CNCOPO
JRST CMDEX1 ;SAY "SAVE"
SKIPN CNFUID
SKIPE CNRUID
JRST CMDEX1
SKIPN CNBAKF
SKIPE CNANYU
JRST CMDEX1 ;SAY "SAVE"
SKIPN CNGCPY
SKIPE CNREDT
JRST CMDEX1 ;SAY "SAVE"
SKIPE CNCGET
JRST CMDEX1 ;SAY "SAVE"
CMDEX2: HALTF%
SETZM CNFCOM ;ASSUME HE DID SAVE
SETZM CNCOPO
SETZM CNFUID
SETZM CNRUID
SETZM CNBAKF
SETZM CNANYU
SETZM CNGCPY
SETZM CNREDT
SETZM CNCGET
RET ;CONTINUE
CMDEX1: TYPE <[ASCIZ/
[Type "SAVE ALU:ALU" to retain the function changes you made]
/]>
JRST CMDEX2
SUBTTL FREEZE COMMAND
CMDFRZ: MOVEI T2,[ASCIZ /library/]
CALL NOISE
MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<library name:>)]
CALL COMMND
LDB T1,[POINT 7,ATMBUF,6]
JUMPE T1,[TMSG <?"library:" expected.
>
RET]
MOVEI T1,ATMBUF
CALL CNVUPP
MOVE T1,[ATMBUF,,LIBHLD]
BLT T1,LIBHLD+17
CALL FNDLIB ;LOOKUP LIBRARY NAME
RET
CALL SKPFRL ;SEE IF ALREADY FROZEN
IFSKP.
HRRZ P1,T1 ;SAVE JFN
TMSG <?Library is already frozen.
>
CALL TYPFIL ;TYPE MESSAGE
HRRZ T1,P1
RLJFN%
ERJMPS .+1
RET
ENDIF.
MOVX T1,GJ%SHT ;NOT ALREADY FROZEN, CREATE FREEZE FILE
HRROI T2,MAZNAM
GTJFN%
IFJER.
TMSG <?Can't create freeze file because:
>
CALL LSTFRC ;TYPE ERR MSG
RET
ENDIF.
HRRZM T1,MAZJFN
MOVX T2,7B5+OF%WR
OPENF%
IFJER.
TMSG <?Can't open freeze file because:
>
CALL LSTFRC
HRRZ T1,MAZJFN
RLJFN%
ERJMPS .+1
RET
ENDIF.
MOVEI T3,[ASCIZ /! Frozen by /]
CALL MAZSTR
JRST FATAL
MOVEI T3,USRNAM
CALL MAZSTR
JRST FATAL
MOVEI T3,[ASCIZ / on /]
CALL MAZSTR
JRST FATAL
CALL MAZTIM ;WRITE TIME TO FILE
JRST FATAL
MOVEI T3,[ASCIZ /
/]
CALL MAZSTR
JRST FATAL
HRRZ T1,MAZJFN
CLOSF%
ERJMPS .+1
RET
SUBTTL GET COMMAND
CMQGET: TXO F,F.QCMD ;Quick version
CMDGET: SKIPN SWCGET ;COPY-ON-GET?
TXZA F,F.GCPY ;No, default is /NOCOPY
TXO F,F.GCPY ;Yes, default is /COPY
MOVEI T2,[ASCIZ/file/]
CALL NOISE
MOVE T2,DFLIBW ;GET DEFAULT LIBRARY (OR 0)
MOVEM T2,JFNBLK+.GJDEV
HRRO T2,EXTLST ;DEFAULT EXT - FIRST ONE IN THE LIST.
MOVEM T2,JFNBLK+.GJEXT
MOVX T2,GJ%OLD
MOVEM T2,JFNBLK+.GJGEN ;STORE FLAGS
MOVEI T2,[FLDDB. (.CMFIL,CM%SDH,,<existing file in a library>)]
CALL COMMND
HRRZM T2,PRSJFN ;SAVE PARSED JFN
MOVEI T2,FLCPCF ;Switch or CRLF
CALL COMMND
HRRZ T3,T3 ;Which parse block?
CAIN T3,FLGCF ;CRLF?
JRST GTDPRS ;yes, done parse
HRRZ T2,(T2) ;Get address of routine to call
CALL (T2) ;Call it
CALL CONFRM ;Confirm the command
JRST GTDPRS ;OK, done parsing
FLCPCF:
FLGCF: FLDDB. (.CMCFM,,,,,FLGTSW)
FLGTSW: FLDDB. (.CMSWI,,GTSWTT)
GTSWTT: NMGTSW,,NMGTSW ;Header
AA COPY,GTSWCP
AA NOCOPY,GTSWNC
NMGTSW==.-GTSWTT-1 ;Number of "GET" switches
;/COPY
GTSWCP: TXOA F,F.GCPY
;/NOCOPY
GTSWNC: TXZ F,F.GCPY
RET
;Here when done parse of "GET" command
GTDPRS: MOVE T1,PRSJFN
MOVEM T1,GTFJFN ;SAVE "GET" FILE JFN
CALL GTFINL ;GET WHICH LIBRARY THE FILE IS IN
RET ;ISN'T IN ANY, RETURN
CALL RGUSR ;GET MY USER NUMBER
RET ;? NOT A REGISTERED USER, RETURN
CALL FNDEXT ;FIND EXTENSION
RET ;CAN'T.. RETURN
CALL GETCD ;GET MY CONNECTED DIRECTORY
;AND MAKE SURE IT'S NOT A LIBRARY
;SEE IF FILE IS RESERVABLE
; (LOOKUP ".MAZ" FILE.. IF IT'S THERE, WE CAN'T DO IT)
CALL SKPFRF ;SEE IF LIBRARY FROZEN
IFSKP.
HRRZM T1,P1 ;SAVE JFN
TMSG <
%Library is frozen.
>
CALL TYPFIL ;TYPE OUT INFO
MOVE T1,P1
RLJFN%
ERJMPS .+1
ENDIF.
CALL GMAZNM ;GET .MAZ FILENAME
RET ;ERRORS.. RETURN
;NOW LOOK IT UP
MOVX T1,GJ%SHT+GJ%OLD
HRROI T2,MAZNAM
GTJFN%
ERJMP CMGET8 ;ASSUME MERELY NOT THERE
;ERJMP CGETE2 ;FAILED.. MIGHT BE OK
;FILE WAS THERE.. COMPLAIN TO HIM
;OPEN IT
HRRZM T1,MAZJFN
MOVX T2,7B5+OF%RD
OPENF%
ERJMP CGETE6 ;CAN'T OPEN IT
HRRZ T1,MAZJFN
BIN%
ERJMP CMGT7B
CAIN T2,"!" ;CHANGE FIRST BYTE
MOVEI T2,"?"
HRRZ T1,T2
PBOUT%
;TYPE IT OUT
CMGT7A: HRRZ T1,MAZJFN
BIN%
ERJMP CMGT7B
HRRZ T1,T2
PBOUT%
JRST CMGT7A
;HERE WHEN WE GOT TO EOF AFTER TYPING OUT THE .MAZ FILE FOR HIM
; CLOSE IT, AND GIVE HIM THE OPTION OF COPYING IT ANYWAY.
CMGT7B: HRRZ T1,MAZJFN
CLOSF%
ERJMP .+1 ;IGNORE ERRORS CLOSING FILE
SKIPN SWGCPY ;Skip if giving user the option
RET ;Assume no copy wanted
TMSG < Do you want a copy anyway? (Answer YES or NO): >
CALL YESNO
RET ;"NO"
JRST GTCOPY ;GO GET A COPY
;HERE IF OK TO GET THE FILE - GET "TILL" TEXT
CMGET8: TXNE F,F.QCMD ;QGET?
JRST [ MOVE T1,[POINT 7,TILTXT] ;Yes, default TILTXT
MOVE T2,[POINT 7,[ASCIZ/One hour/]]
CALL CPYNUL
MOVE T2,T1 ;Dest byte ptr
JRST DONTT1]
MOVE T1,[POINT 7,[ASCIZ/(Till when?) /]]
CALL PR2SET ;SET UP FOR 2ND PARSE
MOVEI T1,CM2BLK ;USE 2ND COMND BLOCK
MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<One-line comment for STATUS information>)]
CALL COMMND
; COPY ANSWER TO TILTXT - MAKE SURE THERE IS SOMETHING THERE, AND APPEND ".."
MOVE T3,[POINT 7,ATM2BF] ;FROM HERE
MOVE T2,[POINT 7,TILTXT] ;TO HERE
DO.
ILDB T1,T3 ;GET A CHAR
CAIE T1,.CHTAB
CAIN T1," "
LOOP. ;IGNORE LEADING SPACES AND TABS
ENDDO.
;GOT FIRST NON-BLANK
JUMPE T1,DEFTIL ;IF NOTHING THERE, GIVE DEFAULT ANSWER
;STORE CHARS UNTIL NULL
NXTIL: IDPB T1,T2
ILDB T1,T3
JUMPN T1,NXTIL
MOVEI T1,"."
IDPB T1,T2
IDPB T1,T2 ;".."
JRST DONTT1 ;DONE TILL
;IF NULL ANSWER TO "TILL WHEN", STORE DEFAULT ANSWER
DEFTIL: MOVEI T3,"?"
IDPB T3,T2
DONTT1: MOVEI T1,.CHCRT
IDPB T1,T2
MOVEI T1,.CHLFD
IDPB T1,T2
SETZ T1, ;NULL TO END IT
IDPB T1,T2
; JRST DONTTX
;WRITE RESERVED MARKER
DONTTX: CALL WRTMAZ ;WRITE THE MAZ FILE
RET ;ERRORS, RETURN
; ** READY TO COPY FILE **
;NOW ACTUALLY COPY THE FILE TO MY AREA
GTCOPY: TXNN F,F.GCPY ;Get a copy?
RET ;No, all done
MOVE T1,GTFJFN
MOVEM T1,IJFN ;FROM HERE
MOVE T2,[POINT 7,CD] ;TO CONNECTED DIRECTORY
MOVE T1,[POINT 7,RETJNM] ;STORE FILENAME TO ENTER HERE
CALL CPYNUL ;COPY STRING
HRRZ T2,GTFJFN
MOVX T3,1B8+1B11+JS%PAF ;NAME.EXT
JFNS%
SETZ T2,
IDPB T2,T1 ;STORE NULL AT END
;SEE IF FILE ALREADY THERE
MOVX T1,GJ%SHT+GJ%OLD
HRROI T2,RETJNM
GTJFN%
ERJMP GTCPY2 ;Isn't, good
RLJFN% ;Didn't really want this JFN
NOP
TMSG <% File >
TYPE RETJNM ;Advise user
TMSG < already exists.
(Supersede?) >
CALL YESNO
RET ;"NO" -- quit.
GTCPY2:
;GET A JFN FOR THIS FILE
MOVX T1,GJ%SHT+GJ%FOU
MOVE T2,[POINT 7,RETJNM]
GTJFN%
ERJMP CGETE8 ;?CAN'T GET A JFN FOR IT
MOVEM T1,OJFN ;OUTPUT FILE JFN
MOVE T1,IJFN ;GET DATE/TIME STUFF FROM FILE NOW
MOVEI T2,RFTAD1
MOVEI T3,2
RFTAD%
CALL PRELOD ;PRELOAD PAGES TO START (OPENS FILE)
CALL OPENO ;OPEN OUTPUT FILE
RET ;ERRORS, GIVE UP
CALL PPCPY ;PAGE/PAGE COPY
MOVE T1,IJFN
RLJFN%
IFJER.
TMSG <% Couldn't release JFN for IFILE
>
ENDIF.
MOVE T1,OJFN
RLJFN%
IFJER.
TMSG <% Couldn't release JFN for OFILE
>
ENDIF.
RET ;RETURN
;ROUTINE TO WRITE THE MAZ FILE
;ASCIZ NAME IS IN "MAZNAM"
;RETURNS .+1 IF ERRORS, .+2 IF OK
WRTMAZ: MOVX T1,GJ%SHT
HRROI T2,MAZNAM
GTJFN%
ERJMP WRTME1
;OPEN FOR OUTPUT, AND WRITE THE MESSAGE INTO IT
HRRZM T1,MAZJFN
MOVX T2,7B5+OF%WR
OPENF%
ERJMP WRTME2 ;OPENF FAILED
MOVEI T3,[ASCIZ/! Reserved by /]
CALL MAZSTR ;WRITE STRING TO .MAZ FILE
JRST WRTMZA ;QUOTA EXCEEDED, GO TRY AGAIN
MOVEI T3,USRNAM ;Get user name
CALL MAZSTR ;WRITE IT
JRST WRTMZA ;GOT QUOTA EXCEEDED
MOVEI T3,[ASCIZ/ at /]
CALL MAZSTR
JRST WRTMZA ;QUOTA EXCEEDED
MOVEI T3,CD ;PRINT THIS
CALL MAZSTR
JRST WRTMZA ;QUOTA EXCEEDED
MOVEI T3,[ASCIZ/ on /]
CALL MAZSTR
JRST WRTMZA
CALL MAZTIM ;WRITE TIME TO .MAZ FILE
JRST WRTMZA
MOVEI T3,[ASCIZ/
! till /]
CALL MAZSTR
JRST WRTMZA
MOVEI T3,TILTXT ;INPUT LINE
CALL MAZSTR ;APPEND THAT TOO
JRST WRTMZA ;QUOTA EXCEEDED
;CLOSE AND RELEASE IT
HRRZ T1,MAZJFN
CLOSF%
ERJMP WRTMZC ;CAN'T CLOSE AND RELEASE FILE
AOS (P) ;RETURN OK
RET
;HERE TO TRY AGAIN IF QUOTA EXCEEDED HAS BEEN FIXED
WRTMZA: HRRZ T1,MAZJFN ;RELEASE JFN AND TRY AGAIN
CLOSF%
ERJMP WRTMZC ;GEEZ, WHAT'S THIS THEN?
JRST WRTMAZ ;GO TRY AGAIN
WRTMZC: CALL CHKQTE ;MAYBE QUOTA EXCEEDED AGAIN?
JRST WRTMZA ;YES
TMSG <?Can't close MAZ file: >
CALL LSTFER
HALTF% ;SOMETHING BAD
JRST .-1 ;DON'T RECOVER
;HERE IF OUTPUT GTJFN FAILED
WRTME1: TMSG <? GTJFN failed for >
TYPE MAZNAM
TMSG <: >
CALL LSTFER ;SAY WHY
HALTF% ;LET HIM DO STUFF
JRST WRTMAZ ;TRY AGAIN IF "CONTINUE"
;HERE IF OPENF FAILED FOR WRITING MAZ FILE
WRTME2: TMSG <?OPENF failed for >
TYPE MAZNAM
TMSG <: >
CALL LSTFER ;SAY WHY
HALTF%
HRRZ T1,MAZJFN ;HE TYPED "CONTINUE", RELEASE IT'S JFN
RLJFN%
JFCL ;ALL ERRORS ARE VERY BAD!
JRST WRTMAZ ;AND GO TRY AGAIN
;ERRORS IN "GET" CODE
CGETE2: CAIE T1,GJFX24 ;FILE NOT FOUND
CAIN T1,GJFX19 ;NO SUCH FILE TYPE
JRST CMGET8 ;OK TO GET THE FILE
;23-AUG-79 /DAW EVEN THOUGH WE DIDN'T SUPPLY A GENERATION NUMBER,
; GTJFN RETURNS "NO SUCH GENERATION NUMBER" IF AN OLD COPY WAS
; DELETED ON THE LIBARY.
CAIN T1,GJFX20 ;NO SUCH GENERATION NUMBER
JRST CMGET8 ; (MEANS OLD .MAZ IS DELETED)
EGTMAZ: TMSG <? GTJFN failed for >
TYPE MAZNAM
TMSG <: >
CALL LSTFER ;SAY WHY
HALTF%
RET
CGETE6: TMSG <?OPENF failed for MAZ file: >
CALL LSTFER
HALTF%
RET
CGETE8: TMSG <?GTJFN failed for output file: >
CALLRET LSTFRC ;Type why, CRLF and return
SUBTTL REPLACE COMMAND
CMDREP: MOVEI T2,[ASCIZ/file/]
CALL NOISE
MOVE T2,DFLIBW ;GET DEFAULT LIBRARY (OR 0)
MOVEM T2,JFNBLK+.GJDEV
HRRO T2,EXTLST ;DEFAULT EXT (THE FIRST ONE)
MOVEM T2,JFNBLK+.GJEXT
MOVX T2,GJ%OLD
MOVEM T2,JFNBLK+.GJGEN ;STORE FLAGS
MOVEI T2,[FLDDB. (.CMFIL,CM%SDH,,<existing file in a library>)]
CALL COMMND
HRRZM T2,PRSJFN
CALL CONFRM
TXZ F,F.SPCR ;No special filespec
TXZ F,F.RCPY ;Clear "DID A COPY" flag
MOVE T1,PRSJFN
MOVEM T1,GTFJFN ;SAVE JFN OF THE FILE WE "GOT"
CALL GTFINL ;GET LIBRARY NUMBER WHERE FILE IS
RET ;?NOT IN A LIBRARY
CALL RGUSR ;Check user access
RET ; ?Not allowed to use ALU replace.
CALL FNDEXT ;FIND EXTENSION
RET ;CAN'T.. RETURN
CALL GETCD ;GET CONNECTED DIRECTORY
; DON'T LET IT BE A LIBRARY
;MAKE SURE FILE IS RESERVED.. LOOKUP ".MAZ" FILE
CALL SKPFRF ;SKIP IF FREEZE IN EFFECT
IFSKP.
HRRZM T1,MAZJFN ;SAVE JFN
CALL CHKFME ;YES, SEE IF BY ME
RET ;NO, LOSE
TMSG <%You have this library frozen.
>
ENDIF.
CALL GMAZNM ;BUILD .MAZ FILE NAME
RET ;ERROR
;LOOK IT UP
MOVX T1,GJ%SHT+GJ%OLD
HRROI T2,MAZNAM
GTJFN%
ERJMP REPLE1 ;FAILED.. COMPLAIN
HRRZM T1,MAZJFN ;SAVE JFN OF IT
CALL CHKRME ;CHECK TO SEE IF FILE IS RESERVED BY ME..
RET ;NO, RETURN
;CHECK TO SEE IF HE IS CONNECTED TO
;THE SAME AREA WHERE THE RESERVED FILE WAS PUT WITH "GET"
;If not, give warning and find out what he wants to do.
CALL CHKCNN ;This may set F.SPCR
SKIPE SWRUID ;Replacing UID?
SKIPN SWFUID ; and putting UID in file?
JRST CMDRE5 ; NO, DON'T OPEN AND READ RESERVED FILE
;LOOKUP RESERVED FILE AND SEE IF IT WAS MODIFIED
;THE FOLLOWING CODE IS EXECUTED IN VERSIONS OF ALU THAT WANT
; TO MODIFY THE FIRST LINE OF THE FILE TO PUT IN INFORMATION
; ABOUT THE LAST MODIFICATION OF THE FILE. IT MAKES A CHECK
; TO SEE IF THE RESERVED FILE HAS BEEN MODIFIED ON THE LIBRARY.
CMDRE2: TXZ F,F.HUD!F.NUD!F.72C ;CLEAR "OLD FILE HAS A UID"
SETZM UID1 ;DON'T KNOW UID OF FILE ON MY AREA YET
MOVE T1,GTFJFN
MOVX T2,OF%RD+7B5 ;READ OLD FILE
OPENF% ;OPEN IT
ERJMP REPLE2 ;?CAN'T
;READ 1ST LINE
CMDRE3: SETZM RFBUF ;CLEAR BUFFER
MOVE T1,[RFBUF,,RFBUF+1]
BLT T1,RFBUF+.RFLN-1
HRRZ T1,GTFJFN ;FROM HERE
MOVE T2,[POINT 7,RFBUF] ;TO HERE
MOVEI T3,LINLEN ;80 CHARS MAX
MOVEI T4,.CHLFD ;TERMINATE WITH A LINE FEED
SIN%
IFJE. (R)
CAIE T1,IOX4 ;END OF FILE REACHED?
JRST REPLE3 ;NO, UNEXPECTED ERROR
ENDIF.
;CLOSE BUT DON'T RELEASE JFN
CMDRE4: HRRZ T1,GTFJFN
TXO T1,CO%NRJ ;DON'T RELEASE JFN
CLOSF%
ERJMP REPLE4 ;OOPS.. CAN'T
;Here for all flavours of REPLACE.
; We have GTFJFN/ file on library to replace.
;We have confirmed that the user is not connected to a library,
; and the file was indeed reserved by him.
; Now we must get IJFN/ file to replace it with.
;See if file is on the connected directory.
CMDRE5: MOVE T1,[POINT 7,RETJNM]
MOVE T2,[POINT 7,CD] ;Start with connected directory
CALL CPYNUL
HRRZ T2,GTFJFN ;NOW APPEND FILENAME
MOVX T3,1B8+1B11+JS%PAF ;JUST NAME.EXT
JFNS%
JXN F,F.SPCR,REPL81 ;Jump if special filename
MOVX T1,GJ%SHT+GJ%OLD
MOVE T2,[POINT 7,RETJNM]
GTJFN%
ERJMP REPLE6 ;Can't find new source file!
JRST REPL82
REPLE6: TMSG <% File >
TYPE RETJNM
TMSG < not found
>
REPL81: MOVE T1,[POINT 7,[ASCIZ/(Type alternate filespec) /]]
CALL PR2SET ;SETUP 2ND PARSE
SETZM JFNBLK ;NO DEFAULTS
MOVE T2,[JFNBLK,,JFNBLK+1]
BLT T2,JFNBLK+20
MOVX T2,GJ%OLD ;GET AN EXISTING FILE
MOVEM T2,JFNBLK+.GJGEN ;STORE FLAGS
MOVEI T1,CM2BLK ;USING THIS PARSE BLOCK NOW
MOVEI T2,FLCRFS ;CR to forget it, or filespec.
CALL COMMND ;PARSE IT
HRRZ T3,T3 ;Which parse block used?
CAIN T3,FLCFM ;CRLF = "forget this REPLACE"?
CALLRET RLMAZP ;Release MAZJFN, return from REPLACE command.
MOVE T1,T2 ;Good filespec, Get JFN
JRST REPL82
;Parse blocks
FLCRFS:
FLCFM: FLDDB. (.CMCFM,CM%SDH,,<CRLF to quit the UPDATE>,,FLFS1)
FLFS1: FLDDB. (.CMFIL,CM%SDH,,<New source file>)
;Here when we got T1/ JFN of new source file
REPL82: MOVEM T1,IJFN ;SAVE AS INPUT JFN
;Get date/time info for IJFN and store in RFTAD1
MOVE T1,IJFN ;READ DATE/TIME OF INPUT FILE
MOVEI T2,RFTAD1
MOVEI T3,2
RFTAD%
;GET NAME IN "IFINAM"
MOVE T1,[POINT 7,IFINAM]
HRRZ T2,IJFN
MOVX T3,1B2+1B5+1B8+1B11+JS%PAF ;DEVICE:<DIRECTORY>FILENAME.EXT
JFNS%
;GET COMPLETE NAME IN "FROMFL"
MOVE T1,[POINT 7,FROMFL]
MOVE T2,IJFN ; "FROM" THIS FILE
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS%
CALL SETMAB ;GET MABJFN, OJFN
RET ;ERRORS
SKIPN SWFUID ;Using UID in file?
JRST NOUSUD ;No
; ** Here when ALU wants to put a new UID in the file **
TXO F,F.RCPY ;Set "Did a COPY" (vs. RENAME) flag.
CALL OPENO ;GET READY TO WRITE NEW FILE
RET ;ERRORS, FORGET IT
CALL IOPEN ;OPEN FILE FOR READING
JRST [CALL RLOJFN ;ERRORS, RELEASE OJFN
RET] ; AND RETURN
SKIPE SWRUID ;REPLACING UID?
JRST ASKWHY ;Yes, don't read new file yet
;See if file has comment as first line which can be used as
;WHY text. It must not look like a UID line or an edit line.
;REDIT has not yet been called.
CALL RDLIN1 ;Read first line of new file
MOVE P1,[POINT 7,RFBUF] ;PTR to first line
ILDB T1,P1 ;LOOK AT FIRST CHAR
CAIE T1,";" ;A COMMENT CHAR?
CAIN T1,"!"
SKIPA ;YES
JRST ASKWHY ;NO, MUST ASK
ILDB T1,P1 ;CHECK NEXT CHAR
CAIN T1,"<" ;PROBABLY EDIT LINE?
JRST ASKWHY ;YES, LOSE
CAIE T1," " ;POSSIBLE START OF UID LINE?
JRST NASKW ;NO, OK
MOVE T2,[POINT 7,[ASCIZ/UPD ID= /]]
CALL CMPSTR ;PROBABLY UID LINE?
SKIPA ;NO
JRST ASKWHY ;YES, LOSE
NASKW: MOVE T1,[POINT 7,WHYTXT]
MOVE T2,[POINT 7,RFBUF]
IBP T2 ;SKIP COMMENT CHAR
CALL CPYNUL ;COPY LINE TO WHY TEXT
JRST NORUI0 ;GO COPY FILE
;GET "WHY" TEXT
;REDIT HAS NOT YET BEEN CALLED.
ASKWHY: CALL PRSWHY ;PARSE WHY TEXT
SKIPN SWRUID ;REPLACING UID?
JRST NORUI0 ;NO
;SEE IF RESERVED FILE HAS A UID LINE
MOVE P1,[POINT 7,RFBUF] ;LOOK FOR ; OR !
ILDB T1,P1
CAIE T1,";"
CAIN T1,"!" ;EITHER IS OK
CAIA
JRST NORUID ;NOPE, NO UID LINE THEN
MOVE T2,[POINT 7,[ASCIZ/ UPD ID= /]] ;THIS MUST BE NEXT
CALL CMPSTR ;COMPARE STRINGS
JRST NORUID ;NO UID LINE
TXO F,F.HUD ; ELSE WE DID FIND ONE
CALL PRELD0 ;READ SOME PAGES IN
HRRZ T1,STIPG2 ;WHERE DOES IT START IN CORE?
MOVE T1,(T1) ; SEE IF FIRST PAGE EXISTS
ERJMP NOPG0 ;? NO, DON'T ALLOW COPY
CALL CHKNUD ;CHECK FOR NEW FILE'S UID
; (SETS OR CLEARS FLAGS; ONLY 1 RETURN)
;COMPARE UID STRING TO SEE IF RESERVED FILE WAS MODIFIED
HRRZ P1,STIPG2
HRLI P1,(POINT 7,) ;POINTER TO "FILE" STRING
MOVE T2,[POINT 7,RFBUF] ;POINTER TO OLD UID STRING
CALL CMPSTR ;SKIP IF EQUAL
JRST RSVFMD ; ? RESERVED FILE WAS MODIFIED
;If he wants to replace it anyway,
; RSVFMD returns to either GOUPDC or GOCOP
;** Come here to copy the file with UID replacement **
;COPY THE FILE. FLAGS F.HUD, F.NUD, AND F.72C ARE CORRECT
;REDIT HAS NOT YET BEEN CALLED
GOUPDC: TXNN F,F.72C ;IF UID LINE NOT 72 CHARS,
JRST GOSLOW ;GO DO SLOW COPY
;EXACTLY 72 CHARS IN THIS UID LINE.. JUST REPLACE IT AND CALL
; FAST COPY ROUTINE
CALL BLDNUI ;BUILD NEW UID
RET ;ERRORS.. RETURN
;REPLACE 72 CHARS IN FILE WITH 72 CHARS IN UIDTXT..
MOVEI T1,UIDTXT ;POINTER TO UID TEXT
MOVEM T1,FSTLIN ;TELL PPCPY WHERE IT IS
;Here when ready to copy, NEWUID set up.
GOCOP: SKIPE SWREDT ;Call REDIT before replace?
CALL CALRDT ;Yes, do it
CALL DORNAM ;RENAME OLD MAC TO MAB
RET ;?CAN'T
;Here when we are ready to copy new source file to place where
; the old source file was.
;REDIT has been called if necessary.
; Both new source (OJFN) and old source (IJFN) are OPEN.
GOCUID: CALL PPCPY ;DO PAGE COPY
SCPPDN: HRRZ T1,IJFN ;NOW DELETE FILE ON MY AREA
MOVEI T2,0 ;KEEP 0 GENERATIONS
DELNF% ;Delete file(s)
IFJER.
TMSG <%Can't delete >
TYPE IFINAM ;TYPE THE NAME
TMSG <: >
CALL LSTFER ;TYPE WHY
TMSG <, continuing...
>
ENDIF.
MOVE T1,IJFN ;Throw away new source's JFN
RLJFN%
ERJMP .+1 ;Can't, no big deal.
JRST DONRPL ;Go finish up "REPLACE" actions
;RESERVED FILE WAS MODIFIED
RSVFMD: TMSG <% Reserved file was modified
Do you want to replace it anyway? (Y,N): >
CALL YESNO
RET ;NO
SKIPE SWFUID ;YES, SKIP IF WE SHOULDN'T PUT UID IN FILE
JRST GOUPDC ; GO DO COPY WITH UID REPLACEMENT
JRST GOCOP ; GO DO COPY WITHOUT UID REPLACEMENT
;FILE TO REPLACE WITH HAS NO PAGE 0
NOPG0: TMSG <? File to copy has no page 0
>
TMSG <[REPLACE aborted]
>
CALL RLMAB ;RELEASE MAB JFN
CALL RLIJFN ;RELEASE IJFN
CALL RLOJFN ;RELEASE OJFN
RET ;RETURN FROM REPLACE
;HERE IF THE OLD UID LINE IN THE FILE IS NOT EXACTLY 72 CHARACTERS
; WE HAVE TO COPY WITHOUT USING PMAP'S. SIGH.
;REDIT HAS NOT YET BEEN CALLED.
GOSLOW: MOVE T3,NPAGES ;GET SIZE OF BUFFER
IORX T3,PM%CNT ;REPEAT COUNT
HRROI T1,-1 ;SAY REMOVING PAGES
HRLI T2,.FHSLF
HRR T2,STIPGS
PMAP% ;UNMAP PAGES
MOVE T1,IJFN
TXO T1,CO%NRJ ;DON'T RELEASE JFN
CLOSF%
ERJMP .+1
CALL IOPEN ;NOW OPEN FILE FOR READING AGAIN
RET ;?CAN'T
;HERE IF NO UID LINE FOUND IN RESERVED FILE.
; WE WILL HAVE TO DO THE SLOW COPY
;REDIT HAS NOT YET BEEN CALLED.
NORUID: CALL RDLIN1 ;Read first line of new file
NORUI0: CALL BLDNUI ;BUILD NEW UID LINE
RET ;ERRORS.. RETURN
SKIPE SWREDT ;Call REDIT before replace?
CALL CALRDT ;Yes, do it
CALL DORNAM ;RENAME OLD MAC TO MAB
RET ;?CAN'T
CALL OUT1ST ;WRITE 1ST LINE TO OUTPUT FILE
MOVE P1,[POINT 7,RFBUF]
ILDB T1,P1 ;GET 1ST CHAR
CAIE T1,";"
CAIN T1,"!" ;UID LINE?
SKIPN SWRUID ;AND REPLACING UID LINES?
JRST OUT1L ;NOPE, OUTPUT STARTING HERE
MOVE T2,[POINT 7,[ASCIZ/ UPD ID= /]]
CALL CMPSTR ;COMPARE
JRST OUT1L ;NO MATCH, OUTPUT STARTING HERE
MOVEI T3,^D10 ;READ UID
MOVE T1,P1
NIN%
IFJER.
SETZ T2, ;ERROR, CLEAR UID
ENDIF.
MOVEM T2,UID1
;HAVE A UID LINE, SKIP IT
;NOW JUST USE BYTE I/O TO COPY THE FILE
LNDONE: CALL BYTWRT ;COPY BYTES
JRST SCPPDN ;DONE SLOW COPY
;READ FIRST LINE OF NEW FILE TO CHECK FOR UID LINE, ETC.
RDLIN1: HRRZ T1,IJFN
MOVE T2,[POINT 7,RFBUF]
MOVEI T3,MAXLIN-1 ;MAX UID LINE LENGTH
MOVEI T4,.CHLFD ;TERMINATE WITH LF
SIN%
ERJMP FSTLER
SETZ T4, ;TIE OFF WITH NUL
IDPB T4,T2
RET
;HERE IF ERROR READING TO END OF FIRST LINE IN NEW FILE
FSTLER: TMSG <? Couldn't read 1st line in new file: >
CALL LSTFER
HALTF%
JRST RDLIN1 ;TRY AGAIN
;HERE IF FIRST LINE WAS NOT UID LINE, OUTPUT IT ALL
OUT1L: MOVE T1,OJFN
MOVE T2,[POINT 7,RFBUF]
SETZ T3,
SOUT%
ERJMP LNDON4 ;ERROR
JRST LNDONE ;DONE FIRST LINE, JUST USE SIN/SOUT LOOP NOW
LNDON4: CALL CHKQTE ;CHECK FOR QUOTA EXCEEDED
JRST OUT1L ;IT WAS, TRY AGAIN
TMSG <? Output error: >
CALL LSTFER
HALTF%
JRST OUT1L ;TRY AGAIN IF CONT
; ** Here if UID lines are not to be put in the file **
; Files are not OPEN.
NOUSUD: CALL PRSWHY ;Find out why replace.
CALL ALUUID ;Get a UID
SKIPE SWREDT ;Call REDIT before REPLACE?
CALL CALRDT ;Yes, do it
CALL DORNAM ;Rename old MAC to MAB
RET ;?Can't
;Try to do a "RENAME"
GORNM: MOVE T1,OJFN ;Get JFN of output file
CALL SETGRC ;Set generation-retention-count from directory
JRST GORNM2 ;?Failed, pretend RENAME failed because
; files were not on same device, and do copy.
MOVE T1,IJFN
MOVE T2,OJFN
RNAMF% ;TRY TO DO THE RENAME
ERJMPR GORNME
JRST RNAMDN ;DONE
;RENAME FAILED.
GORNME: CAIN T1,RNAMX4
JRST GORNM1 ;?QUOTA EXCEEDED IN DEST OF RENAME
CAIN T1,RNAMX1
JRST GORNM2 ;?Files are not on same device
TMSG <? Can't rename >
TYPE IFINAM
TMSG <: >
CALL LSTFER ;TYPE THE ERROR
HALTF%
JRST GORNM ;TRY AGAIN IF HE TYPES "CONTINUE"
GORNM1: TYPE <[ASCIZ/?Quota exceeded on library
[Please fix the problem and type "CONTINUE"]/]>
HALTF%
JRST GORNM ;GO TRY AGAIN
;Here if RENAME failed because files are not on same device.
; Try to copy instead.
GORNM2: CALL OPENO ;Open output file
RET ;?Errors, forget it
CALL IOPEN ;Open new source file for reading
JRST [CALL RLOJFN ;Errors, release OJFN
RET] ;And return
CALL PRELD0 ;Read some pages in
TXO F,F.RCPY ;Set "Did a COPY" (vs. RENAME) flag
JRST GOCUID ;Go do fast copy.
;RENAME WAS SUCCESSFUL
; ** here, should delete all other generations of the source file
; from my area before going to DONRPL **
RNAMDN: JRST DONRPL ;Go finish REPLACE actions
;*** FILE HAS BEEN COPIED/RENAMED TO LIBRARY ***
; The new source file has been deleted from my area.
;IJFN has been released.
DONRPL: SKIPE SWFCOM ;DOING A FILCOM?
CALL FCSTR ;YES, GET STRING FOR FILCOM
CALL DOLOG ;;OUTPUT TO "LOG" (FILUPD.HST)
SKIPN SWBAKF ;MAKING BACKUP FILES?
JRST REPDON ;NO
MOVE T1,MABJFN ;RELEASE BACKUP
RLJFN%
IFJER.
TMSG <% Couldn't Release MABJFN
>
ENDIF.
;HERE WHEN DONE REPLACE TO RELEASE JFNS AND DELETE MAZ FILE
REPDON:
DELOF: MOVE T1,OJFN ;RELEASE NEW FILE
RLJFN%
ERJMP [TMSG <? Couldn't release OJFN: >
CALL LSTFER
HALTF% ;DIE
JRST DELOF] ;TRY AGAIN IF "CONTINUE"
;DELETE MAZ FILE
MOVE T1,MAZJFN
DELF%
IFJER.
TMSG <? Couldn't delete >
TYPE MAZNAM
TYPE CRLF
ENDIF.
;ALL DONE REPLACE.
SKIPE SWCOPO ;COPY OUTPUT FILES TOO?
CALL CHKOF ;CHECK FOR GENERATED OUTPUT FILES
; AND COPY THEM
; RETURN OR RUN FILCOM
SKIPN SWFCOM ;RUN FILCOM?
RET ;NO, JUST RETURN
TMSG <[ALU: Running FILCOM]
>
MOVE T4,[POINT 7,[ASCIZ/R FILCOM/]]
CALL STILF ;OUTPUT STRING AND LINEFEED TO STI BUF
MOVE T4,[POINT 7,FCTXT]
CALL STILF ;STRING FOR FILCOM
MOVEI T2,3 ;CONTROL-C
CALL STICH ;OUTPUT CHAR
HALTF% ;GO DO IT
RET
STILF: ILDB T2,T4 ;GET CHAR
JUMPE T2,STILL ;END, OUTPUT LF
CALL STICH ;PUT CHAR IN BUFFER
JRST STILF ;LOOP
STILL: MOVEI T2,.CHCRT ;GET <CR>, <LF> IS PUT ON BY SYSTEM
STICH: MOVE T1,MYTTY ;TTY DESIGNATOR
STI%
RET ;RETURN
; ERRORS IN "REPLACE"
REPLE1: TMSG <? File wasn't reserved
>
RET ;DONE
REPLE2: TMSG <?OPENF failed for reserved file on the library: >
CALL LSTFER
HALTF%
JRST CMDRE2 ;TRY AGAIN IF "CONTINUE"
REPLE3: TMSG <? Can't read first line of reserved file: >
CALL LSTFER
HALTF%
JRST CMDRE3 ;TRY AGAIN IF CONTINUE
REPLE4: TMSG <?CLOSF failed for reserved file: >
CALL LSTFER
HALTF%
JRST CMDRE4 ;TRY AGAIN IF CONTINUE
SUBTTL STATUS COMMAND
CMDSTT: MOVEI T2,[ASCIZ/of/]
CALL NOISE
SETZM JFNBLK ;NO DEFAULTS IN FILE-SPECS NOW
MOVE T2,[JFNBLK,,JFNBLK+1]
BLT T2,JFNBLK+20 ;CLEAR JFN BLOCK
HRRO T2,EXTLST ;DEFAULT EXTENSION IS FIRST
MOVEM T2,JFNBLK+.GJEXT
MOVEI T2,FLSTTK ;THINGS THAT COULD BE PARSED NOW
CALL COMMND ;GO GET 'EM
HRRZ T3,T3 ;OK, WHICH PARSE BLOCK USED?
CAIN T3,FLSTTK ;KEYWORD?
JRST STCMDK ;YES, DISPATCH
;MUST BE A FILE-SPEC
MOVEM T2,PRSJFN ;SAVE PARSED JFN
MOVEM T2,GTFJFN ;SAVE HERE FOR "FNDEXT"
CALL CONFRM ;CONFIRM
JRST STFILE ;STATUS (OF) FILE
FLSTTK: FLDDB. (.CMKEY,,STTTAB,,<SIGN-OUTS>,FLSTT2)
FLSTT2: FLDDB. (.CMFIL,CM%SDH,,<Filespec of specific file to check>)
STTTAB: STCLEN,,STCLEN ;# OF STATUS COMMAND OPTIONS
AA LIBRARY,STLIB
AA MY-RESERVATIONS,STUSR
AA SIGN-OUTS,STSIGN
STCLEN==.-STTTAB-1
;KEYWORD
STCMDK: MOVE T2,(T2)
JRST (T2) ;DISPATCH
;STATUS (OF) filespec
;JFN IS IN T2 AND PRSJFN
;USE JFNS TO GET FILE.EXT IN RETJNM
STFILE: CALL FNDEXT ;ANY KNOWN EXTENSION?
RET ;NO, FORGET IT
HRROI T1,RETJNM ;PLACE TO RETURN FILESPEC
MOVE T2,GTFJFN
MOVX T3,1B8+1B11+JS%PAF ;FILE.EXT
JFNS%
;LOOK ON ALL THE LIBRARIES FOR A .MAZ FILE
TXZ F,F.TLN!F.FFL ;DIDN'T SEE ANY FILES, OR TYPE LIB NAMES YET
MOVSI P4,-NMLIBS ;AOBJN PTR TO LIBRARIES
STFIL1: HRRZ T1,LIBLST(P4) ;POINT TO LIBRARY DIRECTORY
HRLI T1,(POINT 7,) ;REAL POINTER
MOVE T3,[POINT 7,LIBHLD] ;STORE WHOLE FILESPEC HERE
MOVE T4,[POINT 7,MAZNAM] ;AT SAME TIME, BUILD .MAZ FILENAME
STFIL2: ILDB T2,T1 ;FIRST COPY DIRECTORY NAME
JUMPE T2,STFIL3
IDPB T2,T3
IDPB T2,T4
JRST STFIL2
STFIL3: PUSH P,T3
MOVE T1,T4 ;PASS PTR TO MAZ NAME
CALL FXMAZN ;FIX UP MAZ NAME TO INCLUDE SUBDIR
MOVEM T1,T4 ;UPDATE PTR
POP P,T3
MOVE T1,[POINT 7,RETJNM] ;NOW FILE.EXT
DO.
ILDB T2,T1
IDPB T2,T3
JUMPN T2,TOP.
ENDDO.
MOVE T1,[POINT 7,RETJNM] ;GET NAME FOR .MAZ FILESPEC
STFIL4: ILDB T2,T1
CAIN T2,"."
JRST STFIL5 ;GOT TO EXTENSION
IDPB T2,T4
JRST STFIL4
STFIL5: IDPB T2,T4 ;STORE DOT
MOVE T2,EXTNUM ;GET NUMBER OF EXTENSION
HRRZ T1,STEXTS(T2) ;.MAZ OR SOMETHING
HRLI T1,(POINT 7,)
DO.
ILDB T2,T1
IDPB T2,T4
JUMPN T2,TOP. ;LOOP TILL EVERYTHING STORED
ENDDO.
;WHOLE FILESPEC IS NOW IN LIBHLD - LOOK FOR THE FILE
;MAZ FILESPEC IS NOW IN MAZNAM
MOVX T1,GJ%SHT+GJ%OLD
HRROI T2,LIBHLD
GTJFN% ;CAN WE FIND FILE ON THE LIBRARY?
ERJMP STFIL6 ;NO
TXO F,F.FFL ;YES, SET FLAG
RLJFN% ;IMMEDIATELY RELEASE IT
JFCL ;BETTER WORK!
;SEE IF IT IS RESERVED
MOVX T1,GJ%SHT+GJ%OLD
HRROI T2,MAZNAM
GTJFN%
ERJMP STFIL6 ;NO
HRRZ P1,T1 ;SAVE JFN
TXO F,F.TLN ;TYPE A LIBRARY NAME
CALL TYPLNM ;TYPE LIBRARY NAME
TYPE RETJNM ;TYPE NAME.EXT
TYPE CRLF ;AND CRLF
CALL TYPFIL ;TYPE OUT THE FILE
HRRZ T1,P1 ;GET BACK JFN
RLJFN% ;AND RELEASE IT
JFCL ;BETTER WORK!
STFIL6: AOBJN P4,STFIL1 ;LOOP FOR ALL LIBRARIES
TXNE F,F.FFL ;DID WE SEE THE FILE AT ALL?
JRST STFIL7 ;YES
TMSG < %File not found on any library
>
RET ;SAY THAT
STFIL7: TXNE F,F.TLN ;WAS IT EVER RESERVED?
RET ;YES, WE TYPED INFO
TMSG < [File is not reserved]
>
RET ;RETURN
;STATUS OF MY-RESERVATIONS
STUSR: TXO F,F.SUSR ;MAGIC FLAG DOES ALL...
; ..
;STATUS (OF) SIGN-OUTS
STSIGN: CALL CONFRM ;CONFIRM REQUEST
;SEARCH ALL LIBRARYS FOR SIGNED OUT FILES
MOVSI P4,-NMLIBS ;-# LIBS
JRST STAT1
;STATUS (OF) LIBRARY library:
STLIB: MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<library:>)]
CALL COMMND ;PARSE THE TEXT
LDB T1,[POINT 7,ATMBUF,6] ;ANYTHING TYPED?
JUMPE T1,[TMSG <?"library:" expected
>
RET] ;FORGET IT
MOVEI T1,ATMBUF ;Convert to uppercase
CALL CNVUPP
MOVE T1,[ATMBUF,,LIBHLD]
BLT T1,LIBHLD+17
CALL FNDLIB ;FIND WHICH LIBRARY
RET ;?NOT A LIBRARY
HRRZ P4,LIBNUM ;Get library number
HRLI P4,-1 ;JUST THIS ONE LIBRARY
;HERE WITH P4 = AOBJN PTR TO LIBRARIES
STAT1: TXZ F,F.TLN ;DIDN'T TYPE THIS LIBRARY NAME YET
HRRZM P4,LIBNUM ;GIVE LIB NUM TO SKPFRL
CALL SKPFRL ;SEE IF FROZEN
IFSKP.
DO. ;BLOCK
HRRZ P1,T1 ;JFN IN P1
TXNN F,F.SUSR ;LOOKING FOR SPECIFIC USER?
IFSKP.
HRRZM P1,MAZJFN ;YES, CHECK
CALL CHKFME ;FROZEN BY ME?
EXIT. ;FROZEN, BUT NOT BY ME - SAY NOTHING.
ENDIF.
TXON F,F.TLN ;TYPE LIB NAME IF NEEDED
CALL TYPLNM
MOVE T1,P1
CALL TYPFIL ;TYPE THE .MAZ FILE OUT
HRRZ T1,P1 ;RELEASE .MAZ FILE
RLJFN%
ERJMPS .+1
ENDDO. ;END BLOCK
ENDIF.
HRRZ T2,LIBLST(P4) ;GET A PTR TO A LIBRARY
HRLI T2,(POINT 7,)
MOVE T3,[POINT 7,LIBHLD]
CALL CPT2T3 ;COPY STRING FROM T2 TO T3
MOVE T1,T3 ;PASS PTR
CALL FXMAZN ;FIX MAX NAME TO INCLUDE SUBDIR
MOVEM T1,T3 ;UPDATE PTR
MOVE T2,[POINT 7,[ASCIZ/*.*/]]
CALL CPT2T3 ;COPY STRING FROM T2 TO T3
IDPB T1,T3
MOVX T1,GJ%SHT+GJ%IFG ;WILDCARD CHARS HERE!
HRROI T2,LIBHLD
GTJFN%
ERJMP STATE1 ;?GTJFN FAILED
MOVE P1,T1 ;SAVE GTJFN FLAGS
JRST STAT3A ;FIRST TIME, SKIP GNJFN
;NOW, FOR THIS LIBRARY, WE HAVE THE GTJFN WORD RETURNED IN P1.
; THE JFN NUMBER NOW REFERS TO THE FIRST FILE IN THE LIBRARY.
;LOOK AT EACH FILE UNTIL NO MORE FILES
STAT3: MOVE T1,P1 ;GET GTJFN FLAGS BACK
GNJFN% ;LOOK FOR NEXT FILE
ERJMP STATE2 ;ERROR.. GO SEE WHY
STAT3A: HRRZ T2,T1 ;GET JFN RETURNED
HRROI T1,RETJNM ;PLACE TO RETURN JFN STRING
MOVX T3,1B11 ;JUST RETURN FILE TYPE
JFNS%
;CHECK THIS EXT TO SEE IF IT IS ONE OF THE ONES IN OUR TABLE
; IF SO, TYPE IT OUT
MOVSI P2,-NMEXTS ;-NO EXTS IN TABLE
STAT4: MOVE T1,[POINT 7,RETJNM]
HRRZ T2,STEXTS(P2)
HRLI T2,(POINT 7,)
STAT4A: ILDB T3,T1
ILDB P3,T2
JUMPE T3,STAT5 ;END OF THIS EXT STRING
JUMPE P3,STAT6 ;NO MATCH
CAMN T3,P3 ;THIS CHAR MATCH?
JRST STAT4A ;YES, KEEP LOOKING
;NO MATCH
STAT6: AOBJN P2,STAT4 ;LOOK AT NEXT EXT.
JRST STAT3 ;LOOK AT NEXT FILE
STAT5: JUMPN P3,STAT6 ;IF NOT NULL ON OTHER STRING TOO, NO MATCH
;WE HAVE AN EXACT MATCH (THIS EXT IS IN OUR TABLE)
TXNN F,F.SUSR ;SPECIFIC USER?
IFSKP.
HRRZM P1,MAZJFN ;YES, CHECK
CALL CHKRME
JRST STAT6 ;NOT ME, SKIP THIS FILE
ENDIF.
; ..
;EXT MATCHES.. TYPE OUT THIS FILE
;FIRST TYPE THE FILENAME
;NOTE: FALL HERE FROM ABOVE UNLESS THE OPEN FAILS AND HE CONTINUES
; FROM "STATE5".
TXON F,F.TLN ;TYPED LIBRARY NAME?
CALL TYPLNM ;NOT YET, TYPE IT NOW
STAT5A: HRRZ T2,P1 ;GET JFN
HRROI T1,RETJNM
MOVX T3,1B8 ;NAME
JFNS%
TYPE RETJNM ;NOW TYPE STRING
MOVEI T1,"."
PBOUT%
HRRO T1,EXTLST(P2) ;GET EXTENSION TO TYPE
PSOUT%
TYPE CRLF
CALL TYPFIL ;TYPE OUT THE FILE
JRST STAT3 ;GO ON TO NEXT FILE
;ROUTINE TO TYPE A FILE
;CALL: P1/ JFN (NOT OPENED)
; CALL TYPFIL
; <RETURN HERE, JFN CLOSED BUT NOT RELEASED>
TYPFIL: HRRZ T1,P1 ;GET JFN
MOVX T2,7B5+OF%RD
OPENF%
ERJMP TYPFE1 ;FAILED
;TYPE IT OUT
TYPFL1: HRRZ T1,P1
BIN%
ERJMP TYPFL2 ;FAILED--PROBABLY EOF
HRRZ T1,T2
PBOUT%
JRST TYPFL1
TYPFL2: JUMPE T2,TYPFL3 ;ASSUME EOF IF BYTE IS 0
TMSG <? Error reading file: >
CALL LSTFER
HALTF%
RET
TYPFL3: MOVX T1,CO%NRJ ;DON'T RELEASE JFN
HRR T1,P1
CLOSF% ;CLOSE THE FILE
ERJMP TYPFE2 ;FAILED
RET ;OK, RETURN
;OPENF FAILED
TYPFE1: TMSG <?OPENF failed: >
CALL LSTFER
HALTF%
JRST TYPFIL ;GO TRY AGAIN
;CLOSF FAILED
TYPFE2: TMSG <?CLOSF failed: >
CALL LSTFER
HALTF%
RET ;JUST RETURN IF HE CONTINUES
;ROUTINE TO TYPE "[LIBARY <DIR>]" AND CRLF
TYPLNM: CALL TYPLN1 ;TYPE "[LIBARY <DIR>"
TYPE <[ASCIZ/]
/]>
RET ;RETURN
TYPLN1: TYPE <[ASCIZ/ [Library /]>
HRRO T1,LB1LST(P4)
PSOUT%
TMSG < = >
HRRO T1,LIBLST(P4)
PSOUT%
RET
; ERRORS IN "STATUS" COMMAND
;GTJFN FAILED FOR <LIBRARY>*.*
STATE1: TXNN F,F.SUSR ;MESSAGE WANTED?
CAIN T1,GJFX32 ;"NO FILES MATCH THIS SPEC"
JRST NXTLIB ;NO, YES - GO ON TO NEXT LIBRARY
TMSG <% Library >
HRRO T1,LIBLST(P4)
PSOUT%
TMSG < not properly setup for ALU.
>
JRST NXTLIB ;Go on to next library
;GNJFN FAILED
STATE2:
NXTLIB: TXNN F,F.TLN ;DID WE TYPE THE NAME YET?
TXNE F,F.SUSR
IFSKP.
CALL TYPLN1 ;TYPE "LIBRARY <DIR"
TYPE <[ASCIZ/: No files reserved]
/]>
ENDIF.
AOBJN P4,STAT1 ;GO ON TO NEXT LIBRARY
RET ;NO MORE, ALL DONE
STATE5: TMSG <?OPENF failed: >
CALL LSTFER
HALTF%
JRST STAT5A ;GO TRY AGAIN
STATE7: TMSG <?CLOSF failed: >
CALL LSTFER
HALTF%
RET ;JUST RETURN IF HE CONTINUES
SUBTTL UNFREEZE COMMAND
CMDUNF: MOVEI T2,[ASCIZ /library/]
CALL NOISE
MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<library name:>)]
CALL COMMND
LDB T1,[POINT 7,ATMBUF,6]
JUMPE T1,[TMSG <?"library:" expected.
>
RET]
MOVEI T1,ATMBUF
CALL CNVUPP
MOVE T1,[ATMBUF,,LIBHLD]
BLT T1,LIBHLD+17
CALL FNDLIB ;LOOKUP LIBRARY NAME
RET
CALL SKPFRL ;SEE IF ALREADY FROZEN
IFNSK.
TMSG <?Library is not frozen.
>
RET
ENDIF.
DELF% ;DELETE THE FREEZE FILE
IFJER.
TMSG <%Couldn't delete freeze file.
>
ENDIF.
RET
SUBTTL HELP COMMAND
CMDHLP: MOVEI T2,[ASCIZ/with ALU/]
CALL NOISE
CALL CONFRM
MOVX T1,GJ%OLD+GJ%SHT
HRROI T2,[ASCIZ/HLP:ALU.HLP/]
GTJFN% ;Find HLP:ALU.HLP
IFJER.
MOVX T1,GJ%OLD+GJ%SHT
HRROI T2,[ASCIZ/ALU:ALU.HLP/]
GTJFN%
ERJMP NOHLP ;Not on either HLP: or SYS:
ENDIF.
HRRZ T4,T1 ;Save JFN
MOVE T1,T4 ;Get JFN
MOVE T2,[7B5+OF%RD] ;OPEN for read access
OPENF%
ERJMP COHLPF ;?Can't open help file
;Type the file out on the terminal
CMDHL2: MOVE T1,T4 ;Get JFN
BIN%
ERJMP CMDHL3 ;Error on BIN, assume EOF
MOVEI T1,.PRIOU ;Output to TTY:
BOUT%
ERJMP .+1
JRST CMDHL2 ;Loop till EOF
CMDHL3: MOVE T1,T4 ;Get JFN
CLOSF% ;Close help file
ERJMP .+1 ;Ignore failure
RET ;Return
;No help available
NOHLP: TMSG <? Can't find the ALU help file on HLP: or SYS:
>
RET ;Return giving no help
;Can't OPEN the help file
COHLPF: TMSG <?Can't OPEN ALU.HLP: >
PUSH P,T4 ;Get JFN
CALL LSTFRC ;Type why and CRLF
POP P,T1 ;Try to get rid of JFN
RLJFN%
ERJMP .+1
RET
SUBTTL INFORMATION COMMAND
CMDINF: MOVEI T2,[ASCIZ/about/]
CALL NOISE
MOVEI T2,[FLDDB. (.CMKEY,,INFTAB)]
CALL COMMND ;GET KEYWORD
MOVE T2,(T2) ;PARSED OK, GET ADDRESS
JRST (T2) ;GO DO IT
INFTAB: INFLEN,,INFLEN ;HEADER
AA EXTENSIONS,INFEXT
AA FUNCTION-CONTROL-SWITCHES,INFFT
AA LIBRARIES,INFLIB
AA USERS,INFUSR
AA VERSION,INFVER
INFLEN==.-INFTAB-1 ;NUMBER OF INFORMATION COMMANDS
SUBTTL INFORMATION (ABOUT) FUNCTION-CONTROL-SWITCHES
INFFT: CALL CONFRM ;CONFIRM COMMAND
TMSG <
This version of ALU is setup with the following function-control switches:
>
INFFT1: TMSG <
SWFUID = >
SKIPE SWFUID
JRST FILUDY
TMSG <0 (No "UID" line will be placed into the
file being replaced. ALU log entries will not point you
to the previous edit of the file)
>
JRST INFFT2
FILUDY: TMSG <1 (A "UID" line will be placed into the
file being replaced. This enables you to see who last
edited the file, and allows ALU log entries to point you
to the previous edit of the file)
>
TYPE [ASCIZ /
SWRUID = /]
SKIPN SWRUID
JRST [ TYPE [ASCIZ /0 (New UID lines will be added to the file
and will not replace such lines already in the file.)
/]
JRST INFFT2]
TYPE [ASCIZ /1 (The new UID lines will replace the one already
in the file if there is one.)
/]
INFFT2: TMSG <
SWCOPO = >
SKIPN SWCOPO
JRST COPOFN
TMSG <1 (Files generated from the source file
being REPLACE'd are also copied to the library)
>
JRST INFFT3
COPOFN: TMSG <0 (Only the source file is REPLACE'd, files
generated from it are left alone)
>
INFFT3: TMSG <
SWFCOM = >
SKIPN SWFCOM
JRST FTFCMN
TMSG <1 (FILCOM is run automatically after REPLACE's)
>
JRST INFFT4
FTFCMN: TMSG <0 (FILCOM is not run automatically after REPLACE's)
>
INFFT4: TYPE [ASCIZ /
SWBAKF = /]
SKIPN SWBAKF
JRST [ TYPE [ASCIZ /0 (Backup files, e.g. ".MAB" will not be
generated. Multiple generations of the source (depending
on the generation retention count) will be left on the library.)
/]
JRST INFFT5]
TYPE [ASCIZ /1 (Backup files will be made by renaming the source
being replaced to be a file with the same name and a
related extension, e.g. ".MAB".)
/]
INFFT5: TMSG <
SWANYU = >
SKIPN SWANYU
JRST [ TYPE [ASCIZ /0 (Only registered users may use ALU).
/]
JRST INFFT6]
TYPE [ASCIZ /1 (Any user with access to the libraries can use ALU).
/]
INFFT6: TMSG <
SWGCPY = >
SKIPN SWGCPY
JRST [ TYPE [ASCIZ /0 (If you do a GET and the file is already reserved,
ALU just aborts the GET and does not ask you if you'd like a copy anyway).
/]
JRST INFFT7]
TYPE [ASCIZ /1 (If you do a GET and the file is already reserved,
ALU will give you the option of copying it anyway).
/]
INFFT7: TMSG <
SWREDT = >
SKIPN SWREDT
JRST [ TYPE [ASCIZ /0 (REDIT is not run automatically before REPLACE)
/]
JRST INFFT8]
TYPE [ASCIZ /1 (REDIT is run automatically before REPLACE)
/]
INFFT8: TMSG <
SWCGET = >
SKIPN SWCGET
JRST [ TYPE [ASCIZ \0 (Default on GET and QGET is /NOCOPY)
\]
JRST INFFT9]
TYPE [ASCIZ \1 (Default on GET and QGET is /COPY)
\]
INFFT9: TYPE CRLF ;FINAL CRLF FOR AESTETICS
RET ;RETURN
SUBTTL INFORMATION (ABOUT) LIBRARIES
;TYPES OUT THE LIBRARIES ALU IS BUILT TO LOOK AT
INFLIB: CALL CONFRM ;CONFIRM COMMAND
TMSG <
This version of ALU knows about the following libraries:
LOGICAL NAME DIRECTORY LOG AREA
------------ --------- --------
>
MOVEI T1,^D16 ;"DIRECTORY" starts here
MOVEM T1,ILBCD
MOVEI T1,^D38 ;"LOG AREA" starts here
MOVEM T1,ILBCL
MOVEI P1,0 ;Index to library
INFLB1: MOVE T1,[POINT 7,TLINE] ;BUILD OUTPUT LINE HERE
MOVEM T1,TEMPBP ;Save as temporary BP
MOVEI T1,1 ;Set to column 1
MOVEM T1,TLCOLM ; . .
MOVEI T1," " ;Assume not default lib
SKIPN DFLIBW ;Is there a default lib?
JRST INFLB2 ;No, skip type space here
CAMN P1,DLBIDX ;Is this it?
MOVEI T1,"*" ;Yes, put out a "*" to mark it
INFLB2: CALL TLCHR ;Put char in TLINE
MOVEI T1," " ;GET A SPACE
CALL TLCHR
CALL TLCHR
INFLB3: HRRZ T3,LB1LST(P1)
HRLI T3,(POINT 7,) ;NOW OUTPUT NAME
DO.
ILDB T1,T3
JUMPE T1,ENDLP.
CALL TLCHR
LOOP.
ENDDO.
MOVE T2,ILBCD ;Pad out to where directory will start
CALL TLPAD
HRRZ T3,LIBLST(P1) ;NOW OUTPUT DIRECTORY NAME
HRLI T3,(POINT 7,)
DO.
ILDB T1,T3
JUMPE T1,ENDLP. ;JUMP WHEN DONE
CALL TLCHR
LOOP.
ENDDO.
; ..
;INFLIB ROUTINE (CONT'D).
; ..
MOVE T2,ILBCL ;Pad out to where log-area will start
CALL TLPAD
HRRZ T3,LB2LST(P1) ;Now output LOG-area name
HRLI T3,(POINT 7,)
DO.
ILDB T1,T3
JUMPE T1,ENDLP.
CALL TLCHR
LOOP.
ENDDO.
MOVEI T4,.CHCRT ;CR
IDPB T4,TEMPBP
MOVEI T4,.CHLFD ;LF
IDPB T4,TEMPBP ;APPEND CRLF TO STRING
SETZ T4,
IDPB T4,TEMPBP ;NULL TO END STRING
TYPE TLINE ;NOW OUTPUT THE LINE
AOJ P1, ;Next library
CAIE P1,NMLIBS ;Done?
JRST INFLB1 ;No, loop
SKIPN DFLIBW ;Was default library marked?
JRST INFLB7 ;No
TMSG <
"*" means this library is the default if not specified for GET, REPLACE, etc.
>
INFLB7: TYPE CRLF ;FINAL CRLF FOR NEATNESS
RET ;THEN RETURN
; Routines to get column output right.
;Routine to store character in TLINE.
;Call:
; TEMPBP/ BP to TLINE
; T1/ character value
; CALL TLCHR
; <return here, TLCOLM incremented>
;Uses T1 only
TLCHR: IDPB T1,TEMPBP ;Store char
AOS TLCOLM ;Increment column number
RET ; and return
;Routine to pad out to column #.
;Call:
; T2/ desired column number
; TLCOLM/ actual column number
; CALL TLPAD
; <return here>
;Uses T1-T3
TLPAD: MOVEI T1," " ;Get a space
TLPAD1: CALL TLCHR ;Put at least one out
MOVE T3,TLCOLM ;Get actual column number
CAMG T2,T3 ;Far enough, or too far?
RET ;Yes, return
JRST TLPAD1 ;No, loop
SUBTTL INFORMATION (ABOUT) EXTENSIONS
;TYPES OUT THE LIST OF KNOWN EXTENSIONS AND THEIR CHARACTERISTICS
INFEXT: CALL CONFRM ;CONFIRM THE COMMAND
TMSG <
The following is a list of file types that are known to
this version of ALU. (Note: RSVFILE is the extension of the
file on the library which will contain the "WHY" text.
BACKUP is the extension of the backup file on the library).
>
TMSG <
SOURCE RSVFILE BACKUP
------ ------- ------
>
MOVSI P1,-NMEXTS ;# OF KNOWN EXTENSIONS
INFEX1: MOVE T1,[POINT 7,TLINE] ;WRITE OUTPUT LINE TO HERE
HRRZ T2,EXTLST(P1) ;GET AN EXTENSION
HRLI T2,(POINT 7,) ;MAKE PTR TO IT
CALL CPYNUL
MOVEI T3,.CHTAB
IDPB T3,T1
HRRZ T2,STEXTS(P1) ;.MAZ FILE EXT
HRLI T2,(POINT 7,)
CALL CPYNUL
MOVEI T3,.CHTAB
IDPB T3,T1
HRRZ T2,EXBLST(P1) ;BACKUP FILE EXT
HRLI T2,(POINT 7,)
CALL CPYNUL
MOVEI T3,.CHCRT
IDPB T3,T1
MOVEI T3,.CHLFD
IDPB T3,T1
SETZ T3,
IDPB T3,T1 ;END STRING
TYPE TLINE ;OUTPUT THE LINE
SKIPN SWCOPO ;GENERATED OUTPUT FILES?
JRST INFEXO ;NO
TMSG < Generated output file(s): >
SKIPN P2,EXOLST(P1) ;ANY FOR THIS FILE?
JRST INFEXN ;NO, SAY "NONE"
JRST INFEX6 ;JUMP OVER COMMA PRINTING
INFEX5: TMSG <,>
INFEX6: HRRZ T2,(P2) ;POINT TO ONE
HRLI T2,(POINT 7,)
MOVE T1,[POINT 7,TLINE] ;WRITE TO HERE
CALL CPYNUL
TYPE TLINE
AOBJN P2,INFEX5 ;LOOP IF MORE TO DO
TYPE CRLF
JRST INFEXO
INFEXN: TMSG <-None-
>
INFEXO: TYPE CRLF
AOBJN P1,INFEX1 ;LOOP FOR ALL EXTS
RET ;DONE, RETURN
SUBTTL INFORMATION (ABOUT) USERS
;TYPES OUT THE LIST OF USERS (DIRECTORY NAMES FROM WHICH ALU CAN BE RUN)
INFUSR: CALL CONFRM ;CONFIRM COMMAND
TMSG <
To reserve a file with ALU, you must be
logged in as one of the following users:
>
MOVSI P1,-NMUSRS ;AOBJN POINTER TO USERS
INFUS1: MOVE T1,[POINT 7,TLINE] ;BUILD STRING HERE
HRRZ T2,USRLST(P1) ;POINT TO USER NAME
HRLI T2,(POINT 7,)
CALL CPYNUL
MOVEI T3,.CHCRT ;APPEND CRLF TO STRING
IDPB T3,T1
MOVEI T3,.CHLFD
IDPB T3,T1
SETZ T3,
IDPB T3,T1 ;NULL TO END
TYPE TLINE ;NOW TYPE THE LINE
AOBJN P1,INFUS1 ;GO TO NEXT USER
SKIPN SWANYU ;ANY USER ALLOWED?
JRST INFUS3 ;NO
TMSG <
or any other user with file access to the libraries.
>
INFUS3: TYPE CRLF
RET ;DONE, RETURN
SUBTTL INFORMATION (ABOUT) VERSION (OF ALU)
INFVER: MOVEI T2,[ASCIZ/of ALU/]
CALL NOISE
CALL CONFRM
TMSG < This is >
TYPE AVERST ;Type version string
TYPE CRLF
RET ;Done, return
SUBTTL ^EDDT COMMAND
CMEDDT: CALL CONFRM ;CONFIRM
GODDT: TDZA P3,P3 ;HAVEN'T BEEN HERE BEFORE
GODDT0: SETO P3, ;BEEN HERE BEFORE
MOVE 1,[400000,,770] ;[26] IS PAGE ACCESSIBLE?
RPACS%
AND 2,[EXP PA%RD!PA%EX!PA%PEX]
CAME 2,[EXP PA%RD!PA%EX!PA%PEX]
JRST GETDD ;NO, BUT TRY TO READ DDT IN
MOVE 1,770000 ;DOES IT CONTAIN DDT?
CAME 1,[JRST 770002] ;PROBABLY, IF EQUAL.
JRST NODDT ;GIVE ERROR
TYPE <[ASCIZ/[Return from DDT by typing "POPJ 17,$X"]
/]>
CALL 770000 ;CALL DDT
RET ;RETURN TO COMMAND SCANNER
NODDT: TMSG <?DDT not accessible
>
RET ;RETURN TO COMMAND SCANNER
;HERE IF PAGE IS NOT EVEN ACCESSIBLE. TRY TO READ DDT IN (BUT
; BE CAREFUL TO NOT ALLOW IT TO WIPE OUT EXISTING DATA!)
GETDD: JUMPN P3,NODDT ;IF BEEN HERE BEFORE, GIVE UP
MOVX T1,GJ%OLD!GJ%SHT ;GET DDT
HRROI T2,[ASCIZ/SYS:UDDT.EXE/]
GTJFN%
ERJMP NODDT ;NOT THERE--SAY "NOT ACCESSIBLE"
PUSH P,T1 ;SAVE THE JFN
MOVEI T1,.FHSLF ;SAVE ENTRY VECTOR INFO
GEVEC% ; (GET% SMASHES IT)
PUSH P,T2 ;SAVE THE INFO
MOVE T1,-1(P) ;GET JFN BACK
HRLI T1,.FHSLF ;READ INTO SAME FORK
TXO T1,GT%NOV ;DON'T OVERLAY EXISTING PAGES!!
GET% ;READ IN DDT
ERJMP GETFAI ;FAILED
POP P,T2 ;ENTRY VECTOR INFO
MOVEI T1,.FHSLF
SEVEC% ;RESTORE ENTRY VECTOR
POP P,(P) ;FORGET JFN, DON'T CARE ANYMORE
DMOVE T1,116 ;GET SYMBOL TABLE INFO
MOVEM T1,@770001 ;STORE IN DDT
MOVEM T2,@770002 ;. .
JRST GODDT0 ;GO TRY AGAIN
GETFAI: POP P,(P) ;FORGET ENTRY VECTOR INFO
TMSG <?GET failed-- can't read in DDT: >
CALL LSTFER ;TYPE LAST ERROR IN THIS FORK
TYPE CRLF
POP P,T1 ;RECOVER JFN
RLJFN%
IFJER.
TMSG <?Can't release JFN for SYS:UDDT.EXE: >
CALL LSTFER
TYPE CRLF
ENDIF.
RET ;DONE, RETURN
SUBTTL ^ESET COMMAND
CMESET: MOVEI P3,1 ;"NO" NOT TYPED
CMEST1: MOVEI T2,[FLDDB. (.CMKEY,,ESETTB,<keyword or "NO keyword">)]
CALL COMMND ;PARSE THE KEYWORD
HRRZ T2,(T2)
JRST (T2) ;GO DO IT
ESETTB: ESETLN,,ESETLN ;HEADER
AA ANY-USER-ALLOWED,ESANYU
AA BACKUP,ESBAKF
AA COPY-ON-GET,ESCGET
AA COPY-OUTPUT-FILES,ESCOPO
AA FILCOM-AFTER-REPLACE,ESFCOM
AA GET-RESERVED-FILE-OPTION,ESGCPY
AA NO,ESNO,CM%INV ;INVISIBLE "NO" COMMAND
AA REDIT-BEFORE-REPLACE,ESREDT
AA REPLACE,ESRUID
AA UID-IN-SOURCE,ESFUID
ESETLN==.-ESETTB-1 ;NUMBER OF ^E SET COMMANDS
ESNO: TRC P3,1 ;COMPLEMENT "NO" FLAG
JRST CMEST1 ;GET ANOTHER ARG
ESCOPO: CALL CONFRM
CAME P3,SWCOPO ;ALREADY SET?
SETCMM CNCOPO ;YES, REMEMBER WE CHANGED IT
MOVEM P3,SWCOPO
RET ;DONE, RETURN
ESCGET: CALL CONFRM
CAME P3,SWCGET
SETCMM CNCGET
MOVEM P3,SWCGET
RET
ESFCOM: CALL CONFRM
CAME P3,SWFCOM
SETCMM CNFCOM
MOVEM P3,SWFCOM
RET
ESFUID: CALL CONFRM
CAME P3,SWFUID
SETCMM CNFUID
MOVEM P3,SWFUID
RET
ESBAKF: CALL CONFRM
CAME P3,SWBAKF
SETCMM CNBAKF
MOVEM P3,SWBAKF
RET
ESRUID: CALL CONFRM
CAME P3,SWRUID
SETCMM CNBAKF
MOVEM P3,SWRUID
RET
ESANYU: CALL CONFRM
CAME P3,SWANYU
SETCMM CNANYU
MOVEM P3,SWANYU
RET
ESGCPY: CALL CONFRM
CAME P3,SWGCPY
SETCMM CNGCPY
MOVEM P3,SWGCPY
RET
ESREDT: CALL CONFRM
CAME P3,SWREDT
SETCMM CNREDT
MOVEM P3,SWREDT
RET
SUBTTL MAZSTR - OUTPUT STRING TO MAZ FILE
;OUTPUT STRING TO MAZ FILE
;CALL: T3 / ADDRESS OF ASCIZ STRING
; CALL MAZSTR
; <RETURN HERE IF GOT "QUOTA EXCEEDED" ERROR> (ALL OTHER ERRORS BOMB OUT)
; <RETURN HERE IF OK>
MAZSTR: HRLI T3,(POINT 7,) ;MAKE A STRING POINTER
HRRZ T1,MAZJFN ;T1:= JFN FOR BOUT
MAZST1: ILDB T2,T3 ;GET NEXT BYTE
JUMPE T2,RSKP ;DONE IF NULL
MAZST2: BOUT% ;WRITE IT
IFJER.
CALL MAZSTE ;HANDLE ERROR
JRST MAZST2 ;TRY AGAIN
ENDIF.
JRST MAZST1 ;LOOP
MAZSTE: SAVEAC <T1,T2,T3,T4>
TMSG <?Can't write string to MAZ file: >
CALL LSTFER
HALTF%
RET
;OUTPUT DATE/TIME TO FILE
MAZTIM: HRRZ T1,MAZJFN ;OUTPUT TO THE FILE
SETO T2, ;CURRENT DATE/TIME
;SET FLAGS FOR DATE WITH SLASHES, NO TIME
MOVX T3,OT%SLA+OT%NMN+OT%SCL+OT%DAM+OT%NTM
MAZTI1: ODTIM%
IFJER.
CALL MAZSTE
JRST MAZTI1 ;TRY AGAIN
ENDIF.
MOVEI T3,[ASCIZ/ at /]
CALL MAZSTR
RET ;QUOTA EXCEEDED ERROR
CALL GTTIM ;GET TIME IN HLDTM1
RET ;ERROR, TRY WRITING WHOLE FILE AGAIN
MOVEI T3,HLDTM1
CALL MAZSTR
RET ;QUOTA EXCEEDED ERROR
JRST RSKP ;RETURN OK
SUBTTL GTTIM - GET CURRENT TIME STRING IN HLDTM1
;RETURNS .+1 IF FAILURE, .+2 IF OK
GTTIM: HRROI T1,HLDTIM ;HOLD ASCIZ TIME
SETO T2, ;CURRENT TIME
MOVX T3,OT%NDA+OT%12H+OT%NSC+OT%SCL
ODTIM% ;WRITE TIME TO BUFFER
ERJMP MAZTME
SETZ T2,
IDPB T2,T1
MOVE T3,[POINT 7,HLDTIM] ;FROM HERE
MOVE T4,[POINT 7,HLDTM1] ;TO HERE
GTTIM1: ILDB T2,T3 ;GET A CHAR FROM TIME
CAIE T2,"A"
CAIN T2,"P"
IFNSK.
MOVEI T1," "
IDPB T1,T4
ENDIF.
IDPB T2,T4
JUMPN T2,GTTIM1
JRST RSKP ;RETURN OK
MAZTME: TMSG <?ODTIM failed: >
CALL LSTFER
HALTF%
RET ;TRY WRITING WHOLE MAZ FILE AGAIN IF CONTINUE
SUBTTL BRCHR, YESNO ROUTINES
BRCHR: CAIE T1,15
CAIN T1,12
RET
CAIN T1,0
RET
CAIN T1,32
RET
CAIE T1,13
CAIN T1,14
RET
AOS (P)
RET
;GET A "YES" OR "NO" FROM TTY
; <CR> MEANS NO.
;RETURNS .+1 IF "NO", .+2 IF "YES"
YESNO: CALL ITTLIN
JRST ERESET ;ERRORS.. BACK TO COMMAND SCANNER
;CHECK FOR "YES"
MOVE T3,[POINT 7,TLINE] ;POINT TO ANSWER
ILDB T1,T3
CAIE T1,"y"
CAIN T1,"Y"
JRST RETYES
CAIE T1,"n"
CAIN T1,"N"
JRST RETNO
CALL BRCHR ;<CR> IMPLIES NO
JRST RETNO
TMSG <? Please type "YES" or "NO"
>
JRST YESNO ;TRY AGAIN
RETYES: AOS (P)
RETNO: RET
SUBTTL GTFINL - SEE IF FILE IN GTFJFN IS IN A LIBRARY
; IF SO, SETS LIBNUM TO THE INTERNAL LIBRARY NUMBER AND SKIPS
;ELSE TYPES ERROR MESSAGE AND POPJ'S
;THIS ROUTINE USES THE "RETJNM" FILENAME BUFFER, AND P1
GTFINL: HRROI T1,RETJNM
HRRZ T2,GTFJFN
MOVX T3,1B2+1B5+JS%PAF ;DEVICE AND DIRECTORY FIELD WITH PUNCTUATION
JFNS%
MOVSI P1,-NMLIBS
GTFIN1: HRR T1,LIBLST(P1) ;GET PTR TO A LIB NAME
HRLI T1,(POINT 7,)
MOVE T2,[POINT 7,RETJNM] ;GET PTR TO RETURNED NAME
GTFIN2: ILDB T3,T1
ILDB T4,T2 ;GET CHAR FROM EACH
JUMPE T3,GTFIN3 ; END OF FIRST
JUMPE T4,GTFIN4 ;NO MATCH
CAMN T3,T4
JRST GTFIN2 ;MATCH ON THIS CHAR
;NO MATCH
GTFIN4: AOBJN P1,GTFIN1 ;LOOP FOR ALL NAMES
TMSG <? File is not in a library
>
RET ;RETURN
GTFIN3: JUMPN T4,GTFIN4 ;JUMP IF NO MATCH
HRRM P1,LIBNUM ;SAVE NUMBER OF THE LIBRARY
AOS (P) ;GIVE GOOD RETURN
RET
SUBTTL FNDEXT - SEE IF FILE IN GTFJFN HAS A KNOWN EXTENSION
; IF SO, SET "EXTNUM" AND SKIP RETURN
; ELSE GIVE ERROR AND POPJ
FNDEXT: HRROI T1,RETJNM
HRRZ T2,GTFJFN
MOVX T3,1B11 ;JUST EXT.
JFNS%
MOVSI P1,-NMEXTS ;NUMBER OF KNOWN EXTENSIONS
FNDEX1: HRR T1,EXTLST(P1)
HRLI T1,(POINT 7,)
MOVE T2,[POINT 7,RETJNM]
FNDEX2: ILDB T3,T1
ILDB T4,T2
JUMPE T3,FNDEX4 ;END OF 1ST STRING
JUMPE T4,FNDEX3 ;NO MATCH
CAMN T3,T4
JRST FNDEX2 ;ALL MATCH SO FAR
;NO MATCH
FNDEX3: AOBJN P1,FNDEX1 ;LOOP FOR ALL EXTS
TMSG <? File extension is unknown to ALU
>
RET ;RETURN
FNDEX4: JUMPN T4,FNDEX3 ;NO MATCH
;FOUND OUR EXTENSION
HRRM P1,EXTNUM ;SAVE EXTENSION NUMBER
AOS (P) ;SKIP RETURN FOR SUCCESS
RET ;RETURN
SUBTTL GMAZNM - BUILD .MAZ FILE NAME IN MAZNAM
;MAKES AN ASCII FILENAME FOR THE .MAZ FILE, GIVEN EXTNUM
; SET UP ALREADY BY FNDEXT, AND .MAC FILE JFN IN "GTFJFN".
;SKIP RETURNS IF SUCCESSFUL, WITH ASCII NAME IN "MAZNAM".
GMAZNM: MOVE T1,[POINT 7,MAZNAM]
HRRZ T2,GTFJFN
MOVX T3,1B2+1B5+JS%PAF ;DEV:<DIRECTORY>
JFNS%
CALL FXMAZN ;FIX UP STRING TO INCLUDE SUBDIR
HRRZ T2,GTFJFN
MOVX T3,1B8+JS%PAF
JFNS% ;APPEND FILE NAME
;TACK ON EXT
MOVEI T4,"."
IDPB T4,T1
MOVE T2,EXTNUM ;GET NUMBER OF THE EXTENSION
HRRZ T2,STEXTS(T2) ; .MAZ OR SOMETHING
HRLI T2,(POINT 7,)
CALL CPYNUL
RETSKP
;FIX UP DIRECTORY NAME STRING TO INCLUDE SUBDIRECTORY
; T1/ BYTE PTR TO STRING, LAST CHAR OF WHICH SHOULD BE DIR CLOSING PUNCT
FXMAZN: BKJFN% ;BACK UP OVER CLOSING DIRECTORY PUNCT
ERJMPS .+1
HRROI T2,SUBDIR ;APPEND SUBDIRECTORY STRING IF ANY
SETZ T3,
SOUT
MOVEI T2,">"
IDPB T2,T1 ;FINAL PUNCTUATION
RET
SUBTTL GET FREEZE FILE
SKPFRL: MOVE T1,[POINT 7,MAZNAM]
MOVE T2,LIBNUM
HRRZ T2,LIBLST(T2) ;MAKE PTR TO LIB STRING
HRLI T2,(POINT 7,0)
CALL CPYNUL ;COPY LIB NAME
JRST SKPFR1 ;JOIN COMMON CODE
SKPFRF: MOVE T1,[POINT 7,MAZNAM]
HRRZ T2,GTFJFN ;JFN ON REQUESTED FILE
MOVX T3,1B2+1B5+JS%PAF ;DEVICE AND DIRECTORY
JFNS%
ERCALS FATAL
SKPFR1: CALL FXMAZN ;INCLUDE SUBDIRECTORY
MOVE T2,[POINT 7,[ASCIZ /FREEZE.TXT/]]
CALL CPYNUL ;BUILD REST OF FILE NAME
MOVX T1,GJ%OLD!GJ%SHT
HRROI T2,MAZNAM
GTJFN% ;TRY TO FIND I
ERJMPS RTN
RETSKP
SUBTTL ROUTINE TO OPEN OUTPUT FILE TO WRITE BYTES
;CALL: OJFN/ JFN
; CALL OPENO
; <HERE IF ERROR, MESSAGE TYPED OUT, JFN RELEASED>
; <HERE IF OK>
OPENO: HRRZ T1,OJFN
MOVX T2,7B5+OF%WR
OPENF%
ERJMP OPENE1 ;OPENF FAILED
AOS (P) ;OK--RETURN
RET
OPENE1: TMSG <? Can't OPENF >
MOVEI T1,.PRIOU
HRRZ T2,OJFN
SETZ T3,
JFNS%
TMSG < for writing: >
CALL LSTFER
TYPE CRLF
HRRZ T1,OJFN ;NOW RELEASE JFN
RLJFN%
ERJMP .+1 ;IGNORE ERRORS
RET
SUBTTL IOPEN - OPEN INPUT FILE FOR PMAP'S.
;RETURNS .+2 IF OK
IOPEN: MOVE T1,IJFN
MOVX T2,OF%RD+7B5 ;OPEN FOR READ
OPENF%
ERJMP IOPEE1 ;FAILED.. GO SEE WHY
HRRZ T1,IJFN ;GET BYTE SIZE , & BYTES
MOVE T2,[2,,.FBBYV]
MOVEI T3,P1
GTFDB%
ERJMP IOPEE2 ;?CAN'T GET FDB INFO
LDB T1,[POINTR P1,FB%BSZ] ;GET BYTE SIZE
MOVEM T1,BSINP ;SAVE
MOVEM P2,BCINP ;SAVE BYTE COUNT, TOO
AOS (P) ;OK, RETURN
RET ;DONE, RETURN
IOPEE1: TMSG <?IOPEN: OPENF failed: >
CALL LSTFER
HALTF%
RET
IOPEE2: TMSG <?IOPEN: GTFDB failed: >
CALL LSTFER
HALTF%
RET
SUBTTL PRELOD - PAGE PRELOAD ROUTINE
;THIS ROUTINE PRE-LOADS SOME PAGES FROM IJFN FILE
NPAGES: ^D25 ;MOUTH SIZE
PRELOD: CALL IOPEN ;OPEN INPUT FILE, PAGE MODE
RET ;CAN'T, JUST RETURN
;ENTRY POINT IF FILE IS ALREADY OPEN
PRELD0: MOVE P1,NPAGES ;GET SOME
CALL FINFRE ; FREE PAGES
MOVEM T1,STIPGS ;START OF INPUT PAGES
LSH T1,9
MOVEM T1,STIPG2 ; ADDRESS OF THE BLOCK
SETZM NXTBEG ;START AT PAGE 0
;ENTRY POINT TO READ NEXT FEW PAGES IN WITH PMAP
PRELD1: HRL T1,IJFN ;MAP FROM INPUT JFN
HRR T1,NXTBEG ;START WITH THESE PAGES
HRLI T2,.FHSLF ;OUR PROCESS
HRR T2,STIPGS ; STARTING HERE
MOVX T3,PM%RD!PM%PLD!PM%CNT ;READ, PRELOAD, REPEAT COUNT GIVEN
HRR T3,NPAGES ;READ THIS MANY
PMAP%
IFJE. (R)
CAIE T1,LNGFX1 ;OFF INTO NONX PAGE TABLE?
JRST PRELE1 ;NO, UNEXPECTED
ENDIF.
RET ;DONE, RETURN
PRELE1: TMSG <? PMAP failed to PRE-load pages: >
CALL LSTFER
TYPE CRLF
HALTF%
RET
SUBTTL PPCPY - FAST COPY ROUTINE FOR COPYING FILES
;THIS PAGE/PAGE COPY IS THE FASTEST COPYING ROUTINE
; YOU CAN WRITE FOR TOPS20.
;Inputs:
; IJFN/ OPEN'ed JFN for input file.
; OJFN/ OPEN'ed JFN for output file.
;Some pages have been pre-loaded (PRELD0)
;Date/time info for IJFN is in RFTAD1.
;IF LOC "FSTLIN" IS NON-ZERO, IT POINTS TO AN ASCII LINE
; TO PUT INTO THE OUTPUT FILE (FOR "REPLACE" OPTION).
;WHEN COPY IS FINISHED, FILES ARE CLOSED.
;** Warning: Uses P1 **
PPCPY: MOVE P1,NPAGES ;GET "N" PAGES FOR OUTPUT FILE
CALL FINFRE
MOVEM T1,STOPGS ;START OF OUTPUT PAGES
LSH T1,9 ;;MAKE REAL ADDRESS
MOVEM T1,STOPG2 ;STORE IT
MOVE T2,NPAGES
LSH T2,9
ADDI T1,-1(T2) ;GET LAST WORD OF DEST BUFFER
MOVEM T1,ENDPTR
;MAP FROM DESTINATION
DSKLUP: HRL T1,OJFN
HRR T1,NXTBEG ;CORRESPONDING PAGES OF SOURCE
MOVE T2,STOPGS ; MAP INTO DESTINATION BUFFER
HRLI T2,.FHSLF ;OUR FORK
MOVX T3,PM%WR!PM%CNT ;WRITE, REPEAT COUNT
HRR T3,NPAGES
PMAP%
;SEE IF HE WANTS TO REPLACE THE FIRST 72 CHARS
SKIPN FSTLIN
JRST DSKBL1 ;NO, JUST COPY
;COPY A FEW WORDS, THEN CHANGE IT IN MEMORY
HRL T1,STIPG2 ;FROM HERE
HRR T1,STOPG2 ; TO HERE
MOVEI T2,777(T1) ;FIRST PAGE
BLT T1,(T2) ;COPY FIRST PAGE -- SHOULD HAVE NO ERRORS!
;CHANGE 1ST 72 CHARS
MOVEI T4,^D72
HRRZ T3,FSTLIN ;ADDRESS OF TEXT
HRRZ T2,STOPG2 ;CHANGE THIS
HRLI T2,(POINT 7,)
HRLI T3,(POINT 7,)
C72LUP: ILDB T1,T3
IDPB T1,T2
SOJG T4,C72LUP
HRRZ T1,STIPG2 ;NOW SKIP FIRST PAGE..
HRLI T1,1000(T1)
HRR T1,STOPG2
ADDI T1,1000
MOVEM T1,BLTPTR
SETZM FSTLIN ;COPIED FIRST LINE, CLEAR IT
JRST DSKBLT ;START AT PAGE 1
;HERE TO TRY DSK BLT
DSKBL1: HRL T1,STIPG2 ;FROM HERE
HRR T1,STOPG2 ; TO HERE
MOVEM T1,BLTPTR ;REMEMBER BLT POINTER
TRNA ;SKIP LOAD OF BLT PTR FIRST TIME
DSKBL0: MOVE T1,BLTPTR ;GET BLT PTR
DSKBLT: MOVE T2,ENDPTR ;GET ADDRESS OF LAST WORD OF DEST BUFFER
BLT T1,(T2) ;COPY THE DATA
ERJMP DSKDIS ;PROBABLY END OF FILE, HOLE, OR QUOTA EXCEEDED
MOVE T1,NPAGES ;# OF PAGES / BUFFER
ADDM T1,NXTBEG ;UPDATE PAGE TO START WITH
DSKLU1: CALL PRELD1 ; PRELOAD SOME MORE PAGES
JRST DSKLUP ;LOOP FOR NEXT PAGE GROUP
; HERE WHEN FINALLY A BLT FAILS.. (EOF, HOLE, OR QUOTA EXCEEDED)
DSKDIS: MOVEM T1,SAVBLT ;SAVE HOW FAR WE GOT BEFORE ERROR
CALL GLERR ;GET LAST ERROR CODE
CAIN T1,IOX11 ;NO ROOM?
JRST NORQTA ;NO ROOM OR QUOTA EXCEEDED
CAIE T1,ILLX01 ;NOT ROOM PROBLEM, HIT HOLE OR END?
JRST DSKDE1 ;NO, UNEXPECTED PROBLEM
LDB T1,[331100,,SAVBLT] ;GET MEM PAGE NUMBER ASSOC. WITH NONX SRC PAGE
SUB T1,STIPGS ;GET REL. POSITION IN BUFFER
ADD T1,NXTBEG ;GET ACTUAL FILE PAGE NUMBER
HRL T1,IJFN ;SET UP FOR FFUFP
FFUFP% ;FIND NEXT USED PAGE
ERJMP DSKMEF ;FAILED, PROBABLY END OF FILE
HRRZ T3,T1 ;COPY PAGE NUMBER
SUB T3,NXTBEG ;SEE WHERE IN BUFFER PAGE IS
CAML T3,NPAGES ;IN SUBSEQUENT BUFFER?
JRST DSKNXT ;YES
LSH T3,9 ;NO, IN THIS BUFFER. MAKE MEM OFFSET
MOVE T1,BLTPTR ;GET ORIGINAL BLT POINTER
ADJSP T1,(T3) ;ADJUST FOR CONTINUATION
JRST DSKBLT ;CONTINUE THIS BUFFER
DSKNXT: HRRZM T1,NXTBEG ;REMEMBER NEXT PAGE TO START WITH
JRST DSKLU1 ;GO START NEW BUFFER
DSKMEF: CALL GLERR ;GET LAST ERROR CODE
CAIE T1,FFUFX3 ;NO MORE USED PAGES?
JRST DSKER2 ;NO, UNEXPECTED ERROR
JRST DONCPP ;DONE !
; BAD ERRORS IN COPY
DSKDE1: TMSG <? Unexepected error: >
CALL LSTFER
HALTF%
RET
NORQTA: TMSG <?No room or quota exceeded
(Type "CONTINUE" when problem has been fixed)>
HALTF%
JRST DSKBL0
DSKER2: TMSG <? FFUFP failed: >
CALL LSTFER
HALTF%
RET ;RETURN FROM COPY IF "CONT"
;HERE WHEN COPY IS DONE
DONCPP: MOVE T3,NPAGES ;GET SIZE OF BUFFER
IORX T3,PM%CNT ;REPEAT COUNT
HRROI T1,-1 ;SAY REMOVING PAGES
HRLI T2,.FHSLF
HRR T2,STIPGS
PMAP% ;UNMAP PAGES
MOVE P1,NPAGES ;# PAGES TO CLEAR
MOVE T1,STIPGS ;STARTING PAGE
CALL CLRPMP ;TELL CORE ALLOCATOR THEY ARE FREE
MOVE T3,NPAGES ;NOW UNMAP OUTPUT PAGES
IORX T3,PM%CNT
HRROI T1,-1
HRLI T2,.FHSLF
HRR T2,STOPGS
PMAP%
MOVE P1,NPAGES ;CLEAR SOME PAGES
MOVE T1,STOPGS
CALL CLRPMP ;TELL CORE ALLOCATOR THEY ARE FREE
;SET END PTR ON DESTINATION FILE
MOVE T2,BCINP ;BYTE COUNT OF INPUT FILE
HRRZ T1,OJFN
SFPTR% ;SET FILE PTR
ERJMP SFPER1 ;SFPTR FAILED
HRLI T1,.FBSIZ ;SET EOF PTR IN FILE (CLOSF DOES NOT WHEN
MOVE T3,T2 ;NO SEQUENTIAL OUTPUT HAS BEEN DONE)
SETO T2,
CHFDB%
ERJMP [JSERR
HALTF%
RET]
;SET BYTE SIZE OF DEST FILE
; (CLOSF DOES NOT SET IT WHEN NO SEQ OUTPUT HAS BEEN DONE)
HRLI T1,.FBBYV
SETZ T3,
MOVE T2,BSINP ;BYTE SIZE OF INPUT FILE
DPB T2,[POINTR T3,FB%BSZ] ;BYTE SIZE
MOVX T2,FB%BSZ
CHFDB%
ERJMP [JSERR
HALTF%
RET]
;Set date/time of output file
MOVE T1,OJFN
MOVEI T2,RFTAD1 ;From input file info
MOVEI T3,2
SFTAD%
;CLOSE FILES
HRRZ T1,OJFN
TXO T1,CO%NRJ ;DON'T RELEASE JFN
CLOSF%
ERJMP CLSFE1
HRRZ T1,IJFN
TXO T1,CO%NRJ ;DON'T RELEASE JFN
CLOSF%
ERJMP CLSFE2
RET ;DONE, RETURN
;HERE IF SFPTR FAILS - CAN'T SET SIZE OF OUTPUT FILE
SFPER1: TMSG <? SFPTR failed: >
CALL LSTFER
HALTF%
RET
;CLOSF FAILURES
CLSFE1: TMSG <?Can't close output file: >
CALL LSTFER
HALTF%
RET
CLSFE2: TMSG <?Can't close input file: >
CALL LSTFER
HALTF%
RET
SUBTTL CHKNUD - CHECK UID LINE IN NEW FILE AND SET FLAGS
;MAY SET FLAGS F.NUD AND/OR F.72C
CHKNUD: HRRZ P1,STIPG2 ;START OF FILE
HRLI P1,(POINT 7,) ;POINTER TO "FILE" STRING
ILDB T1,P1 ;FIRST CHAR
CAIE T1,";"
CAIN T1,"!"
CAIA
RET ;NO UID, RETURN
MOVE T2,[POINT 7,[ASCIZ/ UPD ID= /]] ;THIS MUST BE NEXT
CALL CMPSTR ;COMPARE STRINGS
RET ;NO MATCH, NO UID
TXO F,F.NUD ;FOUND UID LINE
MOVE T1,P1 ;READY TO READ THE UID NUMBER
MOVEI T3,^D10 ;READ DECIMAL UID
NIN%
IFJER.
SETZ T2,
ENDIF.
MOVEM T2,UID1 ;SAVE
;SEE HOW LONG IT IS, SET FLAG F.72C IF 72 CHARS EXACTLY (BEFORE CRLF)
HRRZ P1,STIPG2 ;RESET POINTER
HRLI P1,(POINT 7,)
SETZ T4, ;CHAR COUNT
CHKNU1: ILDB T1,P1 ;GET A CHAR
CAIN T1,.CHCRT ;CARRIAGE RETURN?
JRST CHKNU2 ;YES, SEE IF 72 CHARS BEFORE IT
AOJ T4, ;ANOTHER ONE
CAIG T4,^D72
JRST CHKNU1 ;KEEP LOOKING
RET ; MORE THAN 72 CHARS
CHKNU2: CAIN T4,^D72 ;EXACTLY 72?
TXO F,F.72C ;YES, SET FLAG
RET ;AND RETURN
SUBTTL BLDNUI - ROUTINE TO BUILD A NEW UID LINE
;THIS ROUTINE GETS THE NEXT UID NUMBER AND PUTS IT IN THE
; UID TEXT. THE TEXT IS STORED IN "UIDTXT". IT PADS SPACES
; ON THE END TO GET TO 72 CHARS.
BLDNUI: MOVE T1,[ASCIZ/ /] ;5 SPACES
SKIPN SWRUID ;REPLACING UID LINES?
SETZ T1, ;NO, USE NULL INSTEAD
MOVEM T1,UIDTXT ;FILL UIDTXT UP WITH SPACES
MOVE T1,[UIDTXT,,UIDTXT+1]
BLT T1,UIDTXT+LUIDTX-1
MOVE P1,[POINT 7,UIDTXT] ;P1:= PTR TO OUTPUT TEXT
;GET WHICH COMMENT CHARACTER TO USE
MOVE T2,EXTNUM ;WHICH EXTENSION
HLRZ T1,EXTLST(T2) ;GET THE CHAR
IDPB T1,P1 ;STORE FIRST CHAR
;INITIAL STRING IS "UPD ID= "
MOVE T3,[POINT 7,[ASCIZ/ UPD ID= /]]
CALL CPT3P1 ;COPY FROM T3 TO P1 TILL NULL
;GO GET A UID
PUSH P,P1
CALL ALUUID
POP P,T1 ;GET STRING POINTER IN T1
MOVE T2,NEWUID ; GET UID NUMBER TO PUT IN STRING
MOVEI T3,^D10 ;RADIX 10
NOUT%
ERCAL IMPERR ;ALU OR MONITOR BUG
MOVE P1,T1 ;COPY UPDATED STRING PTR
SKIPE SWRUID ;REPLACING UID LINES?
JRST BLDNU1 ;YES, DIFFERENT FORMAT
MOVE T3,[POINT 7,[ASCIZ/, /]]
CALL CPT3P1 ;COPY FROM T3 TO P1 TILL NULL
MOVE T1,P1 ;OUTPUT TO END OF STRING
HRRZ T2,OJFN
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS% ;OUTPUT FULL FILE NAME
HRROI T2,[ASCIZ /, /]
SETZ T3,
SOUT
SETO T2, ;CURRENT DATE/TIME
SETZ T3, ;STANDARD FORMAT
ODTIM%
ERJMP MAZTME
MOVEM T1,P1 ;UPDATE STRING PTR
JRST BLDNU2 ;CONTINUE WITH LINE
BLDNU1: MOVE T3,[POINT 7,[ASCIZ/ on /]]
CALL CPT3P1 ;COPY FROM T3 TO P1 TILL NULL
MOVE T1,P1 ;OUTPUT TO END OF STRING
SETO T2, ;CURRENT DATE/TIME
MOVX T3,OT%SLA+OT%NMN+OT%SCL+OT%DAM+OT%NTM ;DATE WITH SLASHES, NO TIME
ODTIM%
ERJMP MAZTME
MOVEM T1,P1
MOVE T3,[POINT 7,[ASCIZ/ at /]]
CALL CPT3P1 ;COPY FROM T3 TO P1 TILL NULL
CALL GTTIM ;READ THE TIME INTO HLDTM1
RET ;ERROR, RETURN
MOVE T3,[POINT 7,HLDTM1]
CALL CPT3P1 ;COPY FROM T3 TO P1 TILL NULL
BLDNU2: MOVE T3,[POINT 7,[ASCIZ/ by /]]
CALL CPT3P1 ;COPY FROM T3 TO P1 TILL NULL
MOVE T3,[POINT 7,USRNAM] ;COPY USER NAME
CALL CPT3P1 ;COPY FROM T3 TO P1 TILL NULL
AOS (P) ;ALL OK, SKIP RETURN
RET ;RETURN
SUBTTL OUT1ST - WRITE 1ST LINE (UID) TO OUTPUT FILE
;THIS IS DONE IN BYTE MODE I/O
;ALWAYS RETURNS .+1
OUT1ST: MOVE T1,OJFN ;WRITE TO HERE
MOVE T2,[POINT 7,UIDTXT] ;NEW UID TEXT
MOVNI T3,^D72 ;WRITE 72 BYTES
SKIPN SWRUID ;IF NOT REPLACING UID LINES
SETZ T3, ;THEN JUST WRITE TO NULL
SOUT%
ERJMP OUT1ER ;FAILED-- GO SEE WHY
HRROI T2,CRLF
SETZ T3,
SOUT%
ERJMP OUT1ER
RET ;RETURN
OUT1ER: CALL GLERR ;GET LAST ERROR CODE
CAIN T1,IOX11 ;QUOTA EXCEEDED
JRST OUT1QE ;YES
TMSG <? Can't write 1st line of output file: >
CALL LSTFER ;SAY WHY
HALTF%
RET ;RETURN IF CONTINUE
OUT1QE: TMSG <?Quota exceeded or disk full
(Please fix the problem and type "continue")>
HALTF%
JRST OUT1ST ;START ROUTINE AGAIN
SUBTTL GETCD - GET CONNECTED DIRECTORY STRING AND PUT IN "CD"
GETCD: SETO T1, ;-1 FOR CURRENT JOB
MOVE T2,[-1,,T4] ;GET CONNECTED DIRECTORY NUM IN T4
MOVEI T3,.JIDNO
GETJI%
ERJMP GETCDE ;?FAILED
MOVE T1,[POINT 7,CD] ;PUT IN "CD"
MOVE T2,T4
DIRST%
JFCL ;ALL ERRORS SHOULD NEVER HAPPEN
;MAKE SURE HE IS NOT CONNECTED TO ANY OF THE LIBRARIES
; IF HE IS, MAKE HIM FIX IT AND TYPE "CONTINUE"
MOVSI P1,-NMLIBS ;AOBJN PTR TO LIBRARIES
GETC1A: HRRZ T2,LIBLST(P1) ;POINTER TO ASCIZ <LIB>
HRLI T2,(POINT 7,) ;MAKE A REAL B.P.
MOVE T1,[POINT 7,CD] ;POINT TO THIS DIRECTORY NAME
GETCD2: ILDB T3,T1
ILDB T4,T2 ;GET CHAR FROM EACH
JUMPE T3,GETCD3 ;END OF CONNECTED DIRECTORY STRING
CAIN T3,(T4) ;STILL MATCH?
JRST GETCD2 ;YES
GETCDO: AOBJN P1,GETC1A ;LOOP FOR ALL LIBRARIES
RET ;RETURN, ALL DONE
GETCD3: JUMPN T4,GETCDO ;NO MATCH, OK
;CONNECTED DIRECTORY STRING MATCHES A LIBRARY DIRECTORY STRING
; DON'T ALLOW THIS!
;GETCD ROUTINE (CON'T)
TMSG <?You cannot be connected to >
TYPE CD ;TYPE THE CONNECTED DIRECTORY NAME
TMSG < - it is a library
[Please CONNECT somewhere else and type CONTINUE or START]
>
HALTF%
JRST GETCD ;TRY AGAIN IF HE CONTINUES
GETCDE: TMSG <?Can't get your connected directory name: >
CALL LSTFER
HALTF%
JRST GETCD ;TRY AGAIN
SUBTTL CHKRME - SEE IF FILE IS RESERVED BY ME.
;WE HAVE FOUND A MAZ FILE AND ITS JFN IS NOW IN "MAZJFN".
; THIS ROUTINE READS IT AND CHECKS TO MAKE SURE IT SAYS
; THE FILE WAS RESERVED BY ME.
;IF THERE IS AN ERROR, IT RELEASES THE JFN AND RETURNS
; TO .+1.
;IF EVERYTHING IS OK, IT CLOSES THE FILE AND RETURNS TO .+2.
;OPEN FOR READING
CHKRME: TDZA T1,T1 ;FLAG CHECK RESERVATION
CHKFME: SETO T1, ;FLAG CHECK FREEZE
SAVEAC <P1>
TRVAR <CHKMEF>
MOVEM T1,CHKMEF ;SAVE FLAG
HRRZ T1,MAZJFN
MOVX T2,OF%RD+7B5
OPENF%
ERJMP CHKRE1 ;?CAN'T OPEN FOR READING
;READ FIRST LINE INTO A BUFFER
CHKRM1: SETZM MAZBUF ;CLEAR BUFFER
MOVE T1,[MAZBUF,,MAZBUF+1]
BLT T1,MAZBUF+.MAZLN-1
HRRZ T1,MAZJFN ;FROM HERE
MOVE T2,[POINT 7,MAZBUF] ;TO HERE
MOVEI T3,LINLEN ;80 CHARS MAX
MOVEI T4,.CHLFD ;TERMINATE WITH A LINE FEED
SIN%
IFJE. (R)
CAIE T1,IOX4 ;END OF FILE REACHED?
JRST CHKRE2 ;NO, UNEXPECTED ERROR
ENDIF.
;CLOSE BUT DON'T RELEASE JFN
CHKRM2: HRRZ T1,MAZJFN
TXO T1,CO%NRJ ;DON'T RELEASE JFN
CLOSF%
ERJMP CHKRE3 ;OOPS.. CAN'T
;NOW PARSE THE LINE TO SEE IF IT WAS RESERVED BY ME
MOVE P1,[POINT 7,MAZBUF] ;POINT TO LINE
MOVE T2,[POINT 7,[ASCIZ/! Reserved by /]]
SKIPE CHKMEF ;WHICH FLAVOR?
MOVE T2,[POINT 7,[ASCIZ /! Frozen by /]]
CALL CMPSTR ;CHECK MAZ STRING, UPDATE P1
JRST BADFMT ;DOESN'T MATCH, BAD FORMAT
MOVEM P1,SAVNSP ;SAVE NAM: STRING PTR
;FALL
;READ "<NAM>" AND CHECK TO SEE IF IT'S ME.
MOVE T2,[POINT 7,HNBUF] ;PLACE TO HOLD NAME STRING:
CHKRM3: ILDB T1,P1 ;GET CHAR FROM MAZ FILE
JUMPE T1,CHKRE4 ; ?SHOULDN'T FIND A NULL!
IDPB T1,T2 ;STORE CHAR
CAIE T1," " ;WAS IT A SPACE?
JRST CHKRM3 ;NO, LOOP
SETZ T1, ;STORE NULL TO END STRING
DPB T1,T2
;CHECK TO SEE IF ME
MOVE T3,[POINT 7,USRNAM] ;BYTE PTR TO USER NAME STRING
MOVE T1,[POINT 7,HNBUF] ;BYTE PTR TO MAZ STRING
CHKRM4: ILDB T2,T1
ILDB T4,T3
JUMPE T2,[JUMPN T4,NOTRME ;NOT RESERVED BY ME!
JRST RSVME] ;ELSE IS RESERVED BY ME
CAIN T2,(T4)
JRST CHKRM4 ;ALL RIGHT SO FAR
NOTRME: TXNE F,F.SUSR ;MESSAGE WANTED HERE?
IFSKP.
MOVEI T1,"?"
DPB T1,[POINT 7,MAZBUF,6] ;MAKE FIRST CHAR ?
TYPE MAZBUF ;?Reserved by..
ENDIF.
HRRZ T1,MAZJFN
RLJFN% ;RELEASE MAZ FILE JFN
ERJMP .+1
RET ;RETURN
;FILE WAS RESERVED BY ME -- READ IN DIRECTORY NAME WHERE IT IS
RSVME: TXNN F,F.SUSR ;JUST CHECKING STATUS?
SKIPE CHKMEF ;CHECKING FREEZE?
RETSKP ;YES, DONE
MOVE T2,[POINT 7,[ASCIZ/at /]]
CALL CMPSTR ;MAKE SURE STRINGS MATCH
JRST BADFMT ;? FILE IS WRONG FORMAT
MOVEM P1,SAVNSP ;SAVE POINTER INCASE ERRORS
MOVE T2,[POINT 7,RDIR]
RSVME1: ILDB T1,P1 ;GET CHAR FROM MAZ FILE
JUMPE T1,CHKRE4 ;GO COMPLAIN
IDPB T1,T2 ;STORE CHAR
CAIE T1,">" ;WAS THAT A CLOSING BRACKET?
JRST RSVME1 ;NO, LOOP
SETZ T1, ;NULL TO END STRING
IDPB T1,T2
AOS (P) ;SKIP RETURN
RET
; ERRORS IN CHKRME ROUTINE
CHKRE1: TMSG <?OPENF failed for MAZ file: >
CALL LSTFER
HALTF%
JRST CHKRME ;TRY OPENF AGAIN
CHKRE2: TMSG <? Can't read first line of MAZ file: >
CALL LSTFER
HALTF%
JRST CHKRM1 ;TRY AGAIN IF CONTINUE
CHKRE3: TMSG <?CLOSF failed for MAZ file: >
CALL LSTFER
HALTF%
JRST CHKRM2 ;TRY AGAIN IF CONTINUE
BADFMT: TMSG <?Bad format for MAZ file
>
HRRZ T1,MAZJFN
RLJFN% ;RELEASE JFN
ERJMP .+1
RET ;RETURN .+1
CHKRE4: TMSG <? Can't read name string in MAZ file, it is: >
MOVE T1,SAVNSP ;SAVED NAME STRING PTR
PSOUT% ;TYPE REST OF LINE
HALTF%
RET
ENDTV.
SUBTTL CMPSTR - COMPARE STRING TO FILE TEXT
;ARGS:
; P1/ POINTER TO FILE TEXT
; T2/ POINTER TO STRING TO MATCH
;IF NO MATCH, POPJ
; ELSE SKIP WITH P1 UPDATED
CMPSTR: ILDB T3,T2 ;GET STRING MATCH CHAR
JUMPE T3,RSKP ;MATCH IF MATCH STRING ENDED
ILDB T1,P1 ;GET MAZ CHAR
JUMPE T1,RTN ;NO MATCH IF MAZ STRING ENDED
CAIN T1,(T3) ;ALL RIGHT SO FAR?
JRST CMPSTR ;YES, KEEP GOING
RET ;NO MATCH, POPJ
JRST CMPSTR ;GO ON TO NEXT CHAR
SUBTTL CHKCNN - SEE IF CONNECTED DIRECTORY IS WHERE FILE IS
;THIS ROUTINE IS CALLED BY "REPLACE" TO CHECK IF THE CONNECTED
; DIRECTORY IS THE SAME ONE THAT THE FILE WILL BE REPLACED FROM.
; If not, ask the user whether he wants the file on his connected
;directory to be the replacement file. If not, F.SPCR is set.
;
;INPUT: CD/ CONNECTED DIRECTORY
; RDIR/ RESERVED DIRECTORY
;RETURNS: .+1 AFTER THE COMMAND IS CONFIRMED
CHKCNN: MOVE T1,[POINT 7,CD]
MOVE T2,[POINT 7,RDIR]
CHKCN0: ILDB T3,T1 ;GET CHAR FROM CD
ILDB T4,T2 ;GET CHAR FROM RDIR
JUMPE T3,CHKCN1 ;END OF CD
CAIN T3,(T4) ;STILL MATCH?
JRST CHKCN0 ;YES, LOOP
;NO MATCH, HAVE TO CONFIRM THIS
CHKCNC: TMSG <% File was reserved on >
TYPE RDIR
TMSG <, but you are now connected to >
TYPE CD
TMSG <.
Do you want to replace from the connected directory? >
CALL YESNO
TXO F,F.SPCR ;No, say special filespec
RET ;Yes, continue
CHKCN1: JUMPN T4,CHKCNC ;NO MATCH
RET ;MATCHES, OK
SUBTTL SETMAB - SET JFNS FOR MAB FILE, IFILE, OFILE
;ERRORS RETURN TO .+1 WITH ALL JFN'S RELEASED
; RETURNS .+2 IF ALL OK WITH NEW OUTPUT FILE JFN IN OJFN
SETMAB: HRRZ T2,GTFJFN ;JFN OF RESERVED FILE
HRROI T1,RETJNM ; RETURN STRING HERE
MOVX T3,1B2+1B5+1B8+1B11+JS%PAF ;RETURN DEV:<DIRECTORY>NAME.EXT
JFNS%
SKIPN SWBAKF ;MAKING BACKUP FILES?
JRST SETMB1 ;NO
HRRZ T2,GTFJFN
HRROI T1,MABJNM ; GET NAME OF BAK FILE
MOVX T3,1B2+1B5+1B8+JS%PAF ;DEV:<DIRECTORY>NAME
JFNS%
;TACK ON EXT
MOVEI T2,"."
IDPB T2,T1
HRRZ T2,EXTNUM ;WHICH EXTENSION NUMBER
HRRZ T3,EXBLST(T2) ;MAKE T3 POINT TO IT
HRLI T3,(POINT 7,)
DORN1: ILDB T2,T3 ;GET A CHAR
IDPB T2,T1 ;STASH IN NAME
JUMPN T2,DORN1 ;KEEP GOING TILL NULL
;GET A JFN FOR IT
DORN2: MOVX T1,GJ%SHT+GJ%FOU
MOVE T2,[POINT 7,MABJNM]
GTJFN%
ERJMP DORNE2 ;?SHOULDN'T FAIL
MOVEM T1,MABJFN
;DO GTJFN TO WRITE A NEW ONE
SETMB1: MOVX T1,GJ%SHT+GJ%FOU
MOVE T2,[POINT 7,RETJNM]
GTJFN%
ERJMP DORNE4 ;? DARN, CAN'T.
MOVEM T1,OJFN ;THAT BECOMES THE "OUTPUT FILE" JFN
AOS (P) ;RETURN OK
RET
;ERRORS IN "SETMAB" ROUTINE
DORNE2: TMSG <?GTJFN failed for MAB file: >
CALL LSTFER
HALTF%
JRST DORN2 ;TRY IT AGAIN
DORNE4: TMSG <?GTJFN failed for new output file: >
CALL LSTFER
HALTF%
RET ;RETURN BAD
SUBTTL DORNAM - RENAME OLD FILE TO MAB
DORNAM: SKIPN SWBAKF ;MAKING BACKUP FILES?
JRST DORNA1 ;NO
;RENAME IT
HRRZ T1,GTFJFN ;SOURCE
HRRZ T2,MABJFN ;DEST.
RNAMF% ;RENAME IT
ERJMP DORNE3 ;? CANT, GO COMPLAIN
DORNA1: AOS (P)
RET
DORNE3: TMSG <?RNAMF failed: >
CALL LSTFER
HALTF%
RET ;ERROR
SUBTTL ROUTINE TO PARSE "WHY" TEXT
;CALL: CALL PRSWHY
; <RETURNS HERE WITH TEXT IN WHYTXT>
PRSWHY: MOVE T1,[POINT 7,[ASCIZ/(Why?) /]]
CALL PR2SET ;SETUP 2ND PARSE
MOVEI T1,CM2BLK ;USING THIS PARSE BLOCK NOW
MOVEI T2,[FLDDB. (.CMTXT,CM%SDH,,<One-line comment for FILUPD.HST>)]
CALL COMMND ;PARSE IT
; COPY ANSWER TO "WHYTXT" - IF NO ANSWER GIVEN, ASK AGAIN
MOVE T3,[POINT 7,ATM2BF] ;FROM HERE
MOVE T2,[POINT 7,WHYTXT] ;TO HERE
ILDB T1,T3 ;GET 1ST CHAR
JUMPE T1,PRSWHY ;GO ASK AGAIN IF NOTHING TYPED
IDPB T1,T2 ;SOMETHING, STORE 1ST CHAR
PRSWH1: ILDB T1,T3
IDPB T1,T2
JUMPN T1,PRSWH1 ;LOOP IF MORE CHARS
MOVEI T1,.CHCRT ;APPEND CRLF
DPB T1,T2
MOVEI T1,.CHLFD
IDPB T1,T2
SETZ T1,
IDPB T1,T2 ;AND END WITH NULL
RET
SUBTTL COMMON ROUTINES USED BY COMMAND SCANNERS
;SETUP FOR 2ND COMMAND PARSE
;CALL: T1/ POINTER TO CONTROL-R BUFFER
; CALL PR2SET
; <RETURNS HERE>
PR2SET: SKIPN T1 ;ANY BP GIVEN?
HRROI T1,[0] ;NO, GET A NULL ONE
MOVEM T1,CM2BLK+.CMRTY ;SETUP CONTROL-R BUFFER
POP P,T3 ;GET PUSHDOWN PTR THE WAY IT SHOULD BE
MOVEM P,CM2P ;REMEMBER IT
PUSH P,T3 ;RESTORE P
HRRZM T3,PR2STA ;SAVE ADDR AFTER THIS PUSHJ
MOVEI T1,CM2BLK ;INITIALIZE
MOVEI T2,[FLDDB. (.CMINI)]
COMND% ;DO IT
RET ;RETURN
;HERE IF A REPARSE IS NEEDED FOR CM2 FUNCTIONS
NEWPR2: MOVE P,CM2P ;RESTORE PDL
JRST @PR2STA ;START AGAIN AT THE RIGHT ADDRESS
;read a tty line
ITTLIN: MOVEI T1,TXTIBL ;USE TEXTI BLOCK
MOVE T2,[POINT 7,TLINE] ;BUFFER POINTER
MOVEM T2,.RDDBP(T1) ;STORE IT
MOVEI T2,TXTLEN ;SIZE
MOVEM T2,.RDDBC(T1) ;STORE THAT
MOVX T2,RD%JFN!RD%BEL ;BREAK ON END OF TTY LINE
MOVEM T2,.RDFLG(T1) ;STORE FLAGS
TEXTI% ;DO TEXTI
ERJMP [JSERR
RET]
AOS (P) ;GOOD RETURN
RTN: RET ;RETURN OK
SUBTTL COMMAND ERRORS
LOSE: TMSG <
? > ;TYPE PRELIMINARY ERROR TEXT
CALL LSTFER ;TYPE LAST ERROR IN THIS FORK
LOSFIN: TYPE CRLF ;TYPE FINAL STRING
ERESET: MOVEI T1,.PRIIN ;GET READY
CFIBF% ;CLEAR INPUT BUFFER
MOVE P,[IOWD PDLSIZ,PDL] ;RESET STACK
JRST NEWCMD ;AND GO GET ANOTHER COMMAND
;TYPE LAST ERROR IN THIS FORK
LSTFER: MOVEI T1,.PRIOU ;OUTPUT TO TERMINAL
HRLOI T2,.FHSLF ;LAST ERROR IN THIS FORK
SETZ T3, ;ALL OF THE TEXT
ERSTR%
JFCL
JFCL
RET
;GET LAST ERROR IN THIS FORK
GLERR: MOVEI T1,.FHSLF
GETER%
HRRZ T1,T2 ;Error code only
RET
;LSTFER + CRLF
LSTFRC: CALL LSTFER
TMSG <
>
RET
;UNEXPECTED FATAL ERROR
FATAL: TMSG <
?Unexpected error at >
MOVE T2,0(P) ;PC FROM ERCAL
MOVEI T1,.PRIOU
MOVEI T3,^D8
NOUT%
ERJMPS .+1
TMSG <
?>
CALL LSTFRC ;ERROR MSG
HALTF
JRST ST1 ;IF CONTINUED
SUBTTL COMMAND JSYS SUBROUTINES
NOISE: HRROM T2,NOIBLK+.CMDAT ;SAVE AS DATA
MOVEI T2,NOIBLK ;POINT TO BLOCK
JRST COMMND ;AND GO TO COMND JSYS
CONFRM: MOVEI T2,[FLDDB. (.CMCFM)] ;GET CONFIRM FUNCTION
COMMND: COMND% ;PARSE THE FUNCTION
ERJMP LOSE ;ERROR, GO COMPLAIN
TXNE T1,CM%NOP ;DID IT PARSE?
JRST LOSE ;NO, COMPLAIN
RET ;YES, RETURN SUCCESSFULLY
NOIBLK: FLDDB. (.CMNOI) ;BLOCK FOR NOISE FUNCTION
SUBTTL BYTWRT - ROUTINE TO COPY FILE WITH BYTE I/O
;IJFN AND OJFN FILES ARE OPEN
; AFTER THIS ROUTINE COPIES EVERYTHING, IT CLOSES BOTH FILES
; BUT LEAVES THE JFNS ASSIGNED.
BYTWRT: MOVEI P1,1 ;GET A PAGE FOR SIN/SOUT'S
CALL FINFRE
MOVEM T1,STIPGS
LSH T1,^D9
MOVEM T1,STIPG2
RWSLUP: MOVE T1,IJFN ;READ FROM HERE
HRR T2,STIPG2 ;TO HERE
HRLI T2,(POINT 7,)
MOVNI T3,^D512*5 ; READ WHOLE PAGE IF WE CAN
SIN%
ERJMP LNDON1 ;ERROR READING.. PROBABLY EOF
RWSLP1: MOVE T1,OJFN
HRR T2,STIPG2
HRLI T2,(POINT 7,)
MOVNI T3,^D512*5 ;NOW WRITE THE WHOLE PAGE BACK OUT
SOUT%
ERJMP LNDON2 ;ERROR WRITING.. PROBABLY NO ROOM
JRST RWSLUP ;READ/WRITE SLOW LOOP
LNDON1: MOVE P2,T3 ;SAVE BYTE COUNT
CALL GLERR ;GET LAST ERROR CODE
CAIN T1,IOX4 ;EOF?
JRST BYWEOF ;YES
TMSG <? COPY failure reading: >
CALL LSTFER
HALTF%
RET
;HERE WHEN WE GET TO EOF
BYWEOF: MOVNI T3,^D512*5 ;COMPUTE BYTE COUNT
SUB T3,P2
MOVE T1,OJFN
HRRO T2,STIPG2
SOUT% ;WRITE LAST PART
ERJMP LNDON3 ;ERRORS...
;DONE!
MOVE T1,OJFN ;CLOSE OUTPUT FILE
TXO T1,CO%NRJ ;; DON'T RELEASE JFN
CLOSF%
IFJER.
TMSG <? Couldn't close OJFN
>
ENDIF.
MOVE T1,IJFN ;CLOSE INPUT FILE
TXO T1,CO%NRJ
CLOSF%
IFJER.
TMSG <? Couldn't close IJFN
>
ENDIF.
RET ;RETURN
LNDON2: CALL CHKQTE ;CHECK FOR QUOTA EXCEEDED
JRST RWSLP1 ;GO TRY AGAIN
TMSG <? Error writing file: >
CALL LSTFER
HALTF%
JRST RWSLP1 ;GO TRY AGAIN
LNDON3: CALL CHKQTE ;CHECK FOR QUOTA EXCEEDED
JRST BYWEOF ;GO TRY AGAIN
TMSG <? Error writing file: >
CALL LSTFER
HALTF%
JRST BYWEOF ;GO TRY AGAIN
;ROUTINE TO CHECK FOR OTHER GENERATED OUTPUT FILES AND COPY THE
;ONES CREATED AFTER THE SOURCE FILE.
CHKOF: MOVE T2,EXTNUM ;WHICH EXTENSION?
SKIPN T4,EXOLST(T2) ;ANY POSSIBLE OUTPUT FILES?
RET ;NO, JUST RETURN
DMOVE T1,RFTAD1 ;Get DATE/TIME of main source
DMOVEM T1,RFTADS ;Save that info..
;NOW T4= AOBJN LIST TO [ASCIZ/OEXT/]
CHKOF1: MOVEM T4,CKOFLP ;Save ptr.
MOVE T1,[POINT 7,IFINAM] ;GET POINTER TO FILENAME STRING
;N.B.: CAN'T JUST SEARCH FOR ".", DIRECTORY NAMES MAY CONTAIN "."
DO.
ILDB T2,T1 ;GET CHARS FROM <DIR>FIL.EXT TEXT
CAIE T2,76 ;GET TO END ANGLE BRACKET OF DIRECTORY
LOOP.
ENDDO.
DO.
ILDB T2,T1 ;NOW THE "." FOR EXTENSION
CAIE T2,"."
LOOP.
ENDDO.
HRRZ T3,(T4) ;GET ADDRESS OF ASCII OUTPUT EXT.
HRLI T3,(POINT 7,) ;APPEND THIS EXT.
DO.
ILDB T2,T3
JUMPE T2,ENDLP.
IDPB T2,T1
LOOP.
ENDDO.
SETZ T2,
IDPB T2,T1 ;NULL TO END FILENAME STRING
;DO GTJFN FOR THIS FILE, IF NOT THERE, GO ON TO NEXT
MOVX T1,GJ%SHT!GJ%OLD
MOVE T2,[POINT 7,IFINAM]
GTJFN%
ERJMP CHKOFN ;FAILED, GO ON TO NEXT FILE
MOVEM T1,IJFN ;SAVE INPUT JFN
;LOOK AT DATE, IF FILE IS OLDER THAN THE SOURCE, DON'T COPY IT
MOVE T1,IJFN ;HERE'S JFN OF THE FILE
MOVEI T2,RFTAD1 ;ADDR OF ARG BLOCK
MOVEI T3,2 ;LENGTH OF ARG BLOCK
RFTAD% ;GO GET DATE/TIME INFO
MOVE T1,RFTAD1+.RSWRT ;TIME FILE WAS LAST WRITTEN
CAMGE T1,RFTADS+.RSWRT ;WAS IT BEFORE THE SOURCE?
JRST CHKOF5 ;YES, DON'T DO THE RENAME
;FILE IS NEWER THAN THE SOURCE.. COPY IT TO LIBRARY ALSO
;GET A JFN FOR OUTPUT FILE AND PUT IN "OJFN"
MOVE T2,LIBNUM ;WHICH LIBRARY?
HRRZ T2,LIBLST(T2) ;Get DEV:<DIR> of library
HRLI T2,(POINT 7,) ;T2= ptr to it
MOVE T1,[POINT 7,RETJNM] ;RETURN STRING HERE
CALL CPYNUL
HRRZ T2,GTFJFN ;Real source name
MOVX T3,1B8
JFNS%
MOVEI T2,"."
IDPB T2,T1
HRRZ T2,IJFN ;Ext from this gen. output file.
MOVX T3,1B11 ;EXT
JFNS%
MOVX T1,GJ%SHT+GJ%FOU
HRROI T2,RETJNM
GTJFN%
ERJMP CHKOE1 ;?CAN'T -- GO COMPLAIN
MOVEM T1,OJFN ;SAVE JFN
;Tell user what we're doing a la EXEC "copy"
TMSG < > ;Type a space
MOVEI T1,.PRIOU ;Write to TTY:
HRRZ T2,IJFN
SETZ T3,
JFNS% ;The source filespec
TYPE TOINDI ;Look like a copy
MOVEI T1,.PRIOU
HRRZ T2,OJFN
SETZ T3,
JFNS% ;The dest filespec
TMSG < > ;Type a space
TXNE F,F.RCPY ;Did we copy the new source file?
JRST GOCPOF ;Yes, do a COPY for the new source also
GORNRL: MOVE T1,OJFN ;Get T1= JFN of output file
CALL SETGRC ;Set generation-retention-count
JRST GOCPOF ;?can't, Do a COPY instead.
MOVE T1,IJFN ;PREPARE FOR RENAME
MOVE T2,OJFN
RNAMF%
ERJMP RNFL1 ;FAILED.. GO SEE WHY
;Here when COPY or RENAME is done.
; The new file has been deleted from my area and
; IJFN has been released.
ROJFN: MOVE T1,OJFN
RLJFN%
JFCL ;NO ERROR SHOULD HAPPEN!
TYPE <[ASCIZ/[OK]
/]>
JRST CHKOFN ;GO ON TO NEXT OUTPUT FILE
;HERE IF RENAME FAILED
RNFL1: CALL GLERR ;GET LAST ERROR CODE
CAIN T1,RNAMX4
JRST RNFL2 ;?QUOTA EXCEEDED IN DEST OF RENAME
TMSG <
? Can't rename >
TYPE IFINAM
TMSG <: >
CALL LSTFER ;TYPE THE ERROR
HALTF%
JRST GORNRL ;TRY AGAIN IF "CONTINUE"
RNFL2: TYPE <[ASCIZ/
?Quota exceeded on library
[Please fix the problem and type "CONTINUE"]/]>
HALTF%
JRST GORNRL ;TRY IT AGAIN
;Here if we must copy the generated output file to the library
;IJFN and OJFN set up but no yet OPEN.
GOCPOF: CALL OPENO ;Get ready to write new file
RET ;Errors, forget it
CALL IOPEN ;Open file for reading
JRST [CALL RLOJFN ;Errors, release OJFN
RET] ;And return
CALL PRELD0 ;Preload some pages
CALL PPCPY ;** Copy the file **
HRRZ T1,IJFN ;Now delete the file from my area
MOVEI T2,0 ;Keep 0 generations
DELNF%
IFJER.
TMSG <%Can't delete >
TYPE IFINAM ;Type the name
CALL LSTFRC
TMSG <, continuing...
>
ENDIF.
HRRZ T1,IJFN ;Throw away new object file's JFN
RLJFN%
ERJMP .+1 ; Error, ignore it
JRST ROJFN ;Done with this file
;HERE IF CAN'T GTJFN OUTPUT FILE
CHKOE1: TMSG <?Can't write output file: >
CALL LSTFER
TYPE CRLF
CHKOF5: MOVE T1,IJFN
RLJFN% ;RELEASE JFN AND CLOSE FILE
JFCL ;NO ERROR SHOULD HAPPEN!
CHKOFN: MOVE T4,CKOFLP ;Get AOBJN ptr to list of extensions
AOBJN T4,CHKOF1 ;LOOP FOR ALL OUTPUT FILENAMES
RET ;DONE, RETURN
;ROUTINE TO OUTPUT A REPLACE ENTRY TO FILUPD.HST
;CALL: "WHY" TEXT IN "WHYTXT"
; UID IN NEWUID
DOLOG: CALL STLOG ;START LOG ENTRY
MOVE T2,[POINT 7,[ASCIZ/
Replaced /]]
CALL LOGSTR
MOVE T1,P1
CALL TACKLB ;LIB:
MOVE T2,OJFN
MOVX T3,1B8+1B11+JS%PAF ;JUST FILENAME.EXT
JFNS%
MOVE P1,T1
MOVE T2,[POINT 7,[ASCIZ/
Updated file: /]]
CALL LOGSTR
MOVE T1,P1 ;DESTINATION
MOVE T2,OJFN ; FILE WE ARE WRITING TO
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS%
MOVE P1,T1
MOVE T2,[POINT 7,[ASCIZ/
Copied from: /]]
CALL LOGSTR
MOVE T2,[POINT 7,FROMFL]
CALL LOGSTR
SKIPN SWFUID ;UID IN FILE?
JRST DOLOG2 ;NO, CAN'T PRINT UID:
MOVE T2,[POINT 7,[ASCIZ/ UID: /]]
CALL LOGSTR
SKIPN T2,UID1 ;ANY UID?
JRST DOLOG1 ;NO, SAY "NONE"
MOVE T1,P1
MOVEI T3,^D10
NOUT%
ERCAL IMPERR
MOVE P1,T1
JRST DOLOG2
;DOLOG ROUTINE (CONT'D)
DOLOG1: MOVE T2,[POINT 7,[ASCIZ/NONE/]]
CALL LOGSTR
DOLOG2: SKIPN SWBAKF ;MAKING BACKUP FILE?
JRST DOLOG3 ;NO
MOVE T2,[POINT 7,[ASCIZ/
Backup: /]]
CALL LOGSTR
MOVE T1,P1
MOVE T2,MABJFN
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS%
MOVE P1,T1
DOLOG3: MOVE T2,[POINT 7,[ASCIZ/
Why: /]]
CALL LOGSTR
MOVE T2,[POINT 7,WHYTXT]
CALL LOGSTR
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR
SETZ T2,
IDPB T2,P1
CALL ALULOG ;APPEND TO LOG FILE
RET ;RETURN
;ROUTINE TO DO A "ADD" LOG ENTRY
ADDLOG: CALL STLOG ;START OFF THE LOG ENTRY
MOVE T2,[POINT 7,[ASCIZ/
Added /]]
CALL LOGSTR
MOVE T1,P1
CALL TACKLB ;LIB:
MOVE T2,OJFN
MOVX T3,1B8+1B11+JS%PAF
JFNS% ;FILE.EXT
MOVE P1,T1
MOVE T2,[POINT 7,[ASCIZ/
New file: /]]
CALL LOGSTR
MOVE T1,P1
MOVE T2,OJFN
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS%
MOVE P1,T1
MOVE T2,[POINT 7,[ASCIZ/
Copied from: /]]
CALL LOGSTR
MOVE T1,P1
MOVE T2,IJFN
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS%
MOVE P1,T1
MOVE T2,[POINT 7,[ASCIZ/
Why: /]]
CALL LOGSTR
MOVE T2,[POINT 7,WHYTXT]
CALL LOGSTR
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR
SETZ T2,
IDPB T2,P1
CALL ALULOG ;APPEND LOG ENTRY
RET ;RETURN
;WRITE A DELETE LOG ENTRY
LOGDEL: CALL STLOG ;START OFF THE LOG ENTRY
MOVE T2,[POINT 7,[ASCIZ/
Deleted /]]
CALL LOGSTR
MOVE T1,P1
CALL TACKLB ;LIB:
MOVE T2,GTFJFN
MOVX T3,1B8+1B11+JS%PAF
JFNS% ;FILE.EXT
MOVE P1,T1
MOVE T2,[POINT 7,[ASCIZ/
File deleted: /]]
CALL LOGSTR
MOVE T1,P1
MOVE T2,GTFJFN
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS% ;WHOLE FILESPEC
MOVE P1,T1
MOVE T2,[POINT 7,[ASCIZ/
Why: /]]
CALL LOGSTR
MOVE T2,[POINT 7,WHYTXT]
CALL LOGSTR
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR
SETZ T2, ;NULL TO END ENTRY
IDPB T2,P1
CALL ALULOG ;APPEND LOG ENTRY
RET ;RETURN
;ROUTINE TO START OFF THE LOG ENTRY
;PUTS OUT ALU VERSION NUMBER AND UID
STLOG: MOVE P1,[POINT 7,LOGBUF]
MOVE T2,[POINT 7,[ASCIZ/**********
/]]
CALL LOGSTR
MOVE T2,[POINT 7,AVERST] ;Get ALU version number string
CALL LOGSTR
MOVE T2,[POINT 7,[ASCIZ/ UID: /]]
CALL LOGSTR ;GET READY FOR UID TEXT
MOVE T2,NEWUID
MOVEI T3,^D10 ;DECIMAL
MOVE T1,P1
NOUT%
ERCAL IMPERR
MOVE P1,T1
MOVEI T2,.CHTAB
IDPB T2,P1
CALL DTLOG ;DATE/TIME IN LOG
MOVEI T2,.CHTAB ;ANOTHER TAB
IDPB T2,P1 ;TO SEPARATE DATE FROM NAME
MOVE T2,[POINT 7,USRNAM] ;GET USER NAME
CALL LOGSTR ;APPEND STRING TO LOG ENTRY
MOVE T2,[POINT 7,CRLF]
CALL LOGSTR
RET
;ROUTINE TO PUT DATE/TIME IN LOG
DTLOG: MOVE T1,P1
SETO T2, ;CURRENT DATE/TIME
SETZ T3, ;STANDARD FORMAT
ODTIM%
ERCAL IMPERR
MOVE P1,T1 ;GET UPDATED BP
RET
;ROUTINE LOGSTR APPEND STRING IN T2 TO P1
LOGSTR: ILDB T1,T2
JUMPE T1,RTN
IDPB T1,P1
JRST LOGSTR
;ROUTINE TO CHECK FOR QUOTA EXCEEDED ERROR
;RETURNS .+1 IF LAST ERROR WAS QUOTA EXCEEDED, AFTER HE FIXES THE PROBLEM
;RETURNS .+2 IF IT WASN'T
CHKQTE: CALL GLERR ;GET LAST ERROR CODE
CAMN T1,IOX11 ;WAS IT QUOTA EXCEEDED?
JRST CHKQT1 ;YES
RETSKP
CHKQT1: TMSG <? No room or quota exceeded
(Type "CONTINUE" after the problem has been fixed)
>
HALTF%
RET ;RETURN WHEN CONTINUE
; ROUTINES TO RELEASE JFNS
RLMAB: MOVE T1,MABJFN
RLJFN%
ERJMP RLMABE ;CAN'T
RET
RLMABE: HRROI T1,[ASCIZ/% Can't release MAB JFN: /]
JRST RLERR ;GO SAY WHY
RLIJFN: MOVE T1,IJFN
RLJFN%
ERJMP RLIJFE
RET
RLIJFE: HRROI T1,[ASCIZ/% Can't release IJFN: /]
JRST RLERR
RLOJFN: MOVE T1,OJFN
RLJFN%
ERJMP RLOJFE
RET
RLOJFE: HRROI T1,[ASCIZ/% Can't release OJFN: /]
JRST RLERR
RLERR: PSOUT% ;FIRST PART OF MESSAGE
CALL LSTFER ;TYPE WHY
TYPE CRLF
RET ;RETURN OK
SUBTTL ALUUID - ALLOCATE AND RETURN A UID
ALUUID: MOVE T1,[POINT 7,UIDNAM] ;Find out UID name
MOVE T2,LIBNUM ;Which library are we using?
HRRZ T2,LB2LST(T2)
HRLI T2,(POINT 7,)
CALL CPYNUL
MOVE T2,[POINT 7,[ASCIZ/UID.TXT/]]
CALL CPYNUL
MOVX T1,GJ%OLD+GJ%SHT ;GET JFN FOR UID.TXT
HRROI T2,UIDNAM
GTJFN%
IFJER.
; CREATE UID.TXT SINCE IT DOESN'T EXIST
MOVX T1,GJ%NEW+GJ%SHT
HRROI T2,UIDNAM
GTJFN%
ERJMP UIDE2 ;CAN'T GET JFN TO CREATE
ENDIF.
; NOW OPEN UID.TXT AND GENERATE NEW UID.
MOVEM 1,UIDJFN ;SAVE JFN FOR UID.TXT
MOVE T2,[<^D7>B5+OF%RD+OF%WR] ;OPEN THE FILE
OPENF%
ERJMP UIDE3 ;CAN'T OPEN IT
SKIPE PBFPNO ;ALREADY HAVE A PAGE FOR UIDS?
JRST AUID.2 ;YES
MOVEI P1,1 ;NO, GET ONE NOW
CALL FINFRE
MOVEM T1,PBFPNO ;SAVE VALUE
AUID.2: HRLZ T1,UIDJFN ;MAP IN THE UID COUNTER PAGE
HRRZ T2,PBFPNO
HRLI T2,.FHSLF
MOVX T3,PM%RD+PM%WR
PMAP%
;GENERATE NEW UID
MOVE T1,PBFPNO ;GENERATE NEW UID
LSH T1,^D9
SKIPN T2,(T1) ;ANYTHING THERE?
JRST AUID.3 ;NO, MUST BE A BRAND NEW FILE
HRLI T1,(POINT 7,)
MOVEI T3,^D10 ;READ DECIMAL NUMBER
NIN%
ERJMP BADUID ;?NIN FAILED
;THE OLD UID IS NOW IN AC2
AUID.3: AOJ T2, ;INCREMENT IT TO MAKE A NEW UID
MOVEM T2,NEWUID ;AND SAVE THE NEW UID
SETZ T4, ;COUNT # CHARS
DO.
IDIVI T2,^D10
SKIPE T2
AOJA T4,TOP.
ENDDO.
ADDI T4,3 ;+ LAST DIGIT + CRLF
MOVE T1,PBFPNO ;WRITE NEW UID INTO THE FILE
LSH T1,^D9
HRLI T1,(POINT 7,) ;GET DESTINATION DESIGNATOR
MOVE T2,NEWUID
MOVEI T3,^D10
NOUT%
ERCAL IMPERR ;?NOTHING CAN HAPPEN!
;APPEND CRLF TO NUMBER TO MAKE USER EDITING EASIER
MOVEI T2,.CHCRT
IDPB T2,T1
MOVEI T2,.CHLFD
IDPB T2,T1
CALL UNMAPA ;UNMAP THE FILE
;SET FILE POINTER SO OTHERS CAN EDIT IT
MOVE T2,T4 ;BYTE COUNT
HRRZ T1,UIDJFN
SFPTR% ;SET FILE PTR
ERJMP SFPER1 ;?FAILED - GO COMPLAIN
HRLI T1,.FBSIZ ;SET EOF PTR IN FILE
MOVE T3,T2 ;THE NEW VALUE IN T3
SETO T2, ;"CHANGE ALL BITS"
CHFDB%
ERCAL IMPERR
HRLI T1,.FBBYV ;Change byte size word.
MOVEI T2,^D7 ;Set byte size to 7
DPB T2,[POINTR T3,FB%BSZ]
MOVX T2,FB%BSZ ;Change byte size bits
CHFDB%
ERCAL IMPERR
AUID.C: MOVE T1,UIDJFN ;CLOSE THE FILE UID.TXT
CLOSF%
ERJMP UIDE4 ;CAN'T
RET ;DONE, RETURN
SUBTTL ERRORS IN ALUUID ROUTINE
;CAN'T GTJFN TO WRITE NEW UID.TXT
UIDE2: TMSG <?ALUUID - GTJFN failed for output file UID.TXT: >
CALL LSTFER
HALTF%
JRST ALUUID ;TRY AGAIN IF "CONTINUE"
;CAN'T OPENF UID.TXT
UIDE3: TMSG <?ALUUID - OPENF failed for UID.TXT: >
CALL LSTFER
MOVE T1,UIDJFN
RLJFN% ;RELEASE THE JFN
ERJMP .+1
HALTF%
JRST ALUUID ;;TRY AGAIN IF "CONTINUE"
;BAD FORMAT FOR UID
BADUID: TMSG <?ALUUID - UID must be a decimal number, got: >
MOVE T1,PBFPNO ;WHERE THE TEXT LIVES
LSH T1,^D9
HRLI T1,(POINT 7,)
PSOUT% ;TYPE WHAT WAS THERE (GARBAGE!)
CALL UNMAPA ;UNMAP THE FILE
MOVE T1,UIDJFN ;CLOSE THE FILE
CLOSF%
ERJMP UIDE4 ;DIE IF CAN'T
TYPE <[ASCIZ/
[Please fix /]>
TYPE UIDNAM
TYPE <[ASCIZ/ and type "CONTINUE"]
/]>
HALTF% ;TO TOPS20
JRST ALUUID ;TRY AGAIN
UNMAPA: MOVX T1,-1
HRRZ T2,PBFPNO ;PAGE WHERE THE UID IS KEPT
HRLI T2,.FHSLF
MOVX T3,0
PMAP%
RET ;DONE, RETURN
;CAN'T CLOSE UID.TXT
UIDE4: TMSG <?ALUUID - CLOSF failed for UID.TXT: >
CALL LSTFER
HALTF%
JRST AUID.C ;TRY CLOSF AGAIN IF CONTINUE
SUBTTL ALULOG - WRITE AN ENTRY IN THE ALU FILE UPDATE HISTORY LOG FILE
; THE TEXT OF THE ENTRY WILL BE IN "LOGBUF". IT WILL BE APPENDED TO THE
;FILE FILUPD.HST.
ALULOG:
;FIRST, IF FILUPD.HST DOESN'T EXIST, CREATE ONE.
MOVE T1,[POINT 7,LOGNAM]
MOVE T2,LIBNUM ;Which library?
HRRZ T2,LB2LST(T2) ;Get place where it is
HRLI T2,(POINT 7,)
CALL CPYNUL
MOVE T2,[POINT 7,[ASCIZ/FILUPD.HST/]]
CALL CPYNUL
MOVX T1,GJ%OLD+GJ%SHT
HRROI T2,LOGNAM
GTJFN%
SKIPA ;FILE DOESN'T EXIST, CREATE IT
JRST ALG.1 ;FILE EXISTS, GO PROCESS IT.
;CREATE EMPTY FILUPD.HST
ALULG0: MOVX T1,GJ%NEW+GJ%SHT
HRROI T2,LOGNAM
GTJFN%
ERJMP ALOGE1 ;CAN'T GET JFN
ALG.1: MOVEM T1,LOGJFN ;SAVE JFN FOR THE LOG FILE
SETZ T4, ;NOTE FIRST OPENF% ATTEMPT
ALG2: MOVE T2,[7B5+OF%APP] ;OPEN FILE FOR APPENDING
OPENF%
ERJMP ALOGE2 ;CAN'T OPEN FOR APPEND
IFG. T4
TYPE <[ASCIZ/ OK]
/]>
ENDIF.
;NOW APPEND THE ENTRY
MOVE T1,LOGJFN ;WRITE THE LOG ENTRY TO THE FILE
HRROI T2,LOGBUF
MOVEI T3,0
MOVEI T4,0
SOUT%
;NOW CLOSE THE LOG FILE.
ALULGC: MOVE T1,LOGJFN
CLOSF%
ERJMP ALOGE3 ;CLOSF FAILED
RET ;DONE, RETURN
ALOGE1: TMSG <?GTJFN failed for new FILUPD.HST: >
CALL LSTFER
HALTF%
JRST ALULG0
ALOGE2: CALL GLERR ;GET LAST ERROR CODE
CAIN T1,OPNX9 ;BUSY?
JRST [ JUMPG T4,ALOG21 ;JUMP IF MSG ALREADY TYPED
TYPE <[ASCIZ/[File FILUPD.HST busy, waiting.../]>
ALOG21: MOVEI T1,^D1000
DISMS%
AOJA T4,ALG2] ;TRY AGAIN
TMSG <?OPENF% failed for FILUPD.HST: >
CALL LSTFER
HALTF%
JRST ALULG0
ALOGE3: TMSG <?CLOSF failed for FILUPD.HST: >
CALL LSTFER
HALTF%
JRST ALULGC ;GO TRY AGAIN IF "CONTINUE"
SUBTTL CHECK FOR REGISTERED USER
;CALL: CALL RGUSR
; <RETURN HERE IF NO>
; <HERE IF YES, INTERNAL USER # IN INTUNM>
;Checks your logged-in user number against internal list.
; If SWANYU is on (any user allowed), this routine always skips
;but does not set INTUNM.
RGUSR: CALL RGUCHK ;CHECK
JRST NOTRU ;?NOT A REGISTERED USER
JRST RSKP ;A REGISTERED USER, RETURN
NOTRU: TMSG <? You are not a registered user.
>
RET
;HERE IS ROUTINE TO SILENTLY CHECK FOR REGISTERED USER, AND IF SO
; PUTS USER NUMBER IN "INTUNM" AND SKIPS
RGUCHK: SETO T1, ;-1 FOR CURRENT JOB
MOVE T2,[-1,,P1] ;GET USER NUMBER IN P1
MOVEI T3,.JIUNO
GETJI% ;GET IT
ERJMP RGUSE1 ;? FAILED
;LOOK AT ALL REGISTERED USERS AND SEE IF WE ARE ONE OF THEM
MOVSI T4,-NMUSRS
RGUSR1: HRRO T2,USRLST(T4) ;GET PTR TO REGISTERED USER'S NAME
MOVX T1,RC%EMO ;EXACT MATCH ONLY
RCUSR% ;TRANSLATE
ERJMP RGUSRE ;ERROR - GO SEE WHY
TXNE T1,RC%NOM ;NO MATCH?
JRST RGUSR2 ;RIGHT, GO ON TO NEXT
CAMN T3,P1 ;MATCH?
JRST RGUSR3 ;YES - WE ARE A REGISTERED USER
RGUSR2: AOBJN T4,RGUSR1 ;LOOP THRU LIST
SKIPN SWANYU ;ANY USER ALLOWED?
RET ;NO
SETZM USRBIT ;UNKNOWN USER HAS NO PRIVS
JRST RGUSR4 ;CONTINUE
RGUSR3: HLLZ T3,USRLST(T4) ;KNOWN USER, GET FLAGS
MOVEM T3,USRBIT ;SAVE
RGUSR4: GJINF% ;GET LOGIN USER NUM
MOVE T2,T1
HRROI T1,USRNAM
DIRST% ;SAVE USER NAME STRING
JSHLT
AOS (P) ;AND SKIP RETURN
RET
RGUSE1: TMSG <?Can't get user number: >
CALL LSTFER
HALTF%
JRST RGUCHK ;TRY AGAIN IF CONTINUE
;HERE IF RCUSR FAILS TRYING TO TRANSLATE A USER NAME IN OUR LIST
RGUSRE: CALL GLERR ;GET LAST ERROR CODE
CAIE T1,STRX08 ;INVALID USER NAME?
CALL IMPERR ;NO, IMPOSSIBLE ERROR
TMSG <%Invalid user name in table: >
TYPE <(T4)> ;TYPE IT
JRST RGUSR2 ;GO ON TO NEXT
SUBTTL SETPMP - SETUP PAGE MAP
SETPMP: MOVE P2,[POINT 1,PAGMAP]
SETZ T4, ;START WITH PAGE 0
;Set aside some pages for ALU itself
MOVEI T3,LASTLC ;GET LAST USED LOC
LSH T3,-^D9 ;GET ITS PAGE NUMBER
SETO T1, ;MARK THEM ALL AS NOT FREE
SETPM0: IDPB T1,P2
SOSL T3 ;STOP WHEN ALL THOSE PAGES MARKED
AOJA T4,SETPM0
ADDI T4,1 ;NOW START LOOKING AT NEXT PAGE
SETPM1: HRLI T1,.FHSLF
HRR T1,T4
RPACS%
TXNN T2,PA%PEX ;DOES THIS PAGE EXIST?
TDZA T1,T1 ;NO, MARK AS FREE
SETO T1, ;YES, MARK AS NOT FREE
IDPB T1,P2
ADDI T4,1 ;GO ON TO NEXT PAGE
CAIG T4,765 ;SAVE SOME SPACE FOR DDT
JRST SETPM1
SETO T1, ;MARK REST OF PAGES AS NOT FREE
SETPM2: IDPB T1,P2
ADDI T4,1
CAIG T4,777
JRST SETPM2
RET
SUBTTL FINFRE - FIND A CLUMP OF FREE PAGES WE CAN USE
;CALL: MOVEI P1, # OF CONTIGUOUS PAGES WE WANT
; CALL FINFRE
; <RETURNS T1= NUMBER OF THE FIRST ONE>
FINFRE: SETZ T4, ;START AT PAGE 0
MOVE P2,[POINT 1,PAGMAP] ;POINTER TO PAGE MAP
FINFR0:
DO.
ILDB T2,P2 ;LOOK FOR A FREE ONE
JUMPE T2,ENDLP.
AOJA T4,TOP.
ENDDO.
CAILE T4,777 ;DID WE FIND ANY?
JRST NOROOM ;NO - USED THEM ALL!
HRRZ T1,T4 ;ASSUME THIS IS IT
HRRZ T3,P1 ;COUNTDOWN
MOVEM P2,SAVEPB ;SAVE PAGE TABLE BYTE PTR
ADDI T4,1 ;ACCOUNT FOR PAGE WE FOUND
FINFR1: SOJLE T3,GOTEM ;GOT 'EM... MARK AS TAKEN
ILDB T2,P2 ;LOOK SOME MORE
ADDI T4,1 ;ON NEXT PAGE NOW
CAILE T4,777
JRST NOROOM
JUMPE T2,FINFR1 ;STILL OK.. KEEP GOING
;This clump won't do.. try again
JRST FINFR0
GOTEM: MOVE P2,SAVEPB ;GET BYTE PTR AT START OF CLUMP
SETO T2, ;SET FLAG TO -1
DPB T2,P2 ;MARK THAT PAGE
MOVE T3,P1
DO.
SOJLE T3,RTN ;RETURN WHEN MARKED THEM ALL
IDPB T2,P2
LOOP.
ENDDO.
NOROOM: TMSG <? FINFRE: NOT ENOUGH FREE PAGES
>
HALTF%
JRST FINFRE
SUBTTL CLRPMP - CLEAR PAGE MAP & RETURN PAGES
;CLEAR PAGE MAP
;CALL: P1/ # PAGES TO CLEAR
; T1/ STARTING PAGE
CLRPMP: MOVE P2,[POINT 1,PAGMAP]
SETZ T2, ;"CLEAR" BIT
DO.
SOJL T1,ENDLP. ;GET TO THAT PAGE
IBP P2
LOOP.
ENDDO.
DO.
IDPB T2,P2
SOJG P1,TOP.
ENDDO.
RET
;** DEBUG **
LISTFR: TMSG <Used pages:
>
MOVE P2,[POINT 1,PAGMAP]
SETZ T4, ;START AT PAGE 0
LISTF0: ILDB T2,P2
JUMPN T2,LISTF1 ;TELL HIM NON-EMPTY
LISTF2: ADDI T4,1
CAILE T4,1000
RET
JRST LISTF0
LISTF1: MOVEI T1,.PRIOU
HRRZ T2,T4 ;PAGE NUMBER
MOVEI T3,8
NOUT%
ERJMP .+1
TMSG <,>
JRST LISTF2
SUBTTL CHECK OUT DEFAULT LIBRARY
WDFLIB: SKIPN DFLIBW ;SKIP IF THERE IS A DEFAULT LIBRARY
RET ;NO, NOTHING TO CHECK
;IT MUST BE ONE OF THE KNOWN LIBRARIES
MOVSI T4,-NMLIBS ;-# LIBS
WDFL1: HRRZ T1,LB1LST(T4) ;Get ptr to ASCIZ/LIB:/
HRLI T1,(POINT 7,)
PUSH P,DFLIBW
POP P,TEMPBP ;Save temp bp (to default lib)
WDFL2: ILDB T2,T1 ;Get char
ILDB T3,TEMPBP ;Get char
JUMPE T3,WDFDON ;Jump if done with default lib
CAIN T2,(T3) ;Ok so far?
JRST WDFL2 ;Yes, keep matching
;NO MATCH
WDFNOM: AOBJN T4,WDFL1 ;Loop for all libs
TYPE <[ASCIZ \?DFLIB (the default library defined in ALUPRM.MAC)
is not a known library .. please fix ALUPRM.MAC and rebuild ALU
Hint: If V6: is your default library, DEFINE DFLIB,< ASCIZ /V6/ >
\]>
HALTF%
JRST .-1
;END OF THIS LIB
WDFDON: CAIE T2,":" ;Better be at ":" in this library name
JRST WDFNOM ;No, no match
;MATCH, STORE INDEX AWAY.
HRRZM T4,DLBIDX ;Save index for default library
RET ;Return
SUBTTL GET ALU VERSION NUMBER STRING
;Called once-only when ALU is built to initialize AVERST.
SETAVR: MOVE T1,[POINT 7,AVERST] ;T1 = output BP
MOVE T2,[POINT 7,[ASCIZ/ALU %/]]
CALL CPYNUL
LDB T2,[POINT 6,ALUVER,11] ;Major version #
MOVEI T3,^D8 ;Output in octal
NOUT%
ERCAL IMPERR ;?Nothing should happen!
LDB T2,[POINT 6,ALUVER,17] ;Minor version #
JUMPE T2,SETAV1 ;Don't output anything if 0
SUBI T2,1 ;^D26="Z", ^D27="AA"
IDIVI T2,^D26 ;Get two letters
JUMPE T2,SETAV0 ;Don't output 1st letter if null
MOVEI T2,100(T2)
IDPB T2,T1 ;Output it
SETAV0: MOVEI T2,101(T3) ;Get 2nd letter
IDPB T2,T1 ;Output it
SETAV1: HRRZ T2,ALUVER ;Get edit level
JUMPE T2,SETAV2 ;Don't output if zero
MOVEI T3,"("
IDPB T3,T1
MOVEI T3,^D8 ;Octal edit number
NOUT%
ERCAL IMPERR
MOVEI T3,")"
IDPB T3,T1
SETAV2: LDB T2,[POINT 3,ALUVER,2] ;Get "who" field
JUMPE T2,SETAV3 ;Don't output if zero
MOVEI T3,"-"
IDPB T3,T1 ;Mark it
MOVEI T3,^D8
NOUT%
ERCAL IMPERR
SETZ T2, ;End with null
SETAV3: IDPB T2,T1 ;Output null to end
RET ;Done, return
SUBTTL SETUP FILCOM STRING
;SETUP STRING TO SEND TO FILCOM
;CALLED AT END OF REPLACE COMMAND, WHILE ALL JFNS ARE STILL ASSIGNED.
; THE MAC FILE IS OJFN
; THE MAB FILE IS MABJFN
; THE LIBRARY NUMBER IS IN LIBNUM
; THE UID NUMBER IS IN NEWUID
;THE FILCOM STRING IS:
; ALU:UID=LIB:MABNAM,LIB:MACNAM
FCSTR: MOVE T1,[POINT 7,FCTXT]
MOVE T2,[POINT 7,[ASCIZ/ALU:/]] ;Only choice
CALL CPYNUL ;COPY to NUL
MOVE T2,NEWUID ;GET UID NUMBER
MOVEI T3,^D10
NOUT%
ERCAL IMPERR
MOVEI T2,"="
IDPB T2,T1
CALL TACKLB ;LIB:
MOVE T2,MABJFN ;JFN IN T2
MOVX T3,1B8+1B11+JS%PAF
JFNS%
ERCAL IMPERR
MOVEI T2,","
IDPB T2,T1
CALL TACKLB ;LIB:
MOVE T2,OJFN
MOVX T3,1B8+1B11+JS%PAF
JFNS%
ERCAL IMPERR
MOVEI T2,0
IDPB T2,T1
RET ;RETURN
TACKLB: MOVE T2,LIBNUM ;GET LIBRARY NUMBER
HRRZ T2,LB1LST(T2)
HRLI T2,(POINT 7,)
DO.
ILDB T3,T2
JUMPE T3,ENDLP.
IDPB T3,T1
LOOP.
ENDDO.
RET
SUBTTL MISC ROUTINES
;COPY STRING TO NULL
; T1/ DESTINATION PTR
; T2/ SOURCE PTR
CPYNUL: ILDB T3,T2 ;GET SOURCE BYTE
IDPB T3,T1 ;STORE IN DEST
JUMPN T3,CPYNUL
DBP. T1 ;BACKUP DEST OVER NUL
RET
;SAVE AS ABOVE BUT SOURCE IN T3, DEST IN P1
CPT3P1: ILDB T2,T3
IDPB T2,P1
JUMPN T2,CPT3P1
DBP. P1 ;BACKUP DEST OVER NUL
RET
;AND AGAIN, BUT SOURCE IN T2, DEST IN T3
CPT2T3: ILDB T1,T2
IDPB T1,T3
JUMPN T1,CPT2T3
DBP. T3 ;BACKUP DEST OVER NUL
RET
;Routine to set generation-retention-count of a file.
;Call:
; T1/ JFN of output file (another JFN will be RENAMEd to this).
; CALL SETGRC
; <here if error, warning message typed>
; <here if done>
;This must be done prior to a RENAME.
;
; If the routine returns .+1, the program should COPY the file
;instead of RENAME'ing it.
SETGRC: MOVEM T1,GRCJFN ;Save this a sec..
MOVE T2,T1 ;Get JFN in T2
MOVX T1,RC%EMO ;No recognition
RCDIR% ;Get 36-bit directory number
ERJMP STGRE1 ;?Failed
MOVE T1,T3 ;Get directory number
MOVEI T2,CD.LEN ;get length of CRDIR block
MOVEM T2,GRCDBL+.CDLEN ;Store in length word of block
MOVEI T2,GRCDBL ;Point to directory block
GTDIR% ;Get directory parameters
ERJMP STGRE2 ;?failed
MOVE T4,GRCDBL+.CDRET ;Get generation-retention-count
HRRZ T1,GRCJFN ;RH= JFN
HRLI T1,.FBBYV
DPB T4,[POINTR T3,FB%RET] ;Put retention-count we want in there
MOVX T2,FB%RET ;Only change these bits
CHFDB% ;** Change FDB of the output file **
ERJMP STGRE3 ;?can't
JRST RSKP ;OK, return success
;** ERRORS in SETGRC routine **
;Can't get directory number from the JFN
STGRE1: TYPE CNTSRC ;Give warning
CALL TCGFIL
TMSG <RCDIR failed: >
JRST STGREE
;Can't get directory parameters from the dir #
STGRE2: TYPE CNTSRC
CALL TCGFIL
TMSG <GTDIR failed: >
JRST STGREE
;Can't set generation-retention-count in the FDB
STGRE3: TYPE CNTSRC
CALL TCGFIL
TMSG <CHFDB failed: >
; JRST STGREE
STGREE: CALL LSTFER
TMSG <
; file will be copied instead of RENAME'd
>
RET ;Return .+1 to copy
CNTSRC: TEXT <%Can't set generation-retention-count for >
;Routine to type file name of GRCJFN
TCGFIL: MOVEI T1,.PRIOU
MOVE T2,GRCJFN
SETZ T3,
JFNS%
TMSG <
% >
RET
SUBTTL REDIT ROUTINES
;Routine to call REDIT
;Called when file is about to get REPLACED with COPY or RENAME.
;Input:
; IJFN/ new source file
; GTFJFN/ file to replace (on the library)
; NEWUID/ UID number to use
;Call:
; CALL CALRDT
; <return here always>
CALRDT: CALL IREDIT ;Initialize REDIT
JRST CALRD1 ;?Failed, type warning
CALL SREDIT ;Setup REDIT string
CALLRET DREDIT ;Do REDIT and return when done
;Error initializing REDIT
CALRD1: TMSG <% REDIT not called
> ;Clarify the situation
RET ;Return
;Routine to initialize REDIT in a lower fork.
;Call:
; CALL IREDIT
; <here if error, message typed>
; <here if ok>
IREDIT: SKIPE RDTFRK ;Do we have a fork handle already?
JRST IRDT1 ;Yes
;Create a fork for REDIT
MOVX T1,CR%CAP ;Create fork
CFORK%
ERJMP CFFAI ;?Failed
MOVEM T1,RDTFRK ;Save it's fork handle
IRDT1: SKIPE RDTINC ;Is REDIT in core already?
JRST RSKP ;Yes, initialization done
;Do GTJFN and GET to read it into core
MOVX T1,GJ%OLD
HRROI T2,[ASCIZ/SYS:REDIT.EXE/]
GTJFN%
ERJMP RDTJFL ;GTJFN failed
HRRZ T1,T1 ;RH= JFN
PUSH P,T1 ;Save JFN
HRL T1,RDTFRK ;LH= fork handle
GET% ;Read in a copy of REDIT
ERJMP RDTGFL ;?GET failed
SETOM RDTINC ;Got it, set flag
POP P,(P) ;Throw away JFN info, don't need it.
JRST RSKP ;And return success
;CREATE-A-FORK failed.
CFFAI: TMSG <?CFORK failed: >
CALLRET LSTFRC ;Type why and give single return
;GTJFN failed for SYS:REDIT.EXE
RDTJFL: TMSG <?Can't GTJFN SYS:REDIT.EXE: >
CALLRET LSTFRC ;Type why and give single return
;GET failed
RDTGFL: TMSG <?Can't GET SYS:REDIT.EXE: >
CALL LSTFRC ;Type why and CRLF
POP P,T1 ;Release JFN
RLJFN%
ERJMP .+1 ;Error, don't worry.
RET ;Return .+1
;Routine to setup REDIT string
;Called when file is about to get REPLACED with COPY or RENAME.
;Input:
; IJFN/ new source file
; GTFJFN/ file to replace (on the library)
; NEWUID/ UID number to use
;Call:
; CALL SREDIT
; <return here always>
;Output:
; RDTTXT/ ASCIZ string to be sent to REDIT
; ADVTXT/ ASCIZ string to advise user what is happening
SREDIT: STKVAR <RPTR>
MOVE T1,[POINT 7,ADVTXT] ;INIT ADVISORY TEXT
MOVEM T1,ADVPTR
MOVE T1,[POINT 7,RDTTXT] ;Point to text area
MOVE T2,[POINT 7,[ASCIZ/REDIT COMPARE (NEW SOURCE FILE) /]]
CALL CPYNUL
MOVEM T1,RPTR ;SAVE START OF FILESPEC
MOVE T2,IJFN ;New source file
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF ;DEV:<DIRECTORY>FILE.EXT
JFNS%
MOVE T2,RPTR
HRROI T3,[ASCIZ /[Compare: /]
CALL APPAVT ;BUILD ADVISORY TEXT
MOVE T2,[POINT 7,[ASCIZ/ (WITH FILE) /]]
CALL CPYNUL
MOVEM T1,RPTR
MOVE T2,GTFJFN ;File to replace
MOVX T3,1B2+1B5+1B8+1B11+1B14+JS%PAF
JFNS%
MOVE T2,RPTR
HRROI T3,[ASCIZ /
With: /]
CALL APPAVT
MOVE T2,[POINT 7,[ASCIZ/ (CHANGES TO) /]]
CALL CPYNUL
MOVEM T1,RPTR
MOVE T2,LIBNUM
HRRZ T2,LB2LST(T2) ;Get directory to make the .DIF file in
HRLI T2,(POINT 7,)
CALL CPYNUL
MOVE T2,GTFJFN
MOVX T3,1B8 ;Replaced file name only
JFNS%
MOVEI T2,"-" ;DASH
IDPB T2,T1
MOVE T2,NEWUID ;Put UID in filename string
MOVX T3,^D10 ;Decimal
NOUT%
ERJMPS .+1 ;No error should happen
MOVE T2,[POINT 7,[ASCIZ/.RED/]]
CALL CPYNUL
MOVE T2,RPTR
HRROI T3,[ASCIZ /
Changes to: /]
CALL APPAVT
MOVE T2,[POINT 7,[ASCIZ/
/]]
CALL CPYNUL
MOVE T2,T1 ;NO ADDITIONAL TEXT THIS TIME
HRROI T3,[ASCIZ /]
/]
CALL APPAVT ;FINISH UP ADVISORY STRING
SETZ T2, ;Null
IDPB T2,T1
RET ;Done, return
;APPAVT - APPEND TO ADVISORY TEXT
; T1/ END OF STRING #2
; T2/ BEGINNING OF STRING #2
; T3/ PTR TO ASCIZ STRING #1
APPAVT: SAVEAC <T1>
STKVAR <EPTR,BPTR>
MOVEM T2,BPTR ;SAVE SECOND STRING FOR NOW
MOVEM T1,EPTR ;SAVE END OF STRING
MOVE T1,ADVPTR ;PTR TO ADVISORY TEXT
MOVE T2,T3
HLRZ T3,T2
CAIN T3,-1 ;DEFAULT?
HRLI T2,(POINT 7,0) ;YES, FILL IN
CALL CPYNUL ;COPY IT
MOVE T2,BPTR ;NOW FOR SECOND STRING
DO.
CAMN T2,EPTR ;END OF FIRST STRING?
EXIT. ;YES
ILDB T3,T2 ;NO, GET NEXT CHAR FROM IT
IDPB T3,T1 ;APPEND TO ADVISORY TEXT
LOOP. ;DO THIS UNTIL PTRS MATCH
OD.
MOVEM T1,ADVPTR ;SAVE PTR HERE
SETZ T3,
IDPB T3,T1 ;ALWAYS APPEND A NULL
RET
;Routine to actually do the work of calling REDIT.
;Waits until REDIT is done, then returns.
;If errors happen, a warning message is typed.
;IREDIT must have successfully completed before this routine will work.
;Inputs:
; RDTTXT/ holds ASCIZ TEXT SENT TO REDIT
;Call:
; CALL DREDIT
; <return here always>
DREDIT: TYPE <[ASCIZ/[ALU: Calling REDIT]
/]>
; TYPE RDTTXT ;TYPE THE TEXT WE ARE SENDING
TYPE ADVTXT ;TYPE ADVISORY TEXT
;Set REDIT's RESCAN buffer.
MOVE T1,[POINT 7,RDTTXT] ;Get ptr to text string
RSCAN% ;Put in RESCAN buffer
ERJMP RSCFAI ;?Failed
;Start it up
MOVE T1,RDTFRK ;Get fork handle
MOVEI T2,0 ;Start at primary start address
SFRKV% ;Start it up
ERJMP SFRFAI ;?Failed
MOVE T1,RDTFRK ;Get fork handle
WFORK% ;Wait for completion
;Give warning if it didn't terminate successfully
MOVE T1,RDTFRK
RFSTS% ;Read fork status
HLRZ T2,T1 ;Get status
CAIN T2,.RFHLT ;Better be just "halt'ed"
RET ;Ok, return
;Fork status not good.
PUSH P,T1 ;Save status
TMSG <% Problem with REDIT-- FORK STATUS = >
POP P,T1
CALL TYPFSS ;Type it out symbolically
RET ;Return
;Couldn't put text in RESCAN buffer
RSCFAI: TMSG <?Error setting RESCAN buffer for REDIT: >
CALL LSTFRC
JRST RDTNTD
;Couldn't start up the fork
SFRFAI: TMSG <?Couldn't "START" REDIT: >
CALL LSTFRC
JRST RDTNTD
;Here to explain what happens if an error comes up, then
; return .+1
RDTNTD: TMSG <% REDIT not called
>
RET ;Return
SUBTTL GENERAL-PURPOSE ROUTINES
;Routine to type a fork status symbolically from T1.
;Call:
; T1/ results from RFSTS
; CALL TYPFSS
; <return here always>
;Types:
;NNNNNN,,NNNNNN<CRLF>(WHAT IT MEANS)<CRLF>
TYPFSS: PUSH P,T1 ;Save info
MOVEI T1,.PRIOU ;Output to TTY
HLRZ T2,(P) ;Get left half
MOVX T3,NO%LFL+NO%ZRO+6B17+^D8 ;000003
NOUT%
ERJMPS .+1
TMSG <,,>
MOVEI T1,.PRIOU
HRRZ T2,(P)
MOVX T3,NO%LFL+NO%ZRO+6B17+^D8
NOUT%
ERJMPS .+1
TYPE CRLF
;Now type what that means
TMSG <(>
POP P,T4 ;Get into T4
TXZN T4,RF%FRZ ;Frozen?
IFSKP.
TYPE [ASCIZ /Frozen, /]
ENDIF.
HLRZ T1,T4 ;Get status code
CAIN T1,.RFFPT ;Forced termination?
JRST STSFTR ;yes
CAILE T1,.MXSTS ;Too big?
SKIPA T1,[[ASCIZ/?? Unknown status ??/]]
MOVE T1,RFSTST(T1) ;Get address OF ASCIZ status
TYPE <(T1)> ;Type the ASCIZ
TMSG <)>
RET ;Return
;Forced termination
STSFTR: TMSG <Forced termination - >
HRRZ T1,T4 ;Why?
CAILE T1,.MXFTR
SKIPA T1,[[ASCIZ/?? Unknown software channel ??/]]
MOVE T1,FTRTBL(T1) ;Get address of ASCIZ
TYPE <(T1)>
TMSG <)>
RET ;Return
;STATUS values from RFSTS
RFSTST: [ASCIZ /Runnable/]
[ASCIZ /Dismissed for I-O/]
[ASCIZ /Halted, voluntary termination/]
[ASCIZ /Halted/] ;.RFFPT, just type the error
[ASCIZ /Dismissed waiting for another process to terminate/]
[ASCIZ /Dismissed for a specified amount of time/]
[ASCIZ /JSYS-UUO interrupt wait/] ;.RFTRP
[ASCIZ /ADBRK interrupt wait/] ;.RFABK
.MXSTS==.-RFSTST-1
;Values of software channels for forced termination
FTRTBL: [ASCIZ /Software channel 0/]
[ASCIZ /Software channel 1/]
[ASCIZ /Software channel 2/]
[ASCIZ /Software channel 3/]
[ASCIZ /Software channel 4/]
[ASCIZ /Software channel 5/]
[ASCIZ /Arithmetic overflow/]
[ASCIZ /Arithmetic floating point overflow/]
[ASCIZ /Software channel 8/]
[ASCIZ /Pushdown list overflow/]
[ASCIZ /End of file condition/]
[ASCIZ /Data error file condition/]
[ASCIZ /Disk full or quota exceeded/]
[ASCIZ /Software channel 13/]
[ASCIZ /Software channel 14/]
[ASCIZ /Illegal instruction/]
[ASCIZ /Illegal memory read/]
[ASCIZ /Illegal memory write/]
[ASCIZ /Software channel 18/]
[ASCIZ /Inferior process termination or forced freeze/]
[ASCIZ /System resources exhausted/]
[ASCIZ /Software channel 21/]
[ASCIZ /Reference to non-existant page/]
[ASCIZ /Software channel 23/]
[ASCIZ /Software channel 24/]
[ASCIZ /Software channel 25/]
[ASCIZ /Software channel 26/]
[ASCIZ /Software channel 27/]
[ASCIZ /Software channel 28/]
[ASCIZ /Software channel 29/]
[ASCIZ /Software channel 30/]
[ASCIZ /Software channel 31/]
[ASCIZ /Software channel 32/]
[ASCIZ /Software channel 33/]
[ASCIZ /Software channel 34/]
[ASCIZ /Software channel 35/]
.MXFTR==.-FTRTBL-1 ;Maximum index value
SUBTTL LOWER/UPPERCASE CONVERSION
;Used when individually parsed fields need to be converted
; to uppercase. COMND% JSYS only lets you do this with the
; whole line.
;Input:
; t1/ address of ASCIZ string
; CALL CNVUPP
; <return here always>
CNVUPP: HRLI T1,(POINT 7,) ;Make BP
CNVUP1: ILDB T2,T1 ;Get char
JUMPE T2,RTN ;Null ends string
CAIL T2,"A"+40
CAILE T2,"Z"+40
JRST CNVUP1 ;Not lowercase
SUBI T2,40 ;Convert this character to uppercase
DPB T2,T1 ;Store back
JRST CNVUP1 ;Loop until null seen
SUBTTL TABLES OF USERS, LIBRARIES, KNOWN EXTENSIONS
E.BIT==1B0 ;USER MAY DO ^E COMMANDS
DEFINE USR (A,B),<
%%BTS==0
IRPC B,<
%%BTS==%%BTS!B'.BIT
>
%%BTS+[ASCIZ \'A\]
>
USRLST: RUSERS
NMUSRS==.-USRLST
;LIBRARIES
DEFINE LIB (A,B,C),<
[ASCIZ /A/]
>
LIBLST: LIBS
NMLIBS==.-LIBLST
DEFINE LIB (A,B,C),<
[ASCIZ /B':/]
>
LB1LST: LIBS
DEFINE LIB (A,B,C),<
[ASCIZ /C/]
>
LB2LST: LIBS ;Place to put FILUPD.HST, .DIF, .SCM, UID.TXT
DEFINE EXTN(A,B,C,D,E),<
[ASCIZ /B/]
>
STEXTS: EXTS
NMEXTS==.-STEXTS
DEFINE EXTN(A,B,C,D,E),<
XWD D,[ASCIZ /A/]
>
EXTLST: EXTS
DEFINE EXTN(A,B,C,D,E),<
[ASCIZ /C/]
>
EXBLST: EXTS ;BACKUP EXTS
DEFINE EXTN(A,B,C,D,E),<
...X==0 ;# OUTPUT EXTS
IRP E,<
...X==...X+1 ;COUNT # OUTPUT EXTS
>
IFE ...X,<EXP 0> ;IF NO OUTPUT EXTS
IFN ...X,<
-<...X>,,[
IRP E,<
[ASCIZ /E/]
>;END IRP E
]
>;END IFN ...X
>;END DEFINE EXTN
EXOLST: EXTS ;GENERATED OUTPUT EXTS
SUBDIR: SUBDNS ;SUBDIRECTORY NAME STRING
;DEFINE DEFAULT LIBRARY IF GIVEN
DFLIBW:
IFNDEF DFLIB,<
EXP 0 ;NO DEFAULT LIBRARY
>
IFDEF DFLIB,<
POINT 7,[DFLIB]
>
SUBTTL STORAGE
;PRESET SECTION
CMDBLK: NEWPAR ;ADDRESS OF REPARSE ROUTINE
.PRIIN,,.PRIOU ;INPUT,,OUTPUT JFNS
-1,,[ASCIZ /ALU>/] ;CONTROL-R BUFFER
-1,,TXTBUF ;POINTER TO TEXT BUFFER
-1,,TXTBUF ;POINTER TO CURRENT POSITION
TXTLEN ;NUMBER OF CHARACTERS IN BUFFER
0 ;NUMBER OF UNPARSED CHARACTERS
-1,,ATMBUF ;POINTER TO ATOM BUFFER
TXTLEN ;NUMBER OF CHARACTERS IN BUFFER
EXP JFNBLK ;POINTER TO JFN BLOCK
;2ND COMMAND JSYS BLOCK (FOR PARSING RANDOM STRINGS)
CM2BLK: NEWPR2 ;ADDRESS OF 2ND REPARSE ROUTINE
.PRIIN,,.PRIOU ;INPUT,,OUTPUT JFNS
0 ;CONTROL-R BUFFER (FILLED IN)
-1,,TX2BUF ;POINTER TO TEXT BUFFER
-1,,TX2BUF ;POINTER TO CURRENT POSITION
TXTLEN ;NUMBER OF CHARACTERS IN BUFFER
0 ;NUMBER OF UNPARSED CHARACTERS
-1,,ATM2BF ;ATOM BUFFER
TXTLEN ;NUMBER OF CHARACTERS IN BUFFER
EXP JFNBLK ;POINTER TO JFN BLOCK
JFNBLK: GJ%OLD ;FLAGS,,GENERATION NUMBER
.PRIIN,,.PRIOU ;INPUT,,OUTPUT JFNS
BLOCK 20 ;NO DEFAULTS
;TEXTI BLOCK FOR READING LINES
TXTIBL: .RDRTY ;LAST WORD GIVEN
0 ;FLAGS
.PRIIN,,.PRIOU ;INPUT,,OUTPUT JFNS
0 ;DESTINATION PTR (FILLED IN)
0 ;BYTES AVAILABLE (FILLED IN)
0 ;USE START OF BUFFER AS ABOVE
0 ;CONTROL-R TEXT (FILLED IN)
;TEXTI BLOCK TO READ STRING INTO ATMBUF
TXTIB: .RDBRK ;LAST WORD GIVEN
0 ;FLAGS (FILLED IN)
.PRIIN,,.PRIOU ;INPUT,,OUTPUT JFNS
0 ;DESTINATION PTR (FILLED IN)
0 ;BYTES AVAILABLE (FILLED IN)
0 ;USE START OF ATMBUF AS ABOVE
0 ;NO CONTROL-R TEXT
BCHRS ;ADDRESS OF BREAK CHAR MASKS
;CHARACTER MASKS, TO MAKE ONLY CONTROL-Z A BREAK CHARACTER
BCHRS: 1B<.CHCNZ> ;CONTROL-Z ONLY
0
0
0
DLBIDX: BLOCK 1 ;Default library index
PAGMAP: BLOCK ^D512/^D36 + 1 ;BIT TABLE FOR PAGE MAP
PBFPNO: BLOCK 1 ;PAGE NUMBER OF PAGE BUFFER
AVERST: BLOCK ^D20 ;ASCIZ ALU version number
SAVEF: BLOCK 1 ;SAVED FLAGS
RSCANF: BLOCK 1 ;Number rescan chars to do
TEMPBP: BLOCK 1 ;Temp byte ptr.
;BEHAVIOR SWITCHES
SWFUID: BLOCK 1 ;1= PUT UID STRING IN REPLACED SOURCE FILE
SWCOPO: BLOCK 1 ;COPY GENERATED OUTPUT FILES
SWFCOM: BLOCK 1 ;RUN FILCOM AFTER REPLACING SOURCE FILE
SWRUID: BLOCK 1 ;REPLACE UID LINE
SWBAKF: BLOCK 1 ;MAKE BACKUP FILES
SWANYU: BLOCK 1 ;ALLOW ANY USER
SWGCPY: BLOCK 1 ;1= ASK USER IF HE WANTS A COPY OF
;FILE ANYWAY IF IT IS RESERVED AND HE DOES A "GET"
SWREDT: BLOCK 1 ;1= RUN REDIT BEFORE REPLACE
SWCGET: BLOCK 1 ;1= DEFAULT IS /COPY ON GET
SUBTTL ZEROED CORE
XLIST
LIT
LIST ;LITERALS
ZROST==. ;START OF AREA TO CLEAR ON STARTUP
MEPRIV: BLOCK 1 ;-1 IF I AM PRIVILEDGED TO DO ^E COMMANDS
PDL: BLOCK PDLSIZ
SAVEP: BLOCK 1 ;A GOOD STACK POINTER
TXTBUF: BLOCK TXTLEN/5+1 ;BUFFER FOR COMMAND JSYS
ATMBUF: BLOCK TXTLEN/5+1 ;BUFFER FOR ATOM BUFFER
TX2BUF: BLOCK TXTLEN/5+1 ;BUFFER FOR 2ND COMND JSYS
ATM2BF: BLOCK TXTLEN/5+1 ;2ND ATOM BUFFER
PR2STA: BLOCK 1 ;START ADDR OF 2ND PARSE CODE
CM2P: BLOCK 1 ;PDL AT START OF 2ND PARSE
TLINE: BLOCK TXTLEN/5+1 ;READ LINE BY "ITTLIN"
TILTXT: BLOCK TXTLEN/5+1 ;STORED ANSWER TO (TILL WHEN?) WITH ".."
PRSJFN: BLOCK 1 ;JFN OF SOMETHING WE PARSED
UIDJFN: BLOCK 1 ;JFN OF ALU:UID.TXT
UIDNAM: BLOCK FILWDS ;Whole Name of UID.TXT
SAVEPB: BLOCK 1 ;SAVED BP TO PAGMAP
NEWUID: BLOCK 1 ;VALUE RETURNED BY ALUUID
UID1: BLOCK 1 ;UID OF FILE ON MY AREA IN REPLACE
; (OR 0)
LOGJFN: BLOCK 1 ;JFN FOR FILUPD.HST
LOGNAM: BLOCK FILWDS ;Whole name of it
LOGBUF: BLOCK LOGLEN/5+1 ;BUFFER FOR OUTPUT TO LOG FILE
LIBHLD: BLOCK FILWDS ;FOR ASCIZ /<LIBARY>*.*/
RETJNM: BLOCK FILWDS ;PLACE FOR FILENAME
GTFJFN: BLOCK 1 ;JFN OF "GET" FILE
MAZJFN: BLOCK 1 ;JFN OF ".MAZ" FILE
MAZNAM: BLOCK FILWDS ;ASCII FILENAME FOR .MAZ FILE
MABJFN: BLOCK 1 ;;JFN OF ".MAB" FILE
MABJNM: BLOCK FILWDS ;ASCII NAME OF THE FILE
MAZBUF: BLOCK LINLEN/5+1 ;FIRST LINE OF MAZ FILE (S.B. THE ONLY LINE!)
.MAZLN==.-MAZBUF
RFBUF: BLOCK MAXLIN/5+1 ;FIRST LINE OF RESERVED FILE
.RFLN==.-RFBUF
LUIDTX==^D40 ;LENGTH OF UID TEXT
UIDTXT: BLOCK LUIDTX ;HOLDS BUILT UID TEXT
FSTLIN: BLOCK 1 ;ADDRESS OF 72 CHAR LINE TO CHANGE
WHYTXT: BLOCK WHYLEN/5+1 ;"WHY" TEXT
SAVNSP: BLOCK 1 ;SAVED NAM: STRING PTR
HNBUF: BLOCK ^D20 ;PLACE TO HOLD NAM: STRING
CD: BLOCK ^D20 ;MY CURRENT CONNECTED DIRECTORY <DIR>
RDIR: BLOCK ^D20 ;RESERVED DIRECTORY <DIR> FROM MAZ FILE
IJFN: BLOCK 1 ;INPUT JFN FOR COPIES
OJFN: BLOCK 1 ;OUTPUT JFN FOR COPIES
STIPGS: BLOCK 1 ;START OF PAGE BLOCK FOR IFILE
STOPGS: BLOCK 1 ;START OF PAGE BLOCK FOR OFILE
STIPG2: BLOCK 1 ;ADDRESS OF START OF IFILE BLOCK
STOPG2: BLOCK 1 ;ADDRESS OF START OF OFILE BLOCK
ENDPTR: BLOCK 1 ;ADDR OF LAST WORD OF DEST BUFFER
NXTBEG: BLOCK 1 ;PAGES WE HAVE "PRELOADED" IN FROM IJFN
BLTPTR: BLOCK 1 ;FOR MEM/MEM BLT
SAVBLT: BLOCK 1 ; SAVED BLT PTR
BCINP: BLOCK 1 ;BYTE COUNT FOR INPUT FILE
BSINP: BLOCK 1 ;BYTE SIZE FOR INPUT FILE
USRBIT: BLOCK 1 ;FLAGS FOR THIS USER
USRNAM: BLOCK 10 ;USER NAME STRING
LIBNUM: BLOCK 1 ;INTERNAL LIBRARY NUMBER
EXTNUM: BLOCK 1 ;INTERNAL EXTENSION NUMBER
HPTXTP: BLOCK 1 ;Holds help text when parsing a library
IFINAM: BLOCK TXTLEN/5+1 ;<DIR>NAME.EXT STRING FOR IJFN
RFTAD1: BLOCK 2 ;DATE/TIME INFO FOR SOURCE FILE
RFTADS: BLOCK 2 ;The main source file's RFTAD1 when copying
; generated output files.
FROMFL: BLOCK FILWDS ;COMPLETE JFNS TEXT FOR "FROM" FILE
HLDTIM: BLOCK ^D10
HLDTM1: BLOCK ^D10 ;ASCII TIME
FCTXT: BLOCK ^D20 ;FILCOM TEXT
RDTTXT: BLOCK <FILWDS*3>+^D10 ;REDIT text (usually a lot!)
ADVPTR: BLOCK 1 ;WORKING PTR TO ADVTXT
ADVTXT: BLOCK <FILWDS*3>+^D10 ;REDIT ADVISORY TEXT
MYTTY: BLOCK 1 ;MY TERMINAL NUMBER
RDTFRK: BLOCK 1 ;FORK for REDIT
RDTINC: BLOCK 1 ;-1 IF REDIT IN CORE ALREADY
CKOFLP: BLOCK 1 ;AOBJN ptr for CHKOF routine
TLCOLM: BLOCK 1 ;Actual column number on output
ILBCD: BLOCK 1 ;Column # of "DIRECTORY" header
ILBCL: BLOCK 1 ;Column # of "LOG" header
GRCJFN: BLOCK 1 ;JFN used by "SETGRC" routine
GRCDBL: BLOCK CD.LEN ;Directory block used by "SETGRC"
;CHANGE MODE SWITCHES
CNFCOM: BLOCK 1 ;FILCOM
CNCOPO: BLOCK 1 ;COPY OUTPUT FILES
CNFUID: BLOCK 1 ;UID IN SOURCE FILE
CNRUID: BLOCK 1 ;REPLACE UID
CNBAKF: BLOCK 1 ;MAKE BACKUP FILES
CNANYU: BLOCK 1 ;ANY USER ALLOWED TO USE ALU
CNGCPY: BLOCK 1 ;ASK USER IF HE WANTS A COPY ANYWAY
;WHEN FILE IS RESERVED
CNREDT: BLOCK 1 ;RUN REDIT BEFORE REPLACE DONE
CNCGET: BLOCK 1 ;/COPY IS DEFAULT ON "GET"
ZROEND==.-1 ;END OF AREA TO CLEAR ON STARTUP
LASTLC==.-1 ;LAST NON-FREE LOC
END 3,,AENTRY