90 WIDTH "scrn:", 80 95 SCREEN 0,1,0,0 100 TITLE$ = "Alphabetic Person Name Listing" 105 TITLE$ = TITLE$ + " ON DISPLAY" 110 VERSION$ = "Version 2.0" 115 COPY1$ = "Copyright (c) 1983, 1984, by:" 120 COPY2$ = "Melvin O. Duke" 125 PRICE$ = "$35" 130 ADDR1$ = "Melvin O. Duke" 135 ADDR2$ = "P. O. Box 20836" 140 ADDR3$ = "San Jose, CA 95160" 145 REM Dimension Statements go here 150 DIM IDX$(500), WHERE(500) 170 REM Produce the first screen 175 KEY OFF : CLS 180 REM Draw the outer double box 185 R1 = 1 : C1 = 1 : R2 = 24 : C2 = 79 : GOSUB 400 190 REM Find the title location 195 TITLE.POS = 40 - INT(LEN(TITLE$)/2) 200 REM Draw the title box 205 R1=3:C1=TITLE.POS-2:R2=6:C2=TITLE.POS+LEN(TITLE$)+1:GOSUB 600 210 REM Print the title 215 LOCATE 4,TITLE.POS : PRINT TITLE$ 220 LOCATE 5,40-INT(LEN(VERSION$)/2) : PRINT VERSION$; 225 REM Draw the Contribution box 230 R1 = 8 : C1 = 19 : R2 = 17 : C2 = 62 : GOSUB 400 235 REM Request the Contribution 240 LOCATE 9,23 : PRINT "If you are using these programs, and" 245 LOCATE 10,21 : PRINT "finding them of value, your contribution" 250 LOCATE 11,23 : PRINT "("+PRICE$+" suggested) will be anticipated." 255 REM Draw the Mailing Label 260 R1 = 12 : C1 = 28 : R2 = 16 : C2 = 52 : GOSUB 600 265 REM Print the Name and Address 270 LOCATE 13,40-INT(LEN(ADDR1$)/2) : PRINT ADDR1$; 275 LOCATE 14,40-INT(LEN(ADDR2$)/2) : PRINT ADDR2$; 280 LOCATE 15,40-INT(LEN(ADDR3$)/2) : PRINT ADDR3$; 285 REM Draw the Copyright box 290 R1 = 19 : C1 = 24 : R2 = 22 : C2 = 56 : GOSUB 400 295 REM Print the Copyright 300 LOCATE 20,40-INT(LEN(COPY1$)/2) : PRINT COPY1$; 305 LOCATE 21,40-INT(LEN(COPY2$)/2) : PRINT COPY2$; 310 GOTO 740 400 REM subroutine to print a double box 410 FOR I = R1 + 1 TO R2 - 1 420 LOCATE I, C1 : PRINT CHR$(186); 430 LOCATE I, C2 : PRINT CHR$(186); 440 NEXT I 450 FOR J = C1 + 1 TO C2 - 1 460 LOCATE R1, J : PRINT CHR$(205); 470 LOCATE R2, J : PRINT CHR$(205); 480 NEXT J 490 LOCATE R1, C1 : PRINT CHR$(201); 500 LOCATE R1, C2 : PRINT CHR$(187); 510 LOCATE R2, C1 : PRINT CHR$(200); 520 LOCATE R2, C2 : PRINT CHR$(188); 530 RETURN 600 REM subroutine to print a single box 610 FOR I = R1 + 1 TO R2 - 1 620 LOCATE I, C1 : PRINT CHR$(179); 630 LOCATE I, C2 : PRINT CHR$(179); 640 NEXT I 650 FOR J = C1 + 1 TO C2 - 1 660 LOCATE R1, J : PRINT CHR$(196); 670 LOCATE R2, J : PRINT CHR$(196); 680 NEXT J 690 LOCATE R1, C1 : PRINT CHR$(218); 700 LOCATE R1, C2 : PRINT CHR$(191); 710 LOCATE R2, C1 : PRINT CHR$(192); 720 LOCATE R2, C2 : PRINT CHR$(217); 730 RETURN 740 REM ask user to press a key to continue 750 LOCATE 25,1 760 PRINT "Have Data Diskette(s) in Place, then Press any key to continue."; 770 K$ = INKEY$ : IF K$ = "" THEN 770 780 CLS 1000 REM Alphabetic Person Name Listing. 1010 REM By: Melvin O. Duke. Last Updated: 02 December 1983. 1020 OPEN "a:persfile" AS #1 LEN = 256 1030 FIELD 1, 5 AS F1$, 20 AS F2$, 30 AS F3$, 2 AS F4$, 5 AS F5$, 5 AS F6$, 5 AS F7$, 11 AS F8$, 18 AS F9$, 16 AS F10$, 16 AS F11$, 11 AS F12$, 18 AS F13$, 16 AS F14$, 16 AS F15$, 11 AS F16$, 18 AS F17$, 16 AS F18$, 16 AS F19$ 1040 CLS 1050 REM Read all records, and print the actual ones 1060 N.ACT = 1 1070 FOR I = 1 TO 500 1080 GET #1, I 1090 LOCATE 23,1 : PRINT "Processing Record:";I,"Freespace:";FRE(0) 1100 REM Extract Information from the File 1110 WHERE(N.ACT) = CVS(F1$) 1120 IF WHERE(N.ACT) < 1 THEN 1410 1130 T2$ = F2$ 'Surname 1140 REM Right-trim t2$ 1150 FOR J = 1 TO LEN(F2$)-1 1160 IF RIGHT$(T2$,1)=" "THEN T2$=LEFT$(T2$,LEN(T2$)-1) ELSE J=LEN(F2$)-1 1170 NEXT J 1180 T3$ = F3$ 'Given Names 1190 REM Right-trim t3$ 1200 FOR J = 1 TO LEN(F3$)-1 1210 IF RIGHT$(T3$,1)=" "THEN T3$=LEFT$(T3$,LEN(T3$)-1) ELSE J=LEN(F3$)-1 1220 NEXT J 1230 T8$ = F8$ 'Birthdate 1240 REM convert to yyyymmdd 1250 TEMP$ = RIGHT$(T8$,4) 1260 IF MID$(T8$,4,3)="Jan" THEN TEMP$=TEMP$+"01" 1270 IF MID$(T8$,4,3)="Feb" THEN TEMP$=TEMP$+"02" 1280 IF MID$(T8$,4,3)="Mar" THEN TEMP$=TEMP$+"03" 1290 IF MID$(T8$,4,3)="Apr" THEN TEMP$=TEMP$+"04" 1300 IF MID$(T8$,4,3)="May" THEN TEMP$=TEMP$+"05" 1310 IF MID$(T8$,4,3)="Jun" THEN TEMP$=TEMP$+"06" 1320 IF MID$(T8$,4,3)="Jul" THEN TEMP$=TEMP$+"07" 1330 IF MID$(T8$,4,3)="Aug" THEN TEMP$=TEMP$+"08" 1340 IF MID$(T8$,4,3)="Sep" THEN TEMP$=TEMP$+"09" 1350 IF MID$(T8$,4,3)="Oct" THEN TEMP$=TEMP$+"10" 1360 IF MID$(T8$,4,3)="Nov" THEN TEMP$=TEMP$+"11" 1370 IF MID$(T8$,4,3)="Dec" THEN TEMP$=TEMP$+"12" 1380 TEMP$=TEMP$+LEFT$(T8$,2) 'add day 1390 IDX$(N.ACT) = T2$+" "+T3$+TEMP$ 1400 N.ACT = N.ACT + 1 1410 NEXT I 1420 N.ACT = N.ACT - 1 1430 LOCATE 23,1 : PRINT SPACE$(79) 1440 REM Sort the index into ascending sequence 1450 CLS 1460 FOR I = 1 TO 6 1470 B(I) = B(I-1)*4+1 1480 IF B(I) <= N.ACT/2 THEN K1 = I 1490 NEXT I 1500 B(K1) = INT(N.ACT/5) +1 1510 B(1) = 1 1520 LOCATE 21,1 : PRINT "Total Records:";N.ACT; 1530 FOR I = K1 TO 1 STEP -1 1540 LOCATE 23,1 : PRINT "Sorting Group:";I 1550 K1 = B(I) 1560 FOR J = K1 TO N.ACT 1570 LOCATE 23,20 : PRINT "J:";J; 1580 K2$ = IDX$(J) : K3 = WHERE(J) 1590 FOR K = J-K1 TO 0 STEP -K1 1600 LOCATE 23,30 : PRINT "K:";K,"Freespace:";FRE(0) 1610 IF K2$ >= IDX$(K) THEN 1640 1620 IDX$(K+K1) = IDX$(K) : WHERE(K+K1) = WHERE(K) 1630 NEXT K 1640 IDX$(K+K1) = K2$ : WHERE(K+K1) = K3 1650 NEXT J 1660 NEXT I 1670 LOCATE 23,1 : PRINT SPACE$(79) 1680 LOCATE 23,1 : PRINT "Printing the Alphabetical List" 1690 GOSUB 1710 1700 GOTO 1760 1710 LPRINT " Alphabetic Listing of the Persons File ";DATE$;" ";TIME$ 1720 LPRINT 1730 LPRINT " REC SURNAME GIVEN-NAMES";TAB(60);"BIRTHDATE" 1740 LPRINT " --- ------- -----------";TAB(60);"---------" 1750 RETURN 1760 REM Read all records, and print the actual ones 1770 K = 0 1780 CLS 1790 LOCATE 21,1 : PRINT "There are";N.ACT;"records." 1800 FOR I = 1 TO N.ACT 1810 GET #1, ABS(WHERE(I)) 1820 LOCATE 23,1 : PRINT "Printing Record:"; I, "Freespace:";FRE(0) 1830 REM Print the information in Alphabetical Order. 1840 T1 = CVS(F1$) 1850 IF T1 < 1 THEN 1930 1860 K = K + 1 1870 T2$ = F2$ 1880 T3$ = F3$ 1890 T8$ = F8$ 1900 IF K MOD 55 = 0 THEN LPRINT CHR$(12);: GOSUB 1710 1910 LPRINT USING "#####";T1, 1920 LPRINT TAB(10); T2$; T3$; TAB(60); T8$ 1930 NEXT I 1940 CLOSE #1 1950 CLS : LOCATE 21,1 1960 PRINT "End of Program" 1970 LPRINT CHR$(12); 1980 RUN "a:menu"