]> sourceware.org Git - glibc.git/commitdiff
Document limitations on streams passed to freopen
authorJoseph Myers <josmyers@redhat.com>
Fri, 6 Sep 2024 20:38:23 +0000 (20:38 +0000)
committerJoseph Myers <josmyers@redhat.com>
Fri, 6 Sep 2024 20:38:23 +0000 (20:38 +0000)
As recently discussed, document that freopen does not work with
streams opened with functions such as popen, fmemopen, open_memstream
or fopencookie.  I've filed
<https://austingroupbugs.net/view.php?id=1855> to clarify this issue
in POSIX.

Tested with "make info" and "make html".

manual/stdio.texi

index 29888a361f1d356fac83817fb587c1c3f1c52fbb..8590ae955a9cb028e36e17dd15961cc2a106f23e 100644 (file)
@@ -330,6 +330,14 @@ this ability, so using @code{freopen} is more portable.
 When the sources are compiled with @code{_FILE_OFFSET_BITS == 64} on a
 32 bit machine this function is in fact @code{freopen64} since the LFS
 interface replaces transparently the old interface.
+
+@Theglibc{} only supports use of @code{freopen} on streams opened with
+@code{fopen} or @code{fopen64} and on the original values of the
+standard streams @code{stdin}, @code{stdout}, and @code{stderr}; such
+a stream may be reopened multiple times with @code{freopen}.  If it is
+called on another kind of stream (opened with functions such as
+@code{popen}, @code{fmemopen}, @code{open_memstream}, and
+@code{fopencookie}), @code{freopen} fails and returns a null pointer.
 @end deftypefun
 
 @deftypefun {FILE *} freopen64 (const char *@var{filename}, const char *@var{opentype}, FILE *@var{stream})
This page took 0.039112 seconds and 5 git commands to generate.