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

  1. 100 TITLE$ = "List the Marriages File 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. 170 REM Produce the first screen
  12. 175 KEY OFF : CLS
  13. 180 REM Draw the outer double box
  14. 185 R1 = 1 : C1 = 1 : R2 = 24 : C2 = 79 : GOSUB 400
  15. 190 REM Find the title location
  16. 195 TITLE.POS = 40 - INT(LEN(TITLE$)/2)
  17. 200 REM Draw the title box
  18. 205 R1=3:C1=TITLE.POS-2:R2=6:C2=TITLE.POS+LEN(TITLE$)+1:GOSUB 600
  19. 210 REM Print the title
  20. 215 LOCATE 4,TITLE.POS : PRINT TITLE$
  21. 220 LOCATE 5,40-INT(LEN(VERSION$)/2) :  PRINT VERSION$;
  22. 225 REM Draw the Contribution box
  23. 230 R1 = 8 : C1 = 19 : R2 = 17 : C2 = 62 : GOSUB 400
  24. 235 REM Request the Contribution
  25. 240 LOCATE 9,23 : PRINT "If you are using these programs, and"
  26. 245 LOCATE 10,21 : PRINT "finding them of value, your contribution"
  27. 250 LOCATE 11,23 : PRINT "("+PRICE$+" suggested) will be appreciated."
  28. 255 REM Draw the Mailing Label
  29. 260 R1 = 12 : C1 = 28 : R2 = 16 : C2 = 52 : GOSUB 600
  30. 265 REM Print the Name and Address
  31. 270 LOCATE 13,40-INT(LEN(ADDR1$)/2) :  PRINT ADDR1$;
  32. 275 LOCATE 14,40-INT(LEN(ADDR2$)/2) :  PRINT ADDR2$;
  33. 280 LOCATE 15,40-INT(LEN(ADDR3$)/2) :  PRINT ADDR3$;
  34. 285 REM Draw the Copyright box
  35. 290 R1 = 19 : C1 = 27 : R2 = 22 : C2 = 53 : GOSUB 400
  36. 295 REM Print the Copyright
  37. 300 LOCATE 20,40-INT(LEN(COPY1$)/2) :  PRINT COPY1$;
  38. 305 LOCATE 21,40-INT(LEN(COPY2$)/2) :  PRINT COPY2$;
  39. 310 GOTO 740
  40. 400 REM subroutine to print a double box
  41. 410 FOR I = R1 + 1 TO R2 - 1
  42. 420  LOCATE I, C1 : PRINT CHR$(186);
  43. 430  LOCATE I, C2 : PRINT CHR$(186);
  44. 440 NEXT I
  45. 450 FOR J = C1 + 1 TO C2 - 1
  46. 460  LOCATE R1, J : PRINT CHR$(205);
  47. 470  LOCATE R2, J : PRINT CHR$(205);
  48. 480 NEXT J
  49. 490  LOCATE R1, C1 : PRINT CHR$(201);
  50. 500  LOCATE R1, C2 : PRINT CHR$(187);
  51. 510  LOCATE R2, C1 : PRINT CHR$(200);
  52. 520  LOCATE R2, C2 : PRINT CHR$(188);
  53. 530 RETURN
  54. 600 REM subroutine to print a single box
  55. 610 FOR I = R1 + 1 TO R2 - 1
  56. 620  LOCATE I, C1 : PRINT CHR$(179);
  57. 630  LOCATE I, C2 : PRINT CHR$(179);
  58. 640 NEXT I
  59. 650 FOR J = C1 + 1 TO C2 - 1
  60. 660  LOCATE R1, J : PRINT CHR$(196);
  61. 670  LOCATE R2, J : PRINT CHR$(196);
  62. 680 NEXT J
  63. 690  LOCATE R1, C1 : PRINT CHR$(218);
  64. 700  LOCATE R1, C2 : PRINT CHR$(191);
  65. 710  LOCATE R2, C1 : PRINT CHR$(192);
  66. 720  LOCATE R2, C2 : PRINT CHR$(217);
  67. 730 RETURN
  68. 740 REM ask user to press a key to continue
  69. 750 LOCATE 25,1
  70. 760 PRINT "Press any key to continue";
  71. 770 K$ = INKEY$ : IF K$ = "" THEN 770
  72. 780 CLS
  73. 840 CLS
  74. 1000 REM List the Marriages File Program.
  75. 1010 REM By:  Melvin O. Duke.  Updated 26 June, 1983.
  76. 1020 REM Open the Persons File
  77. 1030 OPEN "a:persfile" AS #1 LEN = 256
  78. 1040 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$
  79. 1050 REM open the Marriages File
  80. 1060 OPEN "a:marrfile" AS #2 LEN = 128
  81. 1070 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$
  82. 1080 REM Read the Marriage Records
  83. 1090 CLS : LOCATE 21,1
  84. 1100 PRINT "Listing the Records in the Marriages File"
  85. 1110 REC.COUNT = 0
  86. 1120 GOSUB 1140
  87. 1130 GOTO 1210
  88. 1140 LPRINT "  Listing the Records in the Marriages File  ";DATE$;"  ";TIME$
  89. 1150 LPRINT
  90. 1160 LPRINT " REC   No.  FATHER";
  91. 1170 LPRINT TAB(42);" No.  MOTHER"
  92. 1180 LPRINT " ---   ---  ------";
  93. 1190 LPRINT TAB(42);" ---  ------"
  94. 1200 RETURN
  95. 1210 FOR I = 1 TO 200
  96. 1220  GET #2,I
  97. 1230  REM verify if valid record
  98. 1240  TT1 = CVS(M1$)
  99. 1250  IF TT1 < 1 THEN 1430
  100. 1260  REC.COUNT = REC.COUNT + 1
  101. 1270  LOCATE 23,1 : PRINT "Listing Record:"; TT1
  102. 1280  LPRINT USING "####"; TT1;
  103. 1290  REM husband
  104. 1300  TT2 = CVS(M2$)
  105. 1310  IF TT2 = 0 THEN GOSUB 1740 ELSE GET #1, TT2 : GOSUB 1450
  106. 1320  REM print the father
  107. 1330  LPRINT TAB(7);
  108. 1340  LPRINT USING "####"; TT2;
  109. 1350  LPRINT "  " + T2$ + ", " + T3$;
  110. 1360  REM wife
  111. 1370  TT3 = CVS(M3$)
  112. 1380  IF TT3 = 0 THEN GOSUB 1740 ELSE GET #1, TT3 : GOSUB 1450
  113. 1390  LPRINT TAB(42);
  114. 1400  LPRINT USING "####"; TT3;
  115. 1410  LPRINT "  " + T2$ + ", " + T3$
  116. 1420  IF REC.COUNT MOD 55 = 0 THEN LPRINT CHR$(12);: GOSUB 1140
  117. 1430 NEXT I
  118. 1440 GOTO 1950
  119. 1450 REM Routine to Extract Personal Information
  120. 1460 T1 = CVS(F1$)
  121. 1470 T2$ = F2$
  122. 1480 FOR J = 1 TO LEN(F2$) -1
  123. 1490  IF RIGHT$(T2$,1)=" " THEN T2$ = LEFT$(T2$,LEN(T2$)-1) ELSE J = LEN(F2$)-1
  124. 1500 T3$ = F3$
  125. 1510 NEXT J
  126. 1520 FOR J = 1 TO LEN(F3$) -1
  127. 1530  IF RIGHT$(T3$,1)=" " THEN T3$ = LEFT$(T3$,LEN(T3$)-1) ELSE J = LEN(F3$)-1
  128. 1540 NEXT J
  129. 1550 T4$ = F4$
  130. 1560 IF T4$ = "M" THEN T4$ = "Male"
  131. 1570 IF T4$ = "F" THEN T4$ = "Female"
  132. 1580 T5 = CVS(F5$)
  133. 1590 T6 = CVS(F6$)
  134. 1600 T7 = CVS(F7$)
  135. 1610 T8$ = F8$
  136. 1620 T9$ = F9$
  137. 1630 T10$ = F10$
  138. 1640 T11$ = F11$
  139. 1650 T12$ = F12$
  140. 1660 T13$ = F13$
  141. 1670 T14$ = F14$
  142. 1680 T15$ = F15$
  143. 1690 T16$ = F16$
  144. 1700 T17$ = F17$
  145. 1710 T18$ = F18$
  146. 1720 T19$ = F19$
  147. 1730 RETURN
  148. 1740 REM Blank out a Record
  149. 1750 T1 = 0
  150. 1760 T2$ = ""
  151. 1770 T3$ = ""
  152. 1780 T4$ = ""
  153. 1790 T5 = 0
  154. 1800 T6 = 0
  155. 1810 T7 = 0
  156. 1820 T8$ = ""
  157. 1830 T9$ = ""
  158. 1840 T10$ = ""
  159. 1850 T11$ = ""
  160. 1860 T12$ = ""
  161. 1870 T13$ = ""
  162. 1880 T14$ = ""
  163. 1890 T15$ = ""
  164. 1900 T16$ = ""
  165. 1910 T17$ = ""
  166. 1920 T18$ = ""
  167. 1930 T19$ = ""
  168. 1940 RETURN
  169. 1950 LPRINT CHR$(12);
  170. 1960 CLOSE #1
  171. 1970 CLOSE #2
  172. 1980 CLS : LOCATE 21,1
  173. 1990 PRINT "End of Program"
  174. 2000 END
  175. ,C
  176. 1970 FOR I = 1 TO C
  177. 1980