mirror of
https://github.com/janet-lang/janet
synced 2024-11-18 14:44:48 +00:00
43 lines
1.2 KiB
Plaintext
43 lines
1.2 KiB
Plaintext
# test *debug* flags
|
|
|
|
(import ./helper :prefix "" :exit true)
|
|
(start-suite 15)
|
|
|
|
(assert (deep= (in (disasm (defn a [] (def x 10) x)) :symbolslots)
|
|
@[])
|
|
"no symbolslots when *debug* is false")
|
|
|
|
(setdyn *debug* true)
|
|
(assert (deep= (in (disasm (defn a [] (def x 10) x)) :symbolslots)
|
|
@[[0 2147483647 0 "a"] [1 2147483647 1 "x"]])
|
|
"symbolslots when *debug* is true")
|
|
(setdyn *debug* false)
|
|
|
|
|
|
# need to fix assembling functions
|
|
(comment
|
|
(setdyn *debug* true)
|
|
(def f (asm (disasm (fn [x] (fn [y] (+ x y))))))
|
|
(assert (deep= (in (disasm f) :symbolslots)
|
|
@[[0 2147483647 0 "a"] [1 2147483647 1 "x"]])
|
|
"symbolslots survive disasm/asm")
|
|
(setdyn *debug* false)
|
|
)
|
|
|
|
(setdyn *debug* true)
|
|
(assert (deep= (in (disasm (defn a [arg]
|
|
(def x 10)
|
|
(do
|
|
(def y 20)
|
|
(def z 30)
|
|
(+ x y z)))) :symbolslots)
|
|
@[[-1 2147483647 0 "arg"]
|
|
[0 2147483647 1 "a"]
|
|
[1 2147483647 2 "x"]
|
|
[2 7 3 "y"]
|
|
[3 7 4 "z"]])
|
|
"arg & inner symbolslots")
|
|
(setdyn *debug* false)
|
|
|
|
(end-suite)
|