Browse code

(boot.tal) Optimizaitons

neauoire authored on 08/01/2022 21:34:26
Showing 1 changed files
... ...
@@ -5,22 +5,18 @@
5 5
 %++ { ADD2 } %-- { SUB2 } %** { MUL2 } %// { DIV2 }
6 6
 %<< { LTH2 } %>> { GTH2 } %== { EQU2 } %!! { NEQ2 }
7 7
 
8
-%8// { #03 SFT2 }
9
-%10** { #40 SFT2 } %10// { #04 SFT2 }
8
+%2*  { #10 SFT } %2/  { #01 SFT } %2**  { #10 SFT2 } %2//  { #01 SFT2 }
9
+%4*  { #20 SFT } %4/  { #02 SFT } %4**  { #20 SFT2 } %4//  { #02 SFT2 }
10
+%8*  { #30 SFT } %8/  { #03 SFT } %8**  { #30 SFT2 } %8//  { #03 SFT2 }
11
+%10* { #40 SFT } %10/ { #04 SFT } %10** { #40 SFT2 } %10// { #04 SFT2 }
12
+%20* { #50 SFT } %20/ { #05 SFT } %20** { #50 SFT2 } %20// { #05 SFT2 }
10 13
 
11
-%MIN2 { LTH2k JMP SWP2 POP2 }
12
-%MOD { DIVk MUL SUB }
13
-%DEC { #01 - }
14 14
 %RTN { JMP2r }
15 15
 %TOS { #00 SWP }
16
-%SWP? { #01 JCN SWP } %SWP2? { #01 JCN SWP2 }
17
-%BRK? { #01 JCN BRK }
18
-%RTN? { #01 JCN RTN }
19 16
 
20
-%DEBUG  { ;print-hex/byte JSR2 #0a .Console/write DEO }
21
-%DEBUG2 { ;print-hex/short JSR2 #0a .Console/write DEO }
22
-
23
-%SEL-ENTRY { ;dir/entries #00 .browser/sel LDZ DUP2 ADD2 ADD2 }
17
+%AUTO-NONE   { #00 .Screen/auto DEO }
18
+%AUTO-XADDR  { #05 .Screen/auto DEO }
19
+%AUTO-YADDR  { #06 .Screen/auto DEO }
24 20
 
25 21
 ( devices )
26 22
 
... ...
@@ -40,8 +36,8 @@
40 36
 @pointer
41 37
 	&x  $2 &y  $2
42 38
 @browser
43
-	&x $2 &y $2 
44
-	&sel $1 &last $1
39
+	&x $2 &y $2 &x2 $2 &y2 $2 
40
+	&sel $1 &last $1 &scroll $1
45 41
 
46 42
 ( init )
47 43
 
... ...
@@ -63,18 +59,15 @@
63 59
 	#0100 .Audio0/length DEO2
64 60
 	#dd .Audio0/volume DEO ( TODO: turn ON )
65 61
 
66
-	( determine max visible file length )
67
-	.Screen/width DEI2 8// #00ff MIN2 NIP
68
-	;draw-browser/clear-length STA
69
-
70 62
 	( place )
71 63
 	#0088 .browser/x STZ2
72 64
 	#0010 .browser/y STZ2
65
+	.Screen/height DEI2 #33 SFT2 #0011 -- .browser/y2 STZ2
73 66
 
74 67
 	( draw mascot )
75 68
 	#0010 #0010 #0060 #0060 ;mascot-icn #01 ;draw-icn JSR2
76 69
 
77
-	;read-dir JSR2
70
+	;load-dir JSR2
78 71
 
79 72
 	( theme support )
80 73
 	;load-theme JSR2
... ...
@@ -104,154 +97,116 @@ BRK
104 97
 	.Mouse/y DEI2 DUP2 .pointer/y STZ2 .Screen/y DEO2
105 98
 	#41 .Mouse/state DEI #01 = + .Screen/sprite DEO
106 99
 
100
+	( within browser )
101
+	.Mouse/y DEI2 .browser/y LDZ2 << ,&outside JCN
102
+	.Mouse/y DEI2 .browser/y2 LDZ2 >> ,&outside JCN
103
+
107 104
 	( select choice )
108 105
 	.Mouse/y DEI2 .browser/y LDZ2 --
109 106
 		10// NIP ;select-file JSR2
110 107
 
108
+	( run choice )
111 109
 	.Mouse/state DEI #00 = ,&no-click JCN
112 110
 		.browser/sel LDZ ;run-file JSR2
113 111
 		&no-click
114 112
 
113
+	&outside
114
+
115 115
 BRK
116 116
 
117 117
 @on-button ( -> )
118 118
 
119
+	( controller )
119 120
 	.Controller/button DEI
120 121
 	DUP #10 ! ,&no-up JCN
121
-		.browser/sel LDZ DEC ;select-file JSR2
122
+		.browser/sel LDZ #00 = ,&no-up JCN
123
+		.browser/sel LDZ #01 - ;select-file JSR2 
122 124
 		POP BRK
123 125
 		&no-up
124 126
 	DUP #20 ! ,&no-down JCN
125
-		.browser/sel LDZ INC ;select-file JSR2
127
+		.browser/sel LDZ INC ;dir/lines LDA = ,&no-down JCN 
128
+		.browser/sel LDZ INC ;select-file JSR2 
126 129
 		POP BRK
127 130
 		&no-down
128 131
 	DUP #01 ! ,&no-a JCN
129
-		.browser/sel LDZ ;run-file JSR2
132
+		.browser/sel LDZ ;run-file JSR2 
130 133
 		POP BRK
131 134
 		&no-a
132 135
 	POP
136
+	( keyboard )
133 137
 	.Controller/key DEI
134 138
 	DUP #0d ! ,&no-enter JCN
135 139
 		.browser/sel LDZ ;run-file JSR2
136
-		POP
140
+		POP BRK
137 141
 		&no-enter
138 142
 	POP
139 143
 
140 144
 BRK
141 145
 
142
-@read-dir ( -- )
146
+@load-dir ( -- )
143 147
 
144 148
 	;dir/path .File/name DEO2
145 149
 	#1000 .File/length DEO2
146 150
 	;dir/data .File/read DEO2
151
+	.File/success DEI2 ;dir/length STA2
147 152
 
148
-	( separate into lines )
149
-	#00 ;dir/data STH2k
153
+	( split with null-char )
154
+	;dir/data
150 155
 	&while
151
-		LDAk #0a ! ,&no-lb JCN
152
-		STAk
153
-		STH2r ;add-entry JSR2
154
-		INC2 STH2k ,&while JMP
155
-		&no-lb INC2 LDAk ,&while JCN
156
-	POP2r POP2 POP
157
-RTN
158
-
159
-@add-entry ( line* -- )
160
-	DUP2 ;filter-entry JSR2 ,&ignored JCN
161
-
162
-	( just add entry to end for now, FIXME sort entries )
163
-	;dir/entries
164
-		#00 ;dir/lines LDA DUP2 ADD2
165
-		ADD2
166
-	STA2
167
-	;dir/lines LDAk INC ROT ROT STA
168
-	#0000
169
-
170
-	&ignored
156
+		LDAk #1f > ,&no-lb JCN
157
+			STH2k #00 STH2r STA
158
+			;dir/lines LDA INC ;dir/lines STA
159
+			&no-lb
160
+		INC2 LDAk ,&while JCN
171 161
 	POP2
172
-RTN
173 162
 
174
-@filter-entry ( line* -- ignore-flag )
175
-	POP2 #00
176 163
 RTN
177 164
 
178 165
 @select-file ( id -- )
179
-	( clamp id to useful values )
180
-	DUP #fc LTH ,&not-negative JCN
181
-	DUP EOR
182
-	&not-negative
183
-	;dir/lines LDA DEC LTHk SWP? POP
184 166
 
167
+	( has changed )
185 168
 	DUP .browser/last LDZ ! ,&has-changed JCN
186 169
 		POP RTN
187 170
 		&has-changed
188 171
 
189
-	DUP ;scroll-browser JSR2
190
-
191
-	.browser/x LDZ2 #0018 -- .browser/y LDZ2 [ .browser/sel LDZ TOS 10** ++ ] 
192
-	#0010 #0010 
193
-		;hand-icn #00 ;draw-icn JSR2
172
+	#00 ;draw-browser JSR2
194 173
 
195
-	DUP 
196
-		.browser/sel STZ
197
-	DUP
198
-		.browser/last STZ
174
+	DUP .browser/sel STZ
175
+	DUP .browser/last STZ
199 176
 		#30 + .Audio0/pitch DEO
200
-	;draw-browser JSR2
201 177
 
202
-	.browser/x LDZ2 #0018 -- .browser/y LDZ2 [ .browser/sel LDZ TOS 10** ++ ] 
203
-	#0010 #0010 
204
-		;hand-icn #02 ;draw-icn JSR2
178
+	;follow-selection JSR2
179
+
180
+	#01 ;draw-browser JSR2
205 181
 
182
+	( draw mascot )
206 183
 	#0010 #0010 #0060 #0060 
207 184
 	;mascot-icn [ .browser/sel LDZ #03 AND TOS #0480 ** ++ ] #01 
208 185
 		;draw-icn JSR2
209 186
 
210 187
 RTN
211 188
 
212
-( Scroll the browser to accomodate off-screen line items )
213
-@scroll-browser ( id -- )
214
-	( Check whether the selection moved up or down )
215
-	.browser/last LDZ OVR SWP SUB #80 AND ,&negative JCN
216
-
217
-	&positive ( The selection moved down )
218
-	( Calculate the id currently at the bottom of the screen )
219
-	.Screen/height DEI2 .browser/y LDZ2 #0010 ++ -- 10// NIP
220
-	GTH ,&scroll-up JCN [ RTN ]
221
-	&scroll-up
222
-		.browser/y LDZ2k #0010 -- ROT STZ2
223
-		RTN
224
-
225
-	&negative ( The selection moved up )
226
-	( Calculate the id currently at the top of the screen )
227
-	( TODO make a macro constant for y initial pos )
228
-	#0010 .browser/y LDZ2 -- 10// NIP
229
-
230
-	LTH ,&scroll-down JCN [ RTN ]
231
-	&scroll-down
232
-		.browser/y LDZ2k #0010 ++ ROT STZ2 ( Decrement y by 0x10 )
233
-		RTN
189
+@follow-selection ( -- )
234 190
 
235
-@run-file ( id -- )
236
-
237
-	SEL-ENTRY LDA2
238
-	#0005 ++ DUP2 ;print-string JSR2
239
-	#0a .Console/write DEO
240
-
241
-	DUP2 ;check-rom JSR2 ,&valid JCN
242
-	POP2 RTN
243
-
244
-	&valid
245
-	;load-rom JSR2
191
+	.browser/y2 LDZ2 .browser/y LDZ2 -- 10// NIP #01 - .browser/sel LDZ
192
+	DUP2 > ,&below JCN
193
+		DUP2 SWP - .browser/scroll STZ 
194
+		POP2 RTN
195
+	&below
196
+	POP2
197
+	#00 .browser/scroll STZ 
246 198
 
247 199
 RTN
248 200
 
249
-@print-string ( addr* -- )
201
+@run-file ( id -- )
250 202
 
251
-	&loop
252
-		LDAk .Console/write DEO
253
-		INC2 LDAk ,&loop JCN
254
-	POP2
203
+	;get-entry JSR2 #0005 ++
204
+	
205
+	DUP2 ;check-rom JSR2 ,&valid JCN
206
+		POP2 RTN
207
+		&valid
208
+
209
+	;load-rom JSR2 
255 210
 
256 211
 RTN
257 212
 
... ...
@@ -261,86 +216,45 @@ RTN
261 216
 
262 217
 RTN
263 218
 
264
-@draw-browser ( -- )
265
-
266
-	.browser/x LDZ2 .Screen/x DEO2
267
-	.browser/y LDZ2 .Screen/y DEO2
268
-	SEL-ENTRY ;dir/entries
269
-	&outer ( selected-entry* this-entry* )
270
-		.Screen/y DEI2 #0010 LTH2 ,&inc JCN ( Don't draw anything in the first row )
271
-		EQU2k #0c * #01 + STH
272
-		LDA2k ORAk #00 = ,&end JCN
273
-		,&clear JSR
274
-		STHr ,&draw-one JSR
275
-		.browser/x LDZ2 .Screen/x DEO2
276
-		&inc .Screen/y DEI2 #0010 ++ .Screen/y DEO2
277
-		INC2 INC2 ,&outer JMP
278
-	&end
279
-	POP2 POP2 POP2 POPr
280
-RTN
219
+@draw-browser ( mask -- )
281 220
 
282
-	&draw-one ( line* color -- )
283 221
 	STH
284
-	&loop
285
-		( top-addr ) LDAk #20 - TOS #0010 MUL2 ;font ++ .Screen/addr DEO2
286
-		( top-draw ) STHkr .Screen/sprite DEO
287
-		( bottom-addr ) .Screen/addr DEI2 #0008 ++ .Screen/addr DEO2
288
-		( next-y ) .Screen/y DEI2 #0008 ++ .Screen/y DEO2
289
-		( bottom-draw ) STHkr .Screen/sprite DEO
290
-		( prev-y ) .Screen/y DEI2 #0008 -- .Screen/y DEO2
291
-		( move ) .Screen/x DEI2 #0008 ++ .Screen/x DEO2
292
-		&skip
293
-		INC2 LDAk ,&loop JCN
294
-	POP2 POPr
295
-RTN
296 222
 
297
-	&clear ( -- )
298
-	.Screen/x DEI2k ( Stash the current x pos )
299
-
300
-	( Clear the screen )
301
-	( Clear length gets set in init )
302
-	LIT2 &clear-length 00 00
303
-	&clear-loop
304
-		#00 .Screen/sprite DEO
305
-		.Screen/y DEI2k #0008 ++ ROT DEO2
306
-		#00 .Screen/sprite DEO
307
-		.Screen/y DEI2k #0008 -- ROT DEO2
308
-		.Screen/x DEI2k #0008 ++ ROT DEO2
309
-		INC NEQk ,&clear-loop JCN
223
+	( draw hand )
224
+	.browser/x LDZ2 #0018 -- .browser/y LDZ2 [ .browser/sel LDZ .browser/scroll LDZ - TOS 10** ++ ] 
225
+	#0010 #0010 
226
+		;hand-icn STHkr #03 * ;draw-icn JSR2
227
+	( draw files )
228
+	.browser/y2 LDZ2 .browser/y LDZ2 -- 10// NIP #00
229
+	&loop
230
+		.browser/x LDZ2 .Screen/x DEO2
231
+		DUP TOS 10** .browser/y LDZ2 ++ .Screen/y DEO2
232
+		DUP .browser/scroll LDZ + ;get-entry JSR2 #01 STHkr *  ;draw-str JSR2
233
+		INC GTHk ,&loop JCN
310 234
 	POP2
311
-	ROT DEO2
235
+
236
+	POPr
237
+
312 238
 RTN
313 239
 
314
-@draw-time ( -- )
315
-
316
-	.DateTime/day DEI
317
-		DUP #0f AND ;hex-char JSR2 ;&date-str #0009 ++ STA
318
-		#04 SFT ;hex-char JSR2 ;&date-str #0008 ++ STA
319
-	.DateTime/month DEI
320
-		DUP #0f AND ;hex-char JSR2 ;&date-str #0006 ++ STA
321
-		#04 SFT ;hex-char JSR2 ;&date-str #0005 ++ STA
322
-	.DateTime/year DEI2
323
-		DUP #0f AND ;hex-char JSR2 ;&date-str #0003 ++ STA
324
-		#04 SFT ;hex-char JSR2 ;&date-str #0002 ++ STA
325
-		DUP #0f AND ;hex-char JSR2 ;&date-str INC2 STA
326
-		#04 SFT ;hex-char JSR2 ;&date-str STA
327
-
328
-	.DateTime/second DEI
329
-		DUP #0f AND ;hex-char JSR2 ;&time-str #0007 ++ STA
330
-		#04 SFT ;hex-char JSR2 ;&time-str #0006 ++ STA
331
-	.DateTime/minute DEI
332
-		DUP #0f AND ;hex-char JSR2 ;&time-str #0004 ++ STA
333
-		#04 SFT ;hex-char JSR2 ;&time-str #0003 ++ STA
334
-	.DateTime/hour DEI
335
-		DUP #0f AND ;hex-char JSR2 ;&time-str INC2 STA
336
-		#04 SFT ;hex-char JSR2 ;&time-str STA
337
-
338
-	#0020 #0080 ;&date-str #01 ;draw-label JSR2
339
-	#0080 #0080 ;&time-str #02 ;draw-label JSR2
240
+@get-entry ( id -- addr* )
241
+
242
+	( limit ) STH
243
+	( counter ) LITr 00
244
+	;dir/length LDA2 #0000
245
+	&loop
246
+		EQUkr STHr #00 = ,&no-reached JCN
247
+			POP2r NIP2 ;dir/data ++ RTN
248
+			&no-reached
249
+		DUP2 ;dir/data ++ LDA #00 ! ,&no-lb JCN
250
+			INCr
251
+			&no-lb
252
+		INC2 GTH2k ,&loop JCN
253
+	POP2 POP2
254
+	POP2r
255
+	;dir/data
340 256
 
341 257
 RTN
342
-	&date-str "0000-00-00 $1
343
-	&time-str "00:00:00 $1
344 258
 
345 259
 @hex-char ( hex -- char )
346 260
 
... ...
@@ -350,42 +264,63 @@ RTN
350 264
 
351 265
 @draw-icn ( x* y* width* height* addr* color  -- )
352 266
 	
267
+	AUTO-XADDR
353 268
 	( load ) STH .Screen/addr DEO2 ,&height STR2 ,&width STR2 ,&y STR2 ,&x STR2
354 269
 	,&height LDR2 #0000 
355 270
 	&ver
356 271
 		( save ) DUP2 ,&y LDR2 ADD2 .Screen/y DEO2
272
+		,&x LDR2 .Screen/x DEO2
357 273
 		,&width LDR2 #0000
358 274
 		&hor
359
-			( save ) DUP2 ,&x LDR2 ADD2 .Screen/x DEO2
360 275
 			( draw ) STHkr .Screen/sprite DEO
361
-			( incr ) .Screen/addr DEI2 #0008 ADD2 .Screen/addr DEO2
362 276
 			#0008 ADD2 GTH2k ,&hor JCN
363 277
 		POP2 POP2
364 278
 		#0008 ADD2 GTH2k ,&ver JCN
365 279
 	POP2 POP2
366 280
 	POPr
281
+	AUTO-NONE
367 282
 
368 283
 RTN
369 284
 	&x $2 &y $2 &width $2 &height $2
370 285
 
371
-@draw-label ( x* y* addr* color -- )
286
+@draw-str ( text* color -- )
372 287
 
373
-	STH STH2
374
-	.Screen/y DEO2
375
-	.Screen/x DEO2
376
-	STH2r
377
-	&loop
378
-		( top-addr ) LDAk #20 - TOS #0010 MUL2 ;font ++ .Screen/addr DEO2
379
-		( top-draw ) STHkr .Screen/sprite DEO
380
-		( bottom-addr ) .Screen/addr DEI2 #0008 ++ .Screen/addr DEO2
381
-		( next-y ) .Screen/y DEI2 #0008 ++ .Screen/y DEO2
382
-		( bottom-draw ) STHkr .Screen/sprite DEO
383
-		( prev-y ) .Screen/y DEI2 #0008 -- .Screen/y DEO2
384
-		( move ) .Screen/x DEI2 #0008 ++ .Screen/x DEO2
385
-		INC2 LDAk ,&loop JCN
386
-	POP2 POPr
288
+	AUTO-YADDR
289
+	STH
290
+	&while
291
+		LDAk STHkr ,draw-char JSR
292
+		INC2 LDAk ,&while JCN
293
+	POP2
294
+	POPr
295
+
296
+RTN
297
+
298
+@draw-short ( short* color -- )
299
+
300
+	STH SWP STHkr ,draw-byte JSR
301
+	STHr ,draw-byte JSR
302
+
303
+RTN
304
+
305
+@draw-byte ( byte color -- )
306
+
307
+	STH
308
+	DUP #04 SFT ,&parse JSR STHkr ,draw-char JSR
309
+	#0f AND ,&parse JSR STHr ,draw-char JSR
387 310
 
388 311
 RTN
312
+	&parse ( byte -- char ) DUP #09 GTH ,&above JCN #30 ADD JMP2r 
313
+	&above #57 ADD JMP2r
314
+
315
+@draw-char ( char color -- )
316
+
317
+	SWP
318
+	[ #20 - #00 SWP #40 SFT2 ;font ++ ] .Screen/addr DEO2
319
+	.Screen/sprite DEOk DEO
320
+	.Screen/x DEI2k #0008 ++ ROT DEO2
321
+	.Screen/y DEI2k #0010 -- ROT DEO2
322
+
323
+JMP2r
389 324
 
390 325
 ( theme )
391 326
 
... ...
@@ -406,25 +341,6 @@ RTN
406 341
 
407 342
 RTN
408 343
 
409
-( helpers )
410
-
411
-@print-hex ( value* -- )
412
-
413
-	&short ( value* -- )
414
-		SWP ,&echo JSR 
415
-	&byte ( value -- )
416
-		,&echo JSR
417
-	RTN
418
-
419
-	&echo ( value -- )
420
-	STHk #04 SFT ,&parse JSR .Console/write DEO
421
-	STHr #0f AND ,&parse JSR .Console/write DEO
422
-	RTN
423
-	&parse ( value -- char )
424
-		DUP #09 GTH ,&above JCN #30 + RTN &above #09 - #60 + RTN
425
-
426
-RTN
427
-
428 344
 @pointer-icn
429 345
 	80c0 e0f0 f8e0 1000
430 346
 @hand-icn
... ...
@@ -432,7 +348,6 @@ RTN
432 348
 	0000 0000 0000 fc02
433 349
 	8180 8080 8040 3f00
434 350
 	fc20 c020 c020 c000
435
-
436 351
 @sin-pcm
437 352
 	8083 8689 8c8f 9295 989b 9ea1 a4a7 aaad
438 353
 	b0b3 b6b9 bbbe c1c3 c6c9 cbce d0d2 d5d7
... ...
@@ -460,5 +375,5 @@ RTN
460 375
 @dir
461 376
 	&path ". $1
462 377
 	&lines $1
463
-	&entries $100
378
+	&length $2
464 379
 	&data