Subject: [PATCH] fopen.3: Explain BSD vs glibc "a+" difference.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Where is the initial read position for an "a+" stream?

POSIX leaves this unspecified. Most BSD man pages are silent, and MacOS
has the ambiguous "The stream is positioned at the end of the file", not
differentiating between reads and writes other than to say that fseek(3)
does not affect writes. glibc's documentation explicitly specifies that
the initial read position is the beginning of the file.

My new wording is based on the BSD implementations, so you may prefer
to replace the non-glibc section with "unspecified", or indeed remove
all claims about the initial read position.
---
 man3/fopen.3 | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)

diff --git a/man3/fopen.3 b/man3/fopen.3
index a0f564c39..5f4abb8ea 100644
--- a/man3/fopen.3
+++ b/man3/fopen.3
@@ -100,8 +100,10 @@ The stream is positioned at the end of the file.
 .B a+
 Open for reading and appending (writing at end of file).
 The file is created if it does not exist.
-The initial file position for reading is at the beginning of the file,
-but output is always appended to the end of the file.
+Output is always appended to the end of the file.
+For glibc, the initial file position for reading is at
+the beginning of the file, but for Android/BSD/MacOS, the
+initial file position for reading is the end of the file.
 .PP
 The
 .I mode
-- 
2.21.0.392.gf8f6787159e-goog



[Index of Archives]     [Kernel Documentation]     [Netdev]     [Linux Ethernet Bridging]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux