~ chicken-core (chicken-5) 0f39091c5e21924b087f78eb62b919367a605985
commit 0f39091c5e21924b087f78eb62b919367a605985 Author: Evan Hanson <evhan@foldling.org> AuthorDate: Wed Jan 20 22:14:08 2016 +1300 Commit: Evan Hanson <evhan@foldling.org> CommitDate: Tue Mar 8 22:52:34 2016 +1300 Rename "read-file" to "read-all", drop filename argument handling diff --git a/chicken-install.scm b/chicken-install.scm index 73c60526..a1f2d2c1 100644 --- a/chicken-install.scm +++ b/chicken-install.scm @@ -192,12 +192,12 @@ ((override) (set! *override* (if (and (pair? (cdr x)) (string? (cadr x))) - (read-file (cadr x)) + (call-with-input-file (cadr x) read-all) (cdr x)))) ((hack) (set! *hacks* (append *hacks* (list (eval (cadr x)))))) (else (broken x)))) - (read-file deff)))) + (call-with-input-file deff read-all)))) (pair? *default-sources*) )) (define (resolve-location name) @@ -777,7 +777,7 @@ (delete-duplicates (filter-map (lambda (sf) - (let* ((info (first (read-file sf))) + (let* ((info (first (call-with-input-file sf read-all))) (v (cond ((assq 'version info) => cadr) (else "")))) (cond ((assq 'egg-name info) => @@ -1018,7 +1018,7 @@ EOF (loop (cddr args) eggs)) ((string=? "-override" arg) (unless (pair? (cdr args)) (usage 1)) - (set! *override* (read-file (cadr args))) + (set! *override* (call-with-input-file (cadr args) read-all)) (loop (cddr args) eggs)) ((or (string=? "-x" arg) (string=? "-keep-installed" arg)) (set! *keep-existing* #t) diff --git a/core.scm b/core.scm index ac274b05..a3815b93 100644 --- a/core.scm +++ b/core.scm @@ -560,7 +560,7 @@ (imps (##sys#compiled-module-registration (##sys#current-module))) (oldimps (and (file-exists? fname) - (read-file fname) ) ) ) + (call-with-input-file fname read-all)))) (cond ((equal? imps oldimps) (when verbose-mode (print "not generating import library `" fname "' for module `" diff --git a/extras.scm b/extras.scm index 3b337981..a9421f83 100644 --- a/extras.scm +++ b/extras.scm @@ -30,7 +30,7 @@ (uses data-structures)) (module chicken.io - (read-buffered read-byte read-file read-line + (read-all read-buffered read-byte read-line read-lines read-string read-string! read-token write-byte write-line write-string) @@ -41,18 +41,15 @@ ;;; Read expressions from file: -(define read-file - (let ([read read] - [call-with-input-file call-with-input-file] ) +(define read-all + (let ((read read)) (lambda (#!optional (port ##sys#standard-input) (reader read) max) - (define (slurp port) - (do ((x (reader port) (reader port)) - (i 0 (fx+ i 1)) - (xs '() (cons x xs)) ) - ((or (eof-object? x) (and max (fx>= i max))) (##sys#fast-reverse xs)) ) ) - (if (port? port) - (slurp port) - (call-with-input-file port slurp) ) ) ) ) + (##sys#check-input-port port #t 'read-all) + (do ((x (reader port) (reader port)) + (i 0 (fx+ i 1)) + (xs '() (cons x xs))) + ((or (eof-object? x) (and max (fx>= i max))) + (##sys#fast-reverse xs)))))) ;;; Line I/O: diff --git a/manual/Unit extras b/manual/Unit extras index e66ea6ac..23ff690b 100644 --- a/manual/Unit extras +++ b/manual/Unit extras @@ -133,18 +133,17 @@ These procedures are provided by the {{(chicken io)}} module. Read/write a byte to the port given in {{PORT}}, which default to the values of {{(current-input-port)}} and {{(current-output-port)}}, respectively. -==== read-file - -<procedure>(read-file [FILE-OR-PORT [READER [MAXCOUNT]]])</procedure> - -Returns a list containing all toplevel expressions -read from the file or port {{FILE-OR-PORT}}. If no argument is given, -input is read from the port that is the current value of {{(current-input-port)}}. -After all expressions are read, and if the argument is a port, then the port will -not be closed. The {{READER}} argument specifies the procedure used to read -expressions from the given file or port and defaults to {{read}}. The reader -procedure will be called with a single argument (an input port). -If {{MAXCOUNT}} is given then only up to {{MAXCOUNT}} expressions will be read in. +==== read-all + +<procedure>(read-all [PORT [READER [MAXCOUNT]]])</procedure> + +Returns a list containing all toplevel expressions read from the given +{{PORT}}. If no argument is given, input is read from the value of +{{(current-input-port)}}. The {{READER}} argument specifies the +procedure used to read expressions and defaults to {{read}}. The reader +procedure will be called with a single argument (an input port). If +{{MAXCOUNT}} is given then only up to {{MAXCOUNT}} expressions will be +read in. ==== read-line diff --git a/scripts/reconstruct-egg-name.scm b/scripts/reconstruct-egg-name.scm index c93e4309..8de03fd4 100644 --- a/scripts/reconstruct-egg-name.scm +++ b/scripts/reconstruct-egg-name.scm @@ -41,7 +41,7 @@ (current-directory cd) ) ) ) (define (get-info eggnam #!optional (dir (repository-path))) - (car (read-file (make-pathname dir eggnam +info-extn+))) ) + (car (call-with-input-file (make-pathname dir eggnam +info-extn+) read-all))) (define (put-info info eggnam #!optional (dir (repository-path))) (let ((tmpfil (create-temporary-file))) diff --git a/scripts/setversion b/scripts/setversion index 01660086..f1db588b 100755 --- a/scripts/setversion +++ b/scripts/setversion @@ -5,7 +5,7 @@ exec csi -s "$0" "$@" (use srfi-1 utils posix irregex) -(define buildversion (->string (car (read-file "buildversion")))) +(define buildversion (->string (car (call-with-input-file "buildversion" read-all)))) (define files '("README" "manual/The User's Manual")) diff --git a/scrutinizer.scm b/scrutinizer.scm index 42d4c12e..66331d5e 100644 --- a/scrutinizer.scm +++ b/scrutinizer.scm @@ -1805,7 +1805,7 @@ (mark-variable name '##compiler#type-source 'db) (when specs (install-specializations name specs))))) - (read-file dbfile)) + (call-with-input-file dbfile read-all)) #t))) (define (emit-type-file source-file type-file db block-compilation) diff --git a/support.scm b/support.scm index 8ad6e52b..d1e92a68 100644 --- a/support.scm +++ b/support.scm @@ -1634,7 +1634,7 @@ (##sys#put! id '##core#db (append (or (##sys#get id '##core#db) '()) (list (cdr e))) ))) - (read-file dbfile)))) + (call-with-input-file dbfile read-all)))) ;;; Print version/usage information: diff --git a/types.db b/types.db index 3fb8c28d..c0e7bbda 100644 --- a/types.db +++ b/types.db @@ -1525,9 +1525,9 @@ ;; io +(chicken.io#read-all (#(procedure #:enforce) chicken.io#read-all (#!optional input-port (procedure (input-port) *) fixnum) list)) (chicken.io#read-buffered (#(procedure #:enforce) chicken.io#read-buffered (#!optional input-port) string)) (chicken.io#read-byte (#(procedure #:enforce) chicken.io#read-byte (#!optional input-port) *)) -(chicken.io#read-file (#(procedure #:enforce) chicken.io#read-file (#!optional (or input-port string) (procedure (input-port) *) fixnum) list)) (chicken.io#read-line (#(procedure #:enforce) chicken.io#read-line (#!optional input-port (or false fixnum)) (or eof string))) (chicken.io#read-lines (#(procedure #:enforce) chicken.io#read-lines (#!optional (or input-port string) fixnum) (list-of string))) (chicken.io#read-string (#(procedure #:enforce) chicken.io#read-string (#!optional (or fixnum false) input-port) string))Trap