... | ... |
@@ -12,26 +12,29 @@ |
12 | 12 |
) |
13 | 13 |
|
14 | 14 |
%RTN { JMP2r } |
15 |
+%++ { #01 ADD } %-- { #01 SUB } |
|
15 | 16 |
%8+ { #0008 ADD2 } |
16 | 17 |
%8* { #0008 MUL2 } %8/ { #0008 DIV2 } |
17 | 18 |
%MOD { DUP2 DIV MUL SUB } |
18 | 19 |
|
19 |
-%GRID-CELLS { #2000 } |
|
20 |
-%GRID-LOCKS { #3000 } |
|
21 |
-%GRID-TYPES { #4000 } |
|
22 |
- |
|
23 |
-%GET-OFFSET { |
|
24 |
- #00 SWP #00 ~grid.width MUL2 ROT #00 SWP ADD2 |
|
25 |
-} ( x y -- offset* ) |
|
26 |
-%GET-INDEX { |
|
27 |
- GET-OFFSET GRID-CELLS ADD2 |
|
28 |
-} ( x y -- index* ) |
|
29 |
-%SET-CELL { |
|
30 |
- ROT ROT GET-INDEX POK2 |
|
31 |
-} ( x y char -- ) |
|
32 |
-%GET-CELL { |
|
33 |
- GET-INDEX PEK2 |
|
34 |
-} ( x y -- char ) |
|
20 |
+%DATA-CELLS { #2000 } |
|
21 |
+%DATA-LOCKS { #3000 } |
|
22 |
+%DATA-TYPES { #4000 } |
|
23 |
+ |
|
24 |
+%GET-CHAR { #24 MOD #00 SWP ,b36clc ADD2 PEK2 } ( b36 -- char ) |
|
25 |
+%GET-VALUE { #20 SUB #00 SWP ,values ADD2 PEK2 } ( char -- b36 ) |
|
26 |
+ |
|
27 |
+%GET-INDEX { #00 SWP #00 ~grid.width MUL2 ROT #00 SWP ADD2 } ( x y -- index ) |
|
28 |
+%GET-CELL { GET-INDEX DATA-CELLS ADD2 PEK2 } ( x y -- char ) |
|
29 |
+%SET-CELL { ROT ROT GET-INDEX DATA-CELLS ADD2 POK2 } ( x y char -- ) |
|
30 |
+%GET-TYPE { GET-INDEX DATA-TYPES ADD2 PEK2 } ( x y -- type ) |
|
31 |
+%SET-TYPE { ROT ROT GET-INDEX DATA-TYPES ADD2 POK2 } ( x y type -- ) |
|
32 |
+%GET-LOCK { GET-INDEX DATA-TYPES ADD2 PEK2 } ( x y -- type ) |
|
33 |
+%SET-LOCK { ROT ROT GET-INDEX DATA-TYPES ADD2 POK2 } ( x y type -- ) |
|
34 |
+%GET-PORT { } ( x y lock -- char ) |
|
35 |
+%SET-PORT { } ( x y char -- ) |
|
36 |
+ |
|
37 |
+%GET-CELL-VALUE { GET-CELL GET-VALUE } ( x y -- b36 ) |
|
35 | 38 |
|
36 | 39 |
( variables ) |
37 | 40 |
|
... | ... |
@@ -68,11 +71,11 @@ BRK |
68 | 71 |
|
69 | 72 |
@on-frame |
70 | 73 |
|
71 |
- ~timer #01 ADD DUP =timer |
|
74 |
+ ~timer ++ DUP =timer |
|
72 | 75 |
|
73 | 76 |
( skip ) #08 EQU ^$tick JNZ BRK $tick |
74 | 77 |
|
75 |
- ~timer.frame #01 ADD =timer.frame |
|
78 |
+ ~timer.frame ++ =timer.frame |
|
76 | 79 |
|
77 | 80 |
,run JSR2 |
78 | 81 |
|
... | ... |
@@ -91,20 +94,20 @@ BRK |
91 | 94 |
~Controller.button #f0 AND |
92 | 95 |
DUP #04 SFT #01 AND #01 NEQ ^$no-up JNZ |
93 | 96 |
~selection.y1 #00 EQU ^$no-up JNZ |
94 |
- ~selection.y1 #01 SUB =selection.y1 |
|
95 |
- ~selection.y2 #01 SUB =selection.y2 $no-up |
|
97 |
+ ~selection.y1 -- =selection.y1 |
|
98 |
+ ~selection.y2 -- =selection.y2 $no-up |
|
96 | 99 |
DUP #05 SFT #01 AND #01 NEQ ^$no-down JNZ |
97 |
- ~selection.y1 ~grid.height #01 SUB EQU ^$no-down JNZ |
|
98 |
- ~selection.y1 #01 ADD =selection.y1 |
|
99 |
- ~selection.y2 #01 ADD =selection.y2 $no-down |
|
100 |
+ ~selection.y1 ~grid.height -- EQU ^$no-down JNZ |
|
101 |
+ ~selection.y1 ++ =selection.y1 |
|
102 |
+ ~selection.y2 ++ =selection.y2 $no-down |
|
100 | 103 |
DUP #06 SFT #01 AND #01 NEQ ^$no-left JNZ |
101 | 104 |
~selection.x1 #00 EQU ^$no-left JNZ |
102 |
- ~selection.x1 #01 SUB =selection.x1 |
|
103 |
- ~selection.x2 #01 SUB =selection.x2 $no-left |
|
105 |
+ ~selection.x1 -- =selection.x1 |
|
106 |
+ ~selection.x2 -- =selection.x2 $no-left |
|
104 | 107 |
DUP #07 SFT #01 AND #01 NEQ ^$no-right JNZ |
105 |
- ~selection.x1 ~grid.width #01 SUB EQU ^$no-right JNZ |
|
106 |
- ~selection.x1 #01 ADD =selection.x1 |
|
107 |
- ~selection.x2 #01 ADD =selection.x2 $no-right |
|
108 |
+ ~selection.x1 ~grid.width -- EQU ^$no-right JNZ |
|
109 |
+ ~selection.x1 ++ =selection.x1 |
|
110 |
+ ~selection.x2 ++ =selection.x2 $no-right |
|
108 | 111 |
POP |
109 | 112 |
|
110 | 113 |
~Controller.key #08 NEQ ^$no-backspace JNZ |
... | ... |
@@ -149,10 +152,10 @@ BRK |
149 | 152 |
$hor |
150 | 153 |
( get x,y ) SWP2 OVR STH SWP2 OVR STHr |
151 | 154 |
#2e SET-CELL |
152 |
- ( incr ) SWP #01 ADD SWP |
|
155 |
+ ( incr ) SWP ++ SWP |
|
153 | 156 |
DUP2 LTH ^$hor JNZ |
154 | 157 |
POP2 |
155 |
- ( incr ) SWP #01 ADD SWP |
|
158 |
+ ( incr ) SWP ++ SWP |
|
156 | 159 |
DUP2 LTH ^$ver JNZ |
157 | 160 |
POP2 |
158 | 161 |
|
... | ... |
@@ -160,39 +163,28 @@ BRK |
160 | 163 |
|
161 | 164 |
RTN |
162 | 165 |
|
163 |
-@is-selected ( x y -- flag ) |
|
164 |
- |
|
165 |
- ~selection.x1 ~selection.y1 EQU2 |
|
166 |
+( operations ) |
|
166 | 167 |
|
168 |
+@get-bang ( x y -- bang ) |
|
167 | 169 |
RTN |
168 | 170 |
|
169 |
-@set-lock ( x y flag -- ) |
|
170 |
- |
|
171 |
- ROT ROT GET-OFFSET GRID-LOCKS ADD2 POK2 |
|
171 |
+( old ) |
|
172 | 172 |
|
173 |
-RTN |
|
174 |
- |
|
175 |
-@get-lock ( x y -- flag ) |
|
176 |
- |
|
177 |
- GET-OFFSET GRID-LOCKS ADD2 PEK2 |
|
178 |
- |
|
179 |
-RTN |
|
180 |
- |
|
181 |
-@get-cell-value ( char -- value ) |
|
173 |
+@is-selected ( x y -- flag ) |
|
182 | 174 |
|
183 |
- #00 SWP ,values ADD2 PEK2 |
|
184 |
- |
|
185 |
-RTN |
|
175 |
+ ~selection.x1 ~selection.y1 EQU2 |
|
186 | 176 |
|
187 |
-@get-value-char ( value -- char ) |
|
188 |
- |
|
189 |
- #24 MOD #00 SWP ,b36clc ADD2 PEK2 |
|
190 |
- |
|
191 | 177 |
RTN |
192 | 178 |
|
193 |
-@get-value ( x y -- value ) |
|
179 |
+@get-port ( x y lock -- value ) |
|
194 | 180 |
|
195 |
- GET-CELL #20 SUB ,get-cell-value JSR2 |
|
181 |
+ ( |
|
182 |
+ DUP #01 NEQ ^$no-lock JNZ |
|
183 |
+ DUP2 #01 SET-LOCK |
|
184 |
+ $no-lock |
|
185 |
+ STH DUP2 #02 #02 STHr MUL ADD ,set-type JSR2 |
|
186 |
+ GET-CELL |
|
187 |
+ ) |
|
196 | 188 |
|
197 | 189 |
RTN |
198 | 190 |
|
... | ... |
@@ -217,11 +209,11 @@ RTN |
217 | 209 |
@op-a ( x y char -- ) |
218 | 210 |
|
219 | 211 |
POP |
220 |
- ( get left ) DUP2 SWP #01 SUB SWP ,get-value JSR2 STH |
|
221 |
- ( get right ) DUP2 SWP #01 ADD SWP ,get-value JSR2 STH |
|
222 |
- ( incr y ) #01 ADD |
|
212 |
+ ( get left ) DUP2 SWP -- SWP GET-CELL-VALUE STH |
|
213 |
+ ( get right ) DUP2 SWP ++ SWP GET-CELL-VALUE STH |
|
214 |
+ ( incr y ) ++ |
|
223 | 215 |
( get result ) ADDr STHr |
224 |
- ,get-value-char JSR2 |
|
216 |
+ GET-CHAR |
|
225 | 217 |
SET-CELL |
226 | 218 |
|
227 | 219 |
RTN |
... | ... |
@@ -229,11 +221,12 @@ RTN |
229 | 221 |
@op-b ( x y char -- ) |
230 | 222 |
|
231 | 223 |
POP |
232 |
- ( get left ) DUP2 SWP #01 SUB SWP ,get-value JSR2 STH |
|
233 |
- ( get right ) DUP2 SWP #01 ADD SWP ,get-value JSR2 STH |
|
234 |
- ( incr y ) #01 ADD |
|
224 |
+ ( get left ) DUP2 SWP -- SWP GET-CELL-VALUE STH |
|
225 |
+ ( get right ) DUP2 SWP ++ SWP GET-CELL-VALUE STH |
|
226 |
+ ( incr y ) ++ |
|
235 | 227 |
( get result ) SUBr STHr |
236 |
- ,get-value-char JSR2 |
|
228 |
+ DUP =Console.byte |
|
229 |
+ GET-CHAR |
|
237 | 230 |
SET-CELL |
238 | 231 |
|
239 | 232 |
RTN |
... | ... |
@@ -241,7 +234,7 @@ RTN |
241 | 234 |
@op-c ( x y char -- ) |
242 | 235 |
|
243 | 236 |
POP |
244 |
- #01 ADD |
|
237 |
+ ++ |
|
245 | 238 |
#30 ~timer.frame #08 MOD ADD SET-CELL |
246 | 239 |
|
247 | 240 |
RTN |
... | ... |
@@ -314,12 +307,12 @@ RTN |
314 | 307 |
#2a SET-CELL POP STHr RTN |
315 | 308 |
$not-edge |
316 | 309 |
( collide ) |
317 |
- DUP2 #01 SUB GET-CELL #2e EQU ^$not-collide JNZ |
|
310 |
+ DUP2 -- GET-CELL #2e EQU ^$not-collide JNZ |
|
318 | 311 |
#2a SET-CELL POP STHr RTN |
319 | 312 |
$not-collide |
320 | 313 |
( move ) |
321 | 314 |
DUP2 STHr |
322 |
- SWP #01 SUB SWP SET-CELL |
|
315 |
+ SWP -- SWP SET-CELL |
|
323 | 316 |
#2e SET-CELL |
324 | 317 |
|
325 | 318 |
RTN |
... | ... |
@@ -352,7 +345,7 @@ RTN |
352 | 345 |
|
353 | 346 |
STH |
354 | 347 |
( clear ) DUP2 #2e SET-CELL |
355 |
- ( move ) #01 ADD DUP2 #01 ,set-lock JSR2 |
|
348 |
+ ( move ) ++ DUP2 #01 SET-LOCK |
|
356 | 349 |
STHr SET-CELL |
357 | 350 |
|
358 | 351 |
RTN |
... | ... |
@@ -383,12 +376,12 @@ RTN |
383 | 376 |
#2a SET-CELL POP STHr RTN |
384 | 377 |
$not-edge |
385 | 378 |
( collide ) |
386 |
- DUP2 SWP #01 SUB SWP GET-CELL #2e EQU ^$not-collide JNZ |
|
379 |
+ DUP2 SWP -- SWP GET-CELL #2e EQU ^$not-collide JNZ |
|
387 | 380 |
#2a SET-CELL POP STHr RTN |
388 | 381 |
$not-collide |
389 | 382 |
( move ) |
390 | 383 |
DUP2 |
391 |
- SWP #01 SUB SWP STHr SET-CELL |
|
384 |
+ SWP -- SWP STHr SET-CELL |
|
392 | 385 |
#2e SET-CELL |
393 | 386 |
|
394 | 387 |
RTN |
... | ... |
@@ -426,37 +419,24 @@ RTN |
426 | 419 |
$not-dot |
427 | 420 |
|
428 | 421 |
( skip locked ) |
429 |
- ROT ROT DUP2 ,get-lock JSR2 #00 EQU ^$not-locked JNZ |
|
422 |
+ ROT ROT DUP2 GET-LOCK #00 EQU ^$not-locked JNZ |
|
430 | 423 |
POP POP2 RTN |
431 | 424 |
$not-locked |
432 | 425 |
ROT |
433 | 426 |
|
434 |
- ( A ) DUP #41 EQU ,op-a JNZ2 |
|
435 |
- ( B ) DUP #42 EQU ,op-b JNZ2 |
|
436 |
- ( C ) DUP #43 EQU ,op-c JNZ2 |
|
437 |
- ( D ) DUP #44 EQU ,op-d JNZ2 |
|
438 |
- ( E ) DUP #45 EQU ,op-e JNZ2 |
|
439 |
- ( F ) DUP #46 EQU ,op-f JNZ2 |
|
440 |
- ( G ) DUP #47 EQU ,op-g JNZ2 |
|
441 |
- ( H ) DUP #48 EQU ,op-h JNZ2 |
|
442 |
- ( I ) DUP #49 EQU ,op-i JNZ2 |
|
443 |
- ( J ) DUP #4a EQU ,op-j JNZ2 |
|
444 |
- ( K ) DUP #4b EQU ,op-k JNZ2 |
|
445 |
- ( L ) DUP #4c EQU ,op-l JNZ2 |
|
446 |
- ( M ) DUP #4d EQU ,op-m JNZ2 |
|
447 |
- ( N ) DUP #4e EQU ,op-n JNZ2 ( done. ) |
|
448 |
- ( O ) DUP #4f EQU ,op-o JNZ2 |
|
449 |
- ( P ) DUP #50 EQU ,op-p JNZ2 |
|
450 |
- ( Q ) DUP #51 EQU ,op-q JNZ2 |
|
451 |
- ( R ) DUP #52 EQU ,op-r JNZ2 |
|
452 |
- ( S ) DUP #53 EQU ,op-s JNZ2 |
|
453 |
- ( T ) DUP #54 EQU ,op-t JNZ2 |
|
454 |
- ( U ) DUP #55 EQU ,op-u JNZ2 |
|
455 |
- ( V ) DUP #56 EQU ,op-v JNZ2 |
|
456 |
- ( W ) DUP #57 EQU ,op-w JNZ2 ( done. ) |
|
457 |
- ( X ) DUP #58 EQU ,op-x JNZ2 |
|
458 |
- ( Y ) DUP #59 EQU ,op-y JNZ2 |
|
459 |
- ( Z ) DUP #5a EQU ,op-z JNZ2 |
|
427 |
+ ( A ) DUP #41 EQU ,op-a JNZ2 ( B ) DUP #42 EQU ,op-b JNZ2 |
|
428 |
+ ( C ) DUP #43 EQU ,op-c JNZ2 ( D ) DUP #44 EQU ,op-d JNZ2 |
|
429 |
+ ( E ) DUP #45 EQU ,op-e JNZ2 ( F ) DUP #46 EQU ,op-f JNZ2 |
|
430 |
+ ( G ) DUP #47 EQU ,op-g JNZ2 ( H ) DUP #48 EQU ,op-h JNZ2 |
|
431 |
+ ( I ) DUP #49 EQU ,op-i JNZ2 ( J ) DUP #4a EQU ,op-j JNZ2 |
|
432 |
+ ( K ) DUP #4b EQU ,op-k JNZ2 ( L ) DUP #4c EQU ,op-l JNZ2 |
|
433 |
+ ( M ) DUP #4d EQU ,op-m JNZ2 ( N ) DUP #4e EQU ,op-n JNZ2 |
|
434 |
+ ( O ) DUP #4f EQU ,op-o JNZ2 ( P ) DUP #50 EQU ,op-p JNZ2 |
|
435 |
+ ( Q ) DUP #51 EQU ,op-q JNZ2 ( R ) DUP #52 EQU ,op-r JNZ2 |
|
436 |
+ ( S ) DUP #53 EQU ,op-s JNZ2 ( T ) DUP #54 EQU ,op-t JNZ2 |
|
437 |
+ ( U ) DUP #55 EQU ,op-u JNZ2 ( V ) DUP #56 EQU ,op-v JNZ2 |
|
438 |
+ ( W ) DUP #57 EQU ,op-w JNZ2 ( X ) DUP #58 EQU ,op-x JNZ2 |
|
439 |
+ ( Y ) DUP #59 EQU ,op-y JNZ2 ( Z ) DUP #5a EQU ,op-z JNZ2 |
|
460 | 440 |
( * ) DUP #2a EQU ,op-bang JNZ2 |
461 | 441 |
POP POP2 |
462 | 442 |
|
... | ... |
@@ -469,11 +449,11 @@ RTN |
469 | 449 |
#00 ~grid.width |
470 | 450 |
$hor |
471 | 451 |
( get x,y ) SWP2 OVR STH SWP2 OVR STHr |
472 |
- ( unlock ) #00 ,set-lock JSR2 |
|
473 |
- ( incr ) SWP #01 ADD SWP |
|
452 |
+ ( unlock ) #00 SET-LOCK |
|
453 |
+ ( incr ) SWP ++ SWP |
|
474 | 454 |
DUP2 LTH ^$hor JNZ |
475 | 455 |
POP2 |
476 |
- ( incr ) SWP #01 ADD SWP |
|
456 |
+ ( incr ) SWP ++ SWP |
|
477 | 457 |
DUP2 LTH ^$ver JNZ |
478 | 458 |
POP2 |
479 | 459 |
|
... | ... |
@@ -489,10 +469,10 @@ RTN |
489 | 469 |
$hor |
490 | 470 |
( get x,y ) SWP2 OVR STH SWP2 OVR STHr |
491 | 471 |
DUP2 GET-CELL ,run-char JSR2 |
492 |
- ( incr ) SWP #01 ADD SWP |
|
472 |
+ ( incr ) SWP ++ SWP |
|
493 | 473 |
DUP2 LTH ^$hor JNZ |
494 | 474 |
POP2 |
495 |
- ( incr ) SWP #01 ADD SWP |
|
475 |
+ ( incr ) SWP ++ SWP |
|
496 | 476 |
DUP2 LTH ^$ver JNZ |
497 | 477 |
POP2 |
498 | 478 |
,redraw JSR2 |
... | ... |
@@ -506,19 +486,19 @@ RTN |
506 | 486 |
( Positionx ) |
507 | 487 |
#0000 =Screen.x |
508 | 488 |
~selection.x1 |
509 |
- DUP #04 SFT ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
489 |
+ DUP #04 SFT GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
510 | 490 |
#22 =Screen.color |
511 | 491 |
#0008 =Screen.x |
512 |
- #0f AND ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
492 |
+ #0f AND GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
513 | 493 |
#22 =Screen.color |
514 | 494 |
|
515 | 495 |
( Positiony ) |
516 | 496 |
#0010 =Screen.x |
517 | 497 |
~selection.y1 |
518 |
- DUP #04 SFT ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
498 |
+ DUP #04 SFT GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
519 | 499 |
#22 =Screen.color |
520 | 500 |
#0018 =Screen.x |
521 |
- #0f AND ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
501 |
+ #0f AND GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
522 | 502 |
#22 =Screen.color |
523 | 503 |
|
524 | 504 |
#0020 =Screen.x |
... | ... |
@@ -528,10 +508,10 @@ RTN |
528 | 508 |
( Frame ) |
529 | 509 |
#0030 =Screen.x |
530 | 510 |
~timer.frame |
531 |
- DUP #04 SFT ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
511 |
+ DUP #04 SFT GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
532 | 512 |
#22 =Screen.color |
533 | 513 |
#0038 =Screen.x |
534 |
- #0f AND ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
514 |
+ #0f AND GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
535 | 515 |
#22 =Screen.color |
536 | 516 |
|
537 | 517 |
#0040 =Screen.x |
... | ... |
@@ -541,10 +521,10 @@ RTN |
541 | 521 |
( Speed ) |
542 | 522 |
#0050 =Screen.x |
543 | 523 |
~timer.speed |
544 |
- DUP #04 SFT ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
524 |
+ DUP #04 SFT GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
545 | 525 |
#22 =Screen.color |
546 | 526 |
#0058 =Screen.x |
547 |
- #0f AND ,get-value-char JSR2 #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
527 |
+ #0f AND GET-CHAR #20 SUB #00 SWP #0008 MUL2 ,font ADD2 =Screen.addr |
|
548 | 528 |
#22 =Screen.color |
549 | 529 |
|
550 | 530 |
( TODO: Signal VU ) |
... | ... |
@@ -569,10 +549,10 @@ RTN |
569 | 549 |
( get x,y ) SWP2 OVR STH SWP2 OVR STHr |
570 | 550 |
( sprite ) DUP2 ,get-cell-sprite JSR2 =Screen.addr |
571 | 551 |
( draw ) ,is-selected JSR2 #0d MUL #21 ADD =Screen.color |
572 |
- ( incr ) SWP #01 ADD SWP |
|
552 |
+ ( incr ) SWP ++ SWP |
|
573 | 553 |
DUP2 LTH ^$hor JNZ |
574 | 554 |
POP2 |
575 |
- ( incr ) SWP #01 ADD SWP |
|
555 |
+ ( incr ) SWP ++ SWP |
|
576 | 556 |
DUP2 LTH ^$ver JNZ |
577 | 557 |
POP2 |
578 | 558 |
|
... | ... |
@@ -270,7 +270,7 @@ walktoken(char *w) |
270 | 270 |
case ',': return 3; /* lit2 addr-hb addr-lb */ |
271 | 271 |
case '.': return 2; /* addr-hb addr-lb */ |
272 | 272 |
case '^': return 2; /* Relative jump: lit addr-offset */ |
273 |
- case '#': return (slen(w + 1) == 2 ? 2 : 3); |
|
273 |
+ case '#': return (slen(w + 1) == 4 ? 3 : 2); |
|
274 | 274 |
} |
275 | 275 |
if((m = findmacro(w))) { |
276 | 276 |
int i, res = 0; |
... | ... |
@@ -332,10 +332,12 @@ parsetoken(char *w) |
332 | 332 |
pushshort(findlabeladdr(w + 1), 1); |
333 | 333 |
l->refs++; |
334 | 334 |
return 1; |
335 |
- } else if(w[0] == '#' && sihx(w + 1)) { |
|
336 |
- if(slen(w + 1) == 2) |
|
335 |
+ } else if(w[0] == '#') { |
|
336 |
+ if(slen(w + 1) == 1) |
|
337 |
+ pushbyte((Uint8)w[1], 1); |
|
338 |
+ if(sihx(w + 1) && slen(w + 1) == 2) |
|
337 | 339 |
pushbyte(shex(w + 1), 1); |
338 |
- else if(slen(w + 1) == 4) |
|
340 |
+ else if(sihx(w + 1) && slen(w + 1) == 4) |
|
339 | 341 |
pushshort(shex(w + 1), 1); |
340 | 342 |
else |
341 | 343 |
return 0; |