1  REM  ****  HP BASIC PROGRAM LIBRARY  *******************************
2  REM
3  REM         EXLSE : CTC INVENTORY CONTROL 
4  REM                 FOR FINISHED PRODUCTS
5  REM         36211 REV  B  PART 6 OF 35   2/73 
6  REM
7  REM  ****  CONTRIBUTED PROGRAM  ************************************
10  H$='29'31'13'26'30
11  DIM A$[10],H$[5],B$[20],Y$[10],Z$[15],X$[1]
12  DIM C[4,8],S[16],P[13],K[12],U[30]
13  Y$="0123456789"
100  FILES C1
150  PRINT "(1) TOP OF FORM OR (2) ABDICK";
160  INPUT P5
170  MAT  READ K
172  DATA 31,28,31,30,31,30,31,31,30,31,30,31
200  READ C9,C8,C7,P9
210  DATA 13,4,8,13
220  MAT  READ P
230  DATA 1000,3800,4300,4900,6500,7500,7560,7760,8760,9760,9870,10350,10400
232  MAT  READ U
235  DATA 2100,3101,3300,3200,3400,4100,4200,0,1102,1104,1106,1108,1114,1118,1122
236  DATA 1126,1400,1401,1402,1403,1404,1405,1420,1300,1301,1302,1303,1200,1201,3120
240  P4=K4=0
260  DATA "C1","C2","C3","C4","C5","C6","C7","C8","C9","C10","C11","C12","C13"
300  PRINT "CURRENT DATE";
310  INPUT X
335  GOSUB 4800
355  D1=X1
360  D2=X2
365  D3=X3
370  GOSUB 3200
400  PRINT "FIRST PRD#";
405  INPUT C
410  GOSUB 3000
415  IF B1 THEN 400
420  P2=P
425  PRINT "LAST PRD#";
430  INPUT C
435  GOSUB 3000
440  IF B1 THEN 425
442  IF P >= P2 THEN 448
445  GOSUB 3010
447  GOTO 425
448  P3=P
450  PRINT "FIRST SER#";
455  INPUT X2
460  X1=P2
465  GOSUB 3100
466  C2=X2
470  IF B1 THEN 450
475  PRINT "LAST SER#";
480  INPUT X2
485  X1=P3
490  GOSUB 3100
492  C4=X2
495  IF B1 THEN 475
496  IF P2#P3 THEN 500
497  IF C4 >= C2 THEN 500
498  GOSUB 3120
499  GOTO 475
500  P9=66
520  GOSUB 8000
1000  FOR P1=P2 TO P3
1005  C3=C4
1007  IF P1=P3 THEN 1040
1010  C3=P[P1]
1020  IF P1=1 THEN 1040
1030  C3=C3-P[P1-1]
1040  FOR C1=C2 TO C3
1045  R=C1
1050  IF P1=1 THEN 1060
1055  R=R+P[P1-1]
1060  GOSUB 4000
1065  GOSUB 4100
1070  IF  NOT B1 THEN 1080
1072  GOSUB 3500
1073  IF B1 THEN 1080
1075  GOSUB 2000
1077  K4=K4+1
1080  NEXT C1
1085  C2=1
1090  NEXT P1
1168  PRINT "TOTAL UNITS="K4
1170  END 
2000  GOSUB 5000
2010  PRINT TAB(10);
2020  Z$="####  "
2030  X$="0"
2040  Z[1]=C1
2042  IF S[1]#5 THEN 2050
2044  Z[1]=Z[1]+900
2050  GOSUB 9000
2055  Z$="A#### "
2060  K3=2
2070  GOSUB 4400
2080  X$=" "
2090  K3=K3+1
2095  Z$="##/##/##   "
2100  X=S[4]
2105  GOSUB 4800
2110  Z[1]=X2
2112  Z[2]=X3
2115  Z[3]=X1+70
2117  IF X1<8 THEN 2120
2118  Z[3]=X1+60
2120  GOSUB 9000
2125  K3=K3+1
2127  Z$="##    "
2130  GOSUB 4400
2137  Z$="####    "
2140  GOSUB 4400
2145  Z$="#####    "
2146  X$="0"
2147  IF S[K3]#0 THEN 2152
2148  PRINT "         ";
2150  K3=K3+1
2151  GOTO 2155
2152  GOSUB 4400
2155  X$=" "
2157  Z$="##    "
2160  GOSUB 4400
2165  PRINT "  ";
2167  GOSUB 4400
2172  Z$="##M    "
2173  IF S5=1 THEN 2175
2174  Z$="##A    "
2175  GOSUB 4400
2180  Z$="####     "
2182  K3=K3+1
2185  GOSUB 4400
2190  Z$="######    "
2195  Z[1]=C[R2,7]
2200  GOSUB 9000
2205  Z$="$####     "
2210  Z[1]=S6
2220  GOSUB 9000
2223  Z[1]=S[15]
2224  GOSUB 9000
2225  Z$=" #.##%"
2226  Z[1]=S[16]+S[11]*.01
2227  IF S[16]#0 THEN 2230
2228  Z$="TE - ##"
2229  Z[1]=S[11]
2230  GOSUB 9000
2232  K=1
2235  GOSUB 9900
2240  P9=P9+2
2245  IF P9<60 THEN 2260
2250  GOSUB 8000
2260  RETURN 
3000  B1=0
3005  IF C>0 AND C<31 THEN 3020
3010  GOSUB 4250
3017  RETURN 
3020  P=C
3025  IF C<9 THEN 3090
3030  P=9
3035  IF C <= 16 THEN 3090
3040  P=10
3045  IF C <= 23 THEN 3090
3050  P=11
3055  IF C <= 27 THEN 3090
3060  P=12
3065  IF C <= 29 THEN 3090
3070  P=13
3090  RETURN 
3100  B1=0
3101  IF X1#5 THEN 3103
3102  X2=X2-900
3103  X=P[X1]
3104  IF X1=1 THEN 3110
3106  X=X-P[X1-1]
3110  IF X2>0 AND X2 <= X THEN 3150
3120  GOSUB 4250
3130  B1=1
3150  RETURN 
3200  PRINT "DAYS TO EXPIRE";
3205  INPUT D5
3225  X2=D2+D5
3226  X1=D1
3227  X3=D3
3230  IF X2 <= K[X1] THEN 3260
3235  X2=X2-K[X1]
3237  X1=X1+1
3240  IF X1 <= 12 THEN 3230
3245  X1=X1-12
3250  X3=X3+1
3255  GOTO 3240
3260  D=X3*10^4+X1*100+X2
3265  J=1
3267  B$="SALES LOC"
3270  K1=0
3275  K2=99
3280  GOSUB 3400
3285  B$="LSE STAT (10=1&2)"
3290  K2=10
3295  GOSUB 3400
3300  RETURN 
3400  PRINT B$;
3410  INPUT A$
3415  IF A$[1,1]#"A" THEN 3430
3420  J[J]=-1
3425  GOTO 3460
3430  IF A$#"NE" THEN 3435
3432  J[1]=-2
3433  GOTO 3460
3435  IF A$#"SW" THEN 3440
3437  J[1]=-3
3438  GOTO 3460
3440  GOSUB 4200
3445  IF B1 THEN 3400
3450  IF Z >= K1 AND Z <= K2 THEN 3455
3452  GOSUB 4250
3453  GOTO 3400
3455  J[J]=Z
3460  J=J+1
3465  RETURN 
3500  B1=0
3505  IF S[3]#6 THEN 3525
3510  IF J[1]=-1 THEN 3555
3515  IF J[1]#-2 THEN 3535
3520  IF S[5]<50 THEN 3555
3525  B1=1
3530  RETURN 
3535  IF J[1]#-3 THEN 3550
3540  IF S[5]<50 THEN 3525
3545  GOTO 3555
3550  IF J[1]#S[5] THEN 3525
3555  IF J[2]=-1 THEN 3575
3560  IF J[2]=10 THEN 3570
3562  IF J[2]#S[8] THEN 3525
3565  GOTO 3575
3570  IF S[8]#1 AND S[8]#2 THEN 3525
3575  X=S[4]
3580  GOSUB 4800
3585  IF X1<8 THEN 3600
3590  X1=X1+60
3595  GOTO 3605
3600  X1=X1+70
3605  X2=X2+S[10]
3610  IF X2 <= 12 THEN 3630
3615  X2=X2-12
3620  X1=X1+1
3625  GOTO 3610
3630  X3=X3-1
3631  IF X3>0 THEN 3640
3632  X2=X2-1
3633  IF X2>0 THEN 3636
3634  X2=12
3635  X1=X1-1
3636  X3=K[X2]
3640  D0=X1*10^4+X2*100+X3
3645  IF D0>D THEN 3525
3650  RETURN 
4000  X=R/C8
4038  X1=INT(X)
4040  X2=INT((X-X1)*100)
4042  FOR I=1 TO (C8-1)
4044  IF X2=I*25 THEN 4054
4046  NEXT I
4048  R1=X1
4050  R2=C8
4052  GOTO 4057
4054  R1=X1+1
4056  R2=I
4057  RESTORE 260
4058  FOR N=1 TO C9
4060  READ A$
4062  IF R1<201 THEN 4070
4063  R1=R1-200
4065  NEXT N
4067  PRINT "*"
4068  STOP 
4070  ASSIGN A$,1,W5
4080  RETURN 
4100  B1=0
4102  MAT  READ #1,R1;C
4105  IF C[R2,1]=-1 THEN 4180
4107  B1=1
4110  J=1
4111  FOR I=1 TO 9 STEP 4
4112  S5=SGN(C[R2,J])
4113  C[R2,J]=ABS(C[R2,J])
4114  S[I]=INT(C[R2,J]/10^4)
4115  S[I+1]=C[R2,J]-S[I]*10^4
4116  IF I#9 THEN 4119
4117  S[I+1]=INT(S[I+1]/100)
4118  S[I+2]=C[R2,J]-S[I]*10^4-S[I+1]*100
4119  J=J+2
4120  NEXT I
4122  S[3]=INT(C[R2,2]/10^5)
4125  S[4]=C[R2,2]-S[3]*10^5
4145  S[7]=INT(C[R2,4]/10)
4150  S[8]=C[R2,4]-S[7]*10
4170  S[12]=INT(C[R2,6]/100)
4175  S[13]=C[R2,6]-S[12]*100
4176  S[14]=INT(C[R2,8]/10^5)
4177  S[15]=INT((C[R2,8]-S[14]*10^5)/10)
4178  S[16]=C[R2,8]-S[14]*10^5-S[15]*10
4179  S6=S[13]*10+S[14]
4180  RETURN 
4200  B1=Z=0
4210  FOR I1=1 TO LEN(A$)
4220  FOR I2=1 TO 10
4230  IF A$[I1,I1]=Y$[I2,I2] THEN 4260
4240  NEXT I2
4250  PRINT '7'7"INVALID DATA";H$[3,5];
4255  B1=1
4257  RETURN 
4260  Z=Z*10+I2-1
4270  NEXT I1
4280  RETURN 
4400  Z[1]=S[K3]
4405  K3=K3+1
4410  GOSUB 9000
4420  RETURN 
4800  X1=INT(X/10^4)
4810  X2=INT((X-X1*10^4)/100)
4820  X3=X-X1*10^4-X2*100
4830  RETURN 
5000  IF S[1]#8 THEN 5050
5010  PRINT "VT06";
5020  RETURN 
5050  Z$="####-###"
5055  X$="0"
5060  X=INT(U[S[1]]/1000)
5065  GOTO X OF 5070,5075,5080,5085
5070  Z[1]=2200
5072  GOTO 5090
5075  Z[1]=3000
5077  GOTO 5090
5080  Z[1]=3300
5082  GOTO 5090
5085  Z[1]=3360
5090  Z[2]=U[S[1]]-X*1000
5095  GOSUB 9000
5100  RETURN 
6000  PRINT 
6040  RETURN 
8000  GOTO P5 OF 8005,8010
8005  PRINT '12'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18'18;
8007  GOTO 8020
8010  K=66-P9
8015  GOSUB 9910
8020  K=4
8030  GOSUB 9910
8040  PRINT TAB(16)"DATE: ";
8050  Z$="##/##/##"
8060  X$=" "
8070  Z[1]=D1
8080  Z[2]=D2
8090  Z[3]=D3
8100  GOSUB 9000
8110  PRINT TAB(50)"I N V E N T O R Y  C O N T R O L";
8140  PRINT "                             PAGE: ";
8150  Z$="###"
8160  P4=P4+1
8165  Z[1]=P4
8170  GOSUB 9000
8172  GOSUB 6000
8175  PRINT TAB(52)"LEASES EXPIRING IN ";
8177  Z[1]=D5
8178  GOSUB 9000
8179  PRINT " DAYS";
8180  K=2
8190  GOSUB 9900
8200  PRINT "PRODUCT  SERIAL CUST#   DATE   SALES   CUST#  ";
8205  PRINT "INVOICE LEASE   FIELD  TERMS SALESMAN  AGREEMENT  MAINT.  ";
8210  PRINT "EQ.RENTAL   TAX RATE";
8212  GOSUB 6000
8215  PRINT TAB(12)"#";TAB(32)"LOC. UNIT LOC    #    ";
8217  PRINT "STATUS SER LOC                     ";
8220  PRINT "#      PRICE     PRICE";
8222  GOSUB 6000
8225  PRINT TAB(31);
8230  FOR J=1 TO 2
8235  IF J[J]#-1 THEN 8246
8240  PRINT "( ALL)";
8245  GOTO 8300
8246  IF J=2 AND J[2]#10 THEN 8280
8247  PRINT "( 1&2)";
8248  GOTO 8300
8250  IF J[J]#-2 THEN 8265
8255  PRINT "( NE )";
8260  GOTO 8300
8265  IF J[J]#-3 THEN 8280
8270  PRINT "( SW )";
8275  GOTO 8300
8280  Z$="( ## )"
8285  X$=" "
8287  Z[1]=J[J]
8290  GOSUB 9000
8300  PRINT TAB(54);
8310  NEXT J
8330  K=2
8335  GOSUB 9900
8340  P9=13
8350  RETURN 
9000  REM
9002  V=Z2=Z3=Z4=Z5=Z7=Z8=Z9=1
9004  DIM V$[15]
9008  Z0=Z9-1
9010  Z0=Z0+1
9012  IF Z0=LEN(Z$)+1 THEN 9140
9014  IF Z$[Z0,Z0]="#" THEN 9030
9016  IF Z$[Z0,Z0+1]=".#" THEN 9030
9018  IF Z$[Z0,Z0+1]="+#" THEN 9026
9020  V$[V,V]=Z$[Z0,Z0]
9022  V=V+1
9024  GOTO 9010
9026  Z4=0
9028  GOTO 9010
9030  Z=100
9032  Z6=Z[Z2]
9034  Z9=Z0-1
9036  Z9=Z9+1
9038  IF Z$[Z9,Z9]="." THEN 9044
9040  IF Z$[Z9,Z9]="#" THEN 9036
9042  GOTO 9052
9044  IF Z5#1 THEN 9052
9046  Z5=0
9048  Z=Z9
9050  GOTO 9036
9052  IF Z#100 THEN 9056
9054  Z=Z9
9056  IF Z4=1 THEN 9070
9058  IF Z6 >= 0 THEN 9066
9060  V$[V,V]="-"
9062  V=V+1
9064  GOTO 9070
9066  V$[V,V]=" "
9068  V=V+1
9070  IF Z=Z9 THEN 9076
9072  Z6=ABS(Z6)+5*10^(Z-Z9)
9074  GOTO 9078
9076  Z6=ABS(Z6)+.5
9078  Z7=10^(Z-Z0-1)
9080  Z4=10*Z7
9082  FOR Z1=Z-Z0 TO Z+1-Z9 STEP -1
9084  IF Z1#0 THEN 9094
9086  V$[V,V]="."
9088  V=V+1
9090  Z3=0
9092  GOTO 9132
9094  Z8=INT(Z6/Z7)
9096  IF Z6<Z4 THEN 9104
9098  V$[V,V]="#"
9100  V=V+1
9102  GOTO 9130
9104  Z6=Z6-Z8*Z7
9106  IF Z8=0 THEN 9110
9108  Z3=0
9110  IF Z3=0 THEN 9126
9112  IF Z1#1 THEN 9120
9114  V$[V,V]="0"
9116  V=V+1
9118  GOTO 9130
9120  V$[V,V]=X$
9122  V=V+1
9124  GOTO 9130
9126  V$[V,V]=Y$[Z8+1,Z8+1]
9128  V=V+1
9130  Z7=Z7/10
9132  NEXT Z1
9134  Z3=Z4=Z5=Z7=1
9136  Z2=Z2+1
9138  GOTO 9008
9140  PRINT V$;
9142  V$=""
9144  RETURN 
9900  GOSUB 6000
9910  FOR I=1 TO K
9915  PRINT 
9930  NEXT I
9940  RETURN 
9999  END 
