mirror of
https://github.com/remko/waforth
synced 2025-01-14 08:01:34 +01:00
standalone: Fix export index
This commit is contained in:
parent
5ca31ee8f5
commit
45e99556b9
3 changed files with 65 additions and 58 deletions
|
@ -67,6 +67,10 @@ waforth_core.h: waforth_core.wasm
|
||||||
package: waforth
|
package: waforth
|
||||||
tar czf waforth-v$(VERSION)-$(PACKAGE_SUFFIX).tgz waforth
|
tar czf waforth-v$(VERSION)-$(PACKAGE_SUFFIX).tgz waforth
|
||||||
|
|
||||||
|
.PHONY: check
|
||||||
|
check:
|
||||||
|
echo "" | ./waforth
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
clean:
|
clean:
|
||||||
-rm -f waforth_core.wasm waforth_core.h $(OBJECTS) waforth *.tgz
|
-rm -f waforth_core.wasm waforth_core.h $(OBJECTS) waforth *.tgz
|
||||||
|
|
|
@ -10,8 +10,8 @@
|
||||||
|
|
||||||
#define CORE_TABLE_EXPORT_INDEX 0
|
#define CORE_TABLE_EXPORT_INDEX 0
|
||||||
#define CORE_MEMORY_EXPORT_INDEX 1
|
#define CORE_MEMORY_EXPORT_INDEX 1
|
||||||
#define CORE_ERROR_EXPORT_INDEX 6
|
#define CORE_RUN_EXPORT_INDEX 2
|
||||||
#define CORE_RUN_EXPORT_INDEX 7
|
#define CORE_ERROR_EXPORT_INDEX 9
|
||||||
|
|
||||||
#define ERR_UNKNOWN 0x1
|
#define ERR_UNKNOWN 0x1
|
||||||
#define ERR_QUIT 0x2
|
#define ERR_QUIT 0x2
|
||||||
|
@ -213,6 +213,8 @@ int main(int argc, char *argv_main[]) {
|
||||||
wasm_trap_delete(trap);
|
wasm_trap_delete(trap);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
printf("unknown error: %d\n", err_results.data[0].of.i32);
|
||||||
|
print_trap(trap);
|
||||||
assert(false);
|
assert(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
113
src/waforth.wat
113
src/waforth.wat
|
@ -2067,6 +2067,63 @@
|
||||||
;; Interpreter
|
;; Interpreter
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
|
;; Run the interpreter loop, until no more user input is available (or until
|
||||||
|
;; execution is aborted using QUIT)
|
||||||
|
(func $run (export "run") (param $silent i32)
|
||||||
|
(local $state i32)
|
||||||
|
(local $tos i32)
|
||||||
|
|
||||||
|
;; Load the top-of-stack (TOS) pointer as a local, and thread it through the execution.
|
||||||
|
;; The global TOS pointer will not be accurate until it is reset at the end of the loop,
|
||||||
|
;; at abort time, or at shell `call` time.
|
||||||
|
;;
|
||||||
|
;; Put the local value on the WASM operand stack, so it is threaded through the loop.
|
||||||
|
(local.tee $tos (global.get $tos))
|
||||||
|
|
||||||
|
;; In case a trap occurs, make sure the error is set to an unknown error.
|
||||||
|
;; We'll reset the error to a real value later if no trap occurs.
|
||||||
|
(global.set $error (i32.const 0x1 (; = ERR_UNKNOWN ;)))
|
||||||
|
|
||||||
|
;; Start looping until there is no more input
|
||||||
|
(block $endLoop (param i32) (result i32)
|
||||||
|
(loop $loop (param i32) (result i32)
|
||||||
|
;; Fill the input buffer with user input
|
||||||
|
(call $REFILL)
|
||||||
|
(br_if $endLoop (i32.eqz (call $pop)))
|
||||||
|
|
||||||
|
;; Run the interpreter loop on the entire input buffer
|
||||||
|
(local.set $tos (call $interpret))
|
||||||
|
|
||||||
|
;; Check for stack underflow
|
||||||
|
(if (i32.lt_s (local.get $tos) (i32.const 0x10000 (; = STACK_BASE ;)))
|
||||||
|
(call $fail (i32.const 0x20085 (; = str("stack empty") ;))))
|
||||||
|
|
||||||
|
;; Show prompt
|
||||||
|
(if (i32.eqz (local.get $silent))
|
||||||
|
(then
|
||||||
|
(if (i32.ge_s (i32.load (i32.const 0x208b0 (; = body(STATE) ;))) (i32.const 0))
|
||||||
|
(then
|
||||||
|
;; Write ok
|
||||||
|
(call $shell_emit (i32.const 111))
|
||||||
|
(call $shell_emit (i32.const 107)))
|
||||||
|
(else
|
||||||
|
;; Write error
|
||||||
|
(call $shell_emit (i32.const 101))
|
||||||
|
(call $shell_emit (i32.const 114))
|
||||||
|
(call $shell_emit (i32.const 114))
|
||||||
|
(call $shell_emit (i32.const 111))
|
||||||
|
(call $shell_emit (i32.const 114))))
|
||||||
|
(call $shell_emit (i32.const 10))))
|
||||||
|
(local.get $tos)
|
||||||
|
(br $loop)))
|
||||||
|
|
||||||
|
;; Reset the global TOS pointer to the current local value (still on the WASM operand stack)
|
||||||
|
(global.set $tos)
|
||||||
|
|
||||||
|
;; End of input was reached
|
||||||
|
(global.set $error (i32.const 0x4 (; = ERR_EOI ;))))
|
||||||
|
|
||||||
|
|
||||||
;; Interpret the string in the input buffer word by word, until
|
;; Interpret the string in the input buffer word by word, until
|
||||||
;; the end of the input buffer is reached.
|
;; the end of the input buffer is reached.
|
||||||
;;
|
;;
|
||||||
|
@ -2940,62 +2997,6 @@
|
||||||
;; API Functions
|
;; API Functions
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
;; Run the interpreter loop, until no more user input is available (or until
|
|
||||||
;; execution is aborted using QUIT)
|
|
||||||
(func $run (export "run") (param $silent i32)
|
|
||||||
(local $state i32)
|
|
||||||
(local $tos i32)
|
|
||||||
|
|
||||||
;; Load the top-of-stack (TOS) pointer as a local, and thread it through the execution.
|
|
||||||
;; The global TOS pointer will not be accurate until it is reset at the end of the loop,
|
|
||||||
;; at abort time, or at shell `call` time.
|
|
||||||
;;
|
|
||||||
;; Put the local value on the WASM operand stack, so it is threaded through the loop.
|
|
||||||
(local.tee $tos (global.get $tos))
|
|
||||||
|
|
||||||
;; In case a trap occurs, make sure the error is set to an unknown error.
|
|
||||||
;; We'll reset the error to a real value later if no trap occurs.
|
|
||||||
(global.set $error (i32.const 0x1 (; = ERR_UNKNOWN ;)))
|
|
||||||
|
|
||||||
;; Start looping until there is no more input
|
|
||||||
(block $endLoop (param i32) (result i32)
|
|
||||||
(loop $loop (param i32) (result i32)
|
|
||||||
;; Fill the input buffer with user input
|
|
||||||
(call $REFILL)
|
|
||||||
(br_if $endLoop (i32.eqz (call $pop)))
|
|
||||||
|
|
||||||
;; Run the interpreter loop on the entire input buffer
|
|
||||||
(local.set $tos (call $interpret))
|
|
||||||
|
|
||||||
;; Check for stack underflow
|
|
||||||
(if (i32.lt_s (local.get $tos) (i32.const 0x10000 (; = STACK_BASE ;)))
|
|
||||||
(call $fail (i32.const 0x20085 (; = str("stack empty") ;))))
|
|
||||||
|
|
||||||
;; Show prompt
|
|
||||||
(if (i32.eqz (local.get $silent))
|
|
||||||
(then
|
|
||||||
(if (i32.ge_s (i32.load (i32.const 0x208b0 (; = body(STATE) ;))) (i32.const 0))
|
|
||||||
(then
|
|
||||||
;; Write ok
|
|
||||||
(call $shell_emit (i32.const 111))
|
|
||||||
(call $shell_emit (i32.const 107)))
|
|
||||||
(else
|
|
||||||
;; Write error
|
|
||||||
(call $shell_emit (i32.const 101))
|
|
||||||
(call $shell_emit (i32.const 114))
|
|
||||||
(call $shell_emit (i32.const 114))
|
|
||||||
(call $shell_emit (i32.const 111))
|
|
||||||
(call $shell_emit (i32.const 114))))
|
|
||||||
(call $shell_emit (i32.const 10))))
|
|
||||||
(local.get $tos)
|
|
||||||
(br $loop)))
|
|
||||||
|
|
||||||
;; Reset the global TOS pointer to the current local value (still on the WASM operand stack)
|
|
||||||
(global.set $tos)
|
|
||||||
|
|
||||||
;; End of input was reached
|
|
||||||
(global.set $error (i32.const 0x4 (; = ERR_EOI ;))))
|
|
||||||
|
|
||||||
(func (export "push") (param $v i32)
|
(func (export "push") (param $v i32)
|
||||||
(global.set $tos (call $push (global.get $tos) (local.get $v))))
|
(global.set $tos (call $push (global.get $tos) (local.get $v))))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue