home *** CD-ROM | disk | FTP | other *** search
/ CP/M / CPM_CDROM.iso / mbug / mbug059.arc / INDEXMAR.BAS < prev    next >
BASIC Source File  |  1979-12-31  |  6KB  |  162 lines

  1. 100 TITLE$ = "Marriage Index Program"
  2. 105 TITLE$ = TITLE$ + " ON DISPLAY"
  3. 110 VERSION$ = "Version 1.3"
  4. 115 COPY1$ = "Copyright (c) 1983, by:"
  5. 120 COPY2$ = "Melvin O. Duke"
  6. 125 PRICE$ = "$35"
  7. 130 ADDR1$ = "Melvin O. Duke"
  8. 135 ADDR2$ = "P. O. Box 20836"
  9. 140 ADDR3$ = "San Jose, CA  95160"
  10. 145 REM Dimension Statements go here
  11. 150 DIM REC.NO(400), PERS.ID(400), M.DATE(400)
  12. 170 REM Produce the first screen
  13. 175 KEY OFF : CLS
  14. 180 REM Draw the outer double box
  15. 185 R1 = 1 : C1 = 1 : R2 = 24 : C2 = 79 : GOSUB 400
  16. 190 REM Find the title location
  17. 195 TITLE.POS = 40 - INT(LEN(TITLE$)/2)
  18. 200 REM Draw the title box
  19. 205 R1=3:C1=TITLE.POS-2:R2=6:C2=TITLE.POS+LEN(TITLE$)+1:GOSUB 600
  20. 210 REM Print the title
  21. 215 LOCATE 4,TITLE.POS : PRINT TITLE$
  22. 220 LOCATE 5,40-INT(LEN(VERSION$)/2) :  PRINT VERSION$;
  23. 225 REM Draw the Contribution box
  24. 230 R1 = 8 : C1 = 19 : R2 = 17 : C2 = 62 : GOSUB 400
  25. 235 REM Request the Contribution
  26. 240 LOCATE 9,23 : PRINT "If you are using these programs, and"
  27. 245 LOCATE 10,21 : PRINT "finding them of value, your contribution"
  28. 250 LOCATE 11,23 : PRINT "("+PRICE$+" suggested) will be appreciated."
  29. 255 REM Draw the Mailing Label
  30. 260 R1 = 12 : C1 = 28 : R2 = 16 : C2 = 52 : GOSUB 600
  31. 265 REM Print the Name and Address
  32. 270 LOCATE 13,40-INT(LEN(ADDR1$)/2) :  PRINT ADDR1$;
  33. 275 LOCATE 14,40-INT(LEN(ADDR2$)/2) :  PRINT ADDR2$;
  34. 280 LOCATE 15,40-INT(LEN(ADDR3$)/2) :  PRINT ADDR3$;
  35. 285 REM Draw the Copyright box
  36. 290 R1 = 19 : C1 = 27 : R2 = 22 : C2 = 53 : GOSUB 400
  37. 295 REM Print the Copyright
  38. 300 LOCATE 20,40-INT(LEN(COPY1$)/2) :  PRINT COPY1$;
  39. 305 LOCATE 21,40-INT(LEN(COPY2$)/2) :  PRINT COPY2$;
  40. 310 GOTO 740
  41. 400 REM subroutine to print a double box
  42. 410 FOR I = R1 + 1 TO R2 - 1
  43. 420  LOCATE I, C1 : PRINT CHR$(186);
  44. 430  LOCATE I, C2 : PRINT CHR$(186);
  45. 440 NEXT I
  46. 450 FOR J = C1 + 1 TO C2 - 1
  47. 460  LOCATE R1, J : PRINT CHR$(205);
  48. 470  LOCATE R2, J : PRINT CHR$(205);
  49. 480 NEXT J
  50. 490  LOCATE R1, C1 : PRINT CHR$(201);
  51. 500  LOCATE R1, C2 : PRINT CHR$(187);
  52. 510  LOCATE R2, C1 : PRINT CHR$(200);
  53. 520  LOCATE R2, C2 : PRINT CHR$(188);
  54. 530 RETURN
  55. 600 REM subroutine to print a single box
  56. 610 FOR I = R1 + 1 TO R2 - 1
  57. 620  LOCATE I, C1 : PRINT CHR$(179);
  58. 630  LOCATE I, C2 : PRINT CHR$(179);
  59. 640 NEXT I
  60. 650 FOR J = C1 + 1 TO C2 - 1
  61. 660  LOCATE R1, J : PRINT CHR$(196);
  62. 670  LOCATE R2, J : PRINT CHR$(196);
  63. 680 NEXT J
  64. 690  LOCATE R1, C1 : PRINT CHR$(218);
  65. 700  LOCATE R1, C2 : PRINT CHR$(191);
  66. 710  LOCATE R2, C1 : PRINT CHR$(192);
  67. 720  LOCATE R2, C2 : PRINT CHR$(217);
  68. 730 RETURN
  69. 740 REM ask user to press a key to continue
  70. 750 LOCATE 25,1
  71. 760 PRINT "Press any key to continue";
  72. 770 K$ = INKEY$ : IF K$ = "" THEN 770
  73. 780 CLS
  74. 1000 REM Marriage Index Program
  75. 1010 REM By:  Melvin O. Duke.  Updated 26 June, 1983.
  76. 1020 OPEN "a:marrfile" AS #2 LEN = 128
  77. 1030 FIELD 2, 5 AS M1$, 5 AS M2$, 5 AS M3$, 5 AS M4$, 11 AS M5$, 18 AS M6$, 16 AS M7$, 16 AS M8$, 45 AS M9$
  78. 1040 REM Read all records, and create the index.
  79. 1050 CLS
  80. 1060 C = 0
  81. 1070 FOR I = 1 TO 200
  82. 1080  GET #2, I
  83. 1090  LOCATE 15,1 : PRINT "Processing Marriage Record:"; I;
  84. 1100  REM Extract information from the file
  85. 1110  T1 = CVS(M1$)  'Marriage-id
  86. 1120  IF T1 < 0 THEN 1450
  87. 1130  T2 = CVS(M2$)  'Husband-id
  88. 1140  T3 = CVS(M3$)  'Wife-id
  89. 1150  T5$ = M5$  'Marriage-date as dd mmm yyyy
  90. 1160  IF T5$ = "           " THEN MD = 0 : GOTO 1330
  91. 1170  REM convert Birthdate
  92. 1180  MD = VAL(RIGHT$(T5$,4))*10000!
  93. 1190  MO$ = MID$(T5$,4,3)
  94. 1200  IF MO$ = "Jan" THEN MD = MD +  100 : GOTO 1320
  95. 1210  IF MO$ = "Feb" THEN MD = MD +  200 : GOTO 1320
  96. 1220  IF MO$ = "Mar" THEN MD = MD +  300 : GOTO 1320
  97. 1230  IF MO$ = "Apr" THEN MD = MD +  400 : GOTO 1320
  98. 1240  IF MO$ = "May" THEN MD = MD +  500 : GOTO 1320
  99. 1250  IF MO$ = "Jun" THEN MD = MD +  600 : GOTO 1320
  100. 1260  IF MO$ = "Jul" THEN MD = MD +  700 : GOTO 1320
  101. 1270  IF MO$ = "Aug" THEN MD = MD +  800 : GOTO 1320
  102. 1280  IF MO$ = "Sep" THEN MD = MD +  900 : GOTO 1320
  103. 1290  IF MO$ = "Oct" THEN MD = MD + 1000 : GOTO 1320
  104. 1300  IF MO$ = "Nov" THEN MD = MD + 1100 : GOTO 1320
  105. 1310  IF MO$ = "Dec" THEN MD = MD + 1200 : GOTO 1320
  106. 1320  MD = MD + VAL(LEFT$(T5$,2))
  107. 1330  REM create the husband's index record
  108. 1340  IF T2 = 0 THEN 1390  'skip if zero
  109. 1350  C = C + 1
  110. 1360  REC.NO(C) = T1
  111. 1370  PERS.ID(C) = T2
  112. 1380  M.DATE(C) = MD
  113. 1390  REM create the wife's index record
  114. 1400  IF T3 = 0 THEN 1450  'skip if zero
  115. 1410  C = C + 1
  116. 1420  REC.NO(C) = T1
  117. 1430  PERS.ID(C) = T3
  118. 1440  M.DATE(C) = MD
  119. 1450 NEXT I
  120. 1460 CLOSE #2
  121. 1470 LOCATE 18,1 : PRINT "There are:"; C; "Index Records";
  122. 1700 REM Sort by Person-id
  123. 1710 FOR I = 1 TO 6
  124. 1720  B(I) = B(I-1)*4+1
  125. 1730  IF B(I) <= C/2 THEN K1 = I
  126. 1740 NEXT I
  127. 1750 B(K1) = INT(C/5)+1
  128. 1760 B(1) = 1
  129. 1770 LOCATE 22,1 : PRINT SPACE$(79)
  130. 1780 LOCATE 22,1 : PRINT "Processing Persons"
  131. 1790 FOR I = K1 TO 1 STEP -1
  132. 1800  LOCATE 23,1 : PRINT "For Group I:";I;
  133. 1810  K1 = B(I)
  134. 1820  FOR J = K1 TO C
  135. 1830   LOCATE 23,20 : PRINT "J:";J;
  136. 1840   MTEMP1 = M.DATE(J) : TEMP2 = REC.NO(J) : TEMP3 = PERS.ID(J)
  137. 1850   FOR K = J-K1 TO 0 STEP -K1
  138. 1860    LOCATE 23,30 : PRINT "K:";K, "Freespace:";FRE(0)
  139. 1870    IF TEMP3 > PERS.ID(K) THEN 1910
  140. 1880    IF TEMP3 = PERS.ID(K) AND MTEMP1 > M.DATE(K) THEN 1910
  141. 1890    M.DATE(K+K1)=M.DATE(K):REC.NO(K+K1)=REC.NO(K):PERS.ID(K+K1)=PERS.ID(K)
  142. 1900   NEXT K
  143. 1910   M.DATE(K+K1)=MTEMP1 : REC.NO(K+K1)=TEMP2 : PERS.ID(K+K1)=TEMP3
  144. 1920  NEXT J
  145. 1930 NEXT I
  146. 1940 REM Write the Marriage Index
  147. 1945 CLS : LOCATE 21,1
  148. 1946 PRINT "Writing the Marriages Index"
  149. 1950 OPEN "a:mindex" FOR OUTPUT AS #3
  150. 1960 WRITE #3,C
  151. 1970 FOR I = 1 TO C
  152. 1980  WRITE #3, PERS.ID(I)
  153. 1990  WRITE #3, REC.NO(I)
  154. 2000 NEXT I
  155. 2010 CLOSE #3
  156. 2020 CLS : LOCATE 21,1
  157. 2030 PRINT "End of Program"
  158. 2040 END
  159. RINT SPACE$(22);
  160. 1760 LOCATE 9,18 : PRINT T3$;
  161. 1770 LOCATE 11,18 : PRINT SPACE$(2);
  162. 1780 LOCATE 11,18 : PRINT