12.1.6 String Ports
A string port reads or writes from a byte string. An input string port can be created from either a byte string or a string; in the latter case, the string is effectively converted to a byte string using string->bytes/utf-8. An output string port collects output into a byte string, but get-output-string conveniently converts the accumulated bytes to a string.
Input and output string ports do not need to be explicitly closed. The file-position procedure works for string ports in position-setting mode.
Byte Strings also provides information on bytestrings.
procedure
(open-input-bytes bstr [name]) → input-port?
bstr : bytes? name : any/c = 'string 
| Examples: | ||||||||||||||
| 
 | 
Strings also provides information on strings.
procedure
(open-input-string str [name]) → input-port?
str : string? name : any/c = 'string 
| Examples: | ||||||||||||
| 
 | 
procedure
(open-output-bytes [name]) → output-port?
name : any/c = 'string 
| Examples: | ||||||||||||||||||||||||||||
| 
 | 
procedure
(open-output-string [name]) → output-port?
name : any/c = 'string 
| Examples: | ||||||||||||||||||||||||||||
| 
 | 
procedure
(get-output-bytes out [ reset? start-pos end-pos]) → bytes? out : output-port? reset? : any/c = #f start-pos : exact-nonnegative-integer? = 0 end-pos : exact-nonnegative-integer? = #f 
If reset? is true, then all bytes are removed from the port, and the port’s position is reset to 0; if reset? is #f, then all bytes remain in the port for further accumulation (so they are returned for later calls to get-output-bytes or get-output-string), and the port’s position is unchanged.
The start-pos and end-pos arguments specify the range of bytes in the port to return; supplying start-pos and end-pos is the same as using subbytes on the result of get-output-bytes, but supplying them to get-output-bytes can avoid an allocation. The end-pos argument can be #f, which corresponds to not passing a second argument to subbytes.
| Examples: | ||||||||||||||
| 
 | 
procedure
(get-output-string out) → string?
out : output-port? 
| Examples: | |||||||||||
| 
 |