1
0
mirror of https://github.com/janet-lang/janet synced 2025-01-12 16:40:27 +00:00

More corrections to varargs.

This commit is contained in:
bakpakin 2017-07-15 12:32:24 -04:00
parent 57886db410
commit f0545865a8
4 changed files with 13 additions and 5 deletions

View File

@ -16,8 +16,7 @@ GST_INTERNAL_HEADERS=$(addprefix core/, cache.h)
GST_HEADERS=$(addprefix include/gst/, gst.h) GST_HEADERS=$(addprefix include/gst/, gst.h)
# Use gdb. On mac use lldb # Use gdb. On mac use lldb
DEBUGGER=lldb DEBUGGER=gdb
CC=clang
all: $(GST_TARGET) all: $(GST_TARGET)

View File

@ -90,7 +90,7 @@ void gst_thread_pushnil(Gst *vm, GstThread *thread, uint32_t n) {
void gst_thread_tuplepack(Gst *vm, GstThread *thread, uint32_t n) { void gst_thread_tuplepack(Gst *vm, GstThread *thread, uint32_t n) {
GstValue *stack = thread->data + thread->count; GstValue *stack = thread->data + thread->count;
uint32_t size = gst_frame_size(stack); uint32_t size = gst_frame_size(stack);
if (n > size) { if (n >= size) {
/* Push one extra nil to ensure space for tuple */ /* Push one extra nil to ensure space for tuple */
gst_thread_pushnil(vm, thread, n - size + 1); gst_thread_pushnil(vm, thread, n - size + 1);
stack = thread->data + thread->count; stack = thread->data + thread->count;

View File

@ -102,6 +102,15 @@
(assert (= 3 (tran t)) "return from thread") (assert (= 3 (tran t)) "return from thread")
(assert (= (status t) "dead") "finished thread is dead") (assert (= (status t) "dead") "finished thread is dead")
# Var arg tests
(def vargf (fn [x &] (apply + (if x x 0) 100 &)))
(assert (= 100 (vargf)) "var arg no arguments")
(assert (= 101 (vargf 1)) "var arg no packed arguments")
(assert (= 103 (vargf 1 2)) "var arg tuple size 1")
(assert (= 110 (vargf 1 2 3 4)) "var arg tuple size 3")
(assert (= 210 (vargf 1 2 3 4 10 10 10 10 10 10 10 10 10 10)) "var arg large tuple")
# report # report
(print "\n" num-tests-passed " of " num-tests-run " tests passed\n") (print "\n" num-tests-passed " of " num-tests-run " tests passed\n")

View File

@ -17,8 +17,8 @@
(clear b)) (clear b))
(parse-consume p))) (parse-consume p)))
(def eval (fn [x] (def eval (fn [x &]
(apply (*compile* x) 123))) (apply (*compile* x) &)))
(def t (thread (fn [] (def t (thread (fn []
(while true (while true