diff options
author | Jeff Johnston <jjohnstn@redhat.com> | 2002-05-23 22:05:54 +0000 |
---|---|---|
committer | Jeff Johnston <jjohnstn@redhat.com> | 2002-05-23 22:05:54 +0000 |
commit | 164ee5b054159adfb4acb394ca8a0760f67d63a2 (patch) | |
tree | 9ec4a2825db6e46b2329fbf8f16653e209282c40 /newlib/libc/stdio/setbuffer.c | |
parent | b4bb31ad55c8e71e7a6e2568f7fba3f395d513ba (diff) | |
download | newlib-164ee5b054159adfb4acb394ca8a0760f67d63a2.zip newlib-164ee5b054159adfb4acb394ca8a0760f67d63a2.tar.gz newlib-164ee5b054159adfb4acb394ca8a0760f67d63a2.tar.bz2 |
2002-05-23 Gareth Pearce <tilps@hotmail.com>
* libc/stdio/Makefile.am: Modify to add setbuffer.c and setlinebuf.c.
* libc/stdio/Makefile.in: Regenerated.
* libc/stdio/setbuffer.c: New file.
* libc/stdio/setlinebuf.c: New file.
Diffstat (limited to 'newlib/libc/stdio/setbuffer.c')
-rw-r--r-- | newlib/libc/stdio/setbuffer.c | 118 |
1 files changed, 118 insertions, 0 deletions
diff --git a/newlib/libc/stdio/setbuffer.c b/newlib/libc/stdio/setbuffer.c new file mode 100644 index 0000000..c74c7fc --- /dev/null +++ b/newlib/libc/stdio/setbuffer.c @@ -0,0 +1,118 @@ +/* + * Copyright (c) 1990 The Regents of the University of California. + * All rights reserved. + * + * Redistribution and use in source and binary forms are permitted + * provided that the above copyright notice and this paragraph are + * duplicated in all such forms and that any documentation, + * advertising materials, and other materials related to such + * distribution and use acknowledge that the software was developed + * by the University of California, Berkeley. The name of the + * University may not be used to endorse or promote products derived + * from this software without specific prior written permission. + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. + */ + +/* +Modified copy of setbuf.c to support the setbuffer function +defined as part of BSD. +Modifications by Gareth Pearce, 2001. +*/ + +/* +FUNCTION +<<setbuffer>>---specify full buffering for a file or stream with size + +INDEX + setbuffer + +ANSI_SYNOPSIS + #include <stdio.h> + void setbuffer(FILE *<[fp]>, char *<[buf]>, int <[size]>); + +TRAD_SYNOPSIS + #include <stdio.h> + void setbuffer(<[fp]>, <[buf]>, <[size]>) + FILE *<[fp]>; + char *<[buf]>; + int <[size]>; + +DESCRIPTION +<<setbuffer>> specifies that output to the file or stream identified by +<[fp]> should be fully buffered. All output for this file will go to a +buffer (of size <[size]>). Output will be passed on to the host system +only when the buffer is full, or when an input operation intervenes. + +You may, if you wish, supply your own buffer by passing a pointer to +it as the argument <[buf]>. It must have size <[size]>. You can +also use <<NULL>> as the value of <[buf]>, to signal that the +<<setbuffer>> function is to allocate the buffer. + +WARNINGS +You may only use <<setbuffer>> before performing any file operation +other than opening the file. + +If you supply a non-null <[buf]>, you must ensure that the associated +storage continues to be available until you close the stream +identified by <[fp]>. + +RETURNS +<<setbuffer>> does not return a result. + +PORTABILITY +This function comes from BSD not ANSI or POSIX. + +Supporting OS subroutines required: <<close>>, <<fstat>>, <<isatty>>, +<<lseek>>, <<read>>, <<sbrk>>, <<write>>. + + +FUNCTION + +<<setlinebuf>>---specify line buffering for a file or stream + +INDEX + setlinebuf + +ANSI_SYNOPSIS + #include <stdio.h> + void setlinebuf(FILE *<[fp]>); + +TRAD_SYNOPSIS + #include <stdio.h> + void setlinebuf(<[fp]>) + FILE *<[fp]>; + +DESCRIPTION +<<setlinebuf>> specifies that output to the file or stream identified by +<[fp]> should be line buffered. This causes the file or stream to pass +on output to the host system at every newline, as well as when the +buffer is full, or when an input operation intervenes. + +WARNINGS +You may only use <<setlinebuf>> before performing any file operation +other than opening the file. + +RETURNS +<<setlinebuf>> returns as per setvbuf. + +PORTABILITY +This function comes from BSD not ANSI or POSIX. + +Supporting OS subroutines required: <<close>>, <<fstat>>, <<isatty>>, +<<lseek>>, <<read>>, <<sbrk>>, <<write>>. +*/ + +#include <_ansi.h> +#include <stdio.h> +#include "local.h" + +void +_DEFUN (setbuffer, (fp, buf, size), + FILE * fp _AND + char *buf _AND + int size) +{ + (void) setvbuf (fp, buf, buf ? _IOFBF : _IONBF, (size_t) size); +} |