5 REM :---------->> MINIRBBS V2.5 3/26/81 <<-------------: 10 REM : MINIRBBS : 15 REM : Message Module of RBBS version 2.2 : 20 REM : from Howard Moulton's original SJBBS (in Xitan : 25 REM : Basic), converted to MBASIC and called RBBS or : 30 REM : RIBBS by Bruce Ratoff, and extensively revised/ : 35 REM : expanded by Ron Fowler to become RBBS22. : 40 REM :---------------------------------------------------: 45 REM : The Fowler version, RBBS22, was split into 2 mod- : 50 REM : ules, ENTERBBS and MINIRBBS, by Ben Bronson. : 55 REM :---------------------------------------------------: 60 REM : Both were revised and given RBBS-compatible ver- : 65 REM : sion nos. in 3/81 by Tim Nicholas, to incorporate : 70 REM : updates from his version 2.4 of RBBS : 75 REM :---------------------------------------------------: 80 REM : Bill Earnest's bell-at-line-end routine was added : 85 REM : from RBBS 2.5 (see lines 26000+), and the 'G' : 90 REM : command changed to be compatible with MINICBBS-- : 95 REM : Now both 'G' & 'C' return the caller to CP/M : 100 REM : and don't sign him off. The RBBS22/24 line : 105 REM : numbering has been preserved to facilitate adding : 110 REM : further changes --Ben Bronson, 3/26 : 115 REM :---------------------------------------------------: 280 REM 290 REM 300 DEFINT A-Z 330 VERS$="(MINIRBBS vers 2.5)"' VERSION NUMBER 340 DIM A$(17),M(200,2) 350 POKE 0,&HCD 360 INC=1: ERS$=CHR$(8)+" "+CHR$(8) 370 ON ERROR GOTO 13620 380 REM ** SIGNON FUNCTIONS 390 REM 400 MSGS=1:CALLS=MSGS+1:MNUM=CALLS+1 420 BK=0:GOSUB 13020:N=1:A$="Hyde Park Chicago Remote CP/M Message Subsystem......":N=0:GOSUB 13020 460 BEL=-1:XPR=0'INITIAL BEL ON, NOT EXPERT 470 A$=VERS$:GOSUB 13020 480 SAV$="" 500 INC=0 510 OPEN "I",1,"A:LASTCALR":INPUT #1,N$,O$:CLOSE 740 BK=0:GOSUB 13020:A$="Active # of msg's: ":N=1:GOSUB 13020 745 OPEN "R",1,"A:COUNTERS",5:FIELD#1,5 AS RR$:GET#1,MSGS:M=VAL(RR$) 750 A$=STR$(M):GOSUB 13020 760 A$="You are caller # : ":N=1:GOSUB 13020:GET#1,CALLS 770 CN=VAL(RR$)+INC:A$=STR$(CN):LSET RR$=A$:GOSUB 13020:PUT#1,CALLS 780 A$="Next msg # will be:":N=1:GOSUB 13020:GET#1,MNUM:U=VAL(RR$) 790 A$=STR$(U+1):GOSUB 13020:CLOSE:GOSUB 13020 800 REM 810 REM LOOK FOR MSGS FOR THIS CALLER 820 REM AND BUILD MESSAGE INDEX 830 REM 840 FT=1:MX=0:MZ=0:IU=0:'FLAG FIRST TIME FOR PRINTING HEADING 850 OPEN "R",1,"A:SUMMARY",30:RE=1:FIELD#1,28 AS RR$ 860 BK=0:GET#1,RE:IF EOF(1) THEN 960 870 G=VAL(RR$):MZ=MZ+1:M(MZ,1)=G:IF G=0 THEN 950 880 IF IU=0 THEN IU=G 890 IF G>9998 THEN MZ=MZ-1:GOTO 960 900 GET#1,RE+3:GOSUB 16500:IF INSTR(S$,N$)>0 AND INSTR(S$,O$)>0 THEN 930 910 IF N$<>"SYSOP" THEN 950 920 IF INSTR(S$,"BEN")=0 THEN 950 930 IF FT THEN A$="Please retrieve and kill the following message(s) left for you:":GOSUB 13020:FT=0 940 A$=STR$(G):N=1:GOSUB 13020 950 GET#1,RE+5:M(MZ,2)=VAL(RR$):MX=MX+M(MZ,2)+6:RE=RE+6:GOTO 860 960 CLOSE:GOSUB 13020:GOSUB 13020 999 REM --- G & C commands changed so that both drop to CP/M --- 1000 REM 1020 REM *** MAIN COMMAND ACCEPTOR/DISPATCHER *** 1040 REM 1060 A1$="Function":IF NOT XPR THEN A1$=A1$+" (E,R,S,K,C,G,P,X,Q (or '?' if not known)" 1080 A1$=A1$+"?":GOSUB 13020:C=1:GOSUB 13260:C=0 1100 IF B$="" THEN 1000 1120 FF=INSTR("ER?SKCGPXQL",B$):GOSUB 1140:GOTO 1000 1140 IF FF=0 THEN 1180 1160 ON FF GOTO 6000,8000,5000,18060,11000,10000,2000, 17040,17000,18080,19000 1180 IF N$+O$="SYSOP" THEN IF B$="%" THEN GOSUB 19000:GOTO 1000 1200 A$="I don't understand '"+B$+"', "+N$+".":GOSUB 13020:GOSUB 13020: SAV$="":RETURN 2000 REM 2020 REM ***EXIT TO CP/M*** 2240 GOSUB 13020:POKE 4,0:A$="Entering CP/M...":GOSUB 13020:POKE 0,&HC3:SYSTEM 3000 REM 5000 REM 5020 REM *** DISPLAY MENU OF FUNCTIONS *** 5040 REM 5060 GOSUB 13020:A$="Functions supported:":GOSUB 13020:IF BK THEN RETURN 5080 A$="S--> Scan messages R--> Retrieve message":GOSUB 13020: IF BK THEN RETURN 5100 A$="E--> Enter message K--> Kill message":GOSUB 13020:IF BK THEN RETURN 5160 A$="P--> Prompt (bel) togl X--> eXpert user mode":GOSUB 13020:IF BK THEN RETURN 5180 A$="Q--> Quick summary C--> Comment before exit to CP/M":GOSUB 13020:IF BK THEN RETURN 5190 A$="G--> Goodbye--direct exit to C/PM": 5195 GOSUB 13020:IF BK THEN RETURN 5200 GOSUB 13020:A$="Commands may be strung together, separated by semicolons.":GOSUB 13020: 5205 A$="For example, 'R;123' retrieves message # 123.":GOSUB 13020:IF BK THEN RETURN 5210 A$="For forward sequential retrieval, use '+' after Msg #.":GOSUB 13020:GOSUB 13020 5280 GOSUB 13020:RETURN 6000 REM 6020 REM ***ENTER A NEW MESSAGE*** 6040 REM 6060 F=0:GOSUB 13020:OPEN "R",1,"A:COUNTERS",5:A$="Msg # will be: ":N=1:GOSUB 13020:FIELD#1,5 AS RR$:GET#1,MNUM:V=VAL(RR$) 6080 A$=STR$(V+1):GOSUB 13020:CLOSE 6100 GOSUB 13020:A1$="Todays date (MM/DD/YY)?":GOSUB 13020:GOSUB 13260:D$=B$ 6120 A1$="Who to (C/R for ALL)?":GOSUB 13020:C=1:GOSUB 13260:C=0:IF B$="" THEN T$="ALL" ELSE T$=B$ 6130 REM --- RBBS25 routine substituted here --- 6140 A1$="Subject (26 chars. max.):":GOSUB 13020:C=1:GOSUB 13260:C=0:K$=B$ 6150 IF LEN(K$)>30 THEN GOTO 6140 6160 A1$="Password?":GOSUB 13020:C=1:GOSUB 13260:C=0:PW$=B$:GOSUB 13020 6170 A1$="Type in up to 16 lines. A bell sounds at the end of each.": GOSUB 13020 6180 A1$="To edit or end, hit 2 C/Rs. Don't use semicolons.":GOSUB 13020:GOSUB 13020:F=0 6190 IF F=16 THEN A$="Msg full.":GOSUB 13020:GOTO 6240 6200 F=F+1:A1$=STR$(F)+" ":N=1:GOSUB 13020:GOSUB 13260:IF B$="" THEN F=F-1:GOTO 6240 6205 IF F=13 THEN PRINT "(3 lines left. . . .)" 6215 IF F=15 THEN PRINT "(Last line. . . .)" 6220 A$(F)=B$+" ":GOTO 6190 6240 GOSUB 13020:A1$="Choose: (L)ist, (E)dit, (Q)uit, (C)ontinue, or (S)ave -- ":IF XPR THEN A1$="L,E,Q,C,S: ?" 6260 GOSUB 13020:C=1:GOSUB 13260:C=0 6280 IF B$<>"L" THEN 6360 ELSE GOSUB 12220 6300 GOSUB 13020:FOR L=1 TO F:A$=STR$(L)+" "+A$(L) 6320 IF BK THEN 6240 ELSE GOSUB 13020:NEXT L 6340 GOSUB 13020:GOTO 6240 6360 IF B$="Q" THEN A$="Aborted":GOSUB 13020:RETURN 6380 IF B$="C" THEN 6180 6400 IF B$="E" THEN 6460 6420 IF B$="S" THEN 6560 6440 GOTO 6240 6460 GOSUB 13020:A1$="Line #?":GOSUB 13020:GOSUB 13260:L=VAL(B$) 6480 IF L=0 OR L>F THEN 6240 ELSE A$="Was:":GOSUB 13020:A$=A$(L):GOSUB 13020 6500 A1$="Enter new line":IF NOT XPR THEN A1$=A1$+" (C/R for no change)" 6520 A1$=A1$+":":GOSUB 13020:GOSUB 13260 6540 IF B$="" THEN 6240 ELSE A$(L)=B$+" ":GOTO 6240 6560 REM 6580 IF PW$<>"" THEN PW$=";"+PW$ 6600 A$="Updating summary file, ":N=1:GOSUB 13020 6620 OPEN "R",1,"A:SUMMARY",30:RE=1:FIELD#1,30 AS RR$:RL=30 6640 RE=MZ*6+1:S$=STR$(V+1)+PW$:GOSUB 16000:PUT#1,RE 6660 RE=RE+1:S$=D$:GOSUB 16000:PUT#1,RE 6680 RE=RE+1:S$=N$+" "+O$:GOSUB 16000:PUT#1,RE 6700 RE=RE+1:S$=T$:GOSUB 16000:PUT#1,RE 6720 RE=RE+1:S$=K$:GOSUB 16000:PUT#1,RE 6740 RE=RE+1:S$=STR$(F):GOSUB 16000:PUT#1,RE 6760 RE=RE+1:S$=" 9999":GOSUB 16000:PUT#1,RE 6780 CLOSE#1 6800 A$="next msg #, ":N=1:GOSUB 13020:OPEN "R",1,"A:COUNTERS",5:FIELD#1,5 AS RR$ 6820 GET#1,MNUM:LSET RR$=STR$(VAL(RR$)+1):PUT#1,MNUM 6840 A$="active msg's, ":N=1:GOSUB 13020 6860 GET#1,MSGS:LSET RR$=STR$(VAL(RR$)+1):PUT#1,MSGS:CLOSE#1 6880 A$="and msg file.":N=1:GOSUB 13020:OPEN "R",1,"A:MESSAGES",65:RL=65 6900 FIELD#1,65 AS RR$ 6920 RE=MX+1 6940 S$=STR$(V+1)+PW$:GOSUB 16000:PUT#1,RE 6960 RE=RE+1:S$=D$:GOSUB 16000:PUT#1,RE 6980 RE=RE+1:S$=N$+" "+O$:GOSUB 16000:PUT#1,RE 7000 RE=RE+1:S$=T$:GOSUB 16000:PUT#1,RE 7020 RE=RE+1:S$=K$:GOSUB 16000:PUT#1,RE 7040 RE=RE+1:S$=STR$(F):GOSUB 16000:PUT#1,RE 7060 RE=RE+1 7080 FOR P=1 TO F:S$=A$(P):GOSUB 16000:PUT#1,RE:RE=RE+1:NEXT P 7090 S$=" 9999":GOSUB 16000:PUT#1,RE:CLOSE#1:MX=MX+F+6:MZ=MZ+1:M(MZ,1)=V+1:M(MZ,2)=F 7100 GOSUB 13020:GOSUB 13020:U=U+1:RETURN 8000 REM 8020 REM ***RETRIEVE MESSAGE*** 8040 REM 8060 GOSUB 13020:A1$="MSG # ("+STR$(IU)+" -"+STR$(U)+" )":IF NOT XPR THEN A1$=A1$+" to retrieve (C/R to end)" 8080 A1$=A1$+"?":GOSUB 13020:GOSUB 13260:GOSUB 13020 8100 IF LEN(B$)=0 THEN M=0 ELSE M=VAL(B$) 8120 IF M<1 THEN GOSUB 13020:RETURN 8140 IF M>U THEN A$="There aren't that many msg's, "+N$+".":GOSUB 13020:SAV$="":GOTO 8060 8160 GOSUB 12220:GOSUB 13020 8180 OPEN "R",1,"A:MESSAGES",65:RE=1:FIELD#1,64 AS RR$:MI=0 8200 MI=MI+1:IF (MI>MZ) OR BK THEN 8540 ELSE G=M(MI,1) 8220 IF GM THEN 8480 8260 GOSUB 19100:IF OK THEN 8280 ELSE RE=RE+M(MI,2):GOTO 8200 8280 RE=RE+1:GET#1,RE:GOSUB 16500:D$=S$ 8300 RE=RE+1:GET#1,RE:GOSUB 16500:NO$=S$ 8320 RE=RE+1:GET#1,RE:GOSUB 16500:T$=S$ 8340 RE=RE+1:GET#1,RE:GOSUB 16500:GOSUB 19200:K$=S$ 8360 RE=RE+1:GET#1,RE:J=VAL(RR$):GOSUB 13020 8380 A$="Msg # "+STR$(G)+" Date entered: "+D$+" From: "+NO$:GOSUB 13020 8400 A$="To: "+T$:GOSUB 13020 8410 A$="About: "+K$:GOSUB 13020:GOSUB 13020 8420 RE=RE+1:FOR P=1 TO J:GET#1,RE:GOSUB 16500:A$=S$:GOSUB 13020 8440 IF BK THEN 8540 8460 RE=RE+1:NEXT P:GOSUB 13020 8480 IF RIGHT$(B$,1)<>"+" THEN CLOSE:GOTO 8020 8500 M=M+1:MI=0:RE=1 8520 IF M<=U AND NOT BK THEN 8200 8540 CLOSE:A$="End of msg's.":GOSUB 13020:GOSUB 13020:D$="":NO$="":RETURN 9000 REM 9020 REM ***SUMMARIZE MESSAGES*** 9040 REM COMMON CODE FOR S AND Q CMDS 9060 REM 9080 GOSUB 13020 9090 A1$="Msg # ("+STR$(IU)+" -"+STR$(U)+" ) to start (C/R to end)?" 9095 GOSUB 13020:C=1:GOSUB 13260:C=0:GOSUB 13020 9100 IF LEN(B$)=0 THEN M=0 ELSE M=VAL(B$):GOSUB 13220 9120 IP=INSTR(B$,","):IF IP>0 THEN B$=MID$(B$,IP+1) ELSE ST=0:GOTO 9220 9140 IF LEN(B$)<3 THEN RETURN 9160 IF MID$(B$,2,1)<>"=" THEN RETURN 9180 SV$=MID$(B$,3):B$=LEFT$(B$,1):ST=INSTR("FTS",B$) 9200 IF ST=0 THEN RETURN 9220 IF M<1 THEN RETURN 9240 IF M>U THEN A$="There ain't that many msg's, "+N$+".":GOSUB 13020:SAV$="":RETURN 9260 IF NOT QU THEN GOSUB 12220:GOSUB 13020 9280 OPEN "R",1,"A:SUMMARY",30:RE=1:FIELD #1,28 AS RR$ 9300 GET #1,RE 9320 IF EOF(1) OR BK THEN 9660 ELSE G=VAL(RR$) 9340 IF G>9998 THEN 9660 9360 IF G"Y" THEN 10060 10100 OPEN "R",1,"A:COMMENTS",65:FIELD#1,65 AS RR$:GET#1,1:RE=VAL(RR$)+1:RL=65 10120 IF RE=1 THEN RE=2 10140 S$="From: "+N$+" "+O$:GOSUB 16000 10160 PUT#1,RE 10180 A$="Enter comments, C/R to end: (16 lines max)":GOSUB 13020 10200 A$="Ok>":N=1:GOSUB 13020:GOSUB 13260 10220 IF B$="" THEN 10240 ELSE RE=RE+1:S$=B$:RL=65:GOSUB 16000:PUT#1,RE:GOTO 10200 10240 S$=STR$(RE):RL=65:GOSUB 16000:PUT#1,1:CLOSE 10260 GOSUB 13020:A$="Character count: "+STR$(A)+" typed by system - "+STR$(D)+ " typed by you.":GOSUB 13020 10270 A$="If you left one, thanks for the comment, "+N$+".":GOSUB 13020 10280 GOSUB 13020:GOSUB 13020:A$="Now back to CP/M...":GOSUB 13020:GOTO 2020 10285 REM ------------------------------------------------- 10290 REM To disconnect - reset modem DTR line. ROUTINE REMOVED--BB 11000 REM 11020 REM ***KILL A MESSAGE*** 11040 REM 11060 GOSUB 13020:A1$="Message # to kill?":GOSUB 13020:GOSUB 13260 11080 IF LEN(B$)=0 THEN M=0 ELSE M=VAL(B$) 11100 IF M<1 THEN GOSUB 13020:RETURN 11120 IF M>U THEN A$="There aren't that many msg's, "+N$+".":GOSUB 13020:SAV$="":GOTO 11040 11140 A$="Scanning summary file....":GOSUB 13020:OPEN "R",1,"A:SUMMARY",30:RE=1:FIELD#1,30 AS RR$:RL=30 11160 GET#1,RE 11180 IF EOF(1) THEN 11520 ELSE G=VAL(RR$) 11200 IF G>9998 THEN 11520 11220 IF GM THEN 11520 11260 GOSUB 19100:IF NOT OK THEN 11520 11280 GOSUB 16500:PW=INSTR(S$,";"):PW$="" 11300 IF PW=0 OR N$+O$="SYSOP" OR PERS THEN PERS=0:GOTO 11340 11320 PW$=MID$(S$,PW+1) 11330 A1$="Password ?":GOSUB 13020:C=1:GOSUB 13260:C=0:IF B$<>PW$ THEN A$="Incorrect.":GOSUB 13020:GOSUB 13020:CLOSE:RETURN 11340 S$=" 0"+":"+STR$(G):GOSUB 16000:PUT#1,RE:CLOSE 11360 A$="Updating message file....":GOSUB 13020 11380 OPEN "R",1,"A:MESSAGES",65:RE=1:FIELD#1,65 AS RR$:MI=0 11400 MI=MI+1:IF MI>MZ THEN 11520 ELSE G=M(MI,1) 11420 IF G"" AND A1$<>"" THEN A1$="":RETURN 13100 IF A1$<>"" THEN A$=A1$:A1$="" 13120 IF RIGHT$(A$,1)="?" OR N=1 THEN PRINT A$;:PP$=A$:GOTO 13180 13140 BI=ASC(INKEY$+" "):IF BI=19 THEN BI=ASC(INPUT$(1)) 13160 IF BI=11 THEN BK=-1:GOTO 13220 ELSE PRINT A$ 13180 A=A+LEN(A$) 13220 A$="":N=0 13240 RETURN 13260 REM 13280 REM ***ACCEPT STRING INTO B$ FROM CONSOLE*** 13300 REM 13320 IF BEL AND SAV$="" THEN PRINT CHR$(7); 13340 B$="":BK=0 13360 IF SAV$="" THEN GOSUB 26000 13380 SP=INSTR(SAV$,";"):IF SP=0 THEN B$=SAV$:SAV$="":GOTO 13420 13400 B$=LEFT$(SAV$,SP-1):SAV$=MID$(SAV$,SP+1) 13420 IF LEN(B$)=0 THEN RETURN 13440 IF C=0 THEN 13480 13460 FOR ZZ=1 TO LEN(B$):MID$(B$,ZZ,1)=CHR$(ASC(MID$(B$,ZZ,1))+32*(ASC(MID$(B$,ZZ,1))>96)):NEXT ZZ 13480 IF LEN(B$)<63 THEN 13580 13500 A$="Input line too long - would be truncated to:":GOSUB 13020 13520 B$=LEFT$(B$,62):PRINT B$ 13540 LINE INPUT "Retype line (Y/N)?";QQ$:QQ$=LEFT$(QQ$,1) 13560 IF QQ$="Y" OR QQ$="y" THEN PRINT PP$;:SAV$="":GOTO 13260 13580 D=D+LEN(B$):RETURN 13600 RETURN 13620 REM 15000 REM ***ON ERROR HANDLER*** 15020 IF ERL=18030 THEN RESUME 18050 15040 IF ERL=740 THEN M=0:RESUME 750 15050 IF ERL=760 THEN C=0:RESUME 770 15060 IF ERL=780 THEN U=0:RESUME 790 15070 IF ERL=6060 THEN V=0:RESUME 6080 15080 IF ERL=6800 THEN C=0:RESUME 6820 15090 IF ERL=6840 THEN C=0:RESUME 6860 15100 RESUME NEXT 16000 REM 16010 REM FILL AND STORE DISK RECORD 16020 REM 16030 LSET RR$=LEFT$(S$+SPACE$(RL-2),RL-2)+CHR$(13)+CHR$(10) 16040 RETURN 16500 REM 16510 REM UNPACK DISK RECORD 16520 REM 16530 ZZ=LEN(RR$)-2 16540 WHILE MID$(RR$,ZZ,1)=" " 16550 ZZ=ZZ-1:IF ZZ=1 THEN 16570 16560 WEND 16570 S$=LEFT$(RR$,ZZ) 16580 IF MID$(S$,ZZ,1)="?" THEN S$=S$+" " 16590 RETURN 17000 REM 17010 REM *** TOGGLE EXPERT USER MODE 17020 REM 17030 XPR=NOT XPR:RETURN 17040 REM 17050 REM *** TOGGLE BELL PROMPT 17060 REM 17070 BEL=NOT BEL:RETURN 18000 REM 18010 REM SUBROUTINE TO PRINT A FILE 18020 REM 18030 OPEN "I",1,"A:"+FIL$:BK=0 18040 IF EOF(1) OR BK THEN 18050 ELSE LINE INPUT #1,A$:GOSUB 13020:GOTO 18040 18050 CLOSE #1:RETURN 18060 REM FULL SUMMARY 18070 QU=0:GOSUB 9000:RETURN 18080 REM QUICK SUMMARY 18090 QU=-1:GOSUB 9000:RETURN 19000 REM PRINT "CALLERS" FILE...FOR SYSOP ONLY (PRIVATE CMD) 19010 GOSUB 13020 19020 IF N$+O$<>"SYSOP" THEN 1200' IF NOT SYSOP, SAY "I DON'T UNDERSTAND". 19030 OPEN "R",1,"A:CALLERS",60:FIELD #1,60 AS RR$:GET #1,1:SIZ=VAL(RR$) 19040 CA=CN 19050 FOR CNT=SIZ+1 TO 2 STEP -1 19060 GET #1,CNT:GOSUB 16500:A$=SPACE$(5-LEN(STR$(CA)))+STR$(CA)+" "+S$:GOSUB 13020:IF BK THEN 19090 19070 CA=CA-1 19080 NEXT CNT 19090 CLOSE:A$= "END OF CALLERS.":GOSUB 13020:GOSUB 13020:RETURN 19100 REM TEST FOR PERSONAL MESSAGES 19110 PERS=0:OK=-1:GET #1,RE:IF INSTR(RR$,";*")=0 THEN 19160 19120 PERS=-1 19130 IF N$+O$="SYSOP" THEN 19160 19140 GET #1,RE+3:GOSUB 19170:IF OK THEN 19160 19150 GET #1,RE+2:GOSUB 19170 19160 RETURN 19170 REM TEST 'FROM' OR 'TO' FIELD FOR USER'S NAME 19180 IF INSTR(RR$,N$)>0 AND INSTR(RR$,O$)>0 THEN OK=-1 ELSE OK=0 19190 RETURN 19200 IF PERS THEN S$="("+S$:S$=S$+")":PERS=0 19210 RETURN 26000 CHC=0: SAV$="" 26010 NCH=ASC(INPUT$(1)) 26020 IF NCH=127 THEN 26080 26030 IF NCH<32 THEN 26110 26040 IF CHC>=63 THEN 26010 26050 SAV$=SAV$+CHR$(NCH): CHC=CHC+1: PRINT CHR$(NCH); 26060 IF CHC=55 THEN PRINT CHR$(7); 26070 GOTO 26010 26080 IF CHC=0 THEN 26010 ELSE PRINT RIGHT$(SAV$,1);: GOTO 26100 26090 IF CHC=0 THEN 26010 ELSE PRINT ERS$; 26100 CHC=CHC-1: SAV$=LEFT$(SAV$,CHC): GOTO 26010 26110 IF NCH=8 THEN 26090 26120 IF NCH=13 THEN PRINT: RETURN 26130 IF NCH=21 THEN PRINT " #": GOTO 26000 26140 IF NCH<>24 OR CHC=0 THEN 26010 26150 FOR BCC=1 TO CHC: PRINT ERS$;: NEXT BCC: GOTO 26000