-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRC1000.BAS
1462 lines (1461 loc) · 74.7 KB
/
RC1000.BAS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
10 GOTO 1020
20 'SAVE "A:RC1000.BAS": END
29 REM
50 REM *****************************************************************
51 REM RC1000.bas Version 1.00i/ms
52 REM *****************************************************************
53 REM
54 REM By H.C. Pennington
55 REM 10/01/84
56 REM
57 REM Copyright (c) 1984, Hattori Corporation of America, Inc.
58 REM 1330 West Walnut Parkway, Compton, CA 90220
59 REM
60 REM
999 REM
1000 REM *****************************************************************
1005 REM INITIALIZATION
1010 REM *****************************************************************
1015 REM
1020 CLS 'clear the screen
1025 DIM DA$(81), LN$(81), MG$(35) 'Dimension arrav variables
1026 DIM MU$(40), HL$(41) 'Dimension array variables
1027 DIM DT(85), DA(85), SD(85), SN(85) 'Dimension array variables
1029 '(Below...) Determine video type
1030 PRINT "A": DEF SEG = &HB000: IF PEEK(0) <> 65 THEN X = 1: DEF SEG = &HB800
1031 IF X = 1 THEN FI$ = "GRAPHICA.PIX" ELSE FI$ = "MONOCHRM.PIX"'Set bboard file
1032 '- - - - - - - - - - - - -
1033 LA(3) = 0 'Num of WORLD TIME 1b1s (0-1)
1034 GOTO 1040 ' Skip the watch logo and time due to missing pix file
1035 BLOAD FI$, 0 'Load billboard from disk
1036 '
1037 LOCATE 12, 39: PRINT LEFT$(TIME$, 5); 'Print hrs/minutes on watch
1038 LOCATE 12, 46: PRINT RIGHT$(TIME$, 2); 'Print seconds on watch
1039 IK$ = INKEY$: IF IK$ = "" THEN 1037 'Scan keyboard for key press
1040 LOCATE 21, 50: COLOR 31: PRINT "Initilizing program ... "; 'Print init msg
1041 COLOR 7 'Restore video to normal
1042 '- - - - - - - - - - - - -
1043 KEY OFF 'Turn off line 25 display
1045 CR = 220: CR$ = CHR$(219) 'Cursor chars: type, insert
1046 CC = 0 'Current character
1047 PZ = 2776 'Current line position
1048 PO = PZ 'Current screen position
1049 IL = PZ + 46 'Maximum string length
1050 EN = 80 'Watch: end of data
1051 AP = 0 'AM/PM value
1052 AP$ = "" 'AM/PM string
1053 BL = 0 'Beginning Line # (for sort routine)
1054 C% = 0 'Sort variable
1055 F% = 0 'Sort variable
1056 G% = 0 'Sort variable
1057 N% = 0 'Sort variable
1058 X = 0: J = 0: Y = O 'Loop counters
1059 LO = 1 'Print locater (used in LOCATE stmnts)
1060 LL = 0 'List length-used in WRITE watch data
1061 MG = 0 'Message number-[ used with MU$(MU) ]
1062 MU = 0 'Menu number-[ used with MU$(mu) ]
1063 PR = 0 'Print utility variable
1064 'PR$( 'Print utility-used for LPRINTing file
1065 EL = 0 'End of list
1076 EF = 80 'End file-the max # of lines in a file
1077 MU = 0 'Set menu to Main Menu
1078 LN = 1 'Current line# of data
1080 CL = 0 'Temp line# to print text area
1085 'DA( Data attribute: 4=labl 5=dat
1090 'DT( Data type: O=Me 1=ShA 2=W'kA 3=WTime
1095 F1 = 0 'Flag: 0=nrml input 1=insert
1100 F2 = 0 'Flag: 0=no chug to data l=data altd
1105 F3 = 0 'Flag: file altered & NOT saved
1120 'FR( O=lines free 1=labels free
1125 PR$ = "" 'Set prnt string length
1130 IP$ = "" 'INPUT string
1135 'DL$( Deflt labels; data types 0-3
1140 'DD$( Deflt data; data types 0-3
1145 'IK$="" Inkey input string
1150 IK = 0 'Val of IlK$, if any
1155 LA = 0 '"Found" Label list address
1160 '
1161 WT = 1 'World time record counter
1162 'WT$ 'Wrld time string - hilt when FIELDed
1163 'WX$ 'Wrld time offsets - iait when FIELDed
1166 CN = 0 'Cur line # used for wrking storage
1168 DD = 0 'Day-date validation [not used on IBM]
1170 DY = O 'Days-utility var [ROLL DAYS]
1172 DY$ = "" 'Days-utility var [WRITE WATCH DATA]
1174 HH = 0 'Hours-utility var
1176 HR = 0 'Hours-utility var
1178 HR$ = "" 'Hours-utility var
1180 OS = 0 'Off-set [used in DELETE]
1182 MI$ = "" 'Minutes-utility var.
1184 MM = 0 'Minutes-utility var
1186 MO = 0 'Months-utility var
1188 MO$ = "" 'Months-utility var
1190 Q1 = 0 'Question? 1=YES 0=NO
1192 RQ = 0 'Request! #=request number
1194 SA = 0 'Scrn attrib [ used with COLOR stmnt ]
1196 SSP = 0 'Def# of spcs [ used w/SPC(SP) stmt
1198 SS = 0 'Seconds-utility variable
1200 YR = 0 'Year-utility variable
1202 YY = 0 'Year-utility variable
1204 DR$ = "" 'Watch directory
1205 CT$ = "" 'Cut & Paste buffer
1206 CT = 0 'Data type of "cut" buffer contents
1280 '
1285 V1$ = "EATONSHIRDLU BCDFGJKMPQVWXYZ1234567890:*/#&+-=?."'Validation string
1286 V2$ = V1$ + "" 'Validation string
1287 V4$ = CHR$(8) + CHR$(13) + CHR$(27) 'Validation string
1289 YN$ = "YyNn" + CHR$(27) '"YES/NO" validation string
1290 '
1295 REM -----------------------
1300 REM INITIALIZE COMMAND STRINGS FOR 'EDIT' MODULE
1305 '
1310 RESTORE 1330 'Set next data to be read
1315 FOR X = 1 TO 13 'Build command string
1320 READ Y: CM$(1) = CM$(1) + CHR$(Y) 'Put val into command string
1325 NEXT X 'Loop until done
1330 DATA 13, 08, 27 : 'CR BS Esc
1335 DATA 04, 05, 09, 10 : '^D ^E ^I ^J
1340 DATA 18, 20, 6, 19, 2, 14 : '^R ^T ^F ^S ^B ^N
1345 '- - - - - - - - - - - - -
1350 RESTORE 1370 'Set next data to be read
1355 FOR X = 1 TO 10 'Build command string
1360 READ Y: CM$(2) = CM$(2) + CHR$(Y) 'Put val into command string
1365 NEXT X 'Loop until done
1370 DATA 75, 77, 72, 80 : 'Lt Rt Up Dn
1375 DATA 82, 83 : 'Insert, Delete
1380 DATA 73, 81 : 'PgUp, PgDn
1385 DATA 71, 79 : 'Home, End,
1390 '- - - - - - - - - - - - -
1395 FOR X = 0 TO 9 'Set loop
1400 KEY X + 1, MID$("[]{}<>()|^", X + 1, 1)'Program funct keys
1405 CM$(3) = CM$(3) + MID$("[]{}<>()|^", X + 1, 1)'Build command string
1410 NEXT X 'Loop until done
1415 '
1500 REM ******************************************************************
1501 REM TRANSFRER PROGRAM CONTROL TO MAINLINE
1502 REM ******************************************************************
1503 '
1505 GOSUB 15820 'Initialize all strings
1506 GOSUB 15030 'Draw the screen
1510 OPEN "R", 3, "TIMEZONE.DAT", 20 'Open world time file
1520 FIELD #3, 18 AS WT$: WT = 1 'Field world time record
1525 FIELD #3, 13 AS DU$, 2 AS WH$ 'Field 17 hours
1610 GOSUB 10130 'Create an "empty" file
1620 GOSUB 5710 'Display file in text area
1999 '
2000 REM ********************************************************************
2001 REM MAIN LINE PROGRAM
2002 REM ********************************************************************
2003 '
2004 '- - - - - - - - - MAIN MENU
2010 MU = 0: CLOSE 1, 2 'Set Henu=0 & else files 1 & 2
2020 GOSUB 3340 'Print the menu
2030 COLOR 31 'Set display to hi—blink
2040 SA = 31: MG = 11: GOSUB 13430 'Print prompt
2050 COLOR 7 'Hi—blink off
2060 GOSUB 3540 'Get user input
2061 IF IK$ = CHR$(27) THEN IK$ = "1" 'Esc was pressed—load 1K$
2062 '
2070 ON VAL(IK$) GOTO 3760, 2105, 2640, 2940, 3140 'Jump on val of input
2080 ' Edit Xmit Prnt Sys Exit
2081 '
2090 SOUND 37, 1: GOTO 2060 'BLAT & rtn to KB scan
2099 '
2100 REM ***********************
2101 REM TRANSMIT TO WATCH
2102 REM ***********************
2103 '
2105 SP = 20: MU = 3: GOSUB 3340: SP = 0'Set menu pan & print menu
2106 MG = 32: GOSUB 13430 'Print "set receive" msg
2110 IK$ = INKEY$: IF IK$ = "" THEN 2110'Scan KB
2115 ON INSTR(CHR$(13) + CHR$(27), IK$) GOTO 7605, 2130'Jump on input value
2120 SOUND 37, 1: GOTO 2110 'BLAT & rtn to KB scan
2130 GOTO 2010 'Vector from 2115—Jmp to XMIT
2131 '
2200 REM ***********************
2201 REM SET TIME ZONE
2202 REM ***********************
2203 '
2205 MG = 9: GOSUB 13430: MG = 20 'Print "TZ" msg & set err msg
2206 IP$ = "": LO = 52: GOSUB 13930: GOSUB 14505'Wait for user input
2208 IF IP$ = "" THEN 2950 'EXIT if <Enter> pressed
2210 IF VAL(IP$) < 1 OR VAL(IP$) > 24 THEN GOSUB 13230: GOTO 2205'Invalid input
2212 TZ = VAL(IP$): GOSUB 11330 'Update status display
2214 GOTO 2950 'EXIT to system menu input
2599 '
2600 REM ***********************
2610 REM PRINT WATCH DATA
2620 REM ***********************
2630 '
2640 OPEN "lptl:" FOR RANDOM AS #2: WIDTH #2, 132: MG = 22: GOSUB 13430'Opn Lptr & Prtr msg
2660 IK$ = INKEY$: IF IK$ = "" THEN 2660 'Scan KB for user input
2670 ON INSTR(CHR$(13) + CHR$(27), IK$) GOTO 2700, 2800',Imp on user input
2680 GOTO 2640 'Illegal input -rtn to KB scan
2700 PRINT #2, STRING$(45 - (LEN(MG$(24) + FI$) / 2), 32) + MG$(24) + FI$'Print header
2710 PRINT #2, STRING$(10, 32) + STRING$(70, "=")'Finish header
2720 LPRINT 'Print blank line
2730 X = 1 'Set starting line#
2740 '- - - - - BUILD PRINT STRINGS
2745 '
2750 IF X <= EN THEN PR$ = STRING$(10, 32) + LN$(X) + ">" + DA$(X) + "<" + PR$(DA(X)) + PR$(DT(X))
2760 IF (X + 40) <= EN THEN PR$ = PR$ + STRING$(3, 32) + LN$(X + 40) + ">" + DA$(X + 40) + "<" + PR$(DA(X + 40)) + PR$(DT(X + 40))
2770 '- - - - - - - - - - - - -
2775 IF X > EN THEN 2810 'EXIT: end of active file
2780 PRINT #2, PR$ 'Print data
2790 IK$ = INKEY$: IF IK$ = CHR$(27) THEN 2810'Bail out if Esc pressed
2800 X = X + 1: IF X <= 40 THEN 2750 'Loop until done
2810 LPRINT STRING$(63 - X, 13) 'Simulate form feed
2820 GOSUB 13630: CLOSE 2 'Clear msg & close LPT1
2830 GOTO 2010 'EXIT to menu input
2840 '
2900 REM ***********************
2910 REM SYSTEM MENU
2920 REM ***********************
2930 '
2940 MU = 1: GOSUB 3340 'Print menu
2950 SA = 31: MG = 11: GOSUB 13430 'Print prompt
2960 GOSUB 3540 'Get user input
2970 IF IK$ = CHR$(27) THEN 2010 'EXIT: M-Menu if Esc pressed
2980 ON IK GOTO 11530, 10330, 3030, 3040, 2205 'Jump on user input
2990 ' FNam T&D ' 'Load Save Exit
3000 GOTO 2960 'Scan again if invalid input
3010 ' - - - - - - - - - - - - -
3020 MU = 0 'Reset menu: M-Menu
3030 GOSUB 9070: GOTO 2950 'GSub LOAD & EXIT: S-Mnu input
3040 GOSUB 9330: GOTO 2950 'GSub SAVE & EXIT: S-Mnu input
3050 '
3100 REM ***********************
3110 REM EXIT PROGRAM
3120 REM ***********************
3130 '
3140 MG = 14: GOSUB 13430 'Print "RU sure?" prompt
3150 IK$ = INKEY$: IF IK$ = "" THEN 3150 'Scan KB for response
3160 ON INSTR(YN$, IK$) GOTO 3180, 3180, 3190, 3190, 3190'Jump on Y or N
3170 SOUND 37, 1: GOTO 3150 'BLAT & rtn to KB scan
3180 CLS : END 'Clear screen & NEW program
3190 GOSUB 13630 'Clear msg area
3200 GOTO 2010 'EXIT to S-Menu input
3210 '
3300 REM ***********************
3310 REM PRINT MENUS
3320 REM ***********************
3330 '
3340 LOCATE 2, 2: COLOR 15
3341 IF SP = 0 THEN SP = 28 'Set menu position if not already set
3345 IF F2 > 0 THEN GOSUB 5090 'If data altered, insert into array
3350 MU = MU * 6 'Set Mnu array to prnt menu requested
3355 PRINT SPC(SP); MU$(MU); : COLOR 7 'Print title in Hi-intsty
3356 LOCATE 8, 2: PRINT SPC(77); 'Clear line #8
3360 FOR X = 1 TO 5 'Set loop to print menu
3370 LOCATE X + 2, 2: PRINT SPC(SP); MU$(MU + X); 'Print menu
3380 NEXT X 'Loop until done
3390 MU = MU * .1 'Reset val of MU
3400 RETURN 'Return to caller
3410 '
3500 REM ***********************
3510 REM MENU INPUT - "Choose a number"
3520 REM ***********************
3530 '
3540 V3$ = "12345" 'Input validation string
3550 '
3560 IK$ = INKEY$: IF IK$ = "" THEN 3560 'Scan KB
3570 IF IK$ = CHR$(27) THEN RETURN 'Return if Esc is pressed
3580 IF INSTR(V3$, IK$) THEN IK = VAL(IK$): RETURN'Load IK w/val & rtn to caller
3590 SOUND 37, 1 'BLAT on invalid iput
3600 GOTO 3560 'Rtn to scan KB
3610 '
3700 REM *********************************************************************
3710 REM TEXT ENTRY -- EDIT/CREATE WATCH DATA
3720 REM *********************************************************************
3730 '
3740 '--------KEYBOARD SCAN
3750 '
3760 LOCATE 18, 1: PRINT MG$(F1); 'Print input status mode
3770 GOSUB 14210 'Print help screen
3780 CC = PEEK(PO) 'Get current char on screen
3790 POKE PO, CC: POKE PO + 1, 7 'Put current char on screen
3800 IK$ = INKEY$ 'Scan KB
3810 ON LEN(IK$) GOTO 3890, 3840 'Jmp on length of inkey value
3820 IF IK$ = "" THEN POKE PO + 1, 15: POKE PO, CR: GOTO 3790'IK$ empty; flash 6 scan
3830 '- - - - - - - - - - - - -
3840 IK$ = RIGHT$(IK$, 1) 'Get right most bye of IK$
3850 ON INSTR(CM$(2), IK$) GOTO 4030, 4110, 4970, 4850, 4710, 4400, 5310, 5200, 4190, 4250
3860 ' Left, Rght, Up , Down, Ins , Del , PgUp,
3861 ' PgDn, Home, End
3870 SOUND 37, 1: GOTO 3780 'BLAT & return to KB scan
3880 '- - - - - - - - - - - - -
3890 ON INSTR(CM$(1), IK$) GOTO 4850, 4310, 5630, 6090, 4500, 6700, 5420, 5550, 7575, 7305, 7405, 7485, 7495
3900 ' CR , BSpc, Esc , ^D , ^E , ^I , ^J ,
3901 ' ^R , ^T , ^F , ^S , ^B , ^N
3910 '
3920 ON INSTR(CM$(3), IK$) GOTO 12030, 12030, 12230, 12430, 12630, 12830, 8755, 8785, 7505, 7510
3930 ' F1 , F2 , F3 , F4 , F5 ,
3931 ' F6 , F7 , F8 , F9 , F10
3940 '
3950 IF INSTR(V1$, IK$) THEN 3955 ELSE 3980'Test for valid character
3955 IF F1 THEN 4590 'If insert is on, go do it
3960 POKE PO, ASC(IK$) 'Put character on the screen
3965 F2 = 1: IF F2 THEN F3 = 1 'Set flag: file not SAVEd
3970 PO = PO + 2: IF PO > IL THEN PO = PZ: GOSUB 4780'Calc new scn pos'n & chk for len
3975 GOTO 3780 'EXIT to KB scan
3980 IF ASC(IK$) > 90 THEN IK$ = CHR$(ASC(IK$) - 32): GOTO 3950'Conv to lower case
3982 SOUND 37, 1: GOTO 3780 'BLAT 6 rtn to KB scan
3985 '
4000 REM -----------------------
4010 REM CURSOR LEFT -- LEFT ARROW KEY
4020 '
4030 PO = PO - 2: IF PO < PZ THEN PO = IL: GOSUB 4780'Move back 1 and chk position
4040 CC = PEEK(PO): POKE PO, CR 'Flash cursor
4050 SOUND 2000, 1: POKE PO, CC 'Waste time 6 restore char
4060 GOTO 3780 'EXIT to key scan
4070 '
4080 REM -----------------------
4090 REM CURSOR RIGHT -- RIGHT ARROW KEY
4100 '
4110 PO = PO + 2: IF PO > IL THEN PO = PZ: GOSUB 4780'Move fwd 1 & chk position
4120 CC = PEEK(PO): POKE PO, CR 'Flash cursor
4130 SOUND 2000, 1: POKE PO, CC 'Waste time & restore character
4140 GOTO 3780 'EXIT to KB scan
4150 '
4160 REM -----------------------
4170 REM CURSOR TO BEGINNING OF LINE -- HOME KEY
4180 '
4190 PO = PZ 'Set position to beg of line
4200 GOTO 3780 'EXIT to KB scan
4210 '
4220 REM -----------------------
4230 REM CURSOR TO END OF LINE -- END KEY
4240 '
4250 PO = IL 'Set positon to end of line
4260 GOTO 3780 'EXIT to KB scan
4270 '
4280 REM -----------------------
4290 REM BACKSPACE AND ERASE -- BACKSPACE KEY
4300 '
4310 PO = PO - 2: IF PO < PZ THEN PO = IL: GOSUB 4780'Back 1 & chk position
4320 CC = 32: POKE PO, CR 'Set cur char to space & flash cursor
4330 IF F1 THEN 4400 'Insert is on—go to delete char
4340 SOUND 1000, 1: POKE PO, CC 'BEEP 6 print a space
4350 GOTO 3780 'EXIT to KB scan
4360 '
4370 REM -----------------------
4380 REM DELETE CHARACTER -- DELETE KEY
4390 '
4400 FOR X = PO TO IL STEP 2 'Set limits of move
4410 POKE X, PEEK(X + 2) 'Move entire line left 1 char
4420 NEXT X 'Loop until done
4430 POKE IL, 32 'Put space in position 24
4440 SOUND 1000, 1 'BEEP
4450 GOTO 3780 'EXIT to KB scan
4460 '
4470 REM -----------------------
4480 REM ERASE FROM CURSOR POSITION TO EOL -- ^E
4490 '
4500 FOR X = PO TO IL STEP 2 'Set loop to length of line
4510 POKE X, 32 'Fill with spaces
4520 NEXT X 'Loop until done
4530 F2 = 1 'Set flag: data is altered!
4540 GOTO 3780 'EXIT to KB scan
4550 '
4560 REM -----------------------
4570 REM INSERT CHARACTER -- INSERT MODE ON
4580 '
4590 FOR X = IL TO PO STEP -2 'Set limits of move
4600 POKE X, PEEK(X - 2) 'Move line right 1 character
4610 NEXT X 'Loop until done
4620 POKE PO, ASC(IK$) 'Put a pace under the cursor
4630 PO = PO + 2: IF PO > IL THEN PO = PZ: GOSUB 4780'Increment pos'n & chk for EOLine
4640 F2 = 1 'Set flag: data is altered!
4660 GOTO 3780 'EXTT to KB scan
4670 '
4680 REM -----------------------
4690 REM TOGGLE INSERT MODE ON/OFF INSERT KEY
4700 '
4710 IF F1 THEN F1 = 0: CR = 220 ELSE F1 = 1: CR = 219'Toggle Fl (insert flag)
4720 LOCATE 18, 1: PRINT MG$(F1); 'Pint input status mode (type/insert)
4730 GOTO 3780 'EXIT to KB scan
4740 '
4750 REM -----------------------
4760 REM INSERT OFF -- SUBROUTINE
4770 '
4780 F1 = 0: CR = 220 'Turn off insert mode
4790 LOCATE 18, 1: PRINT MG$(F1); 'Prnt input status mode (type/insert)
4800 RETURN 'Return to caller
4810 '
4820 REM -----------------------
4830 REM SCROLL UP -- UP ARRCM KEY PRESSED
4840 '
4850 IF EN = 1 THEN 4920 'Special case: EXIT if file is 1 line
4860 IF F2 > 0 THEN GOSUB 5090 'Data altrd-insert cur line into file
4870 IF F1 > 0 THEN GOSUB 4780 'If insert on, turn it off
4880 IF EN < EF THEN CN = EN 'Set temporary end of list variable
4890 LN = LN + 1: IF LN > CN THEN LN = 1 'Increment current line#
4900 GOSUB 5710 'Go display data in text area
4910 PO = PZ 'Set cursor to beg of line
4920 GOTO 3780 'EXIT to KB scan
4930 '
4940 REM -----------------------
4950 REM SCROLL DOWN -- DOWN ARROW/CR KEY
4960 '
4970 IF EN = 1 THEN 5040 'Spec case: Exit if file has 1 line
4980 IF F2 > 0 THEN GOSUB 5090 'Data altered: insert into file
4990 IF F1 > 0 THEN GOSUB 4780 'If insert on, turn it off
5000 IF EN < EF THEN CN = EN 'Set temporary end of list
5010 LN = LN - 1: IF LN < 1 THEN LN = CN'Decrement current line#
5020 GOSUB 5710 'Go display data in text area
5030 PO = PZ 'Set cursor to beg of line
5040 GOTO 3780 'EXIT to KB scan
5050 '
5060 REM -----------------------
5070 REM CURRENT LINE (CL$) INTOTHE ARRAY
5080 '
5090 DA$(LN) = "" 'Clr string of current contents
5100 FOR X = 0 TO 23 'Set loop to length of pick-off
5110 DA$(LN) = DA$(LN) + CHR$(SCREEN(18, 29 + X))'Put screen contents into file
5120 NEXT X 'Loop until done
5130 IF F2 = 1 THEN F3 = 1 'Set flag: FILE altered!
5140 F2 = 0 'Reset data changed flag
5150 PO = PZ: RETURN 'Cursor beg of line & EXIT to KB scan
5160 '
5170 REM -----------------------
5180 REM PAGE UP PgUp KEY
5190 '
5200 IF EN = 1 THEN 5260 'Spec case: EXIT if 1 line file
5210 IF EN < 12 THEN 4850 'Can't page-up do up arrow instead
5220 IF F2 > 0 THEN GOSUB 5090 'Data altered-insert into array
5230 IF F1 > 0 THEN GOSUB 4780 'If insert on, then turn off
5240 LN = LN + 11: IF LN > EN THEN LN = LN - EN'Increment line# by 11
5250 GOSUB 5710 'Gp print the data in text area
5255 PO = PZ 'Reset cursor position
5260 GOTO 3780 'FITT to KB scan
5270 '
5280 REM -----------------------
5290 REM PAGE DOWN -- PgDn KEY
5300 '
5310 IF EN = 1 THEN 5370 'Spec case: EXIT if 1 line file
5320 IF EN < 12 THEN 4970 'Can't PgDn - use dwm arrow instead
5330 IF F2 > 0 THEN GOSUB 5090 'Data altered-insert into file
5340 IF F1 > 0 THEN GOSUB 4780 'If insert on, turn it off
5350 LN = LN - 11: IF LN < 1 THEN LN = LN + EN'Decrement line# by 11
5360 GOSUB 5710 'Go print data in text area
5365 PO = PZ 'Reset cursor position
5370 GOTO 3780 'EXIT to KB scan
5380 '
5390 REM -----------------------
5400 REM JUMP NEXT LABEL -- ^J
5410 '
5420 IF EN = 1 THEN 5500 'Spec case: EXIT if 1 line file
5430 IF F2 > 0 THEN GOSUB 5090 'Data altered-insert into array
5440 IF F1 > 0 THEN GOSUB 4780 'If insert on, turn it off
5450 GOSUB 13760 'Search from LN to EN for label
5460 IF LA > 0 THEN 5480 'Label found [ LA >0 ], EXIT
5470 GOSUB 13840 'Search from 1 to LN
5480 IF LA > 0 THEN LN = LA ELSE GOTO 5500'Set LN to found label line#
5490 GOSUB 5710 'Display data in text area
5500 GOTO 3780 'EXIT to KB scan
5510
5520 REM -----------------------
5530 REM RESTORE CHANGES TO DATA -- ^R
5540 '
5550 LOCATE 18, 29 'Set print positon
5560 PRINT DA$(LN); 'Print data in active line
5570 F2 = 0 'Reset changes to data flag
5580 GOTO 3780 'EXIT to KB scan
5590 '
5600 REM -----------------------
5610 REM EXIT TO MAIN MENU -- <Esc> KEY
5620 '
5630 IF F2 > 0 THEN GOSUB 5090 'Data altered - insert into file
5640 IF F1 > 0 THEN GOSUB 4780 'If insert on, turn it off
5650 LOCATE 18, 1: PRINT " "'Locate & clear message area
5660 GOTO 2010 'EXIT to menu routine
5670 '
5680 REM -----------------------
5690 REM PRINT TEXT AREA
5700 '
5710 IF EN > 11 THEN 5920 'Determine file size & jump
5720 ' - - - - -PRINT TOP OF SMALL ARRAY
5730 CL = LN - 5: IF CL < 0 THEN CL = LN - 6'Set cur line# & test for <0
5740 FOR X = 1 TO 5 'Sed loop to print top 5 lines
5750 LOCATE 12 + X, 25 'Set print position
5760 IF CL <= 0 THEN PRINT BL$: GOTO 5790'If no active lines, print blanks
5770 PRINT LN$(CL) + " " + CHR$(179); 'Print line# & vertical bar of box
5780 PRINT DA$(CL) + CHR$(179) + " " + DT$(DA(CL)) + DT$(DT(CL))'Finish prntg line
5790 CL = CL + 1: IF CL = 0 THEN CL = 1 'Increment cur line# & test for 0
5800 NEXT X 'Loop until done
5810 '- - - - - -PRINT BOTTOM OF SMALL ARRAY
5820 CL = LN 'Set cur line# to active line
5830 FOR X = 6 TO 11 'Set loop to print bottom 6 lines
5840 LOCATE 12 + X, 25 'Set print position
5850 IF CL > EN THEN PRINT BL$: GOTO 5880'If no active lines, print blanks
5860 PRINT LN$(CL) + " " + CHR$(179); 'Print line# & vert bar of box
5870 PRINT DA$(CL) + CHR$(179) + " " + DT$(DA(CL)) + DT$(DT(CL))'Finish prntg line
5880 CL = CL + 1 'Increment current line#
5890 NEXT X 'Loop until done
5900 GOTO 6020 'Jump to routine EXIT
5910 ' - - - - -PRINT LARGE ARRAY
5920 CL = LN - 5 'Cur line# to top of text area
5930 IF EN >= EF THEN CN = EF ELSE CN = EN + 1'Set cur end of list = plus 1
5940 IF CL <= 0 THEN CL = EN + CL 'If cur line <0, reset to 1
5950 IF CL = 0 THEN CL = 1 'Test cur line# for 0
5960 FOR X = 1 TO 11 'Set loop to print 11 lines
5970 LOCATE 12 + X, 25 'Set print positon
5980 PRINT LN$(CL) + " " + CHR$(179); 'Print line numbers & vert bar on box
5990 PRINT DA$(CL) + CHR$(179) + " " + DT$(DA(CL)) + DT$(DT(CL))'Finish prntg line
6000 CL = CL + 1: IF CL > EN THEN CL = 1'Inc cur line# & test for E0Fi1e
6010 NEXT X 'Loop until done
6020 GOSUB 11330 'Go print file status
6030 IL = PZ + 46: IF DA(LN) < 5 AND DT(LN) > 0 THEN IL = PZ + 22'Sen len of active line
6040 PO = PZ: RETURN' 'Set cursor to beg of line & RETURN
6050 '
6060 REM -----------------------
6070 REM DELETE LABEL/DATA LINE(S) -- ^D
6080 '
6090 IF DA(LN) = 5 THEN 6100 ELSE 6280 'Get DT of LN & jump on result
6100 IK = DT(LN) 'Preserve data type of current line
6110 IF DA(LN + 1) = 5 THEN GOSUB 6570: GOTO 6280'If nut line lbl: calc fre ibis &
6111 ' 'jump to process the insert
6120 IF LN = EN THEN GOSUB 6570: GOTO 6280'Jump if cur line is EOFile
6130 MG = 12: GOSUB 13430 'Print "will lose data" message
6140 '- - - - - - - - - - - - -
6150 IK$ = INKEY$: IF IK$ = "" THEN 6150 'Wait for user input (Y or N)
6160 ON INSTR("YynN", IK$) GOTO 6190, 6190, 6400, 6400'Jump on valid input
6170 GOTO 6150 'Rtn to KB scan if invalid input
6180 '- - - - - - - - - - - - -
6190 GOSUB 13630 'Answer was YES-clr warning msg
6200 GOSUB 6570 'Calc new number of free labels
6210 '- - - - - - - - - - - - -
6220 GOSUB 13760 'Find next label in file, if any
6230 IF LA > 0 THEN OS = LA - LN: GOTO 6300'Jump if label found
6240 EN = LN - 1: GOSUB 6510 'LA=0, go clear the list
6250 IF DA(1) < 5 THEN GOSUB 6620 'Fix spec case cond #1
6260 GOTO 6340 'Jump to next section of code
6270 '- - - - - - - - - - - - -
6280 OS = 1 'Set off-set =1
6290 '- - - - - - - - - - - - -
6300 MG = 13: GOSUB 13430 'Print "deleting" message
6310 GOSUB 6440 'Move data up in list
6320 EN = EN - OS: GOSUB 6510 'Set EOList & fill unused portion
6330 '- - - - - - - - - - - - -
6340 IF EN < 2 THEN 6350 ELSE 6360 'Jump on spec case #2
6350 IF DA(1) < 5 THEN GOSUB 6620 'Fix spec case conditon #1
6360 IF LN > EN THEN LN = EN 'Make sure there's no bogus line
6370 IF LN < 1 THEN LN = 1 'Hake sure there's no bogus line
6380 IF EN = 0 THEN EN = 1: GOSUB 6620 'Fix spec case condition #1
6390 GOSUB 5710 'Print the data in the text area
6400 GOSUB 13630 'Clear message line
6410 F3 = 1: PO = PZ: GOTO 3770 'Set flag: data altered! Set cursor
6411 'to beg of line & EXIT to KB scan
6420 '
6430 '- - - - -MOVE DATA UP - SBR
6431 '
6440 FOR X = LN TO EN - OS 'Set loop
6450 DA$(1) = DA$(X + OS) 'Move data up by off-set amount
6460 DA(X) = DA(X + OS): DT(X) = DT(X + OS)'Move data attrib & type
6470 NEXT X 'Loop until done
6480 RETURN 'Return to caller
6490 '
6500 '- - - - -CLEAR LIST - SBR
6501 '
6510 FOR X = EN + 1 TO EF 'Set loop
6520 DA$(X) = DD$(0): DT(X) = 0: DA(X) = 4'Load unused lines w/memo data
6530 NEXT X 'Loop until done
6540 RETURN 'Return to caller
6550 '
6560 '- - - - -CALL FREE LABELS - SBR
6561 '
6570 LA(IK) = LA(IK) - 1 'Decrement label count by 1
6580 IF LA(IK) < 0 THEN LA(IK) = 0 'Make sure count doesn't go wrong
6590 RETURN 'Return to caller
6600 '
6610 '- - - - -SPECIAL CASE PROCESSING - SBR
6611 '
6620 IF EN > 2 THEN 6650 'EXIT if no spec case exists
6630 LA(0) = I 'Set Memo labels to 1
6640 DA$(1) = DL$(0): DA(1) = 5: DT(1) = 0'Set line #1 to Memo label
6650 RETURN 'Return to caller
6660 '
6670 REM -----------------------
6680 REM INSERT LABEL/DATA LINE -- ^I
6690 '
6700 IF EN + 1 > EF THEN MG = 7: GOSUB 13230: GOTO 3770'Watch is full-prat msg & EXIT
6710 MU = 2: GOSUB 3340 'Print Insert Menu (I-Menu)
6720 SA = 31: MG = 11: GOSUB 13430 'Print prompt
6730 IF EN < EF THEN GOSUB 3540 ELSE GOTO 7240'Get KB input from user or EXTT
6740 IF IK$ = CHR$(27) THEN 3770 'EXIT to edit/create @ clr menu
6750 '
6760 ' - - - - -INPUT PROCESSING
6761 '
6770 IK = VAL(IK$) - 2: IF IK < 1 THEN IK = O'Set data type requested into 1K
6780 IF IK$ = "1" THEN RQ = 5: GOTO 6820 'Set requested insert to memo LABEL
6790 IF LA(IK) > 0 THEN RQ = 4: GOTO 6831'If SA,WA,WT lbls exist, set to data
6792 RQ = 5 'If falls thru, insert a label
6800 '
6810 '- - - - -MAINLINE INSERT PROCESSING
6811 '
6820 GOSUB 6900 'Chk for directory space-any left?
6830 IF Q1 = 0 THEN MG = 8: GOSUB 13230: GOTO 6720'No dir space-prat msg & go menu
6831 IF DT(LN) = IK THEN LN = LN + 1: GOTO 7080'DT Match, go insert line
6832 IF LA(IK) = 0 AND IK > 0 THEN LN = 1: GOTO 7080'Ins SA,WA,WT lbls @ top of file
6833 IF LA(IK) = 0 AND IK = 0 THEN LN = EN + 1: GOTO 7080'Ins ME lbl @ bot of file
6834 IF LA(0) > 0 AND IK = 0 AND RQ = 4 THEN GOSUB 6990: GOTO 7080'Ins ME data undr
6835 'a memo label
6850 IF LA(IK) > 0 THEN GOSUB 6990: GOTO 7080'Label exists-go find & insert
6860 IF IK = 0 AND RQ = 5 THEN LN = EN + 1: GOTO 7080'Put ME lbl @ end of file
6861 LN = 1 'Set LN=1 if not set by now!
6870 GOTO 7080 'Jump to insert code
6880 '
6890 '- - - - -CALC DIR SPACE - SBR
6891 '
6900 Q1 = 0 'Set "Question 1" =0 [No]
6910 FOR X = 0 TO 3 'Set loop to add four label types
6920 Q1 = Q1 + LA(X) 'Add up the labels used
6930 NEXT X 'Loop until done
6950 IF Q1 > 11 THEN Q1 = 0 ELSE Q1 = 1 'Set Answer: YES-1, NO=0
6960 RETURN 'Return to caller
6970 '
6980 '- - - - -FIND LABEL - SBR
6981 '
6990 X = LN + 1: LA = 0 'Set beginning search param
7000 IF DA(X) = 5 AND DT(X) = IK THEN LA = X: GOTO 7050'Search-ExTT if found
7010 X = X + 1 'Increment counter
7020 IF X <= EN THEN 7000 'Loop to end of list
7030 X = 1 'Not found-start @ beg of list
7040 IF DA(X) = 5 AND DT(X) = IK THEN LA = X: GOTO 7050'Search-ExIT if found
7041 X = X + 1 'Interment counter
7042 IF X < LN + 1 THEN 7040 'Loop until active line# reached
7050 LN = LA + 1 'Load cur line# v/found label address
7055 RETURN 'Return to caller
7060 '
7070 '- - - - -INSERT LABEL/DATA - SER
7071 '
7080 MG = 6: GOSUB 13430 'Print insert message
7090 FOR X = EN + 1 TO LN + 1 STEP -1 'Set range of lines to move
7100 LSET DA$(X) = DA$(X - 1) 'Move the data
7110 DA(X) = DA(X - 1) 'Move data attrib down 1 line
7120 DT(X) = DT(X - 1) 'Move data type down 1 line
7130 NEXT X 'Loop until done
7140 IF RQ = 5 THEN DA$(LN) = DL$(IK) 'Default label into new line
7150 IF RQ = 4 THEN DA$(LN) = DD$(IK) 'Default data into new line
7160 DA(LN) = RQ: DT(LN) = IK 'Set data attrib & type
7180 EN = EN + 1 'Increment end of list +1
7190 IF DA(LN) = 5 THEN LA(IK) = LA(IK) + 1'Increment label count
7200 GOSUB 5710 'Print text area
7210 MU = O: F3 = 1 'Set M-Menu, set data altered flag F3
7211 PO = PZ 'Set cursor pos to beg of line
7220 GOTO 6700 'Re-enter insert routine
7229 '
7230 ' - - - - WATCH FULL - - -
7231 '
7240 MG = 7: GOSUB 13230: GOTO 7210 'Watch full-exit to menu input
7250 '
7300 REM -----------------------
7301 REM FIND A CITY IN WORLD TIME LIST -- ^F
7302 '
7305 IF DA(LN) = 5 OR DT(LN) < 3 THEN 7360'EXIT if wrong DA or DT
7310 MG = 28: GOSUB 13430 'Prat input message
7315 IP$ = "": LO = 47: GOSUB 13930: GOSUB 14505'Prnt msg & wait for input
7320 IF IP$ = "" THEN 7360 'EXIT if null input
7325 IP$ = LEFT$(IP$, 12) 'Make sure search$ is <13 chars
7330 WT = 1 'Set World Time counter to 1
7335 MG = 31: GOSUB 13430 'Print "searching" message
7340 GET 3, WT: WT = WT + 1: IF WT > (LOF(3) / 20) + 1 THEN 7355'Get WT rec from disk
7345 IF INSTR(WT$, IP$) THEN GOSUB 13630: GOTO 7526'Srch $; clr msg; print
7350 GOTO 7340 'Loop if search $ not found
7355 MG = 30: GOSUB 13230 'Print "not found" msg
7360 GOSUB 13630: GOTO 3780 'Clear msg area; EXIT to KB scan
7361 '
7400 REM -----------------------
7401 REM SEARCH FOR A STRING IN DA$( LIST -- ^S
7402 '
7405 IF LN = EN THEN 7460 'EXIT if at end of file
7408 GOSUB 5090 'Pick-off cur data & insert into file
7410 MG = 29: GOSUB 13430 'Print input message
7415 IP$ = "": LO = 47: GOSUB 13930: GOSUB 14505'Null IP$, SOUND inpt, wait for input
7420 IF IP$ = "" THEN 7455 'EXIT if null input
7425 IP$ = LEFT$(IP$, 24) 'Make sure search$ <25 characters
7430 MG = 31: GOSUB 13430 'Print "searching" msg
7435 X = LN + 1 'Get starting line number
7440 IF INSTR(DA$(X), IP$) THEN LN = X: GOTO 7455'Target found! EXIT
7445 X = X + 1: IF X > EN THEN 7450 ELSE 7440'Loop to end of file
7450 MG = 30: GOSUB 13230 'Print "not found" msg
7455 GOSUB 13630 'Clr message
7456 IF X = LN THEN GOSUB 5710 'Print string if found
7460 GOTO 3780 'EXIT to KB scan
7480 REM -----------------------
7481 REM JUMP TO BEG OF DA$( LIST -- ^B
7482 '
7485 GOSUB 5090: PO = PZ 'Active line into list, cursor to beg
7486 LN = 1: GOSUB 5710: GOTO 3780 'Line# to 1, prt txt, EXIT to KB scan
7489 '
7490 REM -----------------------
7491 REM JUMP TO END OF DA$( LIST -- ^N
7492 '
7495 GOSUB 5090: PO = PZ 'Active line into list, cursor to beg
7496 LN = EN: GOSUB 5710: GOTO 3780 'Lin# to EN, prt txt, EXIT to KB scan
7499 '
7500 REM -----------------------
7501 REM ROLL WORLD TIME FROM LIST - F9/F10
7502 '
7503 '- - - - - ROLL BACK - - - -
7505 IF DA(LN) = 5 OR DT(LN) < 3 THEN 3780'EXTT if wrong DA or DT
7506 WT = WT - 1: IF WT < 1 THEN WT = LOF(3) / 20'Decrement world time record counter
7507 GET 3, WT: GOTO 7526 'GET next World time record & jmp
7508 '- - - - - ROLL FWD- - - -
7510 IF DA(LN) = 5 OR DT(LN) < 3 THEN 3780'PITT if wrong DA or DT
7511 WT = WT + 1: IF WT > LOF(3) / 20 THEN WT = 1'Increment word time record counter
7512 GET 3, WT 'GET nxt World Time rec 6 fall thru
7515 '- - - - - - - - - - - - -
7526 LOCATE 18, 29: PRINT WT$; 'Position & print WT record
7551 F2 = 1 'Set flag: data altered!
7560 GOTO 3780 'EXIT to KB scan
7561 '
7570 REM -----------------------
7571 REM TAB RIGHT/LEFT 12 CHARACTERS -- ^T
7572 '
7575 IF DA(LN) = 5 THEN 7580 'Jump if current line is a label
7576 IF DT(LN) > 0 THEN 3780 'EXIT if wrong data type [1,2,3]
7580 IF PO < PZ + 24 THEN PO = PZ + 24: GOTO 7590'Set position to watch's fillet 2
7585 IF PO >= PZ + 24 THEN PO = PZ 'Set position to watch's line#1
7590 GOTO 3780 'MT to KB scan
7591 '
7600 REM *********************************************************************
7601 REM WRITE TO WATCH
7602 REM *********************************************************************
7603 '
7605 Q1 = LN 'Preserve current line number
7610 MG = 21: GOSUB 13430 'Print "Writing..." messge
7611 LO = 54 'Set print pos'n for progress report
7615 OPEN "COM1:2400,N,8,2,RS,CS0,DS0,CD0" FOR RANDOM AS #1'Set cam to RC1000 parameters
7619 '
7620 '----------BUILD WATCH DIRECTORY
7625 '
7630 DR$ = CHR$(0) + "L" 'Set directory header
7635 FOR X = 1 TO EN 'Set loop to run thru active list
7640 IF DA(X) = 5 THEN GOSUB 8705 'Found a label-go process it
7645 NEXT X 'Loop until done
7648 'Y=((X-I)*25)+16384:GOSUB 8715 'Calc add: of end of active file
7650 DR$ = DR$ + "@" + CHR$(0) 'Calc EOF address
7655 DR$ = LEFT$(DR$ + STRING$(22, 0), 26)'Pad unused directory
7660 '
7665 PRINT #1, DR$; 'Write directory to watch
7670 '
7675 '----------MAINLINE WRITE TO WATCH
7680 '
7685 X = 1
7690 LOCATE 9, LO: PRINT X; 'Show load progress
7692 ON DT(X) + 1 GOTO 7740, 7805, 8005, 8205'Jnp to process data type
7695 X = X + 1: IF X <= EN THEN 7690 'Inc X counter til EOList
7696 '- - - - - - - - - - - - -
7697 FOR X = EN + 1 TO 81 'Set loop to fill remainder of watch
7698 LOCATE 9, LO: PRINT X; 'Print progress report
7699 PRINT #1, "@" + STRING$(24, 32); 'Fill watch with dummy data
7700 NEXT X 'Loop until done
7705 '- - - - - - - - - - - - -
7710 CLOSE 1 'Close communications file
7715 LN = Q1: LO = 0 'Restore cur line # & reset prnt posn
7720 GOTO 2010 'EXIT to main menu
7725 '
7730 '----------WRITE MEMO DATA AND LABELS --DT=0/DA=5
7735 '
7740 IF DA(X) = 5 THEN PR$ = "L" ELSE PR$ = "d"'Set data attribute to label or data
7745 PR$ = PR$ + DA$(X) 'Bld "write" string for label or memo
7750 PRINT #1, PR$; 'Write to watch
7755 GOTO 7695 'EXIT to main line write
7760 '
7800 '----------WRITE SCHEDULE ALARM --DT=1
7801 '
7805 IF DA(X) = 5 THEN 7740 'If label use memo's write
7810 AP = 0 'Make sure AP is zero
7815 GOSUB 8505 'Set up for sort & find label
7820 '- - - - - - - - - - - - -
7825 FOR J = 0 TO LL 'Set loop to len of sort list
7826 LOCATE 9, LO + 3: PRINT "-"; 'Show activity
7827 AP = O 'Set AP to zero
7835 MO$ = MID$(DA$(BL + J), 13, 2) 'Pick off month
7840 DY$ = MID$(DA$(BL + J), 16, 2) 'Pick off day
7845 HR$ = MID$(DA$(BL + J), 20, 2) 'Pick off hours
7847 AP$ = MID$(DA$(BL + J), 19, 1): IF AP$ = "P" AND VAL(HR$) < 12 THEN AP = 12'Pick
'AM/PM & set AP
7848 IF AP$ = "A" AND VAL(HR$) = 12 THEN HR$ = "00"'Set midnight to zero
7850 MI$ = MID$(DA$(BL + J), 23, 2) 'Pick off minutes
7855 HR$ = STR$(VAL(HR$) + AP) 'Put hours into 24 hour time
7856 HR$ = "0" + RIGHT$(HR$, LEN(HR$) - 1)'Pad left v/ASCII 0 if HR <9
7857 HR$ = RIGHT$(HR$, 2) 'Cut down to size.
7860 '
7865 SD(J) = VAL(MO$ + DY$ + HR$ + MI$) 'Load array elment w/sort data
7870 SN(J) = VAL(LN$(BL + J)) 'Load array elemest Wane #s
7871 LOCATE 9, LO + 3: PRINT " "; 'Show activity
7875 NEXT J 'Loop until done
7880 '- - - - - - - - - - - - -
7885 GOSUB 8605 'Go sort SD( 6 SN(
7890 '- - - - - - - - - - - - -
7895 FOR J = 0 TO LL - 1 'Set 1p to write LARM to bitch
7900 PR$ = "d" + DA$(SN(J)) 'Build 'write" string
7905 PRINT #1, PR$; 'Send it to the watch
7910 NEXT J 'Loop until done
7915 X = EL 'Reset X new value
7920 GOTO 7695 'EXIT to mainline write routine
7925 '
8000 '----------WRITE WEEKLY ALARM --DT=2
8001 '
8005 IF DA(X) = 5 THEN 7740 'If label use memo's write
8010 GOSUB 8505 'Set up for sort at find label
8015 '- - - - - - - - - - - - -
8020 FOR J = 0 TO LL - 1 'Set loop to list :length
8022 AP = O 'Set AP to zero
8023 LOCATE 9, LO + 3: PRINT "-"; 'Show activity
8025 AP$ = MID$(DA$(BL + J), 19, 1) 'Pk-off A-PM (PM=+12 hrs)
8030 DY$ = MID$(DA$(BL + J), 13, 1) 'Pick-off day
8035 HR$ = MID$(DA$(BL + J), 20, 2) 'Pick-off hour
8040 MI$ = MID$(DA$(BL + J), 23, 2) 'Pick-off minute
8042 IF AP$ = "P" AND VAL(HR$) < 12 THEN AP = 12'Conv to 24 hour time for sort
8045 HR$ = STR$(VAL(HR$) + AP) 'Hours into 24 hour time & pad left
8046 HR$ = "0" + RIGHT$(HR$, LEN(HR$) - 1)'Pad left w/ASCII 0 if HR <9
8047 HR$ = RIGHT$(HR$, 2) 'Cut down to size
8050 '
8055 SD(J) = VAL(DY$ + HR$ + MI$) 'Load array elment w/sort data
8060 SN(J) = VAL(LN$(BL + J)) 'Load array element w/line #s
8061 LOCATE 9, LO + 3: PRINT " "; 'Show activity
8065 NEXT J 'Loop until done
8070 '- - - - - - - - - - - - -
8075 GOSUB 8605 'Go sort SD( & SN(
8080 '
8085 FOR J = 0 TO LL - 1 'Set loop to write to watch
8090 PR$ = "d" + DA$(SN(J)) 'Build "write" string
8095 PRINT #1, PR$; 'Send it to the watch
8100 NEXT J 'Loop until done
8105 X = EL 'Reset X new value
8110 GOTO 7695 'EXIT to mainline write routine
8115 '
8200 '-----------WRITE WORLD TIME --DT=3
8201 '
8205 IF DA(X) = 5 THEN 7740 'If label use memo's write
8210 '- - - - - - - - - - - - -
8215 HR$ = MID$(DA$(X), 14, 2) 'Pick-off hour difference
8220 MI$ = MID$(DA$(X), 17, 2) 'Pick-off minute difference
8225 HR = VAL(HR$) 'Conv hour string to value
8228 AP$ = "0" 'Set default cond for < 12 hours
8229 HR = HR - TZ: IF HR < 0 THEN HR = HR + 24'<NEW calc TZ difference
8230 IF HR > 11 THEN AP$ = "1": HR = HR - 12'Put HR$ into RC format
8231 HR$ = STR$(HR) 'Put HR$ into RC format
8232 HR$ = "0" + RIGHT$(HR$, LEN(HR$) - 1)'Pad left w/ASCII 0 if HR <9
8233 HR$ = RIGHT$(HR$, 2) 'Cut down to size
8235 '- - - - - - - - - - - - -
8240 PR$ = "d" + LEFT$(DA$(X), 12) 'Build 1st half of "write" str
8245 PR$ = PR$ + AP$ + HR$ + MI$ + " "'Build 2nd half of "write" str
8250 PRINT #1, PR$; 'Send it to the watch
8255 GOTO 7695 'EXIT to mainline write routine
8260 '
8500 '----------UTILITY-Determins the li st length:.
8501 '
8505 BL = X: LN = X 'Beg of list N current Line Number=X
8510 GOSUB 13760 'Go find the end of this list
8515 IF LA > 0 THEN EL = LA - 1 'LA is nit label addr
8520 IF LA = 0 THEN EL = EN 'No label found-set End srtlst=to EN
8525 LL = (EL - BL) + 1 'List Length = End List - Beg List
8530 RETURN 'Return to caller
8535 '
8601 '----------SHELL SORT
8602 '
8605 G% = LL: N% = LL 'Load a and N% with the list length
8610 '- - - - - - - - - - - - -
8615 WHILE G% > 1: G% = G% / 2 'Set WHILE condition
8620 FOR F% = 1 TO 1 'Set loop
8625 FOR C% = 0 TO N% - G% - 1 'Set trip counter
8630 WHILE SD(C%) > SD(G% + C%) 'Set WHILE cond to compare elements
8631 LOCATE 9, LO + 3: PRINT "*" 'Print progress report
8635 SWAP SD(C%), SD(G% + C%) 'Swap data in sort array
8640 SWAP SN(C%), SN(G% + C%) 'Swap line numbers in sort array
8645 F% = 0 'Set outer loop counter to 0
8646 LOCATE 9, LO + 3: PRINT " " 'Print progress report
8650 WEND 'End inner WHILE-WEND loop
8655 NEXT C% 'End inner FOR loop
8660 NEXT F% 'End outter FOR loop
8665 WEND 'End outter WHILE-WEND loop-srt done!
8666 LOCATE 9, LO + 3: PRINT " " 'Print progress report
8670 RETURN 'Return to caller
8675 '
8700 '-------------UTILITY -- WATCH DIRECTORY
8701 '
8705 Y = (X - 1) * 25 'Calculate address from line number
8710 Y = Y + (4096 * DT(X)) 'Set data type bit in High nybble
8715 DR$ = DR$ + RIGHT$(MKI$(Y), 1) + LEFT$(MKI$(Y), 1)'Put address into dir string
8720 RETURN 'Return to caller
8725 '
8750 REM ------------------------
8751 REM CUT -- LOAD C&P BUFFER
8752 '
8755 CT$ = "": CT = DT(LN) 'Clr cut buffer & get DT
8758 FOR X = 0 TO 24 'Set loop to read screen
8760 CT$ = CT$ + CHR$(SCREEN(18, 29 + X))'Load C&P buff from screen
8762 NEXT X 'Loop until done
8764 COLOR 0, 7: LOCATE 7, 54: PRINT "*"; 'Show buffer loaded
8766 COLOR 7, O: GOTO 3780 'Reset video & EXIT
8780 REM ------------------------
8781 REM PASTE -- PRINT CUT BUFFER
8782 '
8785 IF DT(LN) = CT OR DT(LN) = O OR DA(LN) = 5 THEN GOTO 8788'Chk target attribs
8786 LOCATE 18, 29: PRINT LEFT$(CT$, 12); : GOTO 8790'Print C&P buffer
8788 LOCATE 18, 29: PRINT CT$; 'Print C&P buffer
8790 F2 = 1: GOTO 3780 'Set flage: data altered
8999 '
9000 REM *********************************************************************
9010 REM FILE I/O -- DISK/CASSETTE
9020 REM *********************************************************************
9030 '
9040 REM
9050 REM READ DISK FIIV
9060 '
9070 IF F1$ = "" THEN MG = 27: GOSUB 13230: GOTO 9220'Print err msg if no file name
9071 IF F3 > 0 THEN MG = 10: GOSUB 13430 ELSE 9075'<NEW chk for altered file
9072 IK$ = INKEY$: IF IK$ = "" THEN 9072 'Scan KB for user's answer to prompt
9073 ON INSTR(YN$, IK$) GOTO 9075, 9075, 9220, 9220, 9220'<NEW jump on Y/N/Esc
9074 GOTO 9072 'Invalid input — rtn to KB scan
9075 ON ERROR GOTO 9550 'Set error trap; EXIT thru "WRITE"
9080 OPEN "I", 1, FI$ 'Open data file
9090 MG = 16: GOSUB 13430 'Print message
9100 INPUT #1, DA$(0) 'Read file record 0 (active lines)
9110 EN = VAL(DA$(0)) 'Set End of List
9140 LA(0) = 0: LA(1) = 0: LA(2) = 0: LA(3) = 0'Set label counts to 0
9150 FOR X = 1 TO EF 'Set Read loop
9160 INPUT #1, DA$(X): 'Read record into file array
9170 GOSUB 9930 'Unpack data file
9180 NEXT X 'Loop until done
9185 ON ERROR GOTO 9225 'Set error trap if no TZ in file
9186 INPUT #1, PR$: TZ = VAL(PR$) 'Read TZ ft convert to value
9190 ON ERROR GOTO 0 'Reset error trap
9200 CLOSE 1 'Close input file
9210 F3 = 0: LN = 1: GOSUB 5710 'Set file altered flg=0, line#=1
9211 ' 'and display data in text area
9220 RETURN 'Return to caller
9225 RESUME NEXT 'Continue if no TZ in file
9230 '
9300 REM -----------------------
9310 REM WRITE DISK FILE -- SAVE
9320 '
9330 IF FI$ = "" THEN MG = 27: GOSUB 13230: GOTO 9520'No file name, prt msg & EXIT
9335 IF F2 = 1 THEN GOSUB 5090 'If data altered, insert into list
9340 ON ERROR GOTO 9590 'Set error trap
9350 OPEN "I", 1, FI$: CLOSE 1 'Test file—OPEN for INPUT & CLOSE
9360 MG = 26: GOSUB 13430 'If file OPENed, it exists, prt msg
9370 IK$ = INKEY$: IF IK$ = "" THEN 9370 'Wait for user response
9380 ON INSTR(YN$, IK$) GOTO 9410, 9410, 9490, 9490, 9490'Jump on input
9390 GOTO 9370 'Rtn to KB scan on invalid input
9400 '
9410 MG = 15: GOSUB 13430 'Print "saving..." message
9420 ON ERROR GOTO 9550 'Set error trap
9430 OPEN "O", 1, FI$ 'Open file for Output
9440 PRINT #1, STR$(EN) 'Write the active # of records
9450 FOR X = 1 TO EF 'Set loop to write active records
9460 GOSUB 10030 'Pact the data into PR$
9470 PRINT #1, PR$ 'Write PR$ to disk
9480 NEXT X 'Loop until done
9485 PRINT #1, STR$(TZ) 'Write cur time zone to end of file
9486 F3 = 0 'Set file not saved flag = 0
9490 CLOSE 1 'CLOSE the file {EXIT point 1}
9500 ON ERROR GOTO 0 'Reset error trap
9510 CLOSE 1 'CLOSE the file {EXIT point 2}
9520 GOSUB 13630 'Clear mesage
9530 RETURN 'Return to Caller
9540 '- - - ERROR TRAP- - - - -
9550 RESUME 9560 'Set next line to execute
9560 MG = 17: GOSUB 13230 'Print messge
9570 GOTO 9490 'Re-enter WRITE routine
9580 '- - - ERROR TRAP- - - - -
9590 RESUME 9410 'Re-enter WRITE routine
9600 '
9900 REM ----------------------
9910 REM UNPACK DATA FILE - SBR
9920 '
9930 DA(X) = 4 'Set default DT to "data"
9940 IF LEFT$(DA$(X), 1) = "L" THEN DA(X) = 5'If data attribute into variable
9950 DT(X) = VAL(RIGHT$(DA$(X), 2)) 'Read data type into variable
9960 IF DA(X) = 5 THEN LA(DT(X)) = LA(DT(X)) + 1'If line is label, count it
9970 LN$(X) = RIGHT$(STR$(X), 2) 'Load the line number into variable
9980 DA$(X) = MID$(DA$(X), 3, 24) 'Trim off excess fat-load data line
9990 RETURN 'Return to caller
9999 '
10000 REM --------------------
10010 REM PACK DATA FILE - SBR
10020 '
10030 IF DA(X) = 5 THEN PR$ = "L " ELSE PR$ = "d "'Set data attrib for WRITE
10070 PR$ = PR$ + DA$(X) + RIGHT$(STR$(DT(X)), 2)'Build WRITE string
10080 RETURN 'Return to caller
10090 '
10100 REM --------------------
10110 REM CREATE "EMPTY" FILE
10120 '
10130 DA(1) = 5: DT(1) = 0: LN$(1) = " 1": DA$(1) = DL$(0)'Create line #1
10140 FOR X = 2 TO EF 'Set loop
10150 DA(X) = 4: DT(X) = 0 'Intialize data attribs & type
10160 LN$(X) = RIGHT$(STR$(X), 2) 'Create line numbers
10170 DA$(X) = DD$(0) 'Load default data strings
10180 NEXT X 'Loop until done
10190 EN = 1: LN = 1: LA(0) = 1: FI$ = ""'Initialize len, Ibis +Et active files
10200 RETURN 'Return to caller
10210 '
10300 REM ********************************************************************
10301 REM UTILITY ROUTINES
10302 REM ********************************************************************