in the middle of debugging the javascript implementation
This commit is contained in:
parent
5fa7af7037
commit
428882af6a
|
@ -173,6 +173,8 @@ EOF
|
|||
empty]
|
||||
[(SpliceListIntoStack!? op)
|
||||
empty]
|
||||
[(UnspliceRestFromStack!? op)
|
||||
empty]
|
||||
[(FixClosureShellMap!? op)
|
||||
empty]))
|
||||
|
||||
|
@ -501,7 +503,11 @@ EOF
|
|||
(assemble-oparg (SetFrameCallee!-proc op)))]
|
||||
[(SpliceListIntoStack!? op)
|
||||
(format "RUNTIME.spliceListIntoStack(MACHINE, ~a);"
|
||||
(assemble-oparg (SpliceListIntoStack!-depth op)))]))
|
||||
(assemble-oparg (SpliceListIntoStack!-depth op)))]
|
||||
[(UnspliceRestFromStack!? op)
|
||||
(format "RUNTIME.unspliceRestFromStack(MACHINE, ~a, ~a);"
|
||||
(assemble-oparg (UnspliceRestFromStack!-depth op))
|
||||
(assemble-oparg (UnspliceRestFromStack!-length op)))]))
|
||||
|
||||
|
||||
|
||||
|
|
15
runtime.js
15
runtime.js
|
@ -261,6 +261,20 @@
|
|||
MACHINE.argcount = MACHINE.argcount + vals.length - 1;
|
||||
};
|
||||
|
||||
var unspliceRestFromStack = function(MACHINE, depth, length) {
|
||||
console.log(depth, length);
|
||||
var lst = NULL;
|
||||
var i;
|
||||
for (i = 0; i < length; i++) {
|
||||
lst = [MACHINE.env[MACHINE.env.length - depth - length + i], lst];
|
||||
}
|
||||
console.log(lst);
|
||||
MACHINE.env.splice(MACHINE.env.length - 1 - depth - length,
|
||||
length,
|
||||
lst);
|
||||
MACHINE.argcount = MACHINE.argcount - length + 1;
|
||||
};
|
||||
|
||||
|
||||
|
||||
// An arity is either a primitive number, an ArityAtLeast instance,
|
||||
|
@ -877,6 +891,7 @@
|
|||
|
||||
exports['trampoline'] = trampoline;
|
||||
exports['spliceListIntoStack'] = spliceListIntoStack;
|
||||
exports['unspliceRestFromStack'] = unspliceRestFromStack;
|
||||
|
||||
|
||||
exports['isNumber'] = isNumber;
|
||||
|
|
|
@ -390,4 +390,38 @@
|
|||
,(make-AssignImmediateStatement 'argcount (make-Const 3))
|
||||
,(make-PerformStatement (make-SpliceListIntoStack! (make-Const 2))))
|
||||
"MACHINE.argcount + ',' + MACHINE.env[0] + ',' + MACHINE.env[1] + ',' + MACHINE.env[2] + ',' + MACHINE.env[3] + ',' + MACHINE.env[4]")
|
||||
"5,3,2,1,world,hello")
|
||||
"5,3,2,1,world,hello")
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
;; testing rest splicing
|
||||
(test (E-many `(,(make-PushEnvironment 1 #f)
|
||||
,(make-AssignImmediateStatement (make-EnvLexicalReference 0 #f)
|
||||
(make-Const "hello"))
|
||||
,(make-AssignImmediateStatement 'argcount (make-Const 1))
|
||||
,(make-PerformStatement (make-UnspliceRestFromStack! (make-Const 0)
|
||||
(make-Const 1))))
|
||||
"MACHINE.argcount + ',' + plt.runtime.isList(MACHINE.env[0])")
|
||||
"1,true")
|
||||
|
||||
|
||||
(test (E-many
|
||||
`(,(make-PushEnvironment 5 #f)
|
||||
,(make-AssignImmediateStatement (make-EnvLexicalReference 0 #f)
|
||||
(make-Const "hello"))
|
||||
,(make-AssignImmediateStatement (make-EnvLexicalReference 1 #f)
|
||||
(make-Const "world"))
|
||||
,(make-AssignImmediateStatement (make-EnvLexicalReference 2 #f)
|
||||
(make-Const 'x))
|
||||
,(make-AssignImmediateStatement (make-EnvLexicalReference 3 #f)
|
||||
(make-Const 'y))
|
||||
,(make-AssignImmediateStatement (make-EnvLexicalReference 4 #f)
|
||||
(make-Const 'z))
|
||||
,(make-AssignImmediateStatement 'argcount (make-Const 5))
|
||||
,(make-PerformStatement (make-UnspliceRestFromStack! (make-Const 2) (make-Const 3))))
|
||||
"MACHINE.argcount + ',' + MACHINE.env.length + ',' + plt.runtime.isList(MACHINE.env[0]) + ',' + MACHINE.env[2] + ',' + MACHINE.env[1]")
|
||||
"3,3,true,hello,world")
|
Loading…
Reference in New Issue
Block a user