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
70
71
72
73
74
75
76
77
78
79
80
81
|
/* fwrite( void *, size_t, size_t, 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>
#include <string.h>
#ifndef REGTEST
#include "pdclib/_PDCLIB_glue.h"
size_t fread( void * _PDCLIB_restrict ptr, size_t size, size_t nmemb, struct _PDCLIB_file_t * _PDCLIB_restrict stream )
{
char * dest = (char *)ptr;
size_t nmemb_i;
if ( _PDCLIB_prepread( stream ) == EOF )
{
return 0;
}
for ( nmemb_i = 0; nmemb_i < nmemb; ++nmemb_i )
{
size_t size_i;
for ( size_i = 0; size_i < size; ++size_i )
{
if ( stream->bufidx == stream->bufend )
{
if ( _PDCLIB_fillbuffer( stream ) == EOF )
{
/* Could not read requested data */
return nmemb_i;
}
}
dest[ nmemb_i * size + size_i ] = stream->buffer[ stream->bufidx++ ];
}
}
return nmemb_i;
}
#endif
#ifdef TEST
#include "_PDCLIB_test.h"
int main( void )
{
FILE * fh;
const char * message = "Testing fwrite()...\n";
char buffer[21];
buffer[20] = 'x';
TESTCASE( ( fh = tmpfile() ) != NULL );
/* fwrite() / readback */
TESTCASE( fwrite( message, 1, 20, fh ) == 20 );
rewind( fh );
TESTCASE( fread( buffer, 1, 20, fh ) == 20 );
TESTCASE( memcmp( buffer, message, 20 ) == 0 );
TESTCASE( buffer[20] == 'x' );
/* same, different nmemb / size settings */
rewind( fh );
TESTCASE( memset( buffer, '\0', 20 ) == buffer );
TESTCASE( fwrite( message, 5, 4, fh ) == 4 );
rewind( fh );
TESTCASE( fread( buffer, 5, 4, fh ) == 4 );
TESTCASE( memcmp( buffer, message, 20 ) == 0 );
TESTCASE( buffer[20] == 'x' );
/* same... */
rewind( fh );
TESTCASE( memset( buffer, '\0', 20 ) == buffer );
TESTCASE( fwrite( message, 20, 1, fh ) == 1 );
rewind( fh );
TESTCASE( fread( buffer, 20, 1, fh ) == 1 );
TESTCASE( memcmp( buffer, message, 20 ) == 0 );
TESTCASE( buffer[20] == 'x' );
/* Done. */
TESTCASE( fclose( fh ) == 0 );
return TEST_RESULTS;
}
#endif
|