summary refs log tree commit diff
path: root/doc/zlib/gzfread.3
blob: 66231cc345c5e7305dc3e3e9d5e8ca137c50984d (plain) (blame)
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
.Dd January 15, 2017
.Dt GZFREAD 3
.Os
.
.Sh NAME
.Nm gzfread
.Nd read from compressed file
.
.Sh LIBRARY
.Lb libz
.
.Sh SYNOPSIS
.In zlib.h
.Ft z_size_t
.Fn gzfread "voidp buf" "z_size_t size" "z_size_t nitems" "gzFile file"
.
.Sh DESCRIPTION
Read up to
.Fa nitems
of size
.Fa size
from
.Fa file
to
.Fa buf ,
otherwise operating as
.Xr gzread 3
does.
This duplicates the interface of stdio's
.Xr fread 3 ,
with
.Vt size_t
request and return types.
If the library defines
.Vt size_t ,
then
.Vt z_size_t
is identical to
.Vt size_t .
If not,
then
.Vt z_size_t
is an unsigned integer type
that can contain a pointer.
.
.Pp
In the event that the end of file is reached
and only a partial item is available at the end,
i.e. the remaining uncompressed data length
is not a multiple of
.Fa size ,
then the file partial item
is nevertheless read into
.Fa buf
and the end-of-file flag is set.
The length of the partial item read
is not provided,
but could be inferred from the result of
.Xr gztell 3 .
This behavior is the same as the behavior of
.Xr fread 3
implementations in common libraries,
but it prevents the direct use of
.Fn gzfread
to read a concurrently written file,
reseting and retrying on end-of-file,
when
.Fa size
is not 1.
.
.Sh RETURN VALUES
.Fn gzfread
returns the number of full items read of size
.Fa size ,
or zero if the end of the file was reached
and a full item could not be read,
or if there was an error.
.Xr gzerror 3
must be consulted if zero is returned
in order to determine if there was an error.
If the multiplication of
.Fa size
and
.Fa nitems
overflows,
i.e. the product does not fit in
.Vt z_size_t ,
then nothing is read,
zero is returned,
and the error state is set to
.Dv Z_STREAM_ERROR .
.
.Sh SEE ALSO
.Xr gzeof 3 ,
.Xr gzerror 3 ,
.Xr gzopen 3 ,
.Xr gzread 3
.
.Sh HISTORY
This manual page was converted from
.In zlib.h
to mdoc format by
.An C. McEnroe Aq Mt june@causal.agency .
.
.Sh AUTHORS
.An Jean-loup Gailly Aq Mt jloup@gzip.org
.An Mark Adler Aq Mt madler@alumni.caltech.edu
ghlight'> This feels more comfortable. 2021-02-08Use xsel in up and add it do install.shJune McEnroe 2021-02-07Swap root window coloursJune McEnroe 2021-02-07Add -X flag to install X stuff on OpenBSDJune McEnroe 2021-02-07Adjust brightness by smaller incrementsJune McEnroe 2021-02-07Fix cwm window cycling, move big by defaultJune McEnroe 2021-02-07Use class names for Foreground, Background, BorderColorJune McEnroe I'm not really sure what difference this makes, but it seems like the right thing to do to be generic? 2021-02-07Add simple battery status and clock to xsessionJune McEnroe I love how simple this is. 2021-02-07Set cursor theme and sizeJune McEnroe 2021-02-07Use scrot for up -s if no screencaptureJune McEnroe Still missing putting the URL in an X selection. 2021-02-07Enable mouse acceleration in XJune McEnroe 2021-02-07Set colours for Xt and cwmJune McEnroe And increase XTerm internalBorder. 2021-02-07Set urgency on bell in xtermJune McEnroe 2021-02-07Add bindings for brightness controlJune McEnroe Weirdly the Fn key doesn't change how the F row registers... I wonder if I can do something about that. 2021-02-07Set X key repeat rateJune McEnroe 2021-02-07Bump font size to 12June McEnroe 11 is what I use on macOS, but I feel like my eyes are working harder here. 2021-02-07Fully configure and rebind cwmJune McEnroe This is sort of a mix of trying to emulate macOS somewhat for my muscle memory and just rebinding some of the cwm defaults to use 4- rather than M-. 2021-02-07Add BintiJune McEnroe 2021-02-07Finish configuring xtermJune McEnroe 2021-02-06Enable tapping, reverse scroll, set scaling in wsconsctlJune McEnroe 2021-02-06Set root window to black on purple snowJune McEnroe 2021-02-06Add xmodmap configurationJune McEnroe 2021-02-06Add initial OpenBSD X configurationJune McEnroe cwm still needs a lot more rebinding, and I need to actually look at its other options. xterm definitely still needs some configuration, but I at least managed to get it to use a decent looking font. Very happy that OpenBSD includes Luxi Mono, which is what my usual font, Go Mono, is based on anyway. Still missing is xmodmap and such. 2021-02-06Add xterm output to schemeJune McEnroe