Main index | Section 3 | Options |
#include <stdio.h>
#include <wchar.h>
Each stream maintains a current position and size. Initially, the position and size are set to zero. Each write begins at the current position and advances it the number of successfully written bytes for open_memstream() or wide characters for open_wmemstream(). If a write moves the current position beyond the length of the buffer, the length of the buffer is extended and a null character is appended to the buffer.
A stream's buffer always contains a null character at the end of the buffer that is not included in the current length.
If a stream's current position is moved beyond the current length via a seek operation and a write is performed, the characters between the current length and the current position are filled with null characters before the write is performed.
After a successful call to fclose(3) or fflush(3), the pointer referenced by bufp will contain the start of the memory buffer and the variable referenced by sizep will contain the smaller of the current position and the current buffer length.
After a successful call to fflush(3), the pointer referenced by bufp and the variable referenced by sizep are only valid until the next write operation or a call to fclose(3).
Once a stream is closed, the allocated buffer referenced by bufp should be released via a call to free(3) when it is no longer needed.
[EINVAL] | |
The bufp or sizep argument was NULL. | |
[ENOMEM] | |
Memory for the stream or buffer could not be allocated. | |
OPEN_MEMSTREAM (3) | August 1, 2015 |
Main index | Section 3 | Options |
Please direct any comments about this manual page service to Ben Bullock. Privacy policy.
“ | Do you laugh when the waiter drops a tray full of dishes? Unix weenies do. They're the first ones to laugh at hapless users, trying to figure out an error message that doesn't have anything to do with what they just typed. | ” |
— The Unix Haters' handbook |