| ... | ... |
@@ -46,9 +46,9 @@ Program p; |
| 46 | 46 |
|
| 47 | 47 |
char ops[][4] = {
|
| 48 | 48 |
"BRK", "NOP", "LIT", "LDR", "STR", "---", "JMP", "JSR", |
| 49 |
- "EQU", "NEQ", "GTH", "LTH", "AND", "XOR", "SHL", "SHR", |
|
| 49 |
+ "EQU", "NEQ", "GTH", "LTH", "AND", "ORA", "SHL", "SHR", |
|
| 50 | 50 |
"POP", "DUP", "SWP", "OVR", "ROT", "---", "CLN", "STH", |
| 51 |
- "ADD", "SUB", "MUL", "DIV", "---", "---", "---", "---" |
|
| 51 |
+ "ADD", "SUB", "MUL", "DIV", "---", "---", "---", "XOR" |
|
| 52 | 52 |
}; |
| 53 | 53 |
|
| 54 | 54 |
int scin(char *s, char c) { int i = 0; while(s[i]) if(s[i++] == c) return i - 1; return -1; } /* string char index */
|
| ... | ... |
@@ -154,17 +154,16 @@ BRK |
| 154 | 154 |
~tileview.addr ADD2 =addr ( addr offset ) |
| 155 | 155 |
~MOUS.x ~tileview.x SUB2 ~MOUS.x ~tileview.x SUB2 #0040 DIV2 #0040 MUL2 SUB2 =pos.x |
| 156 | 156 |
~MOUS.y ~tileview.y SUB2 ~MOUS.y ~tileview.y SUB2 #0040 DIV2 #0040 MUL2 SUB2 =pos.y |
| 157 |
- ,no-fill-mode ~bankview.mode #01 NEQ JMP2? |
|
| 158 |
- ( fill row ) #ff ~addr ~pos.y 8/ ADD2 STR |
|
| 159 |
- ,redraw JSR2 ,click-end JMP2 |
|
| 160 |
- @no-fill-mode |
|
| 161 | 157 |
,no-erase-mode ~bankview.mode #02 NEQ JMP2? |
| 162 |
- ( erase row ) #00 ~addr ~pos.y 8/ ADD2 STR |
|
| 158 |
+ ( load ) ~addr ~pos.y 8/ ADD2 LDR |
|
| 159 |
+ ( mask ) #01 #07 ~pos.x 8/ SWP POP SUB SHL |
|
| 160 |
+ #ff XOR AND |
|
| 161 |
+ ( save ) ~addr ~pos.y 8/ ADD2 STR |
|
| 163 | 162 |
,redraw JSR2 ,click-end JMP2 |
| 164 | 163 |
@no-erase-mode |
| 165 | 164 |
( load ) ~addr ~pos.y 8/ ADD2 LDR |
| 166 | 165 |
( mask ) #01 #07 ~pos.x 8/ SWP POP SUB SHL |
| 167 |
- XOR |
|
| 166 |
+ ORA |
|
| 168 | 167 |
( save ) ~addr ~pos.y 8/ ADD2 STR |
| 169 | 168 |
,redraw JSR2 ,click-end JMP2 |
| 170 | 169 |
|
| ... | ... |
@@ -7,6 +7,11 @@ |
| 7 | 7 |
- Only draw-canvas when mouse has changed |
| 8 | 8 |
- Only draw-canvas target tile |
| 9 | 9 |
- Resize buttons |
| 10 |
+ - Zoom |
|
| 11 |
+ - Erase |
|
| 12 |
+ - Toggle guides |
|
| 13 |
+ - Set eye option |
|
| 14 |
+ - Complete save/load |
|
| 10 | 15 |
) |
| 11 | 16 |
|
| 12 | 17 |
%RTN { JMP2r }
|
| ... | ... |
@@ -19,7 +24,7 @@ |
| 19 | 24 |
|
| 20 | 25 |
;center { x 2 y 2 }
|
| 21 | 26 |
;toolbar { x1 2 y1 2 x2 2 y2 2 }
|
| 22 |
-;cursor { x 2 y 2 x0 2 y0 2 size 1 patt 1 drag 1 }
|
|
| 27 |
+;cursor { x 2 y 2 x0 2 y0 2 size 1 patt 1 drag 1 view 1 }
|
|
| 23 | 28 |
;rect { x1 2 y1 2 x2 2 y2 2 }
|
| 24 | 29 |
;color { byte 1 }
|
| 25 | 30 |
;pos { x 2 y 2 }
|
| ... | ... |
@@ -35,20 +40,20 @@ |
| 35 | 40 |
( find screen center ) |
| 36 | 41 |
~Screen.width #0002 DIV2 =center.x |
| 37 | 42 |
~Screen.height #0002 DIV2 =center.y |
| 43 |
+ #0010 =toolbar.x1 #0010 =toolbar.y1 |
|
| 38 | 44 |
|
| 39 | 45 |
( default brush ) |
| 40 | 46 |
#04 =cursor.size |
| 41 | 47 |
|
| 42 |
- #0010 =canvas.x1 #0016 =canvas.y1 |
|
| 43 | 48 |
#0026 =canvas.w #001a =canvas.h ( 380x260 ) |
| 44 |
- #0010 =toolbar.x1 #0010 =toolbar.y1 |
|
| 45 | 49 |
|
| 46 |
- ,draw-background JSR2 |
|
| 50 |
+ ( center canvas ) |
|
| 51 |
+ ~center.x ~canvas.w 8* 2/ SUB2 =canvas.x1 |
|
| 52 |
+ ~center.y ~canvas.h 8* 2/ SUB2 =canvas.y1 |
|
| 47 | 53 |
|
| 54 |
+ ,draw-background JSR2 |
|
| 48 | 55 |
,fit-canvas JSR2 |
| 49 |
- |
|
| 50 | 56 |
,draw-titlebar JSR2 |
| 51 |
- |
|
| 52 | 57 |
,fit-toolbar JSR2 |
| 53 | 58 |
|
| 54 | 59 |
BRK |
| ... | ... |
@@ -102,9 +107,32 @@ BRK |
| 102 | 107 |
,$no-touch-canvas ~Mouse.x CLN2r ~canvas.x1 GTH2 STH2r ~canvas.x2 LTH2 #0101 NEQ2 JMP2? |
| 103 | 108 |
,$no-touch-canvas ~Mouse.y CLN2r ~canvas.y1 GTH2 STH2r ~canvas.y2 LTH2 #0101 NEQ2 JMP2? |
| 104 | 109 |
~Mouse.x ~canvas.x1 SUB2 ~Mouse.y ~canvas.y1 SUB2 ,paint JSR2 |
| 105 |
- ,$touch-end JMP2 |
|
| 106 | 110 |
$no-touch-canvas |
| 107 | 111 |
|
| 112 |
+ ( background interface ) |
|
| 113 |
+ ~Mouse.x ~Screen.width #0020 SUB2 SUB2 8/ |
|
| 114 |
+ DUP2 |
|
| 115 |
+ #0000 NEQ2 ,$no-toggle-guides ROT JMP2? |
|
| 116 |
+ ~cursor.view #00 EQU =cursor.view |
|
| 117 |
+ ( release ) #00 =Mouse.state |
|
| 118 |
+ ~cursor.view =Console.byte |
|
| 119 |
+ ~Screen.width #0020 SUB2 =Sprite.x |
|
| 120 |
+ ~Screen.height #0010 SUB2 =Sprite.y |
|
| 121 |
+ ,mode_guidesoff #00 ~cursor.view #0008 MUL2 ADD2 =Sprite.addr |
|
| 122 |
+ #01 =Sprite.color |
|
| 123 |
+ $no-toggle-guides |
|
| 124 |
+ DUP2 |
|
| 125 |
+ #0001 NEQ2 ,$no-load-button ROT JMP2? |
|
| 126 |
+ ( release ) #00 =Mouse.state |
|
| 127 |
+ #bb =Console.byte |
|
| 128 |
+ $no-load-button |
|
| 129 |
+ DUP2 |
|
| 130 |
+ #0002 NEQ2 ,$no-save-button ROT JMP2? |
|
| 131 |
+ ( release ) #00 =Mouse.state |
|
| 132 |
+ #cc =Console.byte |
|
| 133 |
+ $no-save-button |
|
| 134 |
+ POP2 |
|
| 135 |
+ |
|
| 108 | 136 |
$touch-end |
| 109 | 137 |
|
| 110 | 138 |
$no-touch |
| ... | ... |
@@ -121,8 +149,10 @@ BRK |
| 121 | 149 |
RTN |
| 122 | 150 |
|
| 123 | 151 |
@paint ( x y ) |
| 152 |
+ |
|
| 153 |
+ ,erase ~Mouse.state #10 EQU JMP2? |
|
| 124 | 154 |
|
| 125 |
- #0004 SUB2 =pos.y #0004 SUB2 =pos.x ( cursor offset ) |
|
| 155 |
+ #0003 SUB2 =pos.y #0003 SUB2 =pos.x ( cursor offset ) |
|
| 126 | 156 |
|
| 127 | 157 |
#00 =px.x #00 =px.y |
| 128 | 158 |
$ver |
| ... | ... |
@@ -130,12 +160,10 @@ RTN |
| 130 | 160 |
$hor |
| 131 | 161 |
( addr ) ,size_icn #00 ~cursor.size 8* ADD2 |
| 132 | 162 |
( byte ) #00 ~px.y ADD2 LDR #07 ~px.x SUB SHR #01 AND |
| 133 |
- |
|
| 134 | 163 |
#00 EQU ,$no-pixel ROT JMP2? |
| 135 | 164 |
,$no-pixel ,patternize JSR2 #00 EQU JMP2? |
| 136 | 165 |
~pos.x #00 ~px.x ADD2 ~pos.y #00 ~px.y ADD2 ,add-pixel JSR2 |
| 137 | 166 |
$no-pixel |
| 138 |
- |
|
| 139 | 167 |
( incr ) ~px.x #01 ADD =px.x |
| 140 | 168 |
,$hor ~px.x #08 LTH JMP2? |
| 141 | 169 |
( incr ) ~px.y #01 ADD =px.y |
| ... | ... |
@@ -146,6 +174,29 @@ RTN |
| 146 | 174 |
|
| 147 | 175 |
RTN |
| 148 | 176 |
|
| 177 |
+@erase ( x y ) |
|
| 178 |
+ |
|
| 179 |
+ #0003 SUB2 =pos.y #0003 SUB2 =pos.x ( cursor offset ) |
|
| 180 |
+ |
|
| 181 |
+ #00 =px.x #00 =px.y |
|
| 182 |
+ $ver |
|
| 183 |
+ #00 =px.x |
|
| 184 |
+ $hor |
|
| 185 |
+ ( addr ) ,size_icn #00 ~cursor.size 8* ADD2 |
|
| 186 |
+ ( byte ) #00 ~px.y ADD2 LDR #07 ~px.x SUB SHR #01 AND |
|
| 187 |
+ #00 EQU ,$no-pixel ROT JMP2? |
|
| 188 |
+ ,$no-pixel ,patternize JSR2 #00 EQU JMP2? |
|
| 189 |
+ ~pos.x #00 ~px.x ADD2 ~pos.y #00 ~px.y ADD2 ,remove-pixel JSR2 |
|
| 190 |
+ $no-pixel |
|
| 191 |
+ ( incr ) ~px.x #01 ADD =px.x |
|
| 192 |
+ ,$hor ~px.x #08 LTH JMP2? |
|
| 193 |
+ ( incr ) ~px.y #01 ADD =px.y |
|
| 194 |
+ ,$ver ~px.y #08 LTH JMP2? |
|
| 195 |
+ ,draw-canvas JSR2 |
|
| 196 |
+ ,draw-toolbar JSR2 |
|
| 197 |
+ |
|
| 198 |
+RTN |
|
| 199 |
+ |
|
| 149 | 200 |
@patternize |
| 150 | 201 |
|
| 151 | 202 |
,$noplain ~cursor.patt #00 NEQ JMP2? |
| ... | ... |
@@ -198,11 +249,19 @@ RTN |
| 198 | 249 |
@add-pixel ( x y ) |
| 199 | 250 |
|
| 200 | 251 |
=pix.y =pix.x |
| 201 |
- |
|
| 202 | 252 |
( get tile addr ) ,data ~pix.x 8/ ~pix.y 8/ ~canvas.w MUL2 ADD2 8* ~pix.y MOD8 ADD2 ADD2 |
| 253 |
+ ( load ) DUP2 LDR |
|
| 254 |
+ ( mask ) #01 #07 ~pix.x MOD8 SWP POP SUB SHL ORA |
|
| 255 |
+ ( save ) ROT ROT STR |
|
| 256 |
+ |
|
| 257 |
+RTN |
|
| 203 | 258 |
|
| 259 |
+@remove-pixel ( x y ) |
|
| 260 |
+ |
|
| 261 |
+ =pix.y =pix.x |
|
| 262 |
+ ( get tile addr ) ,data ~pix.x 8/ ~pix.y 8/ ~canvas.w MUL2 ADD2 8* ~pix.y MOD8 ADD2 ADD2 |
|
| 204 | 263 |
( load ) DUP2 LDR |
| 205 |
- ( mask ) #01 #07 ~pix.x MOD8 SWP POP SUB SHL XOR |
|
| 264 |
+ ( mask ) #01 #07 ~pix.x MOD8 SWP POP SUB SHL #ff XOR AND |
|
| 206 | 265 |
( save ) ROT ROT STR |
| 207 | 266 |
|
| 208 | 267 |
RTN |
| ... | ... |
@@ -217,9 +276,9 @@ RTN |
| 217 | 276 |
( draw ) #09 =Sprite.color |
| 218 | 277 |
( incr ) ~Sprite.x 8+ =Sprite.x |
| 219 | 278 |
( incr ) ~Sprite.addr 8+ =Sprite.addr |
| 220 |
- ,$hor ~Sprite.x ~canvas.x2 LTH2 JMP2? |
|
| 279 |
+ ,$hor ~Sprite.x ~canvas.x2 NEQ2 JMP2? |
|
| 221 | 280 |
( incr ) ~Sprite.y 8+ =Sprite.y |
| 222 |
- ,$ver ~Sprite.y ~canvas.y2 LTH2 JMP2? |
|
| 281 |
+ ,$ver ~Sprite.y ~canvas.y2 NEQ2 JMP2? |
|
| 223 | 282 |
|
| 224 | 283 |
RTN |
| 225 | 284 |
|
| ... | ... |
@@ -230,13 +289,13 @@ RTN |
| 230 | 289 |
( incr ) ~Screen.x ++ =Screen.x |
| 231 | 290 |
( draw ) ~rect.y1 =Screen.y ~color =Screen.color |
| 232 | 291 |
( draw ) ~rect.y2 =Screen.y ~color =Screen.color |
| 233 |
- ,$hor ~Screen.x ~rect.x2 LTH2 JMP2? |
|
| 292 |
+ ,$hor ~Screen.x ~rect.x2 NEQ2 JMP2? |
|
| 234 | 293 |
~rect.y1 =Screen.y |
| 235 | 294 |
$ver |
| 236 | 295 |
( draw ) ~rect.x1 =Screen.x ~color =Screen.color |
| 237 | 296 |
( draw ) ~rect.x2 =Screen.x ~color =Screen.color |
| 238 | 297 |
( incr ) ~Screen.y ++ =Screen.y |
| 239 |
- ,$ver ~Screen.y ~rect.y2 ++ LTH2 JMP2? |
|
| 298 |
+ ,$ver ~Screen.y ~rect.y2 ++ NEQ2 JMP2? |
|
| 240 | 299 |
|
| 241 | 300 |
RTN |
| 242 | 301 |
|
| ... | ... |
@@ -248,9 +307,9 @@ RTN |
| 248 | 307 |
$hor |
| 249 | 308 |
( draw ) ~color =Screen.color |
| 250 | 309 |
( incr ) ~Screen.x ++ =Screen.x |
| 251 |
- ,$hor ~Screen.x ~rect.x2 LTH2 JMP2? |
|
| 310 |
+ ,$hor ~Screen.x ~rect.x2 NEQ2 JMP2? |
|
| 252 | 311 |
( incr ) ~Screen.y ++ =Screen.y |
| 253 |
- ,$ver ~Screen.y ~rect.y2 LTH2 JMP2? |
|
| 312 |
+ ,$ver ~Screen.y ~rect.y2 NEQ2 JMP2? |
|
| 254 | 313 |
|
| 255 | 314 |
RTN |
| 256 | 315 |
|
| ... | ... |
@@ -261,6 +320,10 @@ RTN |
| 261 | 320 |
|
| 262 | 321 |
#0000 EQU2 ~Mouse.state #00 NEQ #0101 EQU2 RTN? ( Return if unchanged ) |
| 263 | 322 |
|
| 323 |
+ ~cursor.x #0003 SUB2 =Sprite.x |
|
| 324 |
+ ~cursor.y #0003 SUB2 =Sprite.y |
|
| 325 |
+ #10 =Sprite.color |
|
| 326 |
+ |
|
| 264 | 327 |
( clear last cursor ) |
| 265 | 328 |
~cursor.x =Sprite.x |
| 266 | 329 |
~cursor.y =Sprite.y |
| ... | ... |
@@ -272,10 +335,20 @@ RTN |
| 272 | 335 |
~Mouse.y =cursor.y |
| 273 | 336 |
|
| 274 | 337 |
( draw new cursor ) |
| 338 |
+ |
|
| 339 |
+ ,$outside-canvas ~Mouse.x CLN2r ~canvas.x1 GTH2 STH2r ~canvas.x2 LTH2 #0101 NEQ2 JMP2? |
|
| 340 |
+ ,$outside-canvas ~Mouse.y CLN2r ~canvas.y1 GTH2 STH2r ~canvas.y2 LTH2 #0101 NEQ2 JMP2? |
|
| 341 |
+ ~cursor.x #0003 SUB2 =Sprite.x |
|
| 342 |
+ ~cursor.y #0003 SUB2 =Sprite.y |
|
| 343 |
+ ,brush_view #00 ~cursor.size #0008 MUL2 ADD2 =Sprite.addr |
|
| 344 |
+ #11 ~Mouse.state ADD =Sprite.color |
|
| 345 |
+ $outside-canvas |
|
| 346 |
+ |
|
| 275 | 347 |
~cursor.x =Sprite.x |
| 276 | 348 |
~cursor.y =Sprite.y |
| 349 |
+ |
|
| 277 | 350 |
,brush_pointer #00 ~Controller #02 EQU #0008 MUL2 ADD2 =Sprite.addr |
| 278 |
- #13 =Sprite.color |
|
| 351 |
+ #1f =Sprite.color |
|
| 279 | 352 |
|
| 280 | 353 |
RTN |
| 281 | 354 |
|
| ... | ... |
@@ -304,7 +377,7 @@ RTN |
| 304 | 377 |
|
| 305 | 378 |
@fit-toolbar |
| 306 | 379 |
|
| 307 |
- ~toolbar.x1 #0018 ADD2 =toolbar.x2 |
|
| 380 |
+ ~toolbar.x1 #0010 ADD2 =toolbar.x2 |
|
| 308 | 381 |
~toolbar.y1 #0040 ADD2 =toolbar.y2 |
| 309 | 382 |
,draw-toolbar JSR2 |
| 310 | 383 |
|
| ... | ... |
@@ -313,7 +386,7 @@ RTN |
| 313 | 386 |
@draw-toolbar |
| 314 | 387 |
|
| 315 | 388 |
~toolbar.x1 -- ~toolbar.y1 -- ~toolbar.x2 ~toolbar.y2 #02 ,line-rect JSR2 |
| 316 |
- ~toolbar.x1 #0002 SUB2 ~toolbar.y1 #0002 SUB2 ~toolbar.x2 ++ ~toolbar.y2 ++ #01 ,line-rect JSR2 |
|
| 389 |
+ ~toolbar.x1 #0002 SUB2 ~toolbar.y1 #0002 SUB2 ~toolbar.x2 ~toolbar.y2 #01 ,line-rect JSR2 |
|
| 317 | 390 |
|
| 318 | 391 |
~toolbar.x1 =Sprite.x |
| 319 | 392 |
~toolbar.y1 =Sprite.y |
| ... | ... |
@@ -339,17 +412,6 @@ RTN |
| 339 | 412 |
( incr ) ~Sprite.addr 8+ =Sprite.addr |
| 340 | 413 |
,$patterns ~Sprite.y ~toolbar.y1 #0040 ADD2 LTH2 JMP2? |
| 341 | 414 |
|
| 342 |
- ( draw brush tools ) |
|
| 343 |
- |
|
| 344 |
- ~toolbar.x1 #0010 ADD2 =Sprite.x |
|
| 345 |
- ~toolbar.y1 =Sprite.y |
|
| 346 |
- |
|
| 347 |
- $brushes |
|
| 348 |
- ( draw ) #09 =Sprite.color |
|
| 349 |
- ( incr ) ~Sprite.y 8+ =Sprite.y |
|
| 350 |
- ( incr ) ~Sprite.addr 8+ =Sprite.addr |
|
| 351 |
- ,$brushes ~Sprite.y ~toolbar.y1 #0040 ADD2 LTH2 JMP2? |
|
| 352 |
- |
|
| 353 | 415 |
RTN |
| 354 | 416 |
|
| 355 | 417 |
@draw-background |
| ... | ... |
@@ -372,7 +434,7 @@ RTN |
| 372 | 434 |
OVR2 OVR2 LTH2 ^$draw-ver SWP JMP? |
| 373 | 435 |
POP2 POP2 |
| 374 | 436 |
|
| 375 |
- ( draw save/load icons ) |
|
| 437 |
+ ( draw save/load/guides icons ) |
|
| 376 | 438 |
~Screen.width #0018 SUB2 =Sprite.x |
| 377 | 439 |
~Screen.height #0010 SUB2 =Sprite.y |
| 378 | 440 |
,load_icn =Sprite.addr |
| ... | ... |
@@ -380,9 +442,12 @@ RTN |
| 380 | 442 |
~Screen.width #0010 SUB2 =Sprite.x |
| 381 | 443 |
,save_icn =Sprite.addr |
| 382 | 444 |
#01 =Sprite.color |
| 445 |
+ ~Screen.width #0020 SUB2 =Sprite.x |
|
| 446 |
+ ,mode_guidesoff =Sprite.addr |
|
| 447 |
+ #01 =Sprite.color |
|
| 383 | 448 |
|
| 384 | 449 |
( draw width ) |
| 385 |
- ~Screen.width #0040 SUB2 =Sprite.x |
|
| 450 |
+ ~Screen.width #0048 SUB2 =Sprite.x |
|
| 386 | 451 |
,font_hex ~canvas.w #f0 AND #04 SHR #08 MUL ADD2 =Sprite.addr |
| 387 | 452 |
( draw ) #02 =Sprite.color |
| 388 | 453 |
~Sprite.x 8+ =Sprite.x |
| ... | ... |
@@ -418,17 +483,29 @@ RTN |
| 418 | 483 |
[ feaa aaaa aaaa fe00 ] |
| 419 | 484 |
[ fe82 fe82 fe82 fe00 ] |
| 420 | 485 |
|
| 486 |
+@brush_view |
|
| 487 |
+ [ 0000 0010 0000 0000 ] |
|
| 488 |
+ [ 0000 1028 1000 0000 ] |
|
| 489 |
+ [ 0000 3828 3800 0000 ] |
|
| 490 |
+ [ 0010 2844 2810 0000 ] |
|
| 491 |
+ [ 0038 4444 4438 0000 ] |
|
| 492 |
+ [ 1028 4482 4428 1000 ] |
|
| 493 |
+ [ 3844 8282 8244 3800 ] |
|
| 494 |
+ [ 7c82 8282 8282 7c00 ] |
|
| 495 |
+ [ 7cfe fefe fefe 7c00 ] |
|
| 496 |
+ |
|
| 421 | 497 |
@brush_pointer [ 80c0 e0f0 f8e0 1000 ] |
| 422 | 498 |
@brush_hand [ 4040 4070 f8f8 f870 ] |
| 423 | 499 |
@brush_eraser [ 2050 b87c 3e1c 0800 ] |
| 424 | 500 |
|
| 425 | 501 |
@mode_guidesoff [ 0038 4492 2810 0000 ] |
| 502 |
+@mode_guideson [ 0000 0082 4438 0000 ] |
|
| 426 | 503 |
@mode_zoomout [ 3048 8484 4834 0200 ] |
| 504 |
+ |
|
| 427 | 505 |
[ 0000 0000 0000 0000 ] |
| 428 | 506 |
[ 0000 0000 0000 0000 ] |
| 429 | 507 |
[ 0000 0000 0000 0000 ] |
| 430 | 508 |
|
| 431 |
-@mode_guideson [ 0000 0082 4438 0000 ] |
|
| 432 | 509 |
@mode_zoomin [ 3245 8284 4834 0200 ] |
| 433 | 510 |
@load_icn [ feaa d6aa d4aa f400 ] |
| 434 | 511 |
@save_icn [ fe82 8282 848a f400 ] |
| ... | ... |
@@ -39,7 +39,8 @@ void op_ldr(Uxn *u) { Uint16 a = pop16(u->src); push8(u->src, mempeek8(u, a)); }
|
| 39 | 39 |
void op_str(Uxn *u) { Uint16 a = pop16(u->src); Uint8 b = pop8(u->src); mempoke8(u, a, b); }
|
| 40 | 40 |
/* Logic */ |
| 41 | 41 |
void op_and(Uxn *u) { Uint8 a = pop8(u->src), b = pop8(u->src); push8(u->src, b & a); }
|
| 42 |
-void op_xor(Uxn *u) { Uint8 a = pop8(u->src), b = pop8(u->src); push8(u->src, b | a); }
|
|
| 42 |
+void op_ora(Uxn *u) { Uint8 a = pop8(u->src), b = pop8(u->src); push8(u->src, b | a); }
|
|
| 43 |
+void op_xor(Uxn *u) { Uint8 a = pop8(u->src), b = pop8(u->src); push8(u->src, b ^ a); }
|
|
| 43 | 44 |
void op_shl(Uxn *u) { Uint8 a = pop8(u->src), b = pop8(u->src); push8(u->src, b << (a % 8)); }
|
| 44 | 45 |
void op_shr(Uxn *u) { Uint8 a = pop8(u->src), b = pop8(u->src); push8(u->src, b >> (a % 8)); }
|
| 45 | 46 |
/* Stack */ |
| ... | ... |
@@ -67,6 +68,7 @@ void op_jsr16(Uxn *u) { push16(u->dst, u->ram.ptr); u->ram.ptr = pop16(u->src);
|
| 67 | 68 |
void op_ldr16(Uxn *u) { Uint16 a = pop16(u->src); push16(u->src, mempeek16(u, a)); }
|
| 68 | 69 |
void op_str16(Uxn *u) { Uint16 a = pop16(u->src); Uint16 b = pop16(u->src); mempoke16(u, a, b); }
|
| 69 | 70 |
void op_and16(Uxn *u) { Uint16 a = pop16(u->src), b = pop16(u->src); push16(u->src, b & a); }
|
| 71 |
+void op_ora16(Uxn *u) { Uint16 a = pop16(u->src), b = pop16(u->src); push16(u->src, b | a); }
|
|
| 70 | 72 |
void op_xor16(Uxn *u) { Uint16 a = pop16(u->src), b = pop16(u->src); push16(u->src, b ^ a); }
|
| 71 | 73 |
void op_shl16(Uxn *u) { Uint16 a = pop16(u->src), b = pop16(u->src); push16(u->src, b << (a % 16)); }
|
| 72 | 74 |
void op_shr16(Uxn *u) { Uint16 a = pop16(u->src), b = pop16(u->src); push16(u->src, b >> (a % 16)); }
|
| ... | ... |
@@ -90,14 +92,14 @@ void op_lth16(Uxn *u) { Uint16 a = pop16(u->src), b = pop16(u->src); push8(u->sr
|
| 90 | 92 |
|
| 91 | 93 |
void (*ops[])(Uxn *u) = {
|
| 92 | 94 |
op_brk, op_nop, op_lit, op_ldr, op_str, op_nop, op_jmp, op_jsr, |
| 93 |
- op_equ, op_neq, op_gth, op_lth, op_and, op_xor, op_shl, op_shr, |
|
| 95 |
+ op_equ, op_neq, op_gth, op_lth, op_and, op_ora, op_shl, op_shr, |
|
| 94 | 96 |
op_pop, op_dup, op_swp, op_ovr, op_rot, op_nop, op_cln, op_sth, |
| 95 |
- op_add, op_sub, op_mul, op_div, op_nop, op_nop, op_nop, op_nop, |
|
| 97 |
+ op_add, op_sub, op_mul, op_div, op_nop, op_nop, op_nop, op_xor, |
|
| 96 | 98 |
/* 16-bit */ |
| 97 | 99 |
op_brk, op_nop16, op_lit16, op_ldr16, op_str16, op_nop, op_jmp16, op_jsr16, |
| 98 |
- op_equ16, op_neq16, op_gth16, op_lth16, op_and16, op_xor16, op_shl16, op_shr16, |
|
| 100 |
+ op_equ16, op_neq16, op_gth16, op_lth16, op_and16, op_ora16, op_shl16, op_shr16, |
|
| 99 | 101 |
op_pop16, op_dup16, op_swp16, op_ovr16, op_rot16, op_nop, op_cln16, op_sth16, |
| 100 |
- op_add16, op_sub16, op_mul16, op_div16, op_nop, op_nop, op_nop, op_nop |
|
| 102 |
+ op_add16, op_sub16, op_mul16, op_div16, op_nop, op_nop, op_nop, op_xor16 |
|
| 101 | 103 |
}; |
| 102 | 104 |
|
| 103 | 105 |
Uint8 opr[][4] = { /* wstack-/+ rstack-/+ */
|