fixed id-rename-as; enhanced sexp-case

This commit is contained in:
ESL 2024-06-20 18:42:11 -04:00
parent 4606c30af1
commit c85dad9f0a
2 changed files with 89 additions and 112 deletions

View file

@ -67,12 +67,12 @@
(and (eq? pat '<id>) (or (symbol? x) (procedure? x))) (and (eq? pat '<id>) (or (symbol? x) (procedure? x)))
(and (eq? pat '<symbol>) (symbol? x)) (and (eq? pat '<symbol>) (symbol? x))
(and (eq? pat '<string>) (string? x)) (and (eq? pat '<string>) (string? x))
(eq? x pat) (eqv? x pat)
(and (pair? pat) (and (pair? pat)
(cond [(and (eq? (car pat) '...) (cond [(and (eq? (car pat) '...)
(pair? (cdr pat)) (pair? (cdr pat))
(null? (cddr pat))) (null? (cddr pat)))
(eq? x (cadr pat))] (eqv? x (cadr pat))]
[(and (pair? (cdr pat)) [(and (pair? (cdr pat))
(eq? (cadr pat) '...) (eq? (cadr pat) '...)
(null? (cddr pat))) (null? (cddr pat)))
@ -87,7 +87,11 @@
[else [else
(and (pair? x) (and (pair? x)
(sexp-match? (car pat) (car x)) (sexp-match? (car pat) (car x))
(sexp-match? (cdr pat) (cdr x)))])))) (sexp-match? (cdr pat) (cdr x)))]))
(and (vector? pat) (vector? x)
(sexp-match? (vector->list pat) (vector->list x)))
(and (box? pat) (box? x)
(sexp-match? (unbox pat) (unbox x)))))
(define-syntax sexp-case (define-syntax sexp-case
(syntax-rules (else) (syntax-rules (else)
@ -125,6 +129,12 @@
[(eq? x (car l)) n] [(eq? x (car l)) n]
[else (loop (cdr l) (fx+ n 1))])))) [else (loop (cdr l) (fx+ n 1))]))))
(define rassq
(lambda (x al)
(and (pair? al)
(let ([a (car al)])
(if (eq? x (cdr a)) a (rassq x (cdr al)))))))
(define list-diff (define list-diff
(lambda (l t) (lambda (l t)
(if (or (null? l) (eq? l t)) (if (or (null? l) (eq? l t))
@ -147,6 +157,9 @@
(define (andmap p l) (define (andmap p l)
(if (pair? l) (and (p (car l)) (andmap p (cdr l))) #t)) (if (pair? l) (and (p (car l)) (andmap p (cdr l))) #t))
(define (ormap p l)
(if (pair? l) (or (p (car l)) (ormap p (cdr l))) #f))
(define (list1? x) (and (pair? x) (null? (cdr x)))) (define (list1? x) (and (pair? x) (null? (cdr x))))
(define (list1+? x) (and (pair? x) (list? (cdr x)))) (define (list1+? x) (and (pair? x) (list? (cdr x))))
(define (list2? x) (and (pair? x) (list1? (cdr x)))) (define (list2? x) (and (pair? x) (list1? (cdr x))))
@ -258,13 +271,22 @@
(define-syntax location-set-val! set-box!) (define-syntax location-set-val! set-box!)
(define (location-special? l) (not (pair? (unbox l)))) (define (location-special? l) (not (pair? (unbox l))))
(define (new-id sym den rename) (define p (list sym den rename)) (lambda () p)) (define (new-id sym den getlits) (define p (list sym den getlits)) (lambda () p))
(define (old-sym id) (car (id))) (define (old-sym id) (car (id)))
(define (old-den id) (cadr (id))) (define (old-den id) (cadr (id)))
(define (old-rename id) (or (caddr (id)) (lambda (nid) nid))) (define (old-literals id) ((or (caddr (id)) (lambda () '()))))
(define (id? x) (or (symbol? x) (procedure? x))) (define (id? x) (or (symbol? x) (procedure? x)))
(define (id->sym id) (if (symbol? id) id (old-sym id))) (define (id->sym id) (if (symbol? id) id (old-sym id)))
(define (id-rename-as id nid) (if (symbol? id) nid ((old-rename id) nid)))
; take a possibly renamed target id, and find image for nid
(define (id-rename-as id nid)
(let loop ([id id])
(if (symbol? id) nid
(let* ([lits (old-literals id)] [oid->id (rassq id lits)])
(unless oid->id (x-error "id-rename-as failed: not found in its own lits" id))
(let ([renamed-nid (loop (car oid->id))])
(cond [(assq renamed-nid lits) => cdr]
[else renamed-nid]))))))
; Expand-time environments map identifiers (symbolic or thunked) to denotations, i.e. locations ; Expand-time environments map identifiers (symbolic or thunked) to denotations, i.e. locations
; containing either a <special> or a <core> value. In normal case, <core> value is (ref <gid>), ; containing either a <special> or a <core> value. In normal case, <core> value is (ref <gid>),
@ -657,13 +679,8 @@
(define new-literals (define new-literals
(body (body
(define nl (define nl
(map (lambda (id) (map (lambda (id) (cons id (new-id (id->sym id) (xenv-ref mac-env id) (lambda () nl))))
(cons id (list-ids tmpl #t (lambda (id) (not (assq id top-bindings))))))
(new-id (id->sym id)
(xenv-ref mac-env id)
(lambda (nid) (cond [(assq nid nl) => cdr] [else nid])))))
(list-ids tmpl #t
(lambda (id) (not (assq id top-bindings))))))
nl)) nl))
(define ellipsis-vars (define ellipsis-vars
@ -1282,7 +1299,7 @@
; Library names and library file lookup ; Library names and library file lookup
;--------------------------------------------------------------------------------------------- ;---------------------------------------------------------------------------------------------
(define (mangle-symbol->string sym) (define (mangle-symbol->string sym)
(define safe '(#\! #\$ #\- #\_ #\=)) (define safe '(#\! #\$ #\- #\_ #\=))
(let loop ([lst (string->list (symbol->string sym))] [text '()]) (let loop ([lst (string->list (symbol->string sym))] [text '()])
(cond [(null? lst) (cond [(null? lst)
@ -1317,18 +1334,6 @@
[(exact-integer? s) (number->string s)] [(exact-integer? s) (number->string s)]
[else (c-error "invalid library name name element" s)])) [else (c-error "invalid library name name element" s)]))
(define modname-separator "_")
(define (listname->modname listname)
(define sep modname-separator)
(let loop ([l listname] [r '()])
(if (pair? l)
(loop (cdr l)
(if (null? r)
(cons (listname-segment->string (car l)) r)
(cons (listname-segment->string (car l)) (cons sep r))))
(string-append* (reverse r)))))
(define (listname->path listname basepath ext) (define (listname->path listname basepath ext)
(define sep (define sep
(let ([sc (base-path-separator basepath)]) (let ([sc (base-path-separator basepath)])
@ -1396,26 +1401,10 @@
(let ([s (read-code-sexp port)]) (let ([s (read-code-sexp port)])
(unless (eof-object? s) (proc s) (loop))))))) (unless (eof-object? s) (proc s) (loop)))))))
(define (file/lib->modname name)
(cond [(and (pair? name) (list? name)) (listname->modname name)]
[(string? name) (path-strip-extension (path-strip-directory name))]
[else (c-error "illegal file or library name:" name)]))
(define (file/lib/stdin->modname name)
(if (and (string? name) (string=? name "-"))
"stdin"
(file/lib->modname name)))
; name prefixes ; name prefixes
(define (fully-qualified-prefix modname)
(string-append modname "."))
(define (fully-qualified-library-prefix lib)
(fully-qualified-prefix (file/lib->modname lib)))
(define (fully-qualified-library-prefixed-name lib id) (define (fully-qualified-library-prefixed-name lib id)
(string-append (file/lib->modname lib) "." (symbol->string id))) (string->symbol (string-append (symbol->string (listname->symbol lib)) "?" (symbol->string id))))
;--------------------------------------------------------------------------------------------- ;---------------------------------------------------------------------------------------------

80
t.c
View file

@ -36,11 +36,13 @@ char *t_code[] = {
"P", "sexp-match?", "P", "sexp-match?",
"%2'(y1:*),.1q,.0?{.0]3}'(y4:<id>),.2q?{.2Y0,.0?{.0}{.3K0}_1}{f},.0?{.0" "%2'(y1:*),.1q,.0?{.0]3}'(y4:<id>),.2q?{.2Y0,.0?{.0}{.3K0}_1}{f},.0?{.0"
"]4}'(y8:<symbol>),.3q?{.3Y0}{f},.0?{.0]5}'(y8:<string>),.4q?{.4S0}{f}," "]4}'(y8:<symbol>),.3q?{.3Y0}{f},.0?{.0]5}'(y8:<string>),.4q?{.4S0}{f},"
".0?{.0]6}.4,.6q,.0?{.0]7}.5p?{'(y3:...),.6aq?{.5dp?{.5ddu}{f}}{f}?{.5d" ".0?{.0]6}.4,.6v,.0?{.0]7}.5p?{'(y3:...),.6aq?{.5dp?{.5ddu}{f}}{f}?{.5d"
"a,.7q]7}.5dp?{'(y3:...),.6daq?{.5ddu}{f}}{f}?{.5a,'(y1:*),.1q?{.7L0]8}" "a,.7v}{.5dp?{'(y3:...),.6daq?{.5ddu}{f}}{f}?{.5a,'(y1:*),.1q?{.7L0}{${"
".7,,#0.0,.3,&2{%1.0u,.0?{.0]2}.1p?{${.3a,:0,@(y11:sexp-match?)[02}?{.1" ".9,,#0.0,.5,&2{%1.0u,.0?{.0]2}.1p?{${.3a,:0,@(y11:sexp-match?)[02}?{.1"
"d,:1^[21}f]2}f]2}.!0.0^_1[81}.6p?{${.8a,.8a,@(y11:sexp-match?)[02}?{.6" "d,:1^[21}f]2}f]2}.!0.0^_1[01}}_1}{.6p?{${.8a,.8a,@(y11:sexp-match?)[02"
"d,.6d,@(y11:sexp-match?)[72}f]7}f]7}f]7", "}?{${.8d,.8d,@(y11:sexp-match?)[02}}{f}}{f}}}}{f},.0?{.0]8}.6V0?{.7V0?"
"{${.9X0,.9X0,@(y11:sexp-match?)[02}}{f}}{f},.0?{.0]9}.7Y2?{.8Y2?{.8z,."
"8z,@(y11:sexp-match?)[92}f]9}f]9",
"S", "sexp-case", "S", "sexp-case",
"l6:y12:syntax-rules;l1:y4:else;;l2:l4:y1:_;l2:y3:key;y3:...;;y7:clause" "l6:y12:syntax-rules;l1:y4:else;;l2:l4:y1:_;l2:y3:key;y3:...;;y7:clause"
@ -62,6 +64,9 @@ char *t_code[] = {
"%2'0,.2,,#0.0,.4,&2{%2.0u?{f]2}.0a,:0q?{.1]2}'1,.2I+,.1d,:1^[22}.!0.0^" "%2'0,.2,,#0.0,.4,&2{%2.0u?{f]2}.0a,:0q?{.1]2}'1,.2I+,.1d,:1^[22}.!0.0^"
"_1[22", "_1[22",
"P", "rassq",
"%2.1p?{.1a,.0d,.2q?{.0]3}.2d,.2,@(y5:rassq)[32}f]2",
"P", "list-diff", "P", "list-diff",
"%2.0u,.0?{.0}{.2,.2q}_1?{n]2}${.3,.3d,@(y9:list-diff)[02},.1ac]2", "%2.0u,.0?{.0}{.2,.2q}_1?{n]2}${.3,.3d,@(y9:list-diff)[02},.1ac]2",
@ -77,6 +82,9 @@ char *t_code[] = {
"P", "andmap", "P", "andmap",
"%2.1p?{${.3a,.3[01}?{.1d,.1,@(y6:andmap)[22}f]2}t]2", "%2.1p?{${.3a,.3[01}?{.1d,.1,@(y6:andmap)[22}f]2}t]2",
"P", "ormap",
"%2.1p?{${.3a,.3[01},.0?{.0]3}.2d,.2,@(y5:ormap)[32}f]2",
"P", "list1?", "P", "list1?",
"%1.0p?{.0du]1}f]1", "%1.0p?{.0du]1}f]1",
@ -136,8 +144,8 @@ char *t_code[] = {
"P", "old-den", "P", "old-den",
"%1${.2[00}da]1", "%1${.2[00}da]1",
"P", "old-rename", "P", "old-literals",
"%1${.2[00}dda,.0?{.0]2}&0{%1.0]1}]2", "%1${.2[00}dda,.0?{.0}{&0{%0n]0}}_1[10",
"P", "id?", "P", "id?",
"%1.0Y0,.0?{.0]2}.1K0]2", "%1.0Y0,.0?{.0]2}.1K0]2",
@ -146,7 +154,10 @@ char *t_code[] = {
"%1.0Y0?{.0]1}.0,@(y7:old-sym)[11", "%1.0Y0?{.0]1}.0,@(y7:old-sym)[11",
"P", "id-rename-as", "P", "id-rename-as",
"%2.0Y0?{.1]2}.1,${.3,@(y10:old-rename)[01}[21", "%2.0,,#0.0,.4,&2{%1.0Y0?{:0]1}${.2,@(y12:old-literals)[01},${.2,.4,@(y"
"5:rassq)[02},.0~?{${.4,'(s46:id-rename-as failed: not found in its own"
" lits),@(y7:x-error)[02}}${.2a,:1^[01},.2,.1A3,.0?{.0d]5}.1]5}.!0.0^_1"
"[21",
"P", "extend-xenv-local", "P", "extend-xenv-local",
"%3.1b,.3,.1,.3,&3{%2.0,:0q?{.1,'(l2:y3:ref;y4:set!;),.1A1?{:1]3}f]3}.1" "%3.1b,.3,.1,.3,&3{%2.0,:0q?{.1,'(l2:y3:ref;y4:set!;),.1A1?{:1]3}f]3}.1"
@ -362,19 +373,19 @@ char *t_code[] = {
"},${${.7,.6^,@(y5:%25map1)[02},.5c,@(y4:list)c,@(y4:%25map),@(y13:appl" "},${${.7,.6^,@(y5:%25map1)[02},.5c,@(y4:list)c,@(y4:%25map),@(y13:appl"
"y-to-list)[02}L6](i11)}.2p?{${.5,.5d,.5d,:6^[03},.3a,.3a,:6^[43}:7^[40" "y-to-list)[02}L6](i11)}.2p?{${.5,.5d,.5d,:6^[03},.3a,.3a,:6^[43}:7^[40"
"}.!0.0^_1[63}.!6.8,.2,.7,.5,&4{%3,,,#0#1#2,#0${${.(i10),&1{%1:0,.1A3~]" "}.!0.0^_1[63}.!6.8,.2,.7,.5,&4{%3,,,#0#1#2,#0${${.(i10),&1{%1:0,.1A3~]"
"1},t,.(i11),:1^[03},:3,.4,&2{%1${:0,&1{%1:0^,.1A3,.0?{.0d]2}.1]2},${.5" "1},t,.(i11),:1^[03},:3,.4,&2{%1${:0,&1{%0:0^]0},${.5,:1,@(y8:xenv-ref)"
",:1,@(y8:xenv-ref)[02},${.6,@(y7:id->sym)[01},@(y6:new-id)[03},.1c]1}," "[02},${.6,@(y7:id->sym)[01},@(y6:new-id)[03},.1c]1},@(y5:%25map1)[02}."
"@(y5:%25map1)[02}.!0.0^_1.!0${:2^,f,.7,:1^[03}.!1.1,:1,&2{%1:1,&1{%1:0" "!0.0^_1.!0${:2^,f,.7,:1^[03}.!1.1,:1,&2{%1:1,&1{%1:0^,.1A0]1},t,.2,:0^"
"^,.1A0]1},t,.2,:0^[13}.!2.5,.5,,#0.8,.4,:0,.8,.4,&5{%2.0,,#0.0,.4,:0,:" "[13}.!2.5,.5,,#0.8,.4,:0,.8,.4,&5{%2.0,,#0.0,.4,:0,:1,:2,:3,:4,&7{%1${"
"1,:2,:3,:4,&7{%1${.2,@(y3:id?)[01}?{:5,.1A3,.0?{.0}{:0,.2A3,.0?{.0}{:1" ".2,@(y3:id?)[01}?{:5,.1A3,.0?{.0}{:0,.2A3,.0?{.0}{:1^,.3A3}_1}_1d]1}.0"
"^,.3A3}_1}_1d]1}.0V0?{${.2X0,:6^[01}X1]1}.0p?{${.2d,:2^[01}}{f}?{${.2a" "V0?{${.2X0,:6^[01}X1]1}.0p?{${.2d,:2^[01}}{f}?{${.2a,:3^[01},,,#0#1:5,"
",:3^[01},,,#0#1:5,&1{%1:0,.1A3d]1}.!0.2,.4,:4,&3{%!0${.2,:2,@(y4:cons)" "&1{%1:0,.1A3d]1}.!0.2,.4,:4,&3{%!0${.2,:2,@(y4:cons),@(y5:%25map2)[03}"
",@(y5:%25map2)[03},:1a,:0^[12}.!1.2u?{${.5dd,:6^[01},${.6a,:6^[01}c]4}" ",:1a,:0^[12}.!1.2u?{${.5dd,:6^[01},${.6a,:6^[01}c]4}${.4,.3^,@(y5:%25m"
"${.4,.3^,@(y5:%25map1)[02},${.6dd,:6^[01},${.3,.6^c,@(y4:%25map),@(y13" "ap1)[02},${.6dd,:6^[01},${.3,.6^c,@(y4:%25map),@(y13:apply-to-list)[02"
":apply-to-list)[02}L6]5}.0p?{${.2d,:6^[01},${.3a,:6^[01}c]1}.0]1}.!0.0" "}L6]5}.0p?{${.2d,:6^[01},${.3a,:6^[01}c]1}.0]1}.!0.0^_1[21}.!0.0^_1[62"
"^_1[21}.!0.0^_1[62}.!7.(i11),.8,.8,&3{%2:2,,#0:0,.3,.5,:1,.4,&5{%1.0u?" "}.!7.(i11),.8,.8,&3{%2:2,,#0:0,.3,.5,:1,.4,&5{%1.0u?{${:3,'(s14:invali"
"{${:3,'(s14:invalid syntax),@(y7:x-error)[02}}.0a,.0a,.1da,${:2,:3,.5," "d syntax),@(y7:x-error)[02}}.0a,.0a,.1da,${:2,:3,.5,:4^[03},.0?{.0,.0,"
":4^[03},.0?{.0,.0,.3,.5,:1^[63}.4d,:0^[51}.!0.0^_1[21}](i12)", ".3,.5,:1^[63}.4d,:0^[51}.!0.0^_1[21}](i12)",
"P", "make-include-transformer", "P", "make-include-transformer",
"%1,#0${f,'(y5:begin)b,'(y5:begin),@(y6:new-id)[03}.!0.1,.1,&2{%2${.2,@" "%1,#0${f,'(y5:begin)b,'(y5:begin),@(y6:new-id)[03}.!0.1,.1,&2{%2${.2,@"
@ -679,15 +690,6 @@ char *t_code[] = {
"%1.0Y0?{.0,@(y21:mangle-symbol->string)[11}.0I0?{'(i10),.1E8]1}.0,'(s3" "%1.0Y0?{.0,@(y21:mangle-symbol->string)[11}.0I0?{'(i10),.1E8]1}.0,'(s3"
"3:invalid library name name element),@(y7:c-error)[12", "3:invalid library name name element),@(y7:c-error)[12",
"C", 0,
"'(s1:_)@!(y17:modname-separator)",
"P", "listname->modname",
"%1,#0@(y17:modname-separator).!0n,.2,,#0.0,.4,&2{%2.0p?{.1u?{.1,${.3a,"
"@(y24:listname-segment->string)[01}c}{.1,:0^c,${.3a,@(y24:listname-seg"
"ment->string)[01}c},.1d,:1^[22}.1A8,@(y14:string-append*)[21}.!0.0^_1["
"22",
"P", "listname->path", "P", "listname->path",
"%3,#0${.4,@(y19:base-path-separator)[01},.0?{.0,S11}{${.5,'(s38:librar" "%3,#0${.4,@(y19:base-path-separator)[01},.0?{.0,S11}{${.5,'(s38:librar"
"y path does not end in separator),@(y7:c-error)[02}}_1.!0n,.2,,#0.5,.7" "y path does not end in separator),@(y7:c-error)[02}}_1.!0n,.2,,#0.5,.7"
@ -730,23 +732,9 @@ char *t_code[] = {
"%3.0,&1{%2,#0.2,.1,:0,&3{%0${:2,@(y14:read-code-sexp)[01},.0R8~?{${.2," "%3.0,&1{%2,#0.2,.1,:0,&3{%0${:2,@(y14:read-code-sexp)[01},.0R8~?{${.2,"
":0[01}:1^[10}]1}.!0.0^_1[20},.3,.3,@(y24:call-with-input-file/lib)[33", ":0[01}:1^[10}]1}.!0.0^_1[20},.3,.3,@(y24:call-with-input-file/lib)[33",
"P", "file/lib->modname",
"%1.0p?{.0L0}{f}?{.0,@(y17:listname->modname)[11}.0S0?{${.2,@(y20:path-"
"strip-directory)[01},@(y20:path-strip-extension)[11}.0,'(s29:illegal f"
"ile or library name:),@(y7:c-error)[12",
"P", "file/lib/stdin->modname",
"%1.0S0?{'(s1:-),.1S=}{f}?{'(s5:stdin)]1}.0,@(y17:file/lib->modname)[11",
"P", "fully-qualified-prefix",
"%1'(s1:.),.1S6]1",
"P", "fully-qualified-library-prefix",
"%1${.2,@(y17:file/lib->modname)[01},@(y22:fully-qualified-prefix)[11",
"P", "fully-qualified-library-prefixed-name", "P", "fully-qualified-library-prefixed-name",
"%2.1X4,'(s1:.),${.4,@(y17:file/lib->modname)[01},@(y14:%25string-appen" "%2${.3X4,'(s1:?),${.6,@(y16:listname->symbol)[01}X4,@(y14:%25string-ap"
"d)[23", "pend)[03}X5]2",
"P", "env-lookup", "P", "env-lookup",
"%3.0K0?{.2,'(l2:y3:ref;y4:set!;),.1A1?{.1,@(y7:old-den)[41}f]4}.1,,#0." "%3.0K0?{.2,'(l2:y3:ref;y4:set!;),.1A1?{.1,@(y7:old-den)[41}f]4}.1,,#0."