minor fixes

This commit is contained in:
ESL 2024-07-05 01:15:23 -04:00
parent a0e92d14ed
commit 332c3a5539
2 changed files with 9 additions and 7 deletions

View file

@ -1448,9 +1448,10 @@
(c-error "library path should end in directory separator" path))) (c-error "library path should end in directory separator" path)))
(define (find-library-path libname) ;=> name of existing .sld file or #f (define (find-library-path libname) ;=> name of existing .sld file or #f
(define listname (if (symbol? libname) (symbol->listname libname) libname))
(let loop ([l *library-path-list*]) (let loop ([l *library-path-list*])
(and (pair? l) (and (pair? l)
(let ([p (libname->path libname (car l) ".sld")]) (let ([p (listname->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)
@ -1501,9 +1502,9 @@
(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) ;=> #f | filepath (external) | #t (loaded) (define (library-available? lib) ;=> #f | filepath (external) | (code . eal) (loaded)
(cond [(string? lib) (file-resolve-relative-to-current lib)] (cond [(string? lib) (file-resolve-relative-to-current lib)]
[(library-info lib #f) #t] ; builtin or preloaded [(library-info lib #f)] ; builtin or preloaded
[else (and (or (symbol? lib) (list1+? lib)) (find-library-path lib))])) [else (and (or (symbol? lib) (list1+? lib)) (find-library-path lib))]))
; name prefixes ; name prefixes

9
t.c
View file

@ -770,8 +770,9 @@ char *t_code[] = {
"irectory separator),@(y7:c-error)[12", "irectory separator),@(y7:c-error)[12",
"P", "find-library-path", "P", "find-library-path",
"%1@(y19:*library-path-list*),,#0.0,.3,&2{%1.0p?{${'(s4:.sld),.3a,:0,@(" "%1,#0.1Y0?{${.3,@(y16:symbol->listname)[01}}{.1}.!0@(y19:*library-path"
"y13:libname->path)[03},.0?{.0F0}{f}?{.0]2}.1d,:1^[21}f]1}.!0.0^_1[11", "-list*),,#0.0,.4,&2{%1.0p?{${'(s4:.sld),.3a,:0,@(y14:listname->path)[0"
"3},.0?{.0F0}{f}?{.0]2}.1d,:1^[21}f]1}.!0.0^_1[21",
"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},."
@ -780,8 +781,8 @@ char *t_code[] = {
"P", "library-available?", "P", "library-available?",
"%1.0S0?{.0,@(y32:file-resolve-relative-to-current)[11}${f,.3,@(y12:lib" "%1.0S0?{.0,@(y32:file-resolve-relative-to-current)[11}${f,.3,@(y12:lib"
"rary-info)[02}?{t]1}.0Y0,.0?{.0}{${.3,@(y7:list1+?)[01}}_1?{.0,@(y17:f" "rary-info)[02},.0?{.0]2}.1Y0,.0?{.0}{${.4,@(y7:list1+?)[01}}_1?{.1,@(y"
"ind-library-path)[11}f]1", "17:find-library-path)[21}f]2",
"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-"