mirror of
https://github.com/false-schemers/skint.git
synced 2025-01-27 19:58:49 +01:00
cond-expand fix; ,time repl command
This commit is contained in:
parent
1c9e8d2b32
commit
b7f0a7980d
2 changed files with 55 additions and 68 deletions
28
src/t.scm
28
src/t.scm
|
@ -965,7 +965,7 @@
|
||||||
(loop (append (cdr decl) decls) code eal esps forms)]
|
(loop (append (cdr decl) decls) code eal esps forms)]
|
||||||
[(eq? (car decl) ld-cond-expand-id) ; flatten and splice
|
[(eq? (car decl) ld-cond-expand-id) ; flatten and splice
|
||||||
(let ([lit=? (lambda (id sym) (and (id? id) (eq? id (id-rename-as sid sym))))])
|
(let ([lit=? (lambda (id sym) (and (id? id) (eq? id (id-rename-as sid sym))))])
|
||||||
(loop (append (preprocess-cond-expand lit=? (cdr decl)) decls env) code eal esps forms))]
|
(loop (append (preprocess-cond-expand lit=? decl env) decls) code eal esps forms))]
|
||||||
[(eq? (car decl) ld-push-cf-id) ; internal
|
[(eq? (car decl) ld-push-cf-id) ; internal
|
||||||
(check-syntax decl '(<id> <string>) "invalid library declarations syntax")
|
(check-syntax decl '(<id> <string>) "invalid library declarations syntax")
|
||||||
(push-current-file! (cadr decl))
|
(push-current-file! (cadr decl))
|
||||||
|
@ -2055,22 +2055,7 @@
|
||||||
(define *verbose* #f)
|
(define *verbose* #f)
|
||||||
(define *quiet* #f)
|
(define *quiet* #f)
|
||||||
|
|
||||||
#;(define (repl-compile-and-run-core-expr core)
|
|
||||||
(when *verbose* (display "TRANSFORM =>") (newline) (write core) (newline))
|
|
||||||
(unless (val-core? core) (x-error "unexpected transformed output" core))
|
|
||||||
(let ([code (compile-to-thunk-code core)] [start #f])
|
|
||||||
(when *verbose*
|
|
||||||
(display "COMPILE-TO-STRING =>") (newline) (display code) (newline)
|
|
||||||
(display "DECODE+EXECUTE =>") (newline)
|
|
||||||
(set! start (current-jiffy)))
|
|
||||||
(let* ([cl (closure (deserialize-code code))] [res (cl)])
|
|
||||||
(when *verbose*
|
|
||||||
(display "Elapsed time: ") (write (* 1000 (/ (- (current-jiffy) start) (jiffies-per-second))))
|
|
||||||
(display " ms.") (newline))
|
|
||||||
(unless (eq? res (void)) (write res) (newline)))))
|
|
||||||
|
|
||||||
(define (repl-compile-and-run-core-expr core)
|
(define (repl-compile-and-run-core-expr core)
|
||||||
(define start #f)
|
|
||||||
(define (compile-and-run core)
|
(define (compile-and-run core)
|
||||||
(define code (compile-to-thunk-code core))
|
(define code (compile-to-thunk-code core))
|
||||||
(define cl (closure (deserialize-code code)))
|
(define cl (closure (deserialize-code code)))
|
||||||
|
@ -2078,7 +2063,6 @@
|
||||||
(for-each (lambda (v) (unless (void? v) (write v) (newline))) vals))
|
(for-each (lambda (v) (unless (void? v) (write v) (newline))) vals))
|
||||||
(when *verbose* (display "TRANSFORM =>") (newline) (write core) (newline))
|
(when *verbose* (display "TRANSFORM =>") (newline) (write core) (newline))
|
||||||
(unless (val-core? core) (x-error "unexpected transformed output" core))
|
(unless (val-core? core) (x-error "unexpected transformed output" core))
|
||||||
(set! start (current-jiffy))
|
|
||||||
(let loop ([cores (list core)])
|
(let loop ([cores (list core)])
|
||||||
(unless (null? cores)
|
(unless (null? cores)
|
||||||
(let ([first (car cores)] [rest (cdr cores)])
|
(let ([first (car cores)] [rest (cdr cores)])
|
||||||
|
@ -2092,10 +2076,7 @@
|
||||||
(loop rest)]
|
(loop rest)]
|
||||||
[else
|
[else
|
||||||
(compile-and-run first)
|
(compile-and-run first)
|
||||||
(loop rest)]))))
|
(loop rest)])))))
|
||||||
(when *verbose*
|
|
||||||
(display "Elapsed time: ") (write (* 1000 (/ (- (current-jiffy) start) (jiffies-per-second))))
|
|
||||||
(display " ms.") (newline)))
|
|
||||||
|
|
||||||
|
|
||||||
(define (repl-eval-top-form x env)
|
(define (repl-eval-top-form x env)
|
||||||
|
@ -2196,6 +2177,10 @@
|
||||||
[(q) (set! *quiet* #t)]
|
[(q) (set! *quiet* #t)]
|
||||||
[(quiet on) (set! *quiet* #t)]
|
[(quiet on) (set! *quiet* #t)]
|
||||||
[(quiet off) (set! *quiet* #f)]
|
[(quiet off) (set! *quiet* #f)]
|
||||||
|
[(time *) (let ([start (current-jiffy)])
|
||||||
|
(repl-eval-top-form (car args) repl-environment)
|
||||||
|
(format #t "Elapsed time: ~s ms.~%"
|
||||||
|
(* 1000 (/ (- (current-jiffy) start) (jiffies-per-second)))))]
|
||||||
[(help)
|
[(help)
|
||||||
(display "Available commands:\n" op)
|
(display "Available commands:\n" op)
|
||||||
(display " ,say hello -- displays nice greeting\n" op)
|
(display " ,say hello -- displays nice greeting\n" op)
|
||||||
|
@ -2214,6 +2199,7 @@
|
||||||
(display " ,unr -- show user name registry\n" op)
|
(display " ,unr -- show user name registry\n" op)
|
||||||
(display " ,uref <name> -- lookup name in user registry\n" op)
|
(display " ,uref <name> -- lookup name in user registry\n" op)
|
||||||
(display " ,urem! <name> -- remove name from user registry\n" op)
|
(display " ,urem! <name> -- remove name from user registry\n" op)
|
||||||
|
(display " ,time <expr> -- time short expression <expr>\n" op)
|
||||||
(display " ,help -- this help\n" op)]
|
(display " ,help -- this help\n" op)]
|
||||||
[else
|
[else
|
||||||
(display "syntax error in repl command\n" op)
|
(display "syntax error in repl command\n" op)
|
||||||
|
|
93
t.c
93
t.c
|
@ -572,24 +572,24 @@ char *t_code[] = {
|
||||||
"${.(i11),.6,@(y11:adjoin-eals)[02},${.5,.(i12),@(y11:adjoin-code)[02},"
|
"${.(i11),.6,@(y11:adjoin-eals)[02},${.5,.(i12),@(y11:adjoin-code)[02},"
|
||||||
".8,:0^[(i10)5}:(i13),.1aq?{.6,.6,.6,.6,.5,.5dL6,:0^[75}:(i12),.1aq?{:("
|
".8,:0^[(i10)5}:(i13),.1aq?{.6,.6,.6,.6,.5,.5dL6,:0^[75}:(i12),.1aq?{:("
|
||||||
"i11),&1{%2${.2,@(y3:id?)[01}?{${.3,:0,@(y12:id-rename-as)[02},.1q]2}f]"
|
"i11),&1{%2${.2,@(y3:id?)[01}?{${.3,:0,@(y12:id-rename-as)[02},.1q]2}f]"
|
||||||
"2},.7,.7,.7,.7,:(i10),.7L6,${.8d,.8,@(y22:preprocess-cond-expand)[02}L"
|
"2},.7,.7,.7,.7,.6,${:(i10),.9,.9,@(y22:preprocess-cond-expand)[03}L6,:"
|
||||||
"6,:0^[85}:7,.1aq?{${'(s35:invalid library declarations syntax),'(l2:y4"
|
"0^[85}:7,.1aq?{${'(s35:invalid library declarations syntax),'(l2:y4:<i"
|
||||||
":<id>;y8:<string>;),.4,@(y12:check-syntax)[03}${.2da,@(y18:push-curren"
|
"d>;y8:<string>;),.4,@(y12:check-syntax)[03}${.2da,@(y18:push-current-f"
|
||||||
"t-file!)[01}.6,.6,.6,.6,.5,:0^[75}:6,.1aq?{${'(s35:invalid library dec"
|
"ile!)[01}.6,.6,.6,.6,.5,:0^[75}:6,.1aq?{${'(s35:invalid library declar"
|
||||||
"larations syntax),'(l1:y4:<id>;),.4,@(y12:check-syntax)[03}${@(y17:pop"
|
"ations syntax),'(l1:y4:<id>;),.4,@(y12:check-syntax)[03}${@(y17:pop-cu"
|
||||||
"-current-file!)[00}.6,.6,.6,.6,.5,:0^[75}:9,.1aq?{${'(s43:invalid incl"
|
"rrent-file!)[00}.6,.6,.6,.6,.5,:0^[75}:9,.1aq?{${'(s43:invalid include"
|
||||||
"ude-library-declarations syntax),'(l3:y4:<id>;y8:<string>;y3:...;),.4,"
|
"-library-declarations syntax),'(l3:y4:<id>;y8:<string>;y3:...;),.4,@(y"
|
||||||
"@(y12:check-syntax)[03}.1,.1dA8,,#0:8,:7,:6,.3,:0,.(i11),.(i13),.(i15)"
|
"12:check-syntax)[03}.1,.1dA8,,#0:8,:7,:6,.3,:0,.(i11),.(i13),.(i15),.("
|
||||||
",.(i17),&9{%2.0u?{:0,:1,:2,:3,.5,:4^[25}${.2a,@(y32:file-resolve-relat"
|
"i17),&9{%2.0u?{:0,:1,:2,:3,.5,:4^[25}${.2a,@(y32:file-resolve-relative"
|
||||||
"ive-to-current)[01},.0S0?{.0F0}{f},.0?{t}{${:8,.5a,'(s27:cannot includ"
|
"-to-current)[01},.0S0?{.0F0}{f},.0?{t}{${:8,.5a,'(s27:cannot include d"
|
||||||
"e declarations),@(y7:x-error)[03}},${f,.5,@(y15:read-file-sexps)[02},."
|
"eclarations),@(y7:x-error)[03}},${f,.5,@(y15:read-file-sexps)[02},.5,n"
|
||||||
"5,n,:6cc,.1L6,n,.5c,:7cc,.5d,:5^[62}.!0.0^_1[72}:5,.1aq?{${'(s42:inval"
|
",:6cc,.1L6,n,.5c,:7cc,.5d,:5^[62}.!0.0^_1[72}:5,.1aq?{${'(s42:invalid "
|
||||||
"id include library declaration syntax),'(l3:y4:<id>;y8:<string>;y3:..."
|
"include library declaration syntax),'(l3:y4:<id>;y8:<string>;y3:...;),"
|
||||||
";),.4,@(y12:check-syntax)[03}n,.1d,:4cc,.7L6,.6,.6,.6,.5,:0^[75}:3,.1a"
|
".4,@(y12:check-syntax)[03}n,.1d,:4cc,.7L6,.6,.6,.6,.5,:0^[75}:3,.1aq?{"
|
||||||
"q?{${'(s45:invalid include-ci library declaration syntax),'(l3:y4:<id>"
|
"${'(s45:invalid include-ci library declaration syntax),'(l3:y4:<id>;y8"
|
||||||
";y8:<string>;y3:...;),.4,@(y12:check-syntax)[03}n,.1d,:2cc,.7L6,.6,.6,"
|
":<string>;y3:...;),.4,@(y12:check-syntax)[03}n,.1d,:2cc,.7L6,.6,.6,.6,"
|
||||||
".6,.5,:0^[75}:1,.1aq?{${.2d,@(y17:xform-sexp->datum)[01},.7L6,.6,.6,.6"
|
".5,:0^[75}:1,.1aq?{${.2d,@(y17:xform-sexp->datum)[01},.7L6,.6,.6,.6,.5"
|
||||||
",.5,:0^[75}f]7}.!0.0^_1[(i17)5",
|
",:0^[75}f]7}.!0.0^_1[(i17)5",
|
||||||
|
|
||||||
"P", "preprocess-library",
|
"P", "preprocess-library",
|
||||||
"%2,#0.1,&1{%1${:0,@(y7:list2+?)[01}?{${:0da,@(y3:id?)[01}}{f}?{${.2,@("
|
"%2,#0.1,&1{%1${:0,@(y7:list2+?)[01}?{${:0da,@(y3:id?)[01}}{f}?{${.2,@("
|
||||||
|
@ -1299,16 +1299,14 @@ char *t_code[] = {
|
||||||
"f@!(y7:*quiet*)",
|
"f@!(y7:*quiet*)",
|
||||||
|
|
||||||
"P", "repl-compile-and-run-core-expr",
|
"P", "repl-compile-and-run-core-expr",
|
||||||
"%1,,#0#1f.!0&0{%1,,,#0#1#2${.5,@(y21:compile-to-thunk-code)[01}.!0.0^U"
|
"%1,#0&0{%1,,,#0#1#2${.5,@(y21:compile-to-thunk-code)[01}.!0.0^U4,U91.!"
|
||||||
"4,U91.!1${@(y4:list),.4^,@(y16:call-with-values)[02}.!2.2^,&0{%1.0Y8~?"
|
"1${@(y4:list),.4^,@(y16:call-with-values)[02}.!2.2^,&0{%1.0Y8~?{Po,.1W"
|
||||||
"{Po,.1W5PoW6]1}]1},@(y10:%25for-each1)[42}.!1@(y9:*verbose*)?{Po,'(s12"
|
"5PoW6]1}]1},@(y10:%25for-each1)[42}.!0@(y9:*verbose*)?{Po,'(s12:TRANSF"
|
||||||
":TRANSFORM =>)W4PoW6Po,.3W5PoW6}.2p~?{${.4,'(s29:unexpected transforme"
|
"ORM =>)W4PoW6Po,.2W5PoW6}.1p~?{${.3,'(s29:unexpected transformed outpu"
|
||||||
"d output),@(y7:x-error)[02}}Z3.!0${.4,l1,,#0.0,.6,&2{%1.0u~?{.0d,.1a,'"
|
"t),@(y7:x-error)[02}}.1,l1,,#0.0,.3,&2{%1.0u~?{.0d,.1a,'(y5:begin),.1a"
|
||||||
"(y5:begin),.1aq?{.0d,.2,:1,&2{%!0:1,.1L6,:0^[11},@(y13:apply-to-list)["
|
"q?{.0d,.2,:1,&2{%!0:1,.1L6,:0^[11},@(y13:apply-to-list)[32}'(y4:once),"
|
||||||
"32}'(y4:once),.1aq?{.0d,:1,.3,.3,:0,&4{%2${:1,:0^[01}'(y5:begin),:1san"
|
".1aq?{.0d,:1,.3,.3,:0,&4{%2${:1,:0^[01}'(y5:begin),:1san,:1sd:2,:3^[21"
|
||||||
",:1sd:2,:3^[21},@(y13:apply-to-list)[32}${.2,:0^[01}.1,:1^[31}]1}.!0.0"
|
"},@(y13:apply-to-list)[32}${.2,:0^[01}.1,:1^[31}]1}.!0.0^_1[21",
|
||||||
"^_1[01}@(y9:*verbose*)?{Po,'(s14:Elapsed time: )W4Po,Z4,.2^,Z3-/,'(i10"
|
|
||||||
"00)*W5Po,'(s4: ms.)W4PoW6]3}]3",
|
|
||||||
|
|
||||||
"P", "repl-eval-top-form",
|
"P", "repl-eval-top-form",
|
||||||
"%2.0p?{${.3,.3a,t,@(y5:xform)[03},'(y5:begin),.1q?{.1d,,#0.4,.1,&2{%1."
|
"%2.0p?{${.3,.3a,t,@(y5:xform)[03},'(y5:begin),.1q?{.1d,,#0.4,.1,&2{%1."
|
||||||
|
@ -1374,24 +1372,27 @@ char *t_code[] = {
|
||||||
"y7:verbose;y3:off;),@(y11:sexp-match?)[02}?{f@!(y9:*verbose*)]5}${.3^,"
|
"y7:verbose;y3:off;),@(y11:sexp-match?)[02}?{f@!(y9:*verbose*)]5}${.3^,"
|
||||||
"'(l1:y1:q;),@(y11:sexp-match?)[02}?{t@!(y7:*quiet*)]5}${.3^,'(l2:y5:qu"
|
"'(l1:y1:q;),@(y11:sexp-match?)[02}?{t@!(y7:*quiet*)]5}${.3^,'(l2:y5:qu"
|
||||||
"iet;y2:on;),@(y11:sexp-match?)[02}?{t@!(y7:*quiet*)]5}${.3^,'(l2:y5:qu"
|
"iet;y2:on;),@(y11:sexp-match?)[02}?{t@!(y7:*quiet*)]5}${.3^,'(l2:y5:qu"
|
||||||
"iet;y3:off;),@(y11:sexp-match?)[02}?{f@!(y7:*quiet*)]5}${.3^,'(l1:y4:h"
|
"iet;y3:off;),@(y11:sexp-match?)[02}?{f@!(y7:*quiet*)]5}${.3^,'(l2:y4:t"
|
||||||
"elp;),@(y11:sexp-match?)[02}?{.4,'(s20:Available commands:%0a)W4.4,'(s"
|
"ime;y1:*;),@(y11:sexp-match?)[02}?{Z3,${@(y16:repl-environment),.4^a,@"
|
||||||
"42: ,say hello -- displays nice greeting%0a)W4.4,'(s40: ,peek <fna"
|
"(y18:repl-eval-top-form)[02}Z4,.1,Z3-/,'(i1000)*,'(s22:Elapsed time: ~"
|
||||||
"me> -- check if file exists%0a)W4.4,'(s50: ,q -- disable "
|
"s ms.~%25),t,@(y6:format)[63}${.3^,'(l1:y4:help;),@(y11:sexp-match?)[0"
|
||||||
"informational messages%0a)W4.4,'(s50: ,quiet on -- disable inform"
|
"2}?{.4,'(s20:Available commands:%0a)W4.4,'(s42: ,say hello -- disp"
|
||||||
"ational messages%0a)W4.4,'(s49: ,quiet off -- enable informational"
|
"lays nice greeting%0a)W4.4,'(s40: ,peek <fname> -- check if file exis"
|
||||||
" messages%0a)W4.4,'(s37: ,v -- turn verbosity on%0a)W4.4,'"
|
"ts%0a)W4.4,'(s50: ,q -- disable informational messages%0a)"
|
||||||
"(s37: ,verbose on -- turn verbosity on%0a)W4.4,'(s38: ,verbose off "
|
"W4.4,'(s50: ,quiet on -- disable informational messages%0a)W4.4,'"
|
||||||
" -- turn verbosity off%0a)W4.4,'(s38: ,verbose off -- turn verbosit"
|
"(s49: ,quiet off -- enable informational messages%0a)W4.4,'(s37: ,"
|
||||||
"y off%0a)W4.4,'(s54: ,ref <name> -- show current denotation for <na"
|
"v -- turn verbosity on%0a)W4.4,'(s37: ,verbose on -- tu"
|
||||||
"me>%0a)W4.4,'(s43: ,rnr -- show root name registry%0a)W4.4,'"
|
"rn verbosity on%0a)W4.4,'(s38: ,verbose off -- turn verbosity off%0a"
|
||||||
"(s48: ,rref <name> -- lookup name in root registry%0a)W4.4,'(s50: ,r"
|
")W4.4,'(s38: ,verbose off -- turn verbosity off%0a)W4.4,'(s54: ,ref "
|
||||||
"rem! <name> -- remove name from root registry%0a)W4.4,'(s43: ,unr "
|
"<name> -- show current denotation for <name>%0a)W4.4,'(s43: ,rnr "
|
||||||
" -- show user name registry%0a)W4.4,'(s48: ,uref <name> -- loo"
|
" -- show root name registry%0a)W4.4,'(s48: ,rref <name> -- lo"
|
||||||
"kup name in user registry%0a)W4.4,'(s50: ,urem! <name> -- remove name"
|
"okup name in root registry%0a)W4.4,'(s50: ,rrem! <name> -- remove nam"
|
||||||
" from user registry%0a)W4.4,'(s29: ,help -- this help%0a)W4]5"
|
"e from root registry%0a)W4.4,'(s43: ,unr -- show user name r"
|
||||||
"}.4,'(s29:syntax error in repl command%0a)W4.4,'(s37:type ,help to see"
|
"egistry%0a)W4.4,'(s48: ,uref <name> -- lookup name in user registry%"
|
||||||
" available commands%0a)W4]5",
|
"0a)W4.4,'(s50: ,urem! <name> -- remove name from user registry%0a)W4."
|
||||||
|
"4,'(s48: ,time <expr> -- time short expression <expr>%0a)W4.4,'(s29:"
|
||||||
|
" ,help -- this help%0a)W4]5}.4,'(s29:syntax error in repl com"
|
||||||
|
"mand%0a)W4.4,'(s37:type ,help to see available commands%0a)W4]5",
|
||||||
|
|
||||||
"P", "repl-from-port",
|
"P", "repl-from-port",
|
||||||
"%3,#0${@(y18:current-file-stack)[00}.!0${k0,.0,${.2,.9,.(i11),.(i10),&"
|
"%3,#0${@(y18:current-file-stack)[00}.!0${k0,.0,${.2,.9,.(i11),.(i10),&"
|
||||||
|
|
Loading…
Add table
Reference in a new issue