commit a293c1daa84ee58c6c9d66fd340b1ea71ccfa109
parent 68a253e67e101bfaa4b7ae71f46feabb00433212
Author: neauoire <aliceffekt@gmail.com>
Date:   Tue, 20 Apr 2021 11:32:26 -0700
Ported the hello-world example
Diffstat:
4 files changed, 25 insertions(+), 30 deletions(-)
diff --git a/README.md b/README.md
@@ -22,35 +22,34 @@ To build the Uxn emulator, you must have [SDL2](https://wiki.libsdl.org/).
 Read more in the [Uxambly Guide](https://wiki.xxiivv.com/site/uxambly.html).
 
 ```
+( Dev/Console )
+
 %RTN { JMP2r }
 
 ( devices )
 
-|0110 ;Console { vector 2 pad 6 char 1 byte 1 short 2 }
+|0110 @Console    [ &pad $8 &char $1 ]
 
 ( program )
 
 |0200
 	
-	,text1 ,print-label JSR2
-	,text2 ,print-label JSR2
-	#ab =Console.byte
-	#cdef =Console.short
-
+	;hello-word ;print JSR2
+	
 BRK
 
-@print-label ( text )
+@print ( addr -- )
 	
-	$loop
-		( send ) DUP2 PEK2 =Console.char
+	&loop
+		( send ) DUP2 PEK2 .Console/char IOW
 		( incr ) #0001 ADD2
-		( loop ) DUP2 PEK2 #00 NEQ ^$loop JNZ
+		( loop ) DUP2 PEK2 #00 NEQ ,&loop JNZ
 	POP2
 
-RTN    
+RTN
+
+@hello-word [ 48 65 6c 6c 6f 20 57 6f 72 6c 64 21 ]
 
-@text1 [ Welcome 20 to 20 UxnVM 0a00 ]
-@text2 [ Hello 20 World 0a00 ] 
 ```
 
 ## TODOs
diff --git a/build.sh b/build.sh
@@ -32,7 +32,7 @@ else
 fi
 
 echo "Assembling.."
-./bin/assembler projects/examples/dev.controller.buttons.usm bin/boot.rom
+./bin/assembler projects/examples/dev.console.usm bin/boot.rom
 
 echo "Running.."
 if [ "${2}" = '--cli' ]; 
diff --git a/projects/examples/dev.console.usm b/projects/examples/dev.console.usm
@@ -4,28 +4,24 @@
 
 ( devices )
 
-|0110 ;Console { vector 2 pad 6 char 1 byte 1 short 2 string 2 }
+|0110 @Console    [ &pad $8 &char $1 ]
 
 ( program )
 
 |0200
 	
-	,text1 ,print-label JSR2
-	,text2 ,print-label JSR2
-	#ab =Console.byte
-	#cdef =Console.short
-
+	;hello-word ;print JSR2
+	
 BRK
 
-@print-label ( text )
+@print ( addr -- )
 	
-	$loop
-		( send ) DUP2 PEK2 =Console.char
+	&loop
+		( send ) DUP2 PEK2 .Console/char IOW
 		( incr ) #0001 ADD2
-		( loop ) DUP2 PEK2 #00 NEQ ^$loop JNZ
+		( loop ) DUP2 PEK2 #00 NEQ ,&loop JNZ
 	POP2
 
-RTN    
+RTN
 
-@text1 [ Welcome 20 to 20 UxnVM 0a00 ]
-@text2 [ Hello 20 World 0a00 ] 
+@hello-word [ 48 65 6c 6c 6f 20 57 6f 72 6c 64 21 ]
diff --git a/src/assembler.c b/src/assembler.c
@@ -49,8 +49,8 @@ char ops[][4] = {
 int   scin(char *s, char c) { int i = 0; while(s[i]) if(s[i++] == c) return i - 1; return -1; } /* string char index */
 int   scmp(char *a, char *b, int len) { int i = 0; while(a[i] == b[i] && i < len) if(!a[i++]) return 1; return 0; } /* string compare */
 int   slen(char *s) { int i = 0; while(s[i] && s[++i]) ; return i; } /* string length */
-int   sihx(char *s) { int i = 0; char c; while((c = s[i++])) if(!(c >= '0' && c <= '9') && !(c >= 'a' && c <= 'f') && !(c >= 'A' && c <= 'F')) return 0; return 1; } /* string is hexadecimal */
-int   shex(char *s) { int n = 0, i = 0; char c; while((c = s[i++])) if(c >= '0' && c <= '9') n = n * 16 + (c - '0'); else if(c >= 'A' && c <= 'F') n = n * 16 + 10 + (c - 'A'); else if(c >= 'a' && c <= 'f') n = n * 16 + 10 + (c - 'a'); return n; } /* string to num */
+int   sihx(char *s) { int i = 0; char c; while((c = s[i++])) if(!(c >= '0' && c <= '9') && !(c >= 'a' && c <= 'f')) return 0; return 1; } /* string is hexadecimal */
+int   shex(char *s) { int n = 0, i = 0; char c; while((c = s[i++])) if(c >= '0' && c <= '9') n = n * 16 + (c - '0'); else if(c >= 'a' && c <= 'f') n = n * 16 + 10 + (c - 'a'); return n; } /* string to num */
 char *scpy(char *src, char *dst, int len) { int i = 0; while((dst[i] = src[i]) && i < len - 2) i++; dst[i + 1] = '\0'; return dst; } /* string copy */
 
 #pragma mark - Helpers
@@ -338,7 +338,7 @@ void
 cleanup(char *filename)
 {
 	int i;
-	printf("Assembled %s(%0.2fkb), %d labels, %d macros.\n\n", filename, (p.ptr - TRIM) / 1000.0, p.llen, p.mlen);
+	printf("Assembled %s(%d bytes), %d labels, %d macros.\n\n", filename, (p.ptr - TRIM), p.llen, p.mlen);
 	for(i = 0; i < p.llen; ++i)
 		if(!p.labels[i].refs)
 			printf("--- Unused label: %s\n", p.labels[i].name);