From 17752decf4bf0ad905f54e965cf541112876a196 Mon Sep 17 00:00:00 2001 From: JeffBezanson Date: Sat, 6 Jun 2009 21:15:54 +0000 Subject: [PATCH] implementing support for lambdas with up to 2^32-1 required arguments using copy-list to implement append2 fixing bug in op_vargc when nrequired==MAX_ARGS making fetching of multibyte numbers from bytecode portable some cleanup in compiler --- femtolisp/compiler.lsp | 98 +++++++++---- femtolisp/flisp.boot | 316 +++++++++++++++++++++-------------------- femtolisp/flisp.c | 109 ++++++++++++-- femtolisp/opcodes.h | 9 +- femtolisp/system.lsp | 10 +- femtolisp/todo | 3 + femtolisp/unittest.lsp | 16 +++ 7 files changed, 355 insertions(+), 206 deletions(-) diff --git a/femtolisp/compiler.lsp b/femtolisp/compiler.lsp index ee1cce0..378b743 100644 --- a/femtolisp/compiler.lsp +++ b/femtolisp/compiler.lsp @@ -15,12 +15,15 @@ :vector :aref :aset! - :loadt :loadf :loadnil :load0 :load1 :loadi8 :loadv :loadv.l - :loadg :loada :loadc :loadg.l - :setg :seta :setc :setg.l + :loadt :loadf :loadnil :load0 :load1 :loadi8 + :loadv :loadv.l + :loadg :loadg.l + :loada :loada.l :loadc :loadc.l + :setg :setg.l + :seta :seta.l :setc :setc.l :closure :argc :vargc :trycatch :copyenv :let :for :tapply - :add2 :sub2 :neg + :add2 :sub2 :neg :largc :lvargc dummy_t dummy_f dummy_nil])) (for 0 (1- (length keys)) @@ -43,23 +46,33 @@ :div0 2)) (define (make-code-emitter) (vector () (table) 0)) +(define (bcode:code b) (aref b 0)) +(define (bcode:ctable b) (aref b 1)) +(define (bcode:nconst b) (aref b 2)) +; get an index for a referenced value in a bytecode object +(define (bcode:indexfor b v) + (let ((const-to-idx (bcode:ctable b)) + (nconst (bcode:nconst b))) + (if (has? const-to-idx v) + (get const-to-idx v) + (begin (put! const-to-idx v nconst) + (prog1 nconst + (aset! b 2 (+ nconst 1))))))) (define (emit e inst . args) (if (memq inst '(:loadv :loadg :setg)) - (let* ((const-to-idx (aref e 1)) - (nconst (aref e 2)) - (v (car args)) - (vind (if (has? const-to-idx v) - (get const-to-idx v) - (begin (put! const-to-idx v nconst) - (set! nconst (+ nconst 1)) - (- nconst 1))))) - (aset! e 2 nconst) - (set! args (list vind)) - (if (>= vind 256) - (set! inst (case inst - (:loadv :loadv.l) - (:loadg :loadg.l) - (:setg :setg.l)))))) + (set! args (list (bcode:indexfor e (car args))))) + (let ((longform + (assq inst '((:loadv :loadv.l) (:loadg :loadg.l) (:setg :setg.l) + (:loada :loada.l) (:seta :seta.l))))) + (if (and longform + (> (car args) 255)) + (set! inst (cadr longform)))) + (let ((longform + (assq inst '((:loadc :loadc.l) (:setc :setc.l))))) + (if (and longform + (or (> (car args) 255) + (> (cadr args) 255))) + (set! inst (cadr longform)))) (aset! e 0 (nreconc (cons inst args) (aref e 0))) e) @@ -70,13 +83,15 @@ ; labels are fixed-up. (define (encode-byte-code e) (let* ((cl (reverse! e)) - (long? (>= (+ (length cl) + (v (list->vector cl)) + (long? (>= (+ (length v) (* 3 (count (lambda (i) - (memq i '(:loadv :loadg :setg - :jmp :brt :brf))) + (memq i '(:loadv.l :loadg.l :setg.l + :loada.l :seta.l :loadc.l + :setc.l :jmp :brt :brf + :largc :lvargc))) cl))) - 65536)) - (v (list->vector cl))) + 65536))) (let ((n (length v)) (i 0) (label-to-loc (table)) @@ -104,7 +119,8 @@ (if (< i n) (let ((nxt (aref v i))) (case vi - ((:loadv.l :loadg.l :setg.l) + ((:loadv.l :loadg.l :setg.l :loada.l :seta.l :largc + :lvargc) (io.write bcode (uint32 nxt)) (set! i (+ i 1))) @@ -119,6 +135,12 @@ (set! i (+ i 1)) (io.write bcode (uint8 (aref v i))) (set! i (+ i 1))) + + ((:loadc.l :setc.l) ; 2 uint32 args + (io.write bcode (uint32 nxt)) + (set! i (+ i 1)) + (io.write bcode (uint32 (aref v i))) + (set! i (+ i 1))) ((:jmp :brf :brt) (put! fixup-to-label (sizeof bcode) nxt) @@ -135,9 +157,9 @@ (io.tostring! bcode)))) (define (const-to-idx-vec e) - (let ((cvec (vector.alloc (aref e 2)))) + (let ((cvec (vector.alloc (bcode:nconst e)))) (table.foreach (lambda (val idx) (aset! cvec idx val)) - (aref e 1)) + (bcode:ctable e)) cvec)) (define (index-of item lst start) @@ -291,7 +313,8 @@ (let ((head (car x))) (if (and (pair? head) (eq? (car head) 'lambda) - (list? (cadr head))) + (list? (cadr head)) + (not (length> (cadr head) MAX_ARGS))) (compile-let g env tail? x) (compile-call g env tail? x)))) @@ -390,12 +413,15 @@ (define (compile-f env f . let?) (let ((g (make-code-emitter)) (args (cadr f))) - (cond ((not (null? let?)) (emit g :let)) - ((null? (lastcdr args)) (emit g :argc (length args))) + (cond ((not (null? let?)) (emit g :let)) + ((length> args MAX_ARGS) (emit g (if (null? (lastcdr args)) + :largc :lvargc) + (length args))) + ((null? (lastcdr args)) (emit g :argc (length args))) (else (emit g :vargc (if (atom? args) 0 (length args))))) (compile-in g (cons (to-proper args) env) #t (caddr f)) (emit g :ret) - (function (encode-byte-code (aref g 0)) + (function (encode-byte-code (bcode:code g)) (const-to-idx-vec g)))) (define (compile f) (compile-f () f)) @@ -455,12 +481,22 @@ (princ (number->string (aref code i))) (set! i (+ i 1))) + ((:loada.l :seta.l :largc :lvargc) + (princ (number->string (ref-uint32-LE code i))) + (set! i (+ i 4))) + ((:loadc :setc) (princ (number->string (aref code i)) " ") (set! i (+ i 1)) (princ (number->string (aref code i))) (set! i (+ i 1))) + ((:loadc.l :setc.l) + (princ (number->string (ref-uint32-LE code i)) " ") + (set! i (+ i 4)) + (princ (number->string (ref-uint32-LE code i))) + (set! i (+ i 4))) + ((:jmp :brf :brt) (princ "@" (hex5 (ref-uint16-LE code i))) (set! i (+ i 2))) diff --git a/femtolisp/flisp.boot b/femtolisp/flisp.boot index 405b54e..257ea23 100644 --- a/femtolisp/flisp.boot +++ b/femtolisp/flisp.boot @@ -1,316 +1,324 @@ zero? -#function("n1f0`W;" []) +#function("r1g0`W;" []) vector.map -#function("n2c0e1f131q42;" [#function("rc0e1f031q42;" [#function("r`g00avc0ms2f0;" [#function("n1g00f0g20g21f0[31\\;" [])]) vector.alloc]) length]) +#function("r2c0e1g131u42;" [#function("vc0e1g031u42;" [#function("v`i00azc0qw2g0;" [#function("r1i00g0i20i21g0[31\\;" [])]) vector.alloc]) length]) vector->list -#function("n1c0e1f031_q43;" [#function("raf0c0ms2f1;" [#function("n1g10g00f0v[g01Kk01;" [])]) length]) +#function("r1c0e1g031_u43;" [#function("vag0c0qw2g1;" [#function("r1i10i00g0z[i01Ko01;" [])]) length]) untrace -#function("n1c0e1f031q42;" [#function("re0f0316K0e1g00e2f031b2[42;^;" [traced? set-top-level-value! function:vals]) top-level-value]) +#function("r1c0e1g031u42;" [#function("ve0g0316K0e1i00e2g031b2[42;^;" [traced? set-top-level-value! function:vals]) top-level-value]) traced? -#function("n1e0f031e0g0031>;" [function:code] #0=[#function("o0e0c1f0K312c2f0t2;" [println x #.apply] #0#) ()]) +#function("r1e0g031e0i0031>;" [function:code] #0=[#function("s0e0c1g0K312c2g0x2;" [println x #.apply] #0#) ()]) trace -#function("n1c0e1f031q322c2;" [#function("rc0e130q42;" [#function("re0g0031@6p0e1g10e2c3f0c4c5c6c7g10L2f0L3L2c8c7g00L2f0L3L3L33142;^;" [traced? set-top-level-value! eval lambda begin println cons quote apply]) gensym]) top-level-value ok]) +#function("r1c0e1g031u322c2;" [#function("vc0e130u42;" [#function("ve0i0031@6p0e1i10e2c3g0c4c5c6c7i10L2g0L3L2c8c7i00L2g0L3L3L33142;^;" [traced? set-top-level-value! eval lambda begin println cons quote apply]) gensym]) top-level-value ok]) to-proper -#function("n1f0A6;0f0;f0?6F0f0L1;f0Me0f0N31K;" [to-proper]) +#function("r1g0A6;0g0;g0?6F0g0L1;g0Me0g0N31K;" [to-proper]) table.values -#function("n1e0c1m_f043;" [table.foldl #function("n3f1f2K;" [])]) +#function("r1e0c1q_g043;" [table.foldl #function("r3g1g2K;" [])]) table.pairs -#function("n1e0c1m_f043;" [table.foldl #function("n3f0f1Kf2K;" [])]) +#function("r1e0c1q_g043;" [table.foldl #function("r3g0g1Kg2K;" [])]) table.keys -#function("n1e0c1m_f043;" [table.foldl #function("n3f0f2K;" [])]) +#function("r1e0c1q_g043;" [table.foldl #function("r3g0g2K;" [])]) table.invert -#function("n1c0e130q42;" [#function("re0c1m_g00332f0;" [table.foldl #function("n3e0g00f1f043;" [put!])]) table]) +#function("r1c0e130u42;" [#function("ve0c1q_i00332g0;" [table.foldl #function("r3e0i00g1g043;" [put!])]) table]) table.foreach -#function("n2e0c1m_f143;" [table.foldl #function("n3g00f0f1322];" [])]) +#function("r2e0c1q_g143;" [table.foldl #function("r3i00g0g1322];" [])]) table.clone -#function("n1c0e130q42;" [#function("re0c1m_g00332f0;" [table.foldl #function("n3e0g00f0f143;" [put!])]) table]) +#function("r1c0e130u42;" [#function("ve0c1q_i00332g0;" [table.foldl #function("r3e0i00g0g143;" [put!])]) table]) symbol-syntax -#function("n1e0e1f0^43;" [get *syntax-environment*]) +#function("r1e0e1g0^43;" [get *syntax-environment*]) string.trim -#function("n3c0^^q43;" [#function("rc0mj02c1mj12c2e3g0031q42;" [#function("n4f2f3X16J02e0f1e1f0f232326a0g00f0f1e2f0f232f344;f2;" [string.find string.char string.inc]) #function("n3e0f2`3216R02e1f1e2f0e3f0f23232326g0g01f0f1e3f0f23243;f2;" [> string.find string.char string.dec]) #function("re0g10g00g10g11`f034g01g10g12f03343;" [string.sub]) length])]) +#function("r3c0^^u43;" [#function("vc0qm02c1qm12c2e3i0031u42;" [#function("r4g2g3X16J02e0g1e1g0g232326a0i00g0g1e2g0g232g344;g2;" [string.find string.char string.inc]) #function("r3e0g2`3216R02e1g1e2g0e3g0g23232326g0i01g0g1e3g0g23243;g2;" [> string.find string.char string.dec]) #function("ve0i10i00i10i11`g034i01i10i12g03343;" [string.sub]) length])]) string.tail -#function("n2e0f0e1f0`f13342;" [string.sub string.inc]) +#function("r2e0g0e1g0`g13342;" [string.sub string.inc]) string.rpad -#function("n3e0f0e1f2f1e2f031v3242;" [string string.rep string.count]) +#function("r3e0g0e1g2g1e2g031z3242;" [string string.rep string.count]) string.rep -#function("n2f1b4X6q0e0f1`326G0c1;f1aW6U0e2f041;f1b2W6f0e2f0f042;e2f0f0f043;e3f1316\x8b0e2f0e4f0f1av3242;e4e2f0f032f1b2U242;" [<= "" string odd? string.rep]) +#function("r2g1b4X6q0e0g1`326G0c1;g1aW6U0e2g041;g1b2W6f0e2g0g042;e2g0g0g043;e3g1316\x8b0e2g0e4g0g1az3242;e4e2g0g032g1b2U242;" [<= "" string odd? string.rep]) string.map -#function("n2c0e130e2f131q43;" [#function("rc0`q322e1f041;" [#function("r^f0g01X6`02e0g00g10e1g11f03231322e2g11f032j0520;" [io.putc string.char string.inc]) io.tostring!]) buffer length]) +#function("r2c0e130e2g131u43;" [#function("vc0`u322e1g041;" [#function("v^g0i01X6`02e0i00i10e1i11g03231322e2i11g032m0520;" [io.putc string.char string.inc]) io.tostring!]) buffer length]) string.lpad -#function("n3e0e1f2f1e2f031v32f042;" [string string.rep string.count]) +#function("r3e0e1g2g1e2g031z32g042;" [string string.rep string.count]) string.join -#function("n2f0A6;0c0;c1e230q42;" ["" #function("re0f0g00M322e1c2mg00N322e3f041;" [io.write for-each #function("n1e0g00g11322e0g00f042;" [io.write]) io.tostring!]) buffer]) +#function("r2g0A6;0c0;c1e230u42;" ["" #function("ve0g0i00M322e1c2qi00N322e3g041;" [io.write for-each #function("r1e0i00i11322e0i00g042;" [io.write]) io.tostring!]) buffer]) simple-sort -#function("n1f0A17>02f0NA6D0f0;c0f0Mq42;" [#function("rc0e1c2mg00N32q42;" [#function("re0e1f0M31g00L1e1f0N3143;" [nconc simple-sort]) separate #function("n1f0g00X;" [])])]) +#function("r1g0A17>02g0NA6D0g0;c0g0Mu42;" [#function("vc0e1c2qi00N32u42;" [#function("ve0e1g0M31i00L1e1g0N3143;" [nconc simple-sort]) separate #function("r1g0i00X;" [])])]) set-syntax! -#function("n2e0e1f0f143;" [put! *syntax-environment*]) +#function("r2e0e1g0g143;" [put! *syntax-environment*]) separate -#function("n2g00f0f1__44;" [] #0=[#function("n4f1A6>0f2f3K;f0f1M316[0g00f0f1Nf1Mf2Kf344;g00f0f1Nf2f1Mf3K44;" [] #0#) ()]) +#function("r2i00g0g1__44;" [] #0=[#function("r4g1A6>0g2g3K;g0g1M316[0i00g0g1Ng1Mg2Kg344;i00g0g1Ng2g1Mg3K44;" [] #0#) ()]) self-evaluating? -#function("n1f0?16>02f0C@17_02e0f03116_02f0C16_02f0e1f031<;" [constant? top-level-value]) +#function("r1g0?16>02g0C@17_02e0g03116_02g0C16_02g0e1g031<;" [constant? top-level-value]) reverse! -#function("n1c0_q42;" [#function("r^g00F6Q02g00Ng00f0g00j02P2k005202f0;" [])]) +#function("r1c0_u42;" [#function("v^i00F6Q02i00Ni00g0i00m02P2o005202g0;" [])]) reverse -#function("n1e0e1_f043;" [foldl cons]) +#function("r1e0e1_g043;" [foldl cons]) revappend -#function("n2e0e1f031f142;" [nconc reverse]) +#function("r2e0e1g031g142;" [nconc reverse]) repl -#function("n0c0^^q43;" [#function("rc0mj02c1mj12f1302e240;" [#function("n0e0c1312e2e3312c4c5mc6mpq42;" [princ "> " io.flush *output-stream* #function("re0e131@16H02c2e3f031q42;" [io.eof? *input-stream* #function("re0f0312f0i12];" [print that]) load-process]) #function("n0e040;" [read]) #function("n1e0e1312e2f041;" [io.discardbuffer *input-stream* raise])]) #function("n0c0mc1mp6G0e2302g0140;^;" [#function("n0g003016@02e040;" [newline]) #function("n1e0f041;" [print-exception]) newline]) newline])]) +#function("r0c0^^u43;" [#function("vc0qm02c1qm12g1302e240;" [#function("r0e0c1312e2e3312c4c5qc6qtu42;" [princ "> " io.flush *output-stream* #function("ve0e131@16H02c2e3g031u42;" [io.eof? *input-stream* #function("ve0g0312g0k12];" [print that]) load-process]) #function("r0e040;" [read]) #function("r1e0e1312e2g041;" [io.discardbuffer *input-stream* raise])]) #function("r0c0qc1qt6G0e2302i0140;^;" [#function("r0i003016@02e040;" [newline]) #function("r1e0g041;" [print-exception]) newline]) newline])]) remainder -#function("n2f0f0f1Vf1T2v;" []) +#function("r2g0g0g1Vg1T2z;" []) ref-uint32-LE -#function("n2e0f0f1`u[`32e0f0f1au[b832e0f0f1b2u[b@32e0f0f1b3u[bH32R4;" [ash]) +#function("r2e0g0g1`y[`32e0g0g1ay[b832e0g0g1b2y[b@32e0g0g1b3y[bH32R4;" [ash]) ref-uint16-LE -#function("n2e0f0f1`u[`32e0f0f1au[b832u;" [ash]) +#function("r2e0g0g1`y[`32e0g0g1ay[b832y;" [ash]) random -#function("n1e0f0316F0e1e230f042;e330f0T2;" [integer? mod rand rand.double]) +#function("r1e0g0316F0e1e230g042;e330g0T2;" [integer? mod rand rand.double]) quote-value -#function("n1e0f0316>0f0;c1f0L2;" [self-evaluating? quote]) +#function("r1e0g0316>0g0;c1g0L2;" [self-evaluating? quote]) println -#function("o0e0f0Q2e1302;" [print newline]) +#function("s0e0g0Q2e1302;" [print newline]) print-to-string -#function("n1c0e130q42;" [#function("re0f0g00322e1f041;" [io.print io.tostring!]) buffer]) +#function("r1c0e130u42;" [#function("ve0g0i00322e1g041;" [io.print io.tostring!]) buffer]) print-exception -#function("n1c0^^q43;" [#function("rc0mj02c1mj12g00F16[02g00Mc2<16[02e3g00b4326\x850f0c4e5g0031c6e7g0031c8352f1e9g0031315M1g00F16\x9f02g00Mc:<16\x9f02g00NF6\xb40f0c;e5g0031c<335M1g00F16\xc402g00Mc=<6\xd90f0c>312f0g00NQ25M1g00F16\xe902g00Mc?<6\x080e@e7g0031312f0cAe5g0031325M1eBg003116\x1d02e3g00b2326?1f1g00M312f0cC312cDe5g0031q325M1f0cE312f1g00312f0eF312];" [#function("o0e0e1f0t3;" [io.princ *error-stream*]) #function("o0e0e1f0t3;" [io.print *error-stream*]) type-error length= "type-error: " cadr ": expected " caddr ", got " cadddr unbound-error "unbound-error: eval: variable " " has no value" error "error: " load-error print-exception "in file " list? ": " #function("re0f03117?02f0C6H0g005K0g01f041;" [string?]) "*** Unhandled exception: " *linefeed*])]) +#function("r1c0^^u43;" [#function("vc0qm02c1qm12i00F16[02i00Mc2<16[02e3i00b4326\x850g0c4e5i0031c6e7i0031c8352g1e9i0031315M1i00F16\x9f02i00Mc:<16\x9f02i00NF6\xb40g0c;e5i0031c<335M1i00F16\xc402i00Mc=<6\xd90g0c>312g0i00NQ25M1i00F16\xe902i00Mc?<6\x080e@e7i0031312g0cAe5i0031325M1eBi003116\x1d02e3i00b2326?1g1i00M312g0cC312cDe5i0031u325M1g0cE312g1i00312g0eF312];" [#function("s0e0e1g0x3;" [io.princ *error-stream*]) #function("s0e0e1g0x3;" [io.print *error-stream*]) type-error length= "type-error: " cadr ": expected " caddr ", got " cadddr unbound-error "unbound-error: eval: variable " " has no value" error "error: " load-error print-exception "in file " list? ": " #function("ve0g03117?02g0C6H0i005K0i01g041;" [string?]) "*** Unhandled exception: " *linefeed*])]) print -#function("o0e0e1f0t3;" [io.print *output-stream*]) +#function("s0e0e1g0x3;" [io.print *output-stream*]) princ -#function("o0e0e1f0t3;" [io.princ *output-stream*]) +#function("s0e0e1g0x3;" [io.princ *output-stream*]) positive? -#function("n1e0f0`42;" [>]) +#function("r1e0g0`42;" [>]) odd? -#function("n1e0f031@;" [even?]) +#function("r1e0g031@;" [even?]) nreconc -#function("n2e0e1f031f142;" [nconc reverse!]) +#function("r2e0e1g031g142;" [nconc reverse!]) newline -#function("n0e0e1312];" [princ *linefeed*]) +#function("r0e0e1312];" [princ *linefeed*]) nestlist -#function("n3e0f2`326>0_;f1e1f0f0f131f2av33K;" [<= nestlist]) +#function("r3e0g2`326>0_;g1e1g0g0g131g2az33K;" [<= nestlist]) negative? -#function("n1f0`X;" []) +#function("r1g0`X;" []) mod0 -#function("n2f0f0f1Vf1T2v;" []) +#function("r2g0g0g1Vg1T2z;" []) mod -#function("n2f0e0f0f132f1T2v;" [div]) +#function("r2g0e0g0g132g1T2z;" [div]) memv -#function("n2f1?6:0^;f1Mf0=6F0f1;e0f0f1N42;" [memv]) +#function("r2g1?6:0^;g1Mg0=6F0g1;e0g0g1N42;" [memv]) member -#function("n2f1?6:0^;f1Mf0>6F0f1;e0f0f1N42;" [member]) +#function("r2g1?6:0^;g1Mg0>6F0g1;e0g0g1N42;" [member]) mark-label -#function("n2e0f0e1f143;" [emit :label]) +#function("r2e0g0e1g143;" [emit :label]) mapcar -#function("o1g00f0f142;" [] #0=[#function("n2f1A6=0f040;f1M?6H0f1M;f0e0e1f132Q2g00f0e0e2f13232K;" [map car cdr] #0#) ()]) +#function("s1i00g0g142;" [] #0=[#function("r2g1A6=0g040;g1M?6H0g1M;g0e0e1g132Q2i00g0e0e2g13232K;" [map car cdr] #0#) ()]) map-int -#function("n2e0f1`326>0_;c1f0`31_K_q43;" [<= #function("rf0j12ag01avc0ms2f0;" [#function("n1g01g10f031_KP2g01Nk01;" [])])]) +#function("r2e0g1`326>0_;c1g0`31_K_u43;" [<= #function("vg0m12ai01azc0qw2g0;" [#function("r1i01i10g031_KP2i01No01;" [])])]) map! -#function("n2f1^f1F6O02f1f0f1M31O2f1Nj15502;" []) +#function("r2g1^g1F6O02g1g0g1M31O2g1Nm15502;" []) map -#function("n2f1?6;0f1;f0f1M31e0f0f1N32K;" [map]) +#function("r2g1?6;0g1;g0g1M31e0g0g1N32K;" [map]) make-system-image -#function("n1c0e1f0e2e3e434c5e6q44;" [#function("r^i02c1c2mq42;" [*print-pretty* #function("rc0mc1mpf0302;" [#function("n0e0c1me2e3e430313142;" [for-each #function("n1f0E16m02e0f031@16m02e1f031G@16m02e2f0g1132@16m02e3e1f03131@6\x9c0e4g10f0322e5g10c6322e4g10e1f031322e5g10c642;^;" [constant? top-level-value memq iostream? io.print io.write "\n"]) reverse! simple-sort environment]) #function("n1g00302e0f041;" [raise])]) #function("n0e0g00312g02i1;" [io.close *print-pretty*])]) file :write :create :truncate (*linefeed* *directory-separator* *argv* that *print-pretty* *print-width* *print-readably*) *print-pretty*]) +#function("r1c0e1g0e2e3e434c5e6u44;" [#function("v^k02c1c2qu42;" [*print-pretty* #function("vc0qc1qtg0302;" [#function("r0e0c1qe2e3e430313142;" [for-each #function("r1g0E16m02e0g031@16m02e1g031G@16m02e2g0i1132@16m02e3e1g03131@6\x9c0e4i10g0322e5i10c6322e4i10e1g031322e5i10c642;^;" [constant? top-level-value memq iostream? io.print io.write "\n"]) reverse! simple-sort environment]) #function("r1i00302e0g041;" [raise])]) #function("r0e0i00312i02k1;" [io.close *print-pretty*])]) file :write :create :truncate (*linefeed* *directory-separator* *argv* that *print-pretty* *print-width* *print-readably*) *print-pretty*]) make-label -#function("n1e040;" [gensym]) +#function("r1e040;" [gensym]) make-code-emitter -#function("n0_e030`Z3;" [table]) +#function("r0_e030`Z3;" [table]) macroexpand-1 -#function("n1f0?6;0f0;c0e1f031q42;" [#function("rf06?0f0g00Nt2;g00;" []) macrocall?]) +#function("r1g0?6;0g0;c0e1g031u42;" [#function("vg06?0g0i00Nx2;i00;" []) macrocall?]) macroexpand -#function("n1c0^^q43;" [#function("rc0mj02c1mj12f1g00_42;" [#function("n2c0e1f031F6]0e2f031F6T0c3e1f031K5Z0e4f0315^0^q42;" [#function("rc0e1f031g11f0g0132q43;" [#function("re0c1e2g1031f0A6G0f15Y0c1f0f1L3e3c4mf032Ke5g103144;" [list* lambda cadr map #function("n1^;" []) lastcdr]) get-defined-vars]) cddr cdddr begin caddr]) #function("n2f0?6;0f0;c0e1f0Mf132q42;" [#function("rf06N0g11e0f031g00NQ2e1f03142;c2e3g0031q42;" [cadr caddr #function("rf06G0g21f0g10NQ2g1142;g10Mc0<6U0g10;g10Mc1<6k0g20g10g1142;g10Mc2<6\x9a0c3e4g1031e5c1L1_L1e6e7g10313133L1q43;e8c9mg1042;" [quote lambda let-syntax #function("rg31f1e0e1c2mf032g213242;" [nconc map #function("n1f0Mg41e0f031g3132g31L3;" [cadr])]) cadr nconc copy-list cddr map #function("n1g31f0g2142;" [])]) macrocall?]) assq])])]) +#function("r1c0^^u43;" [#function("vc0qm02c1qm12g1i00_42;" [#function("r2c0e1g031F6]0e2g031F6T0c3e1g031K5Z0e4g0315^0^u42;" [#function("vc0e1g031i11g0i0132u43;" [#function("ve0c1e2i1031g0A6G0g15Y0c1g0g1L3e3c4qg032Ke5i103144;" [list* lambda cadr map #function("r1^;" []) lastcdr]) get-defined-vars]) cddr cdddr begin caddr]) #function("r2g0?6;0g0;c0e1g0Mg132u42;" [#function("vg06N0i11e0g031i00NQ2e1g03142;c2e3i0031u42;" [cadr caddr #function("vg06G0i21g0i10NQ2i1142;i10Mc0<6U0i10;i10Mc1<6k0i20i10i1142;i10Mc2<6\x9a0c3e4i1031e5c1L1_L1e6e7i10313133L1u43;e8c9qi1042;" [quote lambda let-syntax #function("vi31g1e0e1c2qg032i213242;" [nconc map #function("r1g0Mi41e0g031i3132i31L3;" [cadr])]) cadr nconc copy-list cddr map #function("r1i31g0i2142;" [])]) macrocall?]) assq])])]) macrocall? -#function("n1f0MC16E02e0e1f0M^43;" [get *syntax-environment*]) +#function("r1g0MC16E02e0e1g0M^43;" [get *syntax-environment*]) lookup-sym -#function("n4f1A6;0c0;c1f1Mq42;" [(global) #function("rc0e1g00f0`33q42;" [#function("rf06M0g136C0c0f0L2;c1g12f0L3;e2g10g11Ng1317b02g00A6k0g125p0g12au^44;" [arg closed lookup-sym]) index-of])]) +#function("r4g1A6;0c0;c1g1Mu42;" [(global) #function("vc0e1i00g0`33u42;" [#function("vg06M0i136C0c0g0L2;c1i12g0L3;e2i10i11Ni1317b02i00A6k0i125p0i12ay^44;" [arg closed lookup-sym]) index-of])]) load-process -#function("n1e0f041;" [eval]) +#function("r1e0g041;" [eval]) load -#function("n1c0e1f0e232q42;" [#function("rc0mc1mp;" [#function("n0c0^q32^^^43;" [#function("rc0mj0;" [#function("n3e0g1031@6R0g00e1g1031f0e2f13143;e3g10312e2f141;" [io.eof? read load-process io.close])])]) #function("n1e0g00312e1c2g10f0L341;" [io.close raise load-error])]) file :read]) +#function("r1c0e1g0e232u42;" [#function("vc0qc1qt;" [#function("r0c0^u32^^^43;" [#function("vc0qm0;" [#function("r3e0i1031@6R0i00e1i1031g0e2g13143;e3i10312e2g141;" [io.eof? read load-process io.close])])]) #function("r1e0i00312e1c2i10g0L341;" [io.close raise load-error])]) file :read]) list? -#function("n1f0A17I02f0F16I02e0f0N41;" [list?]) +#function("r1g0A17I02g0F16I02e0g0N41;" [list?]) list-tail -#function("n2e0f1`326?0f0;e1f0Nf1av42;" [<= list-tail]) +#function("r2e0g1`326?0g0;e1g0Ng1az42;" [<= list-tail]) list-ref -#function("n2e0f0f132M;" [list-tail]) +#function("r2e0g0g132M;" [list-tail]) list-partition -#function("n2c0^q42;" [#function("rc0mj02e1g01`326I0e2c341;e4f0g00g01`__3541;" [#function("n5f0?6O0e0f2`326L0e1f331f4K;f4;e2f2f1326o0g00f0f1`_e1f331f4K45;g00f0Nf1af2uf0Mf3Kf445;" [> reverse! >=]) <= error "list-partition: invalid count" reverse!])]) +#function("r2c0^u42;" [#function("vc0qm02e1i01`326I0e2c341;e4g0i00i01`__3541;" [#function("r5g0?6O0e0g2`326L0e1g331g4K;g4;e2g2g1326o0i00g0g1`_e1g331g4K45;i00g0Ng1ag2yg0Mg3Kg445;" [> reverse! >=]) <= error "list-partition: invalid count" reverse!])]) list-head -#function("n2e0f1`326>0_;f0Me1f0Nf1av32K;" [<= list-head]) +#function("r2e0g1`326>0_;g0Me1g0Ng1az32K;" [<= list-head]) list->vector -#function("n1e0f0t2;" [vector]) +#function("r1e0g0x2;" [vector]) length> -#function("n2f1`X6<0f0;f1`W6N0f0F16M02f0;f0A6Y0f1`X;e0f0Nf1av42;" [length>]) +#function("r2g1`X6<0g0;g1`W6N0g0F16M02g0;g0?6Y0g1`X;e0g0Ng1az42;" [length>]) length= -#function("n2f1`X6;0^;f1`W6F0f0A;f0A6Q0f1`W;e0f0Nf1av42;" [length=]) +#function("r2g1`X6;0^;g1`W6F0g0?;g0?6Q0g1`W;e0g0Ng1az42;" [length=]) lastcdr -#function("n1f0?6;0f0;e0f031N;" [last-pair]) +#function("r1g0?6;0g0;e0g031N;" [last-pair]) last-pair -#function("n1f0N?6<0f0;e0f0N41;" [last-pair]) +#function("r1g0N?6<0g0;e0g0N41;" [last-pair]) just-compile-args -#function("n3e0c1mf142;" [for-each #function("n1e0g00g02^f044;" [compile-in])]) +#function("r3e0c1qg142;" [for-each #function("r1e0i00i02^g044;" [compile-in])]) iota -#function("n1e0e1f042;" [map-int identity]) +#function("r1e0e1g042;" [map-int identity]) io.readline -#function("n1e0f0c142;" [io.readuntil #\x000a]) +#function("r1e0g0c142;" [io.readuntil #\x000a]) index-of -#function("n3f1A6:0^;f0f1M<6F0f2;e0f0f1Nf2au43;" [index-of]) +#function("r3g1A6:0^;g0g1M<6F0g2;e0g0g1Ng2ay43;" [index-of]) in-env? -#function("n2e0c1mf142;" [any #function("n1e0g00f042;" [memq])]) +#function("r2e0c1qg142;" [any #function("r1e0i00g042;" [memq])]) identity -#function("n1f0;" []) +#function("r1g0;" []) hex5 -#function("n1e0e1f0b@32b5c243;" [string.lpad number->string #\0]) +#function("r1e0e1g0b@32b5c243;" [string.lpad number->string #\0]) get-defined-vars -#function("n1e0g00f03141;" [delete-duplicates] #0=[#function("n1f0?6:0_;f0Mc0<16I02f0NF6\x8c0e1f031C16`02e1f031L117\x8b02e1f031F16\x8502e2f031C16\x8502e2f031L117\x8b02_;f0Mc3<6\xa40e4e5g00f0N32t2;_;" [define cadr caadr begin append map] #0#) ()]) +#function("r1e0i00g03141;" [delete-duplicates] #0=[#function("r1g0?6:0_;g0Mc0<16I02g0NF6\x8c0e1g031C16`02e1g031L117\x8b02e1g031F16\x8502e2g031C16\x8502e2g031L117\x8b02_;g0Mc3<6\xa40e4e5i00g0N32x2;_;" [define cadr caadr begin append map] #0#) ()]) for-each -#function("n2f1F6J0f0f1M312e0f0f1N42;];" [for-each]) +#function("r2g1F6J0g0g1M312e0g0g1N42;];" [for-each]) foldr -#function("n3f2A6;0f1;f0f2Me0f0f1f2N3342;" [foldr]) +#function("r3g2A6;0g1;g0g2Me0g0g1g2N3342;" [foldr]) foldl -#function("n3f2A6;0f1;e0f0f0f2Mf132f2N43;" [foldl]) +#function("r3g2A6;0g1;e0g0g0g2Mg132g2N43;" [foldl]) fits-i8 -#function("n1f0I16O02e0f0b\xb03216O02e1f0b\xaf42;" [>= <=]) +#function("r1g0I16O02e0g0b\xb03216O02e1g0b\xaf42;" [>= <=]) filter -#function("n2g00f0f1_43;" [] #0=[#function("n3f1A6;0f2;f0f1M316V0g00f0f1Nf1Mf2K43;g00f0f1Nf243;" [] #0#) ()]) +#function("r2i00g0g1_43;" [] #0=[#function("r3g1A6;0g2;g0g1M316V0i00g0g1Ng1Mg2K43;i00g0g1Ng243;" [] #0#) ()]) expand -#function("n1e0f041;" [macroexpand]) +#function("r1e0g041;" [macroexpand]) every -#function("n2f1?17O02f0f1M3116O02e0f0f1N42;" [every]) +#function("r2g1?17O02g0g1M3116O02e0g0g1N42;" [every]) even? -#function("n1e0f0a32`W;" [logand]) +#function("r1e0g0a32`W;" [logand]) eval -#function("n1e0e1f0313140;" [compile-thunk expand]) +#function("r1e0e1g0313140;" [compile-thunk expand]) error -#function("o0e0c1f0K41;" [raise error]) +#function("s0e0c1g0K41;" [raise error]) encode-byte-code -#function("n1c0e1f031q42;" [#function("rc0e1e2f031b3e3c4mf032T2uc532q42;" [#function("rc0e1g0031q42;" [#function("rc0e1f031`e230e230e330^q47;" [#function("r^f1f0X6\xbc02g00f1[j52f5e0<6k0e1f2g00f1au[e2f431332f1b2uj15\xb90e3f4e4e5e6g1016\x8502e7f5c8326\x920c9f5q325\x940f53231322f1auj12f1f0X6\xb80c:g00f1[q325\xb90^5202e;cvector]) >= length count #function("n1e0f0c142;" [memq (:loadv :loadg :setg :jmp :brt :brf)]) 65536]) reverse!]) +#function("r1c0e1g031u42;" [#function("vc0e1g031u42;" [#function("vc0e1e2g031b3e3c4qi0032T2yc532u42;" [#function("vc0e1i0031`e230e230e330^u47;" [#function("v^g1g0X6\xbc02i10g1[m52g5e0<6k0e1g2i10g1ay[e2g431332g1b2ym15\xb90e3g4e4e5e6i0016\x8502e7g5c8326\x920c9g5u325\x940g53231322g1aym12g1g0X6\xb80c:i10g1[u325\xb90^5202e;c= length count #function("r1e0g0c142;" [memq (:loadv.l :loadg.l :setg.l :loada.l :seta.l :loadc.l :setc.l :jmp :brt :brf :largc :lvargc)]) 65536]) list->vector]) reverse!]) emit -#function("o2e0f1c1326I0c2f0a[q325J0^2f0`e3f1f2Kf0`[32\\2f0;" [memq (:loadv :loadg :setg) #function("rc0g00b2[q42;" [#function("rc0g12Mq42;" [#function("rc0e1g10f0326K0e2g10f0325f0e3g10f0g00332g00auk002g00avq42;" [#function("rg30b2g10\\2f0L1k322e0f0c1326Z0c2g31q32k31;^;" [>= 256 #function("rf0e0=6<0e1;f0e2=6G0e3;f0e4=6R0e5;^;" [:loadv :loadv.l :loadg :loadg.l :setg :setg.l])]) has? get put!])])]) nreconc]) +#function("s2e0g1c1326M0e2g0g2M32L1m25N0^2c3e4g1c532u322c6e4g1c732u322g0`e8g1g2Kg0`[32\\2g0;" [memq (:loadv :loadg :setg) bcode:indexfor #function("vg016B02e0i02Mc1326O0e2g031o01;^;" [> 255 cadr]) assq ((:loadv :loadv.l) (:loadg :loadg.l) (:setg :setg.l) (:loada :loada.l) (:seta :seta.l)) #function("vg016T02e0i02Mc13217T02e0e2i0231c1326a0e2g031o01;^;" [> 255 cadr]) ((:loadc :loadc.l) (:setc :setc.l)) nreconc]) div -#function("n2f0f1Vf0`X16Q02f1`X16J02a17Q02b/17W02`u;" []) +#function("r2g0g1Vg0`X16Q02g1`X16J02a17Q02b/17W02`y;" []) display -#function("n1e0f0312];" [princ]) +#function("r1e0g0312];" [princ]) disassemble -#function("o1f1A6J0e0f0`322e1302];5K0^2c2f1Me3f031e4f031q44;" [disassemble newline #function("rc0^q42;" [#function("rc0mj02c1`e2g0131q43;" [#function("n1f0J16>02f0G@6T0e0c1312e2f0g10au42;e3f041;" [princ "\n" disassemble print]) #function("r^f0f1X6M02c0e1c2m^e333q32520;" [#function("re0g00`326C0e1305D0^2`g20avc2ms2e3e4g0031c5e6e7f031a32c8342g00auk002c9f0q42;" [> newline #function("n1e0c141;" [princ "\t"]) princ hex5 ": " string.tail string "\t" #function("re0f0c1326Z0g20g32e2g31g1032[312g10b4uk10;e0f0c3326\x7f0g20g32g31g10[[312g10auk10;e0f0c4326\xa30e5e6g31g10[31312g10auk10;e0f0c7326\xe20e5e6g31g10[31c8322g10auk102e5e6g31g10[31312g10auk10;e0f0c9326\x0c0e5c:e;estring (:loadc :setc) " " (:jmp :brf :brt) "@" hex5 ref-uint16-LE (:jmp.l :brf.l :brt.l)])]) table.foldl #function("n3f217J02f1g21g00[<16J02f0;" []) Instructions]) length])]) function:code function:vals]) +#function("s1g1A6J0e0g0`322e1302];5K0^2c2g1Me3g031e4g031u44;" [disassemble newline #function("vc0^u42;" [#function("vc0qm02c1`e2i0131u43;" [#function("r1g0J16>02g0G@6T0e0c1312e2g0i10ay42;e3g041;" [princ "\n" disassemble print]) #function("v^g0g1X6M02c0e1c2q^e333u32520;" [#function("ve0i00`326C0e1305D0^2`i20azc2qw2e3e4i0031c5e6e7g031a32c8342i00ayo002c9g0u42;" [> newline #function("r1e0c141;" [princ "\t"]) princ hex5 ": " string.tail string "\t" #function("ve0g0c1326Z0i20i32e2i31i1032[312i10b4yo10;e0g0c3326\x7f0i20i32i31i10[[312i10ayo10;e0g0c4326\xa30e5e6i31i10[31312i10ayo10;e0g0c7326\xcb0e5e6e2i31i103231312i10b4yo10;e0g0c8326\x0a0e5e6i31i10[31c9322i10ayo102e5e6i31i10[31312i10ayo10;e0g0c:326Q1e5e6e2i31i103231c9322i10b4yo102e5e6e2i31i103231312i10b4yo10;e0g0c;326{1e5ci31i103231322i10b2yo10;e0g0c?326\xa51e5cstring (:loada.l :seta.l :largc :lvargc) (:loadc :setc) " " (:loadc.l :setc.l) (:jmp :brf :brt) "@" hex5 ref-uint16-LE (:jmp.l :brf.l :brt.l)])]) table.foldl #function("r3g217J02g1i21i00[<16J02g0;" []) Instructions]) length])]) function:code function:vals]) delete-duplicates -#function("n1f0?6;0f0;c0f0Mf0Nq43;" [#function("re0f0f1326C0e1f141;f0e1f131K;" [member delete-duplicates])]) +#function("r1g0?6;0g0;c0g0Mg0Nu43;" [#function("ve0g0g1326C0e1g141;g0e1g131K;" [member delete-duplicates])]) count -#function("n2c0^q42;" [#function("rc0mj02f0g00g01`43;" [#function("n3f1A6;0f2;g00f0f1Nf0f1M316T0f2au5V0f243;" [])])]) +#function("r2c0^u42;" [#function("vc0qm02g0i00i01`43;" [#function("r3g1A6;0g2;i00g0g1Ng0g1M316T0g2ay5V0g243;" [])])]) copy-tree -#function("n1f0?6;0f0;e0f0M31e0f0N31K;" [copy-tree]) +#function("r1g0?6;0g0;e0g0M31e0g0N31K;" [copy-tree]) const-to-idx-vec -#function("n1c0e1f0b2[31q42;" [#function("re0c1mg00a[322f0;" [table.foreach #function("n2g00f1f0\\;" [])]) vector.alloc]) +#function("r1c0e1e2g03131u42;" [#function("ve0c1qe2i0031322g0;" [table.foreach #function("r2i00g1g0\\;" []) bcode:ctable]) vector.alloc bcode:nconst]) compile-while -#function("n4c0e1f031e1f031q43;" [#function("re0g00g01^^342e1g00f0322e0g00g01^g02342e2g00e3f1332e2g00e4322e0g00g01^g03342e2g00e5f0332e1g00f142;" [compile-in mark-label emit :brf :pop :jmp]) make-label]) +#function("r4c0e1g031e1g031u43;" [#function("ve0i00i01^^342e1i00g0322e0i00i01^i02342e2i00e3g1332e2i00e4322e0i00i01^i03342e2i00e5g0332e1i00g142;" [compile-in mark-label emit :brf :pop :jmp]) make-label]) compile-thunk -#function("n1e0c1_f0L341;" [compile lambda]) +#function("r1e0c1_g0L341;" [compile lambda]) compile-sym -#function("n4c0e1f2f1`]34q42;" [#function("rc0f0Mq42;" [#function("rf0c0=6M0e1g10g13`[e2g003143;f0c3=6p0e1g10g13a[e2g0031e4g003144;e1g10g13b2[g1243;" [arg emit cadr closed caddr])]) lookup-sym]) +#function("r4c0e1g2g1`]34u42;" [#function("vc0g0Mu42;" [#function("vg0c0=6M0e1i10i13`[e2i003143;g0c3=6p0e1i10i13a[e2i0031e4i003144;e1i10i13b2[i1243;" [arg emit cadr closed caddr])]) lookup-sym]) compile-short-circuit -#function("n6f3?6E0e0f0f1f2f444;f3N?6Z0e0f0f1f2f3M44;c1e2f031q42;" [compile-in #function("re0g00g01^g03M342e1g00e2322e1g00g05f0332e1g00e3322e4g00g01g02g03Ng04g05362e5g00f042;" [compile-in emit :dup :pop compile-short-circuit mark-label]) make-label]) +#function("r6g3?6E0e0g0g1g2g444;g3N?6Z0e0g0g1g2g3M44;c1e2g031u42;" [compile-in #function("ve0i00i01^i03M342e1i00e2322e1i00i05g0332e1i00e3322e4i00i01i02i03Ni04i05362e5i00g042;" [compile-in emit :dup :pop compile-short-circuit mark-label]) make-label]) compile-prog1 -#function("n3e0f0f1^e1f231342e2f231F6e0e3f0f1^e2f231342e4f0e542;^;" [compile-in cadr cddr compile-begin emit :pop]) +#function("r3e0g0g1^e1g231342e2g231F6e0e3g0g1^e2g231342e4g0e542;^;" [compile-in cadr cddr compile-begin emit :pop]) compile-or -#function("n4e0f0f1f2f3^e146;" [compile-short-circuit :brt]) +#function("r4e0g0g1g2g3^e146;" [compile-short-circuit :brt]) compile-let -#function("n4c0f3Mf3Nq43;" [#function("re0f1e1e2f03131326H0^5T0e3e4c5f032312e6g00e7e8g01f0]33332c9e:g00g01f133q42;" [length= length cadr error string "apply: incorrect number of arguments to " emit :loadv compile-f #function("re0g10e1322e0g10g126K0e25M0e3af0u43;" [emit :copyenv :tcall :call]) compile-arglist])]) +#function("r4c0g3Mg3Nu43;" [#function("ve0g1e1e2g03131326H0^5T0e3e4c5g032312e6i00e7e8i01g0]33332c9e:i00i01g133u42;" [length= length cadr error string "apply: incorrect number of arguments to " emit :loadv compile-f #function("ve0i10e1322e0i10i126K0e25M0e3ag0y43;" [emit :copyenv :tcall :call]) compile-arglist])]) compile-in -#function("n4f3C6E0e0f0f1f3c144;f3?6\xba0f3`<6[0e2f0e342;f3a<6k0e2f0e442;f3]<6{0e2f0e542;f3^<6\x8b0e2f0e642;f3_<6\x9b0e2f0e742;e8f3316\xaf0e2f0e9f343;e2f0e:f343;c;f3Mq42;" [compile-sym [:loada :loadc :loadg] emit :load0 :load1 :loadt :loadf :loadnil fits-i8 :loadi8 :loadv #function("rf0c0=6J0e1g00e2e3g033143;f0c4=6c0e5g00g01g02g0344;f0c6=6}0e7g00g01g02g03N44;f0c8=6\x930e9g00g01g0343;f0c:=6\xb90e1g00e2e;g01g0332332e1g00e<42;f0c==6\xd30e>g00g01g02g03N44;f0c?=6\xed0e@g00g01g02g03N44;f0cA=6\x110eBg00g01e3g0331c6eCg0331K44;f0cD=691eEg00g01e3g0331eFg0331eGg033145;f0cH=6^1eIg00g01]e3g0331342e1g00eJ42;f0cK=6\x8d1eIg00g01^eFg0331342eLg00g01e3g0331cM44;f0cN=6\xe31eIg00g01^c:_e3g0331L3342eOeFg0331316\xbf1^5\xc51ePcQ312eIg00g01^eFg0331342e1g00eR42;eSg00g01g02g0344;" [quote emit :loadv cadr if compile-if begin compile-begin prog1 compile-prog1 lambda compile-f :closure and compile-and or compile-or while compile-while cddr for compile-for caddr cadddr return compile-in :ret set! compile-sym [:seta :setc :setg] trycatch 1arg-lambda? error "trycatch: second form must be a 1-argument lambda" :trycatch compile-app])]) +#function("r4g3C6E0e0g0g1g3c144;g3?6\xba0g3`<6[0e2g0e342;g3a<6k0e2g0e442;g3]<6{0e2g0e542;g3^<6\x8b0e2g0e642;g3_<6\x9b0e2g0e742;e8g3316\xaf0e2g0e9g343;e2g0e:g343;c;g3Mu42;" [compile-sym [:loada :loadc :loadg] emit :load0 :load1 :loadt :loadf :loadnil fits-i8 :loadi8 :loadv #function("vg0c0=6J0e1i00e2e3i033143;g0c4=6c0e5i00i01i02i0344;g0c6=6}0e7i00i01i02i03N44;g0c8=6\x930e9i00i01i0343;g0c:=6\xb90e1i00e2e;i01i0332332e1i00e<42;g0c==6\xd30e>i00i01i02i03N44;g0c?=6\xed0e@i00i01i02i03N44;g0cA=6\x110eBi00i01e3i0331c6eCi0331K44;g0cD=691eEi00i01e3i0331eFi0331eGi033145;g0cH=6^1eIi00i01]e3i0331342e1i00eJ42;g0cK=6\x8d1eIi00i01^eFi0331342eLi00i01e3i0331cM44;g0cN=6\xe31eIi00i01^c:_e3i0331L3342eOeFi0331316\xbf1^5\xc51ePcQ312eIi00i01^eFi0331342e1i00eR42;eSi00i01i02i0344;" [quote emit :loadv cadr if compile-if begin compile-begin prog1 compile-prog1 lambda compile-f :closure and compile-and or compile-or while compile-while cddr for compile-for caddr cadddr return compile-in :ret set! compile-sym [:seta :setc :setg] trycatch 1arg-lambda? error "trycatch: second form must be a 1-argument lambda" :trycatch compile-app])]) compile-if -#function("n4c0e1f031e1f031e2f331e3f331e4f331F6_0e5f3315`0^q46;" [#function("rf2]<6H0e0g00g01g02f344;f2^<6_0e0g00g01g02f444;e0g00g01^f2342e1g00e2f0332e0g00g01g02f3342g026\x9b0e1g00e3325\xa60e1g00e4f1332e5g00f0322e0g00g01g02f4342e5g00f142;" [compile-in emit :brf :ret :jmp mark-label]) make-label cadr caddr cdddr cadddr]) +#function("r4c0e1g031e1g031e2g331e3g331e4g331F6_0e5g3315`0^u46;" [#function("vg2]<6H0e0i00i01i02g344;g2^<6_0e0i00i01i02g444;e0i00i01^g2342e1i00e2g0332e0i00i01i02g3342i026\x9b0e1i00e3325\xa60e1i00e4g1332e5i00g0322e0i00i01i02g4342e5i00g142;" [compile-in emit :brf :ret :jmp mark-label]) make-label cadr caddr cdddr cadddr]) compile-for -#function("n5e0f4316h0e1f0f1^f2342e1f0f1^f3342e1f0f1^f4342e2f0e342;e4c541;" [1arg-lambda? compile-in emit :for error "for: third form must be a 1-argument lambda"]) +#function("r5e0g4316h0e1g0g1^g2342e1g0g1^g3342e1g0g1^g4342e2g0e342;e4c541;" [1arg-lambda? compile-in emit :for error "for: third form must be a 1-argument lambda"]) compile-f -#function("o2c0e130e2f131q43;" [#function("rg02A@6D0e0f0e1325w0e2f131A6_0e0f0e3e4f131335w0e0f0e5f1?6o0`5u0e4f131332e6f0e7f131g00K]e8g0131342e0f0e9322e:e;f0`[31ee?e@g03131eAg03142;" [emit :let length> MAX_ARGS lastcdr :largc :lvargc length :argc :vargc compile-in to-proper caddr :ret function encode-byte-code bcode:code const-to-idx-vec]) make-code-emitter cadr]) compile-call -#function("n4c0f3Mq42;" [#function("rc0f0C16d02e1f0g0132@16d02f0E16d02e2f03116d02e3f031G6p0e3f0315r0f0q42;" [#function("rc0f0G16A02e1f031q42;" [#function("rf0@6H0e0g20g21^g00345I0^2c1e2g20g21g23N33q42;" [compile-in #function("rg006G0c0e1e2g00^33q42;e3g30g326W0e45Y0e5f043;" [#function("rf016C02e0g43Nf032@6R0e1g20f0325S0^2c2g10q42;" [length= argc-error #function("rf0e0=6Y0g10`W6K0e1g50e242;e1g50g20g1043;f0e3=6\x940g10`W6s0e1g50e442;g10b2W6\x860e1g50e542;e1g50g20g1043;f0e6=6\xe00g10`W6\xad0e7g30a42;g10aW6\xbf0e1g50e842;g10b2W6\xd20e1g50e942;e1g50g20g1043;f0e:=6\x080g10`W6\xfa0e1g50e;42;e1g50g20g1043;f0e<=6/0g10`W6!0e7g30a42;e1g50g20g1043;f0e==6Y1g10`W6K1e1g50e>c?43;e1g50g20g1043;f0e@=6\x8c1g10b2X6t1e7g30b242;e1g50g526\x841eA5\x861e@g1043;e1g50g2042;" [:list emit :loadnil :+ :load0 :add2 :- argc-error :neg :sub2 :* :load1 :/ :vector :loadv [] :apply :tapply])]) get arg-counts emit :tcall :call]) compile-arglist]) builtin->instruction]) in-env? constant? top-level-value])]) +#function("r4c0g3Mu42;" [#function("vc0g0C16d02e1g0i0132@16d02g0E16d02e2g03116d02e3g031G6p0e3g0315r0g0u42;" [#function("vc0g0G16A02e1g031u42;" [#function("vg0@6H0e0i20i21^i00345I0^2c1e2i20i21i23N33u42;" [compile-in #function("vi006G0c0e1e2i00^33u42;e3i30i326W0e45Y0e5g043;" [#function("vg016C02e0i43Ng032@6R0e1i20g0325S0^2c2i10u42;" [length= argc-error #function("vg0e0=6Y0i10`W6K0e1i50e242;e1i50i20i1043;g0e3=6\x940i10`W6s0e1i50e442;i10b2W6\x860e1i50e542;e1i50i20i1043;g0e6=6\xe00i10`W6\xad0e7i30a42;i10aW6\xbf0e1i50e842;i10b2W6\xd20e1i50e942;e1i50i20i1043;g0e:=6\x080i10`W6\xfa0e1i50e;42;e1i50i20i1043;g0e<=6/0i10`W6!0e7i30a42;e1i50i20i1043;g0e==6Y1i10`W6K1e1i50e>c?43;e1i50i20i1043;g0e@=6\x8c1i10b2X6t1e7i30b242;e1i50i526\x841eA5\x861e@i1043;e1i50i2042;" [:list emit :loadnil :+ :load0 :add2 :- argc-error :neg :sub2 :* :load1 :/ :vector :loadv [] :apply :tapply])]) get arg-counts emit :tcall :call]) compile-arglist]) builtin->instruction]) in-env? constant? top-level-value])]) compile-begin -#function("n4f3?6D0e0f0f1f2^44;f3N?6Y0e0f0f1f2f3M44;e0f0f1^f3M342e1f0e2322e3f0f1f2f3N44;" [compile-in emit :pop compile-begin]) +#function("r4g3?6D0e0g0g1g2^44;g3N?6Y0e0g0g1g2g3M44;e0g0g1^g3M342e1g0e2322e3g0g1g2g3N44;" [compile-in emit :pop compile-begin]) compile-arglist -#function("n3c0e1f2e232q42;" [#function("rf06g0e0g00e1g02e232g01332c3e4e5c6me7f0e23232Kq322e2au;e0g00g02g01332e8g0241;" [just-compile-args list-head MAX_ARGS #function("re0g10g11^f044;" [compile-in]) nconc map #function("n1e0f0K;" [list]) list-partition length]) length> MAX_ARGS]) +#function("r3c0e1g2e232u42;" [#function("vg06g0e0i00e1i02e232i01332c3e4e5c6qe7g0e23232Ku322e2ay;e0i00i02i01332e8i0241;" [just-compile-args list-head MAX_ARGS #function("ve0i10i11^g044;" [compile-in]) nconc map #function("r1e0g0K;" [list]) list-partition length]) length> MAX_ARGS]) compile-app -#function("n4c0f3Mq42;" [#function("rf0F16N02f0Mc0<16N02e1e2f031316b0e3g00g01g02g0344;e4g00g01g02g0344;" [lambda list? cadr compile-let compile-call])]) +#function("r4c0g3Mu42;" [#function("vg0F16`02g0Mc0<16`02e1e2g0313116`02e3e2g031e432@6t0e5i00i01i02i0344;e6i00i01i02i0344;" [lambda list? cadr length> MAX_ARGS compile-let compile-call])]) compile-and -#function("n4e0f0f1f2f3]e146;" [compile-short-circuit :brf]) +#function("r4e0g0g1g2g3]e146;" [compile-short-circuit :brf]) compile -#function("n1e0_f042;" [compile-f]) +#function("r1e0_g042;" [compile-f]) char? -#function("n1e0f031c1<;" [typeof wchar]) +#function("r1e0g031c1<;" [typeof wchar]) cddr -#function("n1f0NN;" []) +#function("r1g0NN;" []) cdddr -#function("n1f0NNN;" []) +#function("r1g0NNN;" []) cddar -#function("n1f0MNN;" []) +#function("r1g0MNN;" []) cdar -#function("n1f0MN;" []) +#function("r1g0MN;" []) cdadr -#function("n1f0NMN;" []) +#function("r1g0NMN;" []) cdaar -#function("n1f0MMN;" []) +#function("r1g0MMN;" []) cadr -#function("n1f0NM;" []) +#function("r1g0NM;" []) caddr -#function("n1f0NNM;" []) +#function("r1g0NNM;" []) cadddr -#function("n1f0NNNM;" []) +#function("r1g0NNNM;" []) cadar -#function("n1f0MNM;" []) +#function("r1g0MNM;" []) caar -#function("n1f0MM;" []) +#function("r1g0MM;" []) caadr -#function("n1f0NMM;" []) +#function("r1g0NMM;" []) caaar -#function("n1f0MMM;" []) +#function("r1g0MMM;" []) builtin->instruction -#function("n1c0e1e2c3f03231q42;" [#function("re0e1f03216@02f0;" [has? Instructions]) intern string #\:]) +#function("r1c0e1e2c3g03231u42;" [#function("ve0e1g03216@02g0;" [has? Instructions]) intern string #\:]) bq-process -#function("n1c0^q42;" [#function("rc0mj02e1g00316]0g00H6Y0c2e3e4g003131q42;g00;g00?6l0c5g00L2;g00Mc6<6\x860e3e3e7g00313141;g00Mc8<6\x980e7g0041;e9f0g0032@6\xbb0c:e;g0031eg00_q43;" [#function("n1f0F16K02f0Mc0<17K02f0Mc1<17U02f0c2<;" [*comma-at* *comma-dot* *comma*]) self-evaluating? #function("rf0Mc0<6A0e1f0NK;e2e1f0L3;" [list vector apply]) bq-process vector->list quote backquote cadr *comma* any #function("rf0A6=0c0f1K;e1c2f1Ke3f031L142;" [list nconc list* bq-process]) lastcdr map bq-bracket1 #function("r^f0F16A02f0Mc0<@6Z02e1f0M31f1Kj12f0Nj05202c2f0F6t0e3f1e4f031L1325\x910f0A6\x830e5f1315\x910e3f1e6f031L132q42;" [*comma* bq-bracket #function("rf0NA6<0f0M;c0f0K;" [nconc]) nreconc cadr reverse! bq-process])])]) +#function("r1c0^u42;" [#function("vc0qm02e1i00316]0i00H6Y0c2e3e4i003131u42;i00;i00?6l0c5i00L2;i00Mc6<6\x860e3e3e7i00313141;i00Mc8<6\x980e7i0041;e9g0i0032@6\xbb0c:e;i0031ei00_u43;" [#function("r1g0F16K02g0Mc0<17K02g0Mc1<17U02g0c2<;" [*comma-at* *comma-dot* *comma*]) self-evaluating? #function("vg0Mc0<6A0e1g0NK;e2e1g0L3;" [list vector apply]) bq-process vector->list quote backquote cadr *comma* any #function("vg0A6=0c0g1K;e1c2g1Ke3g031L142;" [list nconc list* bq-process]) lastcdr map bq-bracket1 #function("v^g0F16A02g0Mc0<@6Z02e1g0M31g1Km12g0Nm05202c2g0F6t0e3g1e4g031L1325\x910g0A6\x830e5g1315\x910e3g1e6g031L132u42;" [*comma* bq-bracket #function("vg0NA6<0g0M;c0g0K;" [nconc]) nreconc cadr reverse! bq-process])])]) bq-bracket1 -#function("n1f0F16@02f0Mc0<6J0e1f041;e2f041;" [*comma* cadr bq-process]) +#function("r1g0F16@02g0Mc0<6J0e1g041;e2g041;" [*comma* cadr bq-process]) bq-bracket -#function("n1f0?6C0e0e1f031L2;f0Mc2<6W0e0e3f031L2;f0Mc4<6k0c5e3f031L2;f0Mc6<6{0e3f041;e0e1f031L2;" [list bq-process *comma* cadr *comma-at* copy-list *comma-dot*]) +#function("r1g0?6C0e0e1g031L2;g0Mc2<6W0e0e3g031L2;g0Mc4<6k0c5e3g031L2;g0Mc6<6{0e3g041;e0e1g031L2;" [list bq-process *comma* cadr *comma-at* copy-list *comma-dot*]) +bcode:nconst +#function("r1g0b2[;" []) +bcode:indexfor +#function("r2c0e1g031e2g031u43;" [#function("ve0g0i01326G0e1g0i0142;e2g0i01g1332g1i00b2g1ay\\2;" [has? get put!]) bcode:ctable bcode:nconst]) +bcode:ctable +#function("r1g0a[;" []) +bcode:code +#function("r1g0`[;" []) assv -#function("n2f1?6:0^;e0f131f0=6J0f1M;e1f0f1N42;" [caar assv]) +#function("r2g1?6:0^;e0g131g0=6J0g1M;e1g0g1N42;" [caar assv]) assoc -#function("n2f1?6:0^;e0f131f0>6J0f1M;e1f0f1N42;" [caar assoc]) +#function("r2g1?6:0^;e0g131g0>6J0g1M;e1g0g1N42;" [caar assoc]) array? -#function("n1f0H17E02c0e1f031q42;" [#function("rf0F16?02f0Mc0<;" [array]) typeof]) +#function("r1g0H17E02c0e1g031u42;" [#function("vg0F16?02g0Mc0<;" [array]) typeof]) argc-error -#function("n2e0e1c2f0c3f1f1aW6J0c45L0c53541;" [error string "compile error: " " expects " " argument." " arguments."]) +#function("r2e0e1c2g0c3g1g1aW6J0c45L0c53541;" [error string "compile error: " " expects " " argument." " arguments."]) arg-counts #table(:not 1 :set-cdr! 2 :cons 2 :number? 1 :equal? 2 :cdr 1 :vector? 1 :eqv? 2 := 2 :div0 2 :atom? 1 :aref 2 :compare 2 :< 2 :null? 1 :eq? 2 :car 1 :set-car! 2 :builtin? 1 :aset! 3 :bound? 1 :boolean? 1 :pair? 1 :symbol? 1 :fixnum? 1) append -#function("o0f0A6:0_;f0NA6E0f0M;e0e1f0M31e2f0NQ242;" [nconc copy-list append]) +#function("s0g0A6:0_;g0NA6E0g0M;e0g0Me1g0NQ242;" [copy-list append]) any -#function("n2f1F16O02f0f1M3117O02e0f0f1N42;" [any]) +#function("r2g1F16O02g0g1M3117O02e0g0g1N42;" [any]) abs -#function("n1f0`X6=0f0w;f0;" []) +#function("r1g0`X6=0g0{;g0;" []) __start -#function("n1e0302f0NF6Q0f0Ni12e2e3f031315a0f0i12e4e5312e6302e7`41;" [__init_globals *argv* __script cadr princ *banner* repl exit]) +#function("r1e0302g0NF6Q0g0Nk12e2e3g031315a0g0k12e4e5312e6302e7`41;" [__init_globals *argv* __script cadr princ *banner* repl exit]) __script -#function("n1c0mc1mp;" [#function("n0e0g0041;" [load]) #function("n1e0f0312e1a41;" [print-exception exit])]) +#function("r1c0qc1qt;" [#function("r0e0i0041;" [load]) #function("r1e0g0312e1a41;" [print-exception exit])]) __init_globals -#function("n0e0c1<17K02e0c2<17K02e0c3<6Z0c4i52c6i75c0c8i52c9i72e:i;2ei?;" [*os-name* win32 win64 windows "\\" *directory-separator* "\r\n" *linefeed* "/" "\n" *stdout* *output-stream* *stdin* *input-stream* *stderr* *error-stream*]) +#function("r0e0c1<17K02e0c2<17K02e0c3<6Z0c4k52c6k75c0c8k52c9k72e:k;2ek?;" [*os-name* win32 win64 windows "\\" *directory-separator* "\r\n" *linefeed* "/" "\n" *stdout* *output-stream* *stdin* *input-stream* *stderr* *error-stream*]) MAX_ARGS 127 Instructions -#table(:sub2 70 :nop 0 :set-cdr! 32 :/ 37 :setc 59 :tapply 68 :cons 27 dummy_nil 74 :equal? 14 :cdr 30 :call 3 :eqv? 13 := 39 :setg.l 60 :list 28 :atom? 15 :aref 43 :load0 48 :let 66 dummy_t 72 :argc 62 :< 40 :null? 17 :loadg 53 :load1 49 :car 29 :brt.l 10 :vargc 63 :loada 54 :set-car! 31 :setg 57 :aset! 44 :bound? 21 :pair? 22 :symbol? 19 :fixnum? 25 :loadi8 50 :not 16 :* 36 :neg 71 :pop 2 :loadnil 47 :brf 6 :vector 42 :- 35 :loadv 51 :closure 61 dummy_f 73 :number? 20 :trycatch 64 :add2 69 :loadv.l 52 :vector? 24 :brf.l 9 :seta 58 :apply 33 :dup 1 :div0 38 :copyenv 65 :for 67 :loadc 55 :compare 41 :eq? 12 :function? 26 :+ 34 :jmp 5 :loadt 45 :brt 7 :builtin? 23 :loadg.l 56 :tcall 4 :ret 11 :boolean? 18 :loadf 46 :jmp.l 8) +#table(:sub2 74 :nop 0 :set-cdr! 32 :/ 37 :setc 63 :tapply 72 :lvargc 77 :cons 27 dummy_nil 80 :equal? 14 :cdr 30 :call 3 :eqv? 13 := 39 :setg.l 60 :list 28 :atom? 15 :aref 43 :load0 48 :let 70 dummy_t 78 :argc 66 :< 40 :null? 17 :loadg 53 :load1 49 :car 29 :brt.l 10 :vargc 67 :loada 55 :set-car! 31 :setg 59 :aset! 44 :bound? 21 :pair? 22 :symbol? 19 :fixnum? 25 :loadi8 50 :not 16 :* 36 :neg 75 :pop 2 :largc 76 :loadnil 47 :brf 6 :vector 42 :- 35 :loadv 51 :loada.l 56 :seta.l 62 :closure 65 dummy_f 79 :number? 20 :trycatch 68 :add2 73 :loadv.l 52 :vector? 24 :brf.l 9 :seta 61 :apply 33 :dup 1 :div0 38 :setc.l 64 :copyenv 69 :for 71 :loadc 57 :loadc.l 58 :compare 41 :eq? 12 :function? 26 :+ 34 :jmp 5 :loadt 45 :brt 7 :builtin? 23 :loadg.l 54 :tcall 4 :ret 11 :boolean? 18 :loadf 46 :jmp.l 8) >= -#function("n2f1f0X17A02f0f1W;" []) +#function("r2g1g0X17A02g0g1W;" []) > -#function("n2f1f0X;" []) +#function("r2g1g0X;" []) <= -#function("n2f0f1X17A02f0f1W;" []) +#function("r2g0g1X17A02g0g1W;" []) 1arg-lambda? -#function("n1f0F16e02f0Mc0<16e02f0NF16e02e1f031F16e02e2e1f031a42;" [lambda cadr length=]) +#function("r1g0F16e02g0Mc0<16e02g0NF16e02e1g031F16e02e2e1g031a42;" [lambda cadr length=]) 1- -#function("n1f0av;" []) +#function("r1g0az;" []) 1+ -#function("n1f0au;" []) +#function("r1g0ay;" []) /= -#function("n2f0f1W@;" []) +#function("r2g0g1W@;" []) *whitespace* "\t\n\v\f\r \u0085  ᠎           \u2028\u2029   " *syntax-environment* -#table(define #function("o1f0C6B0c0f0f1ML3;c0f0Mc1f0Nf1KKL3;" [set! lambda]) letrec #function("o1c0e1e2f032e3e1c4mf032f132KKe1c5mf032K;" [lambda map car nconc #function("n1c0f0K;" [set!]) #function("n1^;" [])]) backquote #function("n1e0f041;" [bq-process]) assert #function("n1c0f0]c1c2c3f0L2L2L2L4;" [if raise quote assert-failed]) label #function("n2c0f0L1c1f0f1L3L3^L2;" [lambda set!]) do #function("o2c0e130f1Me2e3f032e2e4f032e2c5mf032q46;" [#function("rc0f0c1f2c2f1e3c4L1e5g01N3132e3c4L1e5g0231e3f0L1e5f43132L133L4L3L2L1e3f0L1e5f33132L3;" [letrec lambda if nconc begin copy-list]) gensym map car cadr #function("n1e0f031F6C0e1f041;f0M;" [cddr caddr])]) when #function("o1c0f0c1f1K^L4;" [if begin]) unwind-protect #function("n2c0e130e130q43;" [#function("rc0f1c1_g01L3L2L1c2c3g00c1f0L1c4f1L1c5f0L2L3L3L3f1L1L3L3;" [let lambda prog1 trycatch begin raise]) gensym]) dotimes #function("o1c0f0Me1f031q43;" [#function("rc0`c1f1aL3e2c3L1f0L1L1e4g013133L4;" [for - nconc lambda copy-list]) cadr]) define-macro #function("o1c0c1f0ML2c2f0Nf1KKL3;" [set-syntax! quote lambda]) unless #function("o1c0f0^c1f1KL4;" [if begin]) let #function("o1c0^q42;" [#function("rg00C6P0g00j02g01Mk002g01Nk015Q0^2c0c1e2c3mg0032g01KKe2c4mg0032q43;" [#function("rg006C0c0g00f0L35E0f0f1K;" [label]) lambda map #function("n1f0F6<0f0M;f0;" []) #function("n1f0F6?0e0f041;^;" [cadr])])]) cond #function("o0c0^q42;" [#function("rc0mj02f0g0041;" [#function("n1f0?6:0^;c0f0Mq42;" [#function("rf0Mc0<17A02f0M]<6V0f0NA6O0f0M;c1f0NK;f0NA6n0c2f0Mg10g00N31L3;c3f0Mc1f0NKg10g00N31L4;" [else begin or if])])])]) throw #function("n2c0c1c2c3L2f0f1L4L2;" [raise list quote thrown-value]) time #function("n1c0e130q42;" [#function("rc0f0c1L1L2L1c2g00c3c4c5c1L1f0L3c6L4L3L3;" [let time.now prog1 princ "Elapsed time: " - " seconds\n"]) gensym]) let* #function("o1f0?6L0e0c1L1_L1e2f13133L1;e0c1L1e3f031L1L1e2f0NF6}0e0c4L1f0NL1e2f13133L15\x7F0f13133e5f031L2;" [nconc lambda copy-list caar let* cadar]) case #function("o1c0^q42;" [#function("rc0mj02c1e230q42;" [#function("n2f1c0<6=0c0;f1A6E0^;f1?6X0c1f0e2f131L3;f1NA6m0c1f0e2f1M31L3;c3f0c4f1L2L3;" [else eqv? quote-value memv quote]) #function("rc0f0g10L2L1e1c2L1e3e4c5mg11323132L3;" [let nconc cond copy-list map #function("n1g10g00f0M32f0NK;" [])]) gensym])]) catch #function("n2c0e130q42;" [#function("rc0g01c1f0L1c2c3c4f0L2c5c6f0L2c7c8L2L3c5c9f0L2g00L3L4c:f0L2c;f0L2L4L3L3;" [trycatch lambda if and pair? eq car quote thrown-value cadr caddr raise]) gensym])) +#table(define #function("s1g0C6B0c0g0g1ML3;c0g0Mc1g0Ng1KKL3;" [set! lambda]) letrec #function("s1c0e1e2g032e3e1c4qg032g132KKe1c5qg032K;" [lambda map car nconc #function("r1c0g0K;" [set!]) #function("r1^;" [])]) backquote #function("r1e0g041;" [bq-process]) assert #function("r1c0g0]c1c2c3g0L2L2L2L4;" [if raise quote assert-failed]) label #function("r2c0g0L1c1g0g1L3L3^L2;" [lambda set!]) do #function("s2c0e130g1Me2e3g032e2e4g032e2c5qg032u46;" [#function("vc0g0c1g2c2g1e3c4L1e5i01N3132e3c4L1e5i0231e3g0L1e5g43132L133L4L3L2L1e3g0L1e5g33132L3;" [letrec lambda if nconc begin copy-list]) gensym map car cadr #function("r1e0g031F6C0e1g041;g0M;" [cddr caddr])]) when #function("s1c0g0c1g1K^L4;" [if begin]) unwind-protect #function("r2c0e130e130u43;" [#function("vc0g1c1_i01L3L2L1c2c3i00c1g0L1c4g1L1c5g0L2L3L3L3g1L1L3L3;" [let lambda prog1 trycatch begin raise]) gensym]) dotimes #function("s1c0g0Me1g031u43;" [#function("vc0`c1g1aL3e2c3L1g0L1L1e4i013133L4;" [for - nconc lambda copy-list]) cadr]) define-macro #function("s1c0c1g0ML2c2g0Ng1KKL3;" [set-syntax! quote lambda]) unless #function("s1c0g0^c1g1KL4;" [if begin]) let #function("s1c0^u42;" [#function("vi00C6P0i00m02i01Mo002i01No015Q0^2c0c1e2c3qi0032i01KKe2c4qi0032u43;" [#function("vi006C0c0i00g0L35E0g0g1K;" [label]) lambda map #function("r1g0F6<0g0M;g0;" []) #function("r1g0F6?0e0g041;^;" [cadr])])]) cond #function("s0c0^u42;" [#function("vc0qm02g0i0041;" [#function("r1g0?6:0^;c0g0Mu42;" [#function("vg0Mc0<17A02g0M]<6V0g0NA6O0g0M;c1g0NK;g0NA6n0c2g0Mi10i00N31L3;c3g0Mc1g0NKi10i00N31L4;" [else begin or if])])])]) throw #function("r2c0c1c2c3L2g0g1L4L2;" [raise list quote thrown-value]) time #function("r1c0e130u42;" [#function("vc0g0c1L1L2L1c2i00c3c4c5c1L1g0L3c6L4L3L3;" [let time.now prog1 princ "Elapsed time: " - " seconds\n"]) gensym]) let* #function("s1g0?6L0e0c1L1_L1e2g13133L1;e0c1L1e3g031L1L1e2g0NF6}0e0c4L1g0NL1e2g13133L15\x7F0g13133e5g031L2;" [nconc lambda copy-list caar let* cadar]) case #function("s1c0^u42;" [#function("vc0qm02c1e230u42;" [#function("r2g1c0<6=0c0;g1A6E0^;g1?6X0c1g0e2g131L3;g1NA6m0c1g0e2g1M31L3;c3g0c4g1L2L3;" [else eqv? quote-value memv quote]) #function("vc0g0i10L2L1e1c2L1e3e4c5qi11323132L3;" [let nconc cond copy-list map #function("r1i10i00g0M32g0NK;" [])]) gensym])]) catch #function("r2c0e130u42;" [#function("vc0i01c1g0L1c2c3c4g0L2c5c6g0L2c7c8L2L3c5c9g0L2i00L3L4c:g0L2c;g0L2L4L3L3;" [trycatch lambda if and pair? eq car quote thrown-value cadr caddr raise]) gensym])) *banner* "; _\n; |_ _ _ |_ _ | . _ _\n; | (-||||_(_)|__|_)|_)\n;-------------------|----------------------------------------------------------\n\n" diff --git a/femtolisp/flisp.c b/femtolisp/flisp.c index 254ae8d..9de9b55 100644 --- a/femtolisp/flisp.c +++ b/femtolisp/flisp.c @@ -739,8 +739,15 @@ static value_t apply_liststar(value_t L, int star) value_t fl_copylist(value_t *args, u_int32_t nargs) { - argcount("copy-list", nargs, 1); - return FL_COPYLIST(args[0]); + if (nargs != 2) + argcount("copy-list", nargs, 1); + value_t l = FL_COPYLIST(args[0]); + if (nargs == 2) { + if (!iscons(args[0])) + return args[1]; + ((cons_t*)(curheap-sizeof(cons_t)))->cdr = args[1]; + } + return l; } value_t fl_liststar(value_t *args, u_int32_t nargs) @@ -777,6 +784,20 @@ static value_t do_trycatch() #define fn_vals(f) (((value_t*)ptr(f))[1]) #define fn_env(f) (((value_t*)ptr(f))[2]) +#if _BYTE_ORDER == __BIG_ENDIAN +#define GET_UINT32(a, i) \ + ((((uint32_t)a[i+0])<<0) | \ + (((uint32_t)a[i+1])<<8) | \ + (((uint32_t)a[i+2])<<16) | \ + (((uint32_t)a[i+3])<<24)) +#define GET_UINT16(a, i) \ + ((((uint16_t)a[i+0])<<0) | \ + (((uint16_t)a[i+1])<<8)) +#else +#define GET_UINT32(a, i) (*(uint32_t*)&a[i]) +#define GET_UINT16(a, i) (*(uint16_t*)&a[i]) +#endif + /* stack on entry: caller's responsibility: @@ -837,8 +858,13 @@ static value_t apply_cl(uint32_t nargs) if (s > 0) { v = list(&Stack[bp+i], s); if (nargs > MAX_ARGS) { - c = (cons_t*)curheap; - (c-2)->cdr = (c-1)->car; + if (s == 1) { + v = car_(v); + } + else { + c = (cons_t*)curheap; + (c-2)->cdr = (c-1)->car; + } } Stack[bp+i] = v; Stack[bp+i+1] = Stack[bp+nargs]; @@ -853,6 +879,33 @@ static value_t apply_cl(uint32_t nargs) } nargs = i+1; goto next_op; + case OP_LARGC: + case OP_LVARGC: + // move extra arguments from list to stack + i = GET_UINT32(code, ip); ip+=4; + x = POP(); // cloenv + if (nargs > MAX_ARGS) { + v = POP(); // list of rest args + nargs--; + } + else v = NIL; + while (nargs < i) { + if (!iscons(v)) + lerror(ArgError, "apply: too few arguments"); + PUSH(car_(v)); + nargs++; + v = cdr_(v); + } + if (op == OP_LVARGC) { + PUSH(v); + nargs++; + } + else { + if (iscons(v)) + lerror(ArgError, "apply: too many arguments"); + } + PUSH(x); + goto next_op; case OP_LET: // last arg is closure environment to use nargs--; @@ -916,26 +969,26 @@ static value_t apply_cl(uint32_t nargs) SP = s-n; Stack[SP-1] = v; goto next_op; - case OP_JMP: ip = (uint32_t)*(uint16_t*)&code[ip]; goto next_op; + case OP_JMP: ip = (uint32_t)GET_UINT16(code,ip); goto next_op; case OP_BRF: v = POP(); - if (v == FL_F) ip = (uint32_t)*(uint16_t*)&code[ip]; + if (v == FL_F) ip = (uint32_t)GET_UINT16(code,ip); else ip += 2; goto next_op; case OP_BRT: v = POP(); - if (v != FL_F) ip = (uint32_t)*(uint16_t*)&code[ip]; + if (v != FL_F) ip = (uint32_t)GET_UINT16(code,ip); else ip += 2; goto next_op; - case OP_JMPL: ip = *(uint32_t*)&code[ip]; goto next_op; + case OP_JMPL: ip = GET_UINT32(code,ip); goto next_op; case OP_BRFL: v = POP(); - if (v == FL_F) ip = *(uint32_t*)&code[ip]; + if (v == FL_F) ip = GET_UINT32(code,ip); else ip += 4; goto next_op; case OP_BRTL: v = POP(); - if (v != FL_F) ip = *(uint32_t*)&code[ip]; + if (v != FL_F) ip = GET_UINT32(code,ip); else ip += 4; goto next_op; case OP_RET: v = POP(); return v; @@ -1304,12 +1357,12 @@ static value_t apply_cl(uint32_t nargs) goto next_op; case OP_LOADVL: v = fn_vals(Stack[bp-1]); - v = vector_elt(v, *(uint32_t*)&code[ip]); ip+=4; + v = vector_elt(v, GET_UINT32(code,ip)); ip+=4; PUSH(v); goto next_op; case OP_LOADGL: v = fn_vals(Stack[bp-1]); - v = vector_elt(v, *(uint32_t*)&code[ip]); ip+=4; + v = vector_elt(v, GET_UINT32(code,ip)); ip+=4; goto do_loadg; case OP_LOADG: v = fn_vals(Stack[bp-1]); @@ -1325,7 +1378,7 @@ static value_t apply_cl(uint32_t nargs) case OP_SETGL: v = fn_vals(Stack[bp-1]); - v = vector_elt(v, *(uint32_t*)&code[ip]); ip+=4; + v = vector_elt(v, GET_UINT32(code,ip)); ip+=4; goto do_setg; case OP_SETG: v = fn_vals(Stack[bp-1]); @@ -1354,6 +1407,15 @@ static value_t apply_cl(uint32_t nargs) } PUSH(v); goto next_op; + case OP_LOADAL: + assert(nargs > 0); + i = GET_UINT32(code,ip); ip+=4; + if (captured) + v = vector_elt(Stack[bp], i); + else + v = Stack[bp+i]; + PUSH(v); + goto next_op; case OP_SETA: assert(nargs > 0); v = Stack[SP-1]; @@ -1369,6 +1431,15 @@ static value_t apply_cl(uint32_t nargs) Stack[bp+i] = v; } goto next_op; + case OP_SETAL: + assert(nargs > 0); + v = Stack[SP-1]; + i = GET_UINT32(code,ip); ip+=4; + if (captured) + vector_elt(Stack[bp], i) = v; + else + Stack[bp+i] = v; + goto next_op; case OP_LOADC: case OP_SETC: s = code[ip++]; @@ -1383,6 +1454,18 @@ static value_t apply_cl(uint32_t nargs) else PUSH(vector_elt(v, i)); goto next_op; + case OP_LOADCL: + case OP_SETCL: + s = GET_UINT32(code,ip); ip+=4; + i = GET_UINT32(code,ip); ip+=4; + v = Stack[bp+nargs]; + while (s--) + v = vector_elt(v, vector_size(v)-1); + if (op == OP_SETCL) + vector_elt(v, i) = Stack[SP-1]; + else + PUSH(vector_elt(v, i)); + goto next_op; case OP_CLOSURE: case OP_COPYENV: diff --git a/femtolisp/opcodes.h b/femtolisp/opcodes.h index 6e19416..b38519e 100644 --- a/femtolisp/opcodes.h +++ b/femtolisp/opcodes.h @@ -17,11 +17,14 @@ enum { OP_VECTOR, OP_AREF, OP_ASET, OP_LOADT, OP_LOADF, OP_LOADNIL, OP_LOAD0, OP_LOAD1, OP_LOADI8, - OP_LOADV, OP_LOADVL, OP_LOADG, OP_LOADA, OP_LOADC, OP_LOADGL, - OP_SETG, OP_SETA, OP_SETC, OP_SETGL, + OP_LOADV, OP_LOADVL, + OP_LOADG, OP_LOADGL, + OP_LOADA, OP_LOADAL, OP_LOADC, OP_LOADCL, + OP_SETG, OP_SETGL, + OP_SETA, OP_SETAL, OP_SETC, OP_SETCL, OP_CLOSURE, OP_ARGC, OP_VARGC, OP_TRYCATCH, OP_COPYENV, OP_LET, OP_FOR, - OP_TAPPLY, OP_ADD2, OP_SUB2, OP_NEG, + OP_TAPPLY, OP_ADD2, OP_SUB2, OP_NEG, OP_LARGC, OP_LVARGC, OP_BOOL_CONST_T, OP_BOOL_CONST_F, OP_THE_EMPTY_LIST, diff --git a/femtolisp/system.lsp b/femtolisp/system.lsp index 8c6f045..ca8c5f9 100644 --- a/femtolisp/system.lsp +++ b/femtolisp/system.lsp @@ -77,8 +77,8 @@ (define (append . lsts) (cond ((null? lsts) ()) ((null? (cdr lsts)) (car lsts)) - (#t (nconc (copy-list (car lsts)) - (apply append (cdr lsts)))))) + (#t (copy-list (car lsts) + (apply append (cdr lsts)))))) (define (member item lst) (cond ((atom? lst) #f) @@ -173,14 +173,14 @@ ; work and always terminates. (define (length= lst n) (cond ((< n 0) #f) - ((= n 0) (null? lst)) - ((null? lst) (= n 0)) + ((= n 0) (atom? lst)) + ((atom? lst) (= n 0)) (else (length= (cdr lst) (- n 1))))) (define (length> lst n) (cond ((< n 0) lst) ((= n 0) (and (pair? lst) lst)) - ((null? lst) (< n 0)) + ((atom? lst) (< n 0)) (else (length> (cdr lst) (- n 1))))) (define (last-pair l) diff --git a/femtolisp/todo b/femtolisp/todo index fe9872f..38261f6 100644 --- a/femtolisp/todo +++ b/femtolisp/todo @@ -1024,6 +1024,9 @@ new evaluator todo: * make (for ...) a special form * trycatch should require 2nd arg to be a lambda expression * immediate load int8 instruction +- unlimited lambda lists + . need 32-bit argument versions of loada, seta, loadc, setc + . largs instruction to move args after MAX_ARGS from list to stack - maxstack calculation, make Stack growable - stack traces and better debugging support - let eversion diff --git a/femtolisp/unittest.lsp b/femtolisp/unittest.lsp index 62043a1..911e1b0 100644 --- a/femtolisp/unittest.lsp +++ b/femtolisp/unittest.lsp @@ -98,6 +98,22 @@ ; long argument lists (assert (= (apply + (iota 100000)) 4999950000)) +(define as (apply list* (map-int (lambda (x) (gensym)) (+ MAX_ARGS 1)))) +(define f (compile `(lambda ,as ,(lastcdr as)))) +(assert (equal? (apply f (iota (+ MAX_ARGS 0))) `())) +(assert (equal? (apply f (iota (+ MAX_ARGS 1))) `(,MAX_ARGS))) +(assert (equal? (apply f (iota (+ MAX_ARGS 2))) `(,MAX_ARGS ,(+ MAX_ARGS 1)))) + +(define as (map-int (lambda (x) (gensym)) 1000)) +(define f (compile `(lambda ,as ,(car (last-pair as))))) +(assert (equal? (apply f (iota 1000)) 999)) + +(define as (apply list* (map-int (lambda (x) (gensym)) 995))) +(define f (compile `(lambda ,as ,(lastcdr as)))) +(assert (equal? (apply f (iota 994)) '())) +(assert (equal? (apply f (iota 995)) '(994))) +(assert (equal? (apply f (iota 1000)) '(994 995 996 997 998 999))) + ; ok, a couple end-to-end tests as well (define (fib n) (if (< n 2) n (+ (fib (- n 1)) (fib (- n 2))))) (assert (equal? (fib 20) 6765))