home *** CD-ROM | disk | FTP | other *** search
/ Oakland CPM Archive / oakcpm.iso / cpmug / cpmug090.ark / GLCDPOST.BAS < prev    next >
BASIC Source File  |  1984-04-29  |  8KB  |  234 lines

  1.      rem This is the Check Disbursement Posting Program
  2.  
  3. %INCLUDE ALL.BAS
  4.      dim n(2,20),k$(3,20)
  5.      first=8:last=18
  6.  
  7. fa$="DATE    /...5../    /...5...10...15...20.../                    "
  8. fa$=fa$+"      PAGE  ####"
  9. fb$="                    *** CASH/CHECK DISBURSEMENTS ***"
  10. fb1$="                    --------------------------------"
  11. fc$=" CHECK #    DATE    DESCRIPTION                 ACCOUNT #"
  12. fc$=fc$+"    AMOUNT      NET"
  13. fd$="########  /...5../  /...5...10...15...20.../ ##########"
  14. fd$=fd$+"  ###,###.##-"
  15. fd1$="          /...5../  /...5...10...15...20.../ ##########"
  16. fd1$=fd1$+"  ###,###.##-"
  17. fd2$="########  /...5../  /...5...10...15...20.../           "
  18. fd2$=fd2$+"  ###,###.##-"
  19. fe$="                                             ##########"
  20. fe$=fe$+"  ###,###.##-"
  21. fe1$="                                             ##########"
  22. fe1$=fe1$+"  ###,###.##- ###,###.##-"
  23. ff$="                              /...5...10...1/"
  24. ff$=ff$+"        ##,###,###.##-*"
  25.  
  26. fg$="DATE    /...5../    /...5...10...15...20.../                    "
  27. fg$=fg$+"      PAGE  ####"
  28. fh$="                    *** GENERAL LEDGER ***"
  29. fh1$="                    ----------------------"
  30. fi$=" ACCOUNT #  DESCRIPTION                       REF #    "
  31. fi$=fi$+"BAL.FWRD.      CURRENT        BALANCE"
  32. fj$="##########  /...5...10...15...20...25...3/         ##,###,###.##-"
  33. fk$="           /.../  /...5...10...15...20.../ ########            "
  34. fk$=fk$+" ##,###,###.##-"
  35. fl$="                                             "
  36. fl$=fl$+"                   ##,###,###.##-* ##,###,###.##-"
  37.  
  38. 1000 PRINT clear$:PRINT
  39. 1002 PRINT "BEFORE PROCEEDING, IT IS A GOOD PRACTICE TO BACK UP"
  40. 1005 PRINT "BOTH THE GENERAL LEDGER FILE AND THE CHECK DISBURSEMENTS FILE"
  41. 1010 PRINT "BY MAKING COPIES USING THE DISKCOPY FACILITY OF YOUR DOS."
  42. 1015 PRINT:PRINT"IF YOU ARE UNFAMILIAR WITH THE PROCESS, ASK YOUR"
  43. 1020 PRINT "SYSTEM SUPERVISOR FOR HELP.":PRINT
  44. 1025 PRINT "IF THIS HAS BEEN DONE; TYPE Y TO CONTINUE!"
  45. 1030 INPUT line temp$
  46. 1035 IF left$(temp$,1)<>"y" and left$(temp$,1)<>"Y" THEN CHAIN "master11"
  47.  
  48. 1540 PRINT clear$:PRINT
  49. 1545 PRINT "PUT THE GENERAL LEDGER DISK IN DRIVE B":PRINT
  50. 1550 PRINT "PUT THE CHECK DISBURSEMENTS DISK IN DRIVE A":PRINT
  51. 1555 PRINT "TYPE RETURN WHEN READY":INPUT line temp$
  52.      initialize
  53. 2000 PRINT clear$:PRINT
  54. 2005 PRINT "LOADING ACCOUNT NUMBER TABLES":PRINT
  55. 2010 PRINT "*** PLEASE WAIT ***"
  56. 2020 open "b:glref" as 1
  57.      read #1;z2
  58.     zn%=z2+2
  59.      dim h(zn%),ref%(zn%)
  60.      for z=1 to z2
  61.      read #1;h(z)
  62.      next z
  63.      close 1
  64. 3070 N(2,1)=8:N(2,2)=24:N(2,3)=24:N(2,4)=1
  65. 4000 REM THIS IS THE ACTUAL POSTING PROGRAM
  66. 4010 open "b:gl" recl 138 as 1
  67.      open "a:glcd" recl 250 as 2
  68. 4015 P9=100:PAGE=0
  69. 4030 GOSUB 20000
  70. 4100 LPRINTER
  71. 4500 I=1
  72. 4505 read #2,i;N(0,1),N(0,2),Q$,N(0,7),N(0,8),N(0,9),\
  73.      N(0,10),N(0,11),N(0,12),N(0,13),N(0,14),N(0,15),N(0,16),\
  74.      N(0,17),N(0,18),N(0,19),FLAG$
  75. 4510 IF N(0,2)=0 THEN GOTO 10000 rem Get out when finished
  76. 4515 IF FLAG$="P" THEN 4540
  77. 4525 IF P9>60 THEN GOSUB 9000
  78. 4530 GOSUB 5000
  79. 4531 IF FLAG.CR<>1 THEN GOSUB 9100
  80. 4532 IF P9>60 THEN GOSUB 9000
  81. 4534 GOSUB 5100
  82. 4536 IF P9>60 THEN GOSUB 9000
  83. 4540 I=I+1:GOTO 4505
  84. 5000 REM SUBROUTINE TO POST AND PRINT TOTALS
  85. 5002 IF N(0,2)=0 THEN 5050
  86. 5003 FOR Z4=1 TO Z2
  87. 5004 IF N(0,2)=H(Z4) THEN read #1,z4;n(1,1),n(1,2),r$,n(1,4),n(1,5),\
  88.      n(1,6),n(1,7),n(1,8),n(1,9),n(1,10):goto 5006
  89. 5005 NEXT Z4
  90. 5006 FOR X=4 TO 6:N(1,X)=N(1,X)+N(0,7):NEXT X
  91. 5050 RETURN
  92.  
  93. 5100 NU.LEFT%=0:NU.TRAN%=0:NET.AMT=0
  94.     FOR B=FIRST TO LAST STEP 2
  95.     IF N(0,B)<>0 THEN NU.TRAN%=NU.TRAN%+1:\
  96.     NET.AMT=NET.AMT+N(0,B+1)
  97.     NEXT B
  98. 5110 IF N(0,7)=0 THEN PRINT USING FD2$;N(0,1),LEFT$(Q$,8),\
  99.     MID$(Q$,9,24),N(0,7):P9=P9+1:GOTO 5235
  100. 5115 FOR J=first to last STEP 2
  101. 5120 IF N(0,J)=0 THEN 5220
  102. 5125 FOR Z4=1 TO Z2
  103. 5130 IF N(0,j)=H(Z4) THEN read #1,z4;n(1,1),n(1,2),r$,n(1,4),n(1,5),\
  104.      n(1,6),n(1,7),n(1,8),n(1,9),n(1,10):goto 5140
  105. 5135 NEXT Z4
  106. 5140 IF NU.TRAN%>1 THEN GOSUB 5400 ELSE GOTO 5142
  107.     GOTO 5145
  108. 5142 PRINT USING FD$;N(0,1),LEFT$(Q$,8),MID$(Q$,9,24),N(0,J),N(0,J+1)
  109. 5145 P9=P9+1
  110. 5170 FOR X=4 TO 6:N(1,X)=N(1,X)+N(0,J+1):NEXT X
  111. 5220 NEXT J
  112. 5225 IF N(0,7)=0 THEN PRINT USING FD2$;N(0,1),LEFT$(Q$,8),\
  113.       MID$(Q$,9,24),N(0,7):P9=P9+1
  114. 5235 RETURN
  115. 5400 IF NU.LEFT%=1 THEN PRINT USING FE1$;N(0,J),N(0,J+1),NET.AMT:\
  116.     NU.LEFT%=NU.LEFT%-1:RETURN
  117. 5420 IF NU.LEFT%>1 THEN PRINT USING FE$;N(0,J),N(0,J+1):\
  118.     NU.LEFT%=NU.LEFT%-1:RETURN
  119. 5430 PRINT USING FD$;N(0,1),LEFT$(Q$,8),MID$(Q$,9,24),\
  120.     N(0,J),N(0,J+1):NU.LEFT%=NU.TRAN%-1
  121. 5440 RETURN
  122.  
  123. 9000 P9=0:PAGE=PAGE+1
  124. 9005 PRINT CHR$(12)
  125. 9010 PRINT USING FA$;D$(4),MID$(CO.NAME$,25,24),PAGE
  126. 9015 PRINT FB$
  127. 9020 PRINT FB1$
  128. 9025 PRINT FC$
  129. 9030 PRINT:P9=P9+6
  130. 9095 RETURN
  131. 9100 PRINT USING FD1$;D$(4),"CHECK DISBURSEMENTS",ACCT.NUM,CASH.OUT
  132. 9105 FLAG.CR=1
  133. 9195 RETURN
  134. 10000 dr$="TOTAL DEBITS":cr$="TOTAL CREDITS"
  135. 10010 PRINT USING FF$;dr$,DEBIT
  136. 10020 PRINT USING FF$;cr$,CREDIT
  137. 10030 GOSUB 30000
  138. 10040 console
  139. 10050 CLOSE 1:CLOSE 2
  140. 10100 PRINT "PUT DISK #1 BACK IN DRIVE A - TYPE <cr> TO CONTINUE"
  141. 10105 INPUT line temp$
  142.     if size("master11.int")<1 then 10100
  143. 10110    lprinter
  144. 10115 print chr$(12):for z=1 to 100:next z:print chr$(12) 
  145. 10120    console
  146. 10195 chain"master11"
  147. 20000 console:PRINT clear$:PRINT
  148. 20010 PRINT "*** VALIDATING ACCOUNT NUMBERS ***"
  149. 20020 PRINT:PRINT "PLEASE WAIT"
  150. 20030 I=1
  151. 20040 read #2,i;N(0,1),N(0,2),Q$,N(0,7),N(0,8),N(0,9),\
  152.      N(0,10),N(0,11),N(0,12),N(0,13),N(0,14),N(0,15),N(0,16),\
  153.      N(0,17),N(0,18),N(0,19),FLAG$
  154. 20050 IF N(0,2)=0 THEN 29975
  155. 20055 IF FLAG$="P" THEN 21010
  156. 20062 FOR Z4=1 TO Z2
  157.      IF N(0,2)=H(Z4) THEN 20070
  158.       NEXT Z4
  159. 20064 J=2:GOTO 20500
  160. 20070 CASH.OUT=CASH.OUT+N(0,7):ACCT.NUM=N(0,2)
  161. 20072 IF N(0,7)<0 THEN CREDIT=CREDIT+N(0,7):REF%(Z4)=REF%(Z4)+1
  162. 20074 IF N(0,7)>0 THEN DEBIT=DEBIT+N(0,7):REF%(Z4)=REF%(Z4)+1
  163. 20076 FOR J=first to last STEP 2
  164. 20080 FOR Z4=1 TO Z2
  165. 20085 IF N(0,J)=0 THEN 21000
  166. 20090 IF N(0,J)=H(Z4) THEN 21000
  167. 20100 NEXT Z4
  168. 20500    lprinter
  169.     print:print n(0,j);" in record ";i;" is not a VALID account number!"
  170.     abort = 1
  171.     console
  172.     IF J=2 THEN 20076
  173. 21000 IF N(0,J+1)<0 THEN CREDIT=CREDIT+N(0,J+1):REF%(Z4)=REF%(Z4)+1
  174. 21002 IF N(0,J+1)>0 THEN DEBIT=DEBIT+N(0,J+1):REF%(Z4)=REF%(Z4)+1
  175. 21004 NEXT J
  176. 21010 I=I+1
  177. 21020 GOTO 20040
  178. 29975 PRINT clear$:PRINT
  179.     if abort = 1 then print "*** POSTING ABORTED !!! ***":GOTO 10050
  180. 29980 PRINT "*** POSTING ***"
  181. 29985 PRINT:PRINT "PLEASE WAIT"
  182. 29995 RETURN
  183. 30000 P9=100:PAGE=0
  184. 30005 IF P9>60 THEN GOSUB 31000
  185. 30010 OPEN "A:GLCDSIZE" AS 20:READ #20;LIMIT,DUMMY:CLOSE 20
  186.     LIMIT=LIMIT-1
  187. 30100 FOR I=1 TO Z2
  188. 30200 IF REF%(I)=0 THEN 30795
  189. 30300 READ #1,I;N(1,1),N(1,2),R$,N(1,4),N(1,5),N(1,6),N(1,7),\
  190.     N(1,8),N(1,9),N(1,10)
  191. 30305 PRINT USING FJ$;N(1,2),R$,N(1,6):P9=P9+1
  192. 30310 CURRENT=0
  193. 30500 FOR K=1 TO LIMIT
  194. 30510 read #2,K;N(0,1),N(0,2),Q$,N(0,7),N(0,8),N(0,9),\
  195.       N(0,10),N(0,11),N(0,12),N(0,13),N(0,14),N(0,15),N(0,16),\
  196.       N(0,17),N(0,18),N(0,19),FLAG$
  197. 30512 IF FLAG$="P" THEN 30580
  198. 30515 IF N(0,2)=N(1,2) AND N(0,7)<>0 THEN PRINT USING FK$;LEFT$(Q$,5),\
  199.     MID$(Q$,9,24),N(0,1),N(0,7):FOR X=4 TO 6:N(1,X)=N(1,X)+N(0,7):NEXT X:\
  200.     CURRENT=CURRENT+N(0,7):P9=P9+1:REF%(I)=REF%(I)-1
  201. 30520 IF P9>60 THEN GOSUB 31000
  202. 30530 IF REF%(I)=0 THEN K=LIMIT:GOTO 30580
  203. 30550 FOR J1=FIRST TO LAST STEP 2
  204. 30555 IF N(0,J1)=N(1,2) AND N(0,J1+1)<>0 THEN PRINT USING FK$;LEFT$(Q$,5),\
  205.     MID$(Q$,9,24),N(0,1),N(0,J1+1):FOR X=4 TO 6:N(1,X)=N(1,X)+N(0,J1+1):\
  206.     NEXT X:CURRENT=CURRENT+N(0,J1+1):P9=P9+1:REF%(I)=REF%(I)-1
  207. 30560 IF P9>60 THEN GOSUB 31000
  208. 30566 IF REF%(I)=0 THEN K=LIMIT:GOTO 30580
  209. 30570 NEXT J1
  210. 30580 NEXT K
  211. 30600 PRINT USING FL$;CURRENT,N(1,6):P9=P9+1
  212. 30650 PRINT #1,I;N(1,1),N(1,2),R$,N(1,4),N(1,5),N(1,6),N(1,7),\
  213.     N(1,8),N(1,9),N(1,10)
  214. 30655 PRINT:PRINT:P9=P9+2
  215. 30660 IF P9>60 THEN GOSUB 31000
  216. 30795 NEXT I
  217. 30800 FOR I=1 TO LIMIT
  218. 30810 read #2,I;N(0,1),N(0,2),Q$,N(0,7),N(0,8),N(0,9),\
  219.       N(0,10),N(0,11),N(0,12),N(0,13),N(0,14),N(0,15),N(0,16),\
  220.       N(0,17),N(0,18),N(0,19),FLAG$
  221. 30815 FLAG$="P"
  222. 30820 print #2,I;N(0,1),N(0,2),Q$,N(0,7),N(0,8),N(0,9),\
  223.       N(0,10),N(0,11),N(0,12),N(0,13),N(0,14),N(0,15),N(0,16),\
  224.       N(0,17),N(0,18),N(0,19),FLAG$
  225. 30825 NEXT I
  226. 30995 RETURN
  227. 31000 PRINT CHR$(12):P9=0:PAGE=PAGE+1
  228. 31005 PRINT USING FG$;D$(4),MID$(CO.NAME$,25,24),PAGE
  229. 31010 PRINT FH$
  230. 31015 PRINT FH1$
  231. 31020 PRINT FI$
  232. 31025 PRINT:P9=P9+6
  233. 31095 RETURN
  234.