90 WIDTH "scrn:", 80
95 SCREEN 0,1,0,0
100 TITLE$ = "Update the Parent/Child Index Program"
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 CH.ID(1000), PA.ID(1000), B.DATE(1000)
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 Parent/Child Index Program
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 REM Read all records, and create the index.
1050 CLS
1060 C = 0
1070 FOR I = 1 TO 500
1080  GET #1, I
1090  LOCATE 15,1 : PRINT "Processing Person Record:"; I;
1100  REM Extract information from the file
1110  T1 = CVS(F1$)  'Child-id
1120  IF T1 < 0 THEN 1450
1130  T6 = CVS(F6$)  'Father-id
1140  T7 = CVS(F7$)  'Mother-id
1150  T8$ = F8$  'Birthdate as dd mmm yyyy
1160  IF T8$ = "           " THEN BD = 0 : GOTO 1330
1170  REM convert Birthdate
1180  BD = VAL(RIGHT$(T8$,4))*10000!
1190  MO$ = MID$(T8$,4,3)
1200  IF MO$ = "Jan" THEN BD = BD +  100 : GOTO 1320
1210  IF MO$ = "Feb" THEN BD = BD +  200 : GOTO 1320
1220  IF MO$ = "Mar" THEN BD = BD +  300 : GOTO 1320
1230  IF MO$ = "Apr" THEN BD = BD +  400 : GOTO 1320
1240  IF MO$ = "May" THEN BD = BD +  500 : GOTO 1320
1250  IF MO$ = "Jun" THEN BD = BD +  600 : GOTO 1320
1260  IF MO$ = "Jul" THEN BD = BD +  700 : GOTO 1320
1270  IF MO$ = "Aug" THEN BD = BD +  800 : GOTO 1320
1280  IF MO$ = "Sep" THEN BD = BD +  900 : GOTO 1320
1290  IF MO$ = "Oct" THEN BD = BD + 1000 : GOTO 1320
1300  IF MO$ = "Nov" THEN BD = BD + 1100 : GOTO 1320
1310  IF MO$ = "Dec" THEN BD = BD + 1200 : GOTO 1320
1320  BD = BD + VAL(LEFT$(T8$,2))
1330  REM create the father/child index record
1340  IF T6 = 0 THEN 1390  'skip if zero
1350  C = C + 1
1360  CH.ID(C) = T1
1370  PA.ID(C) = T6
1380  B.DATE(C) = BD
1390  REM create the mother/child index record
1400  IF T7 = 0 THEN 1450  'skip if zero
1410  C = C + 1
1420  CH.ID(C) = T1
1430  PA.ID(C) = T7
1440  B.DATE(C) = BD
1450 NEXT I
1460 CLOSE #1
1470 LOCATE 18,1 : PRINT "There are:"; C; "Index Records";
1480 REM Sort the index into ascending sequence
1700 REM
1710 REM Sort by Parent
1720 FOR I = 1 TO 6
1730  B(I) = B(I-1)*4+1
1740  IF B(I) <= C/2 THEN K1 = I
1750 NEXT I
1760 B(K1) = INT(C/5)+1
1770 B(1) = 1
1775 LOCATE 22,1 : PRINT "Processing Parents     ";
1780 FOR I = K1 TO 1 STEP -1
1790 LOCATE 23,1 : PRINT "For Group:";I;
1800  K1 = B(I)
1810  FOR J = K1 TO C
1820   LOCATE 23,20 : PRINT "J:";J;
1830   K2=PA.ID(J) : B.TEMP = B.DATE(J) : TEMP3 = CH.ID(J)
1840   FOR K = J-K1 TO 0 STEP -K1
1850    LOCATE 23,30 : PRINT "K:";K, "Freespace:";FRE(0)
1860    IF K2 > PA.ID(K) THEN 1900
1870    IF K2 = PA.ID(K) AND B.TEMP > B.DATE(K) THEN 1900
1880    PA.ID(K+K1)=PA.ID(K) : CH.ID(K+K1)=CH.ID(K):B.DATE(K+K1)=B.DATE(K)
1890   NEXT K
1900   PA.ID(K+K1)=K2: CH.ID(K+K1)=TEMP3: B.DATE(K+K1)=B.TEMP
1910  NEXT J
1920 NEXT I
1930 REM Write the Parent/Child Index
1935 CLS : LOCATE 21,1
1936 PRINT "Writing the Parent/Child Index"
1940 OPEN "a:pcindex" FOR OUTPUT AS #2
1950 WRITE #2,C
1960 FOR I = 1 TO C
1970  WRITE #2, PA.ID(I)
1980  WRITE #2, CH.ID(I)
1990 NEXT I
2000 CLOSE #2
2010 CLS : LOCATE 21,1
2020 PRINT "End of Program"
2030 RUN "a:menu"