blob: a5d7e5668b9324b00018a8e0ce2ba3e935d1bebb (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
/* fputs( const char *, FILE * )
This file is part of the Public Domain C Library (PDCLib).
Permission is granted to use, modify, and / or redistribute at will.
*/
#include <stdio.h>
#ifndef REGTEST
#include "pdclib/_PDCLIB_glue.h"
int fputs( const char * _PDCLIB_restrict s, struct _PDCLIB_file_t * _PDCLIB_restrict stream )
{
if ( _PDCLIB_prepwrite( stream ) == EOF )
{
return EOF;
}
while ( *s != '\0' )
{
/* Unbuffered and line buffered streams get flushed when fputs() does
write the terminating end-of-line. All streams get flushed if the
buffer runs full.
*/
stream->buffer[ stream->bufidx++ ] = *s;
if ( ( stream->bufidx == stream->bufsize ) ||
( ( stream->status & _IOLBF ) && *s == '\n' )
)
{
if ( _PDCLIB_flushbuffer( stream ) == EOF )
{
return EOF;
}
}
++s;
}
if ( stream->status & _IONBF )
{
if ( _PDCLIB_flushbuffer( stream ) == EOF )
{
return EOF;
}
}
return 0;
}
#endif
#ifdef TEST
#include "_PDCLIB_test.h"
int main( void )
{
const char * const message = "SUCCESS testing fputs()";
FILE * fh;
size_t i;
TESTCASE( ( fh = tmpfile() ) != NULL );
TESTCASE( fputs( message, fh ) >= 0 );
rewind( fh );
for ( i = 0; i < 23; ++i )
{
TESTCASE( fgetc( fh ) == message[i] );
}
TESTCASE( fclose( fh ) == 0 );
return TEST_RESULTS;
}
#endif
|