summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndy Wingo <wingo@pobox.com>2021-01-12 11:45:39 +0100
committerAndy Wingo <wingo@pobox.com>2021-01-12 12:08:12 +0100
commit9fecf20fcf1bac764b3d812e07ed4a4a56be52a2 (patch)
treef4e8469394d1dd5e5f2fea9dee002f34ba47203c
parenta20ef7e7698582445f5e596c7c0e67dcd3915e32 (diff)
downloadguile-9fecf20fcf1bac764b3d812e07ed4a4a56be52a2.tar.gz
Close accumulating output ports after use
* module/ice-9/ports.scm (call-with-port): New procedure, from r7rs. (call-with-input-file, call-with-output-file): Refactor to use call-with-port. (call-with-output-string): Close the string after normal exit. * module/scheme/base.scm (scheme): Re-export call-with-port from base.
-rw-r--r--module/ice-9/ports.scm40
-rw-r--r--module/scheme/base.scm15
2 files changed, 25 insertions, 30 deletions
diff --git a/module/ice-9/ports.scm b/module/ice-9/ports.scm
index dbc7ef7a7..b219feeae 100644
--- a/module/ice-9/ports.scm
+++ b/module/ice-9/ports.scm
@@ -1,5 +1,5 @@
;;; Ports
-;;; Copyright (C) 2016, 2019 Free Software Foundation, Inc.
+;;; Copyright (C) 2016,2019,2021 Free Software Foundation, Inc.
;;;
;;; This library is free software: you can redistribute it and/or modify
;;; it under the terms of the GNU Lesser General Public License as
@@ -107,6 +107,7 @@
open-input-file
open-output-file
open-io-file
+ call-with-port
call-with-input-file
call-with-output-file
with-input-from-port
@@ -425,6 +426,15 @@ file with the given name already exists, the effect is unspecified."
"Open file with name STR for both input and output."
(open-file str OPEN_BOTH))
+(define (call-with-port port proc)
+ "Call @var{proc}, passing it @var{port} and closing @var{port} upon exit of
+@var{proc}. Return the return values of @var{proc}."
+ (call-with-values
+ (lambda () (proc port))
+ (lambda vals
+ (close-port port)
+ (apply values vals))))
+
(define* (call-with-input-file
file proc #:key (binary #f) (encoding #f) (guess-encoding #f))
"PROC should be a procedure of one argument, and FILE should be a
@@ -441,11 +451,7 @@ never again be used for a read or write operation."
#:binary binary
#:encoding encoding
#:guess-encoding guess-encoding)))
- (call-with-values
- (lambda () (proc p))
- (lambda vals
- (close-input-port p)
- (apply values vals)))))
+ (call-with-port p proc)))
(define* (call-with-output-file file proc #:key (binary #f) (encoding #f))
"PROC should be a procedure of one argument, and FILE should be a
@@ -459,11 +465,7 @@ If the procedure does not return, then the port will not be closed
automatically unless it is possible to prove that the port will
never again be used for a read or write operation."
(let ((p (open-output-file file #:binary binary #:encoding encoding)))
- (call-with-values
- (lambda () (proc p))
- (lambda vals
- (close-output-port p)
- (apply values vals)))))
+ (call-with-port p proc)))
(define (with-input-from-port port thunk)
(parameterize ((current-input-port port))
@@ -525,9 +527,9 @@ procedures, their behavior is implementation dependent."
#:encoding encoding))
(define (call-with-input-string string proc)
- "Calls the one-argument procedure @var{proc} with a newly created
-input port from which @var{string}'s contents may be read. The value
-yielded by the @var{proc} is returned."
+ "Call the one-argument procedure @var{proc} with a newly created input
+port from which @var{string}'s contents may be read. All values yielded
+by the @var{proc} are returned."
(proc (open-input-string string)))
(define (with-input-from-string string thunk)
@@ -543,12 +545,14 @@ procedures, their behavior is implementation dependent."
(lambda (p) (with-input-from-port p thunk))))
(define (call-with-output-string proc)
- "Calls the one-argument procedure @var{proc} with a newly created output
-port. When the function returns, the string composed of the characters
-written into the port is returned."
+ "Call the one-argument procedure @var{proc} with a newly created
+output port. When the function returns, port is closed and the string
+composed of the characters written into the port is returned."
(let ((port (open-output-string)))
(proc port)
- (get-output-string port)))
+ (let ((res (get-output-string port)))
+ (close-port port)
+ res)))
(define (with-output-to-string thunk)
"Calls THUNK and returns its output as a string."
diff --git a/module/scheme/base.scm b/module/scheme/base.scm
index 5a366f846..b97259f18 100644
--- a/module/scheme/base.scm
+++ b/module/scheme/base.scm
@@ -1,5 +1,5 @@
;;; R7RS compatibility libraries
-;;; Copyright (C) 2019-2020 Free Software Foundation, Inc.
+;;; Copyright (C) 2019-2021 Free Software Foundation, Inc.
;;;
;;; This library is free software: you can redistribute it and/or modify
;;; it under the terms of the GNU Lesser General Public License as
@@ -34,6 +34,7 @@
#:use-module (srfi srfi-11)
#:use-module (ice-9 exceptions)
#:use-module ((srfi srfi-34) #:select (guard))
+ #:use-module (ice-9 ports)
#:use-module (ice-9 textual-ports)
#:use-module (ice-9 binary-ports)
#:use-module (rnrs bytevectors)
@@ -65,7 +66,6 @@
square
(r7:expt . expt)
boolean=? symbol=?
- call-with-port
features
input-port-open? output-port-open?)
#:re-export
@@ -75,7 +75,7 @@
boolean?
bytevector-length
bytevector-u8-ref bytevector-u8-set! bytevector? caar cadr
- call-with-current-continuation call-with-values
+ call-with-current-continuation call-with-port call-with-values
call/cc car case cdar cddr cdr ceiling char->integer char-ready?
char<=? char<? char=? char>=? char>? char? close-input-port
close-output-port close-port complex? cond cons
@@ -565,15 +565,6 @@ defaults to 0 and SEND defaults to the length of SOURCE."
(exact->inexact (expt x y))
(expt x y)))
-(define (call-with-port port proc)
- "Call @var{proc}, passing it @var{port} and closing @var{port} upon exit of
-@var{proc}. Return the return values of @var{proc}."
- (call-with-values
- (lambda () (proc port))
- (lambda vals
- (close-port port)
- (apply values vals))))
-
(define (features)
(append
(case (native-endianness)