mirror of
https://github.com/false-schemers/skint.git
synced 2025-01-13 20:03:30 +01:00
*library-registry* and friends
This commit is contained in:
parent
9dc95e1fce
commit
a0e92d14ed
2 changed files with 88 additions and 65 deletions
104
src/t.scm
104
src/t.scm
|
@ -1415,6 +1415,28 @@
|
||||||
(cons (listname-segment->string (car l)) (cons sep r))))
|
(cons (listname-segment->string (car l)) (cons sep r))))
|
||||||
(file-resolve-relative-to-base-path (string-append* (reverse (cons ext r))) basepath))))
|
(file-resolve-relative-to-base-path (string-append* (reverse (cons ext r))) basepath))))
|
||||||
|
|
||||||
|
(define (symbol-libname? sym) ; integrable candidate
|
||||||
|
(let* ([str (symbol->string sym)] [sl (string-length str)])
|
||||||
|
(and (< 6 sl)
|
||||||
|
(char=? (string-ref str 0) #\l)
|
||||||
|
(char=? (string-ref str 1) #\i)
|
||||||
|
(char=? (string-ref str 2) #\b)
|
||||||
|
(char=? (string-ref str 3) #\:)
|
||||||
|
(char=? (string-ref str 4) #\/)
|
||||||
|
(char=? (string-ref str 5) #\/)
|
||||||
|
(substring str 6 sl))))
|
||||||
|
|
||||||
|
(define (symbol->listname sym) ;=> listname | #f
|
||||||
|
(let loop ([s (symbol-libname? sym)] [r '()])
|
||||||
|
(cond [(not s) (and (pair? r) (reverse! r))]
|
||||||
|
[(string-position #\/ s) =>
|
||||||
|
(lambda (n) (loop (substring s (+ n 1) (string-length s))
|
||||||
|
(cons (string->symbol (substring s 0 n)) r)))]
|
||||||
|
[else (loop #f (cons (string->symbol s) r))])))
|
||||||
|
|
||||||
|
(define (libname->path libname basepath ext)
|
||||||
|
(let ([listname (if (symbol? libname) (symbol->listname libname) libname)])
|
||||||
|
(and (list1+? listname) (listname->path listname basepath ext))))
|
||||||
|
|
||||||
; hacks for locating library files
|
; hacks for locating library files
|
||||||
|
|
||||||
|
@ -1428,7 +1450,7 @@
|
||||||
(define (find-library-path libname) ;=> name of existing .sld file or #f
|
(define (find-library-path libname) ;=> name of existing .sld file or #f
|
||||||
(let loop ([l *library-path-list*])
|
(let loop ([l *library-path-list*])
|
||||||
(and (pair? l)
|
(and (pair? l)
|
||||||
(let ([p (listname->path libname (car l) ".sld")])
|
(let ([p (libname->path libname (car l) ".sld")])
|
||||||
(if (and p (file-exists? p)) p (loop (cdr l)))))))
|
(if (and p (file-exists? p)) p (loop (cdr l)))))))
|
||||||
|
|
||||||
#;(define (resolve-input-file/lib-name name) ;=> path (or error is signalled)
|
#;(define (resolve-input-file/lib-name name) ;=> path (or error is signalled)
|
||||||
|
@ -1479,11 +1501,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 (library-available? lib)
|
(define (library-available? lib) ;=> #f | filepath (external) | #t (loaded)
|
||||||
(cond [(assoc lib *std-lib->alist-env*) #t] ; FIXME
|
(cond [(string? lib) (file-resolve-relative-to-current lib)]
|
||||||
[(string? lib) (file-resolve-relative-to-current lib)]
|
[(library-info lib #f) #t] ; builtin or preloaded
|
||||||
[(and (pair? lib) (list? lib)) (find-library-path lib)]
|
[else (and (or (symbol? lib) (list1+? lib)) (find-library-path lib))]))
|
||||||
[else #f]))
|
|
||||||
|
|
||||||
; name prefixes
|
; name prefixes
|
||||||
|
|
||||||
|
@ -1577,10 +1598,19 @@
|
||||||
(define (root-environment id at)
|
(define (root-environment id at)
|
||||||
(env-lookup id *root-environment* at))
|
(env-lookup id *root-environment* at))
|
||||||
|
|
||||||
|
;---------------------------------------------------------------------------------------------
|
||||||
|
; Library registry and built-in libraries
|
||||||
|
;---------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
; standard library environments in alist form (used as import envs)
|
(define *library-registry* '()) ; alist of a form ((libsym . ic&ex) ...)
|
||||||
|
|
||||||
(define *std-lib->alist-env* '())
|
(define (library-info lib alloc?) ;=> (code . eal) | #f
|
||||||
|
(let ([key (if (symbol? lib) lib (listname->symbol lib))])
|
||||||
|
(cond [(assq key *library-registry*) => cdr]
|
||||||
|
[(not alloc?) #f]
|
||||||
|
[else (let ([ic&ex (cons '(begin) '())])
|
||||||
|
(set! *library-registry* (cons (cons key ic&ex) *library-registry*))
|
||||||
|
ic&ex)])))
|
||||||
|
|
||||||
(for-each
|
(for-each
|
||||||
(lambda (r)
|
(lambda (r)
|
||||||
|
@ -1592,22 +1622,17 @@
|
||||||
[(i) '(scheme inexact)] [(f) '(scheme file)] [(e) '(scheme eval)]
|
[(i) '(scheme inexact)] [(f) '(scheme file)] [(e) '(scheme eval)]
|
||||||
[(o) '(scheme complex)] [(h) '(scheme char)] [(l) '(scheme case-lambda)]
|
[(o) '(scheme complex)] [(h) '(scheme char)] [(l) '(scheme case-lambda)]
|
||||||
[(x) '(scheme cxr)] [(b) '(scheme base)]))
|
[(x) '(scheme cxr)] [(b) '(scheme base)]))
|
||||||
(define (put-loc! e k loc)
|
(define (get-env! lib) ;=> ic&ex
|
||||||
(let ([p (assq k (cdr e))])
|
(library-info lib #t))
|
||||||
(cond [p (set-cdr! p loc)]
|
(define (put-loc! ic&ex k loc)
|
||||||
[else (set-cdr! e (cons (cons k loc) (cdr e)))])))
|
(let ([p (assq k (cdr ic&ex))])
|
||||||
(define (get-env! lib)
|
(cond [p (set-cdr! p loc)] [else (set-cdr! ic&ex (cons (cons k loc) (cdr ic&ex)))])))
|
||||||
(or (assoc lib *std-lib->alist-env*)
|
|
||||||
(let ([p (cons lib '())])
|
|
||||||
(set! *std-lib->alist-env* (cons p *std-lib->alist-env*))
|
|
||||||
p)))
|
|
||||||
(let loop ([name (car r)] [keys (cdr r)])
|
(let loop ([name (car r)] [keys (cdr r)])
|
||||||
(cond
|
(cond [(null? keys) ; all go to (repl)
|
||||||
[(null? keys) ; all go to (repl)
|
(put-loc! (get-env! '(repl)) name (root-environment name 'ref))]
|
||||||
(put-loc! (get-env! '(repl)) name (root-environment name 'ref))]
|
[else
|
||||||
[else
|
(put-loc! (get-env! (key->lib (car keys))) name (root-environment name 'ref))
|
||||||
(put-loc! (get-env! (key->lib (car keys))) name (root-environment name 'ref))
|
(loop name (cdr keys))])))
|
||||||
(loop name (cdr keys))])))
|
|
||||||
'((* v b) (+ v b) (- v b) (... v u b) (/ v b) (< v b) (<= v b) (= v b) (=> v u b) (> v b) (>= v b)
|
'((* v b) (+ v b) (- v b) (... v u b) (/ v b) (< v b) (<= v b) (= v b) (=> v u b) (> v b) (>= v b)
|
||||||
(_ b) (abs v b) (and v u b) (append v b) (apply v b) (assoc v b) (assq v b) (assv v b) (begin v u b)
|
(_ b) (abs v b) (and v u b) (append v b) (apply v b) (assoc v b) (assq v b) (assv v b) (begin v u b)
|
||||||
(binary-port? b) (boolean=? b) (boolean? v b) (bytevector b) (bytevector-append b)
|
(binary-port? b) (boolean=? b) (boolean? v b) (bytevector b) (bytevector-append b)
|
||||||
|
@ -1673,35 +1698,16 @@
|
||||||
|
|
||||||
; add std libraries to root env as expand time mappings of library's symbolic name
|
; add std libraries to root env as expand time mappings of library's symbolic name
|
||||||
; to an identifyer-syntax expanding into (quote (<init-code> . <eal>)) form
|
; to an identifyer-syntax expanding into (quote (<init-code> . <eal>)) form
|
||||||
(for-each
|
; NB: later, this will need to be done via auto-allocating denotations!
|
||||||
(let ([syntax-id (new-id 'syntax (make-location 'syntax) #f)])
|
(let ([syntax-id (new-id 'syntax (make-location 'syntax) #f)])
|
||||||
|
(for-each
|
||||||
(lambda (p)
|
(lambda (p)
|
||||||
(let* ([lib (car p)] [eal (cdr p)] [sym (listname->symbol lib)])
|
(let* ([sym (car p)] [ic&ex (cdr p)])
|
||||||
(define (libid-transformer sexp env)
|
(define (libid-transformer sexp env)
|
||||||
(list syntax-id (list 'quote (cons '(begin) eal))))
|
(list syntax-id (list 'quote ic&ex)))
|
||||||
(define-in-root-environment! sym
|
(define-in-root-environment! sym
|
||||||
(make-location libid-transformer) #t))))
|
(make-location libid-transformer) #t)))
|
||||||
*std-lib->alist-env*)
|
*library-registry*))
|
||||||
|
|
||||||
#|
|
|
||||||
(define (std-lib->alist-env lib)
|
|
||||||
(cond [(assoc lib *std-lib->alist-env*) => cdr]
|
|
||||||
[else #f]))
|
|
||||||
|
|
||||||
(define (std-lib->env lib)
|
|
||||||
(cond [(std-lib->alist-env lib) =>
|
|
||||||
(lambda (al)
|
|
||||||
(lambda (id at)
|
|
||||||
(and (eq? at 'ref)
|
|
||||||
(let ([p (assq id al)])
|
|
||||||
(if p (cdr p) #f)))))]
|
|
||||||
[else #f]))
|
|
||||||
|#
|
|
||||||
|
|
||||||
|
|
||||||
;---------------------------------------------------------------------------------------------
|
|
||||||
; Library processing
|
|
||||||
;---------------------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
49
t.c
49
t.c
|
@ -747,6 +747,20 @@ char *t_code[] = {
|
||||||
":2cA8,@(y14:string-append*)[01},@(y34:file-resolve-relative-to-base-pa"
|
":2cA8,@(y14:string-append*)[01},@(y34:file-resolve-relative-to-base-pa"
|
||||||
"th)[22}.!0.0^_1[42",
|
"th)[22}.!0.0^_1[42",
|
||||||
|
|
||||||
|
"P", "symbol-libname?",
|
||||||
|
"%1.0X4,.0S3,.0,'6<?{'(cl),'0,.3S4C=?{'(ci),'1,.3S4C=?{'(cb),'2,.3S4C=?"
|
||||||
|
"{'(c:),'3,.3S4C=?{'(c/),'4,.3S4C=?{'(c/),'5,.3S4C=?{.0,'6,.3S7]3}f]3}f"
|
||||||
|
"]3}f]3}f]3}f]3}f]3}f]3",
|
||||||
|
|
||||||
|
"P", "symbol->listname",
|
||||||
|
"%1n,${.3,@(y15:symbol-libname?)[01},,#0.0,&1{%2.0~?{.1p?{.1A9]2}f]2}.0"
|
||||||
|
",'(c/)S8,.0?{.0,.3,.1,'0,.5S7X5c,.3S3,'1,.3+,.5S7,:0^[42}.2,.2X5c,f,:0"
|
||||||
|
"^[32}.!0.0^_1[12",
|
||||||
|
|
||||||
|
"P", "libname->path",
|
||||||
|
"%3.0Y0?{${.2,@(y16:symbol->listname)[01}}{.0},${.2,@(y7:list1+?)[01}?{"
|
||||||
|
".3,.3,.2,@(y14:listname->path)[43}f]4",
|
||||||
|
|
||||||
"C", 0,
|
"C", 0,
|
||||||
"'(l1:s2:./;)@!(y19:*library-path-list*)",
|
"'(l1:s2:./;)@!(y19:*library-path-list*)",
|
||||||
|
|
||||||
|
@ -757,7 +771,7 @@ char *t_code[] = {
|
||||||
|
|
||||||
"P", "find-library-path",
|
"P", "find-library-path",
|
||||||
"%1@(y19:*library-path-list*),,#0.0,.3,&2{%1.0p?{${'(s4:.sld),.3a,:0,@("
|
"%1@(y19:*library-path-list*),,#0.0,.3,&2{%1.0p?{${'(s4:.sld),.3a,:0,@("
|
||||||
"y14:listname->path)[03},.0?{.0F0}{f}?{.0]2}.1d,:1^[21}f]1}.!0.0^_1[11",
|
"y13:libname->path)[03},.0?{.0F0}{f}?{.0]2}.1d,:1^[21}f]1}.!0.0^_1[11",
|
||||||
|
|
||||||
"P", "read-file-sexps",
|
"P", "read-file-sexps",
|
||||||
"%2.1,&1{%1:0?{t,.1P79}n,,#0.2,.1,&2{%1${:1,@(y14:read-code-sexp)[01},."
|
"%2.1,&1{%1:0?{t,.1P79}n,,#0.2,.1,&2{%1${:1,@(y14:read-code-sexp)[01},."
|
||||||
|
@ -765,9 +779,9 @@ char *t_code[] = {
|
||||||
"22",
|
"22",
|
||||||
|
|
||||||
"P", "library-available?",
|
"P", "library-available?",
|
||||||
"%1@(y20:*std-lib->alist-env*),.1A5?{t]1}.0S0?{.0,@(y32:file-resolve-re"
|
"%1.0S0?{.0,@(y32:file-resolve-relative-to-current)[11}${f,.3,@(y12:lib"
|
||||||
"lative-to-current)[11}.0p?{.0L0}{f}?{.0,@(y17:find-library-path)[11}f]"
|
"rary-info)[02}?{t]1}.0Y0,.0?{.0}{${.3,@(y7:list1+?)[01}}_1?{.0,@(y17:f"
|
||||||
"1",
|
"ind-library-path)[11}f]1",
|
||||||
|
|
||||||
"P", "fully-qualified-library-prefixed-name",
|
"P", "fully-qualified-library-prefixed-name",
|
||||||
"%2.1,'(y1:?),.2Y0?{.2}{${.4,@(y16:listname->symbol)[01}},@(y13:symbol-"
|
"%2.1,'(y1:?),.2Y0?{.2}{${.4,@(y16:listname->symbol)[01}},@(y13:symbol-"
|
||||||
|
@ -813,7 +827,12 @@ char *t_code[] = {
|
||||||
"%2.1,@(y18:*root-environment*),.2,@(y10:env-lookup)[23",
|
"%2.1,@(y18:*root-environment*),.2,@(y10:env-lookup)[23",
|
||||||
|
|
||||||
"C", 0,
|
"C", 0,
|
||||||
"n@!(y20:*std-lib->alist-env*)",
|
"n@!(y18:*library-registry*)",
|
||||||
|
|
||||||
|
"P", "library-info",
|
||||||
|
"%2.0Y0?{.0}{${.2,@(y16:listname->symbol)[01}},@(y18:*library-registry*"
|
||||||
|
"),.1A3,.0?{.0d]4}.3~?{f]4}n,'(l1:y5:begin;)c,@(y18:*library-registry*)"
|
||||||
|
",.1,.4cc@!(y18:*library-registry*).0]5",
|
||||||
|
|
||||||
"C", 0,
|
"C", 0,
|
||||||
"${'(l343:l3:y1:*;y1:v;y1:b;;l3:y1:+;y1:v;y1:b;;l3:y1:-;y1:v;y1:b;;l4:y"
|
"${'(l343:l3:y1:*;y1:v;y1:b;;l3:y1:+;y1:v;y1:b;;l3:y1:-;y1:v;y1:b;;l4:y"
|
||||||
|
@ -956,19 +975,17 @@ char *t_code[] = {
|
||||||
"e),.1v?{'(l2:y6:scheme;y4:eval;)]2}'(y1:o),.1v?{'(l2:y6:scheme;y7:comp"
|
"e),.1v?{'(l2:y6:scheme;y4:eval;)]2}'(y1:o),.1v?{'(l2:y6:scheme;y7:comp"
|
||||||
"lex;)]2}'(y1:h),.1v?{'(l2:y6:scheme;y4:char;)]2}'(y1:l),.1v?{'(l2:y6:s"
|
"lex;)]2}'(y1:h),.1v?{'(l2:y6:scheme;y4:char;)]2}'(y1:l),.1v?{'(l2:y6:s"
|
||||||
"cheme;y11:case-lambda;)]2}'(y1:x),.1v?{'(l2:y6:scheme;y3:cxr;)]2}'(y1:"
|
"cheme;y11:case-lambda;)]2}'(y1:x),.1v?{'(l2:y6:scheme;y3:cxr;)]2}'(y1:"
|
||||||
"b),.1v?{'(l2:y6:scheme;y4:base;)]2}]2}.!0&0{%3.0d,.2A3,.0?{.3,.1sd]4}."
|
"b),.1v?{'(l2:y6:scheme;y4:base;)]2}]2}.!0&0{%1t,.1,@(y12:library-info)"
|
||||||
"1d,.4,.4cc,.2sd]4}.!1&0{%1@(y20:*std-lib->alist-env*),.1A5,.0?{.0]2}n,"
|
"[12}.!1&0{%3.0d,.2A3,.0?{.3,.1sd]4}.1d,.4,.4cc,.2sd]4}.!2.3d,.4a,,#0.0"
|
||||||
".2c,@(y20:*std-lib->alist-env*),.1c@!(y20:*std-lib->alist-env*).0]3}.!"
|
",.6,.5,.7,&4{%2.1u?{${'(y3:ref),.3,@(y16:root-environment)[02},.1,${'("
|
||||||
"2.3d,.4a,,#0.0,.5,.5,.8,&4{%2.1u?{${'(y3:ref),.3,@(y16:root-environmen"
|
"l1:y4:repl;),:0^[01},:2^[23}${${'(y3:ref),.5,@(y16:root-environment)[0"
|
||||||
"t)[02},.1,${'(l1:y4:repl;),:0^[01},:2^[23}${${'(y3:ref),.5,@(y16:root-"
|
"2},.3,${${.9a,:1^[01},:0^[01},:2^[03}.1d,.1,:3^[22}.!0.0^_1[42},@(y10:"
|
||||||
"environment)[02},.3,${${.9a,:1^[01},:0^[01},:2^[03}.1d,.1,:3^[22}.!0.0"
|
"%25for-each1)[02}",
|
||||||
"^_1[42},@(y10:%25for-each1)[02}",
|
|
||||||
|
|
||||||
"C", 0,
|
"C", 0,
|
||||||
"${@(y20:*std-lib->alist-env*),${f,'(y6:syntax)b,'(y6:syntax),@(y6:new-"
|
"${f,'(y6:syntax)b,'(y6:syntax),@(y6:new-id)[03},${@(y18:*library-regis"
|
||||||
"id)[03},.0,&1{%1.0a,.1d,${.3,@(y16:listname->symbol)[01},,#0.2,:0,&2{%"
|
"try*),.3,&1{%1.0a,.1d,,#0.1,:0,&2{%2:1,'(y5:quote),l2,:0,l2]2}.!0t,.1^"
|
||||||
"2:1,'(l1:y5:begin;)c,'(y5:quote),l2,:0,l2]2}.!0t,.1^b,.3,@(y27:define-"
|
"b,.4,@(y27:define-in-root-environment!)[43},@(y10:%25for-each1)[02}_1",
|
||||||
"in-root-environment!)[53}_1,@(y10:%25for-each1)[02}",
|
|
||||||
|
|
||||||
"C", 0,
|
"C", 0,
|
||||||
"f@!(y9:*verbose*)",
|
"f@!(y9:*verbose*)",
|
||||||
|
|
Loading…
Reference in a new issue