summary refs log tree commit diff
path: root/doc/zlib/gzseek.3
blob: a14b2db6d6fa834d1b87c2ea2f1046507dd0dfd6 (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
108
.Dd January 15, 2017
.Dt GZSEEK 3
.Os
.
.Sh NAME
.Nm gzseek ,
.Nm gzrewind ,
.Nm gztell
.Nd seek compressed file
.
.Sh LIBRARY
.Lb libz
.
.Sh SYNOPSIS
.In zlib.h
.Ft z_off_t
.Fn gzseek "gzFile file" "z_off_t offset" "int whence"
.Ft int
.Fn gzrewind "gzFile file"
.Ft z_off_t
.Fn gztell "gzFile file"
.
.Sh DESCRIPTION
Sets the starting position
for the next
.Xr gzread 3
or
.Xr gzwrite 3
on the given compressed file.
The
.Fa offset
represents a number of bytes
in the uncompressed data stream.
The
.Fa whence
parameter
is defined as in
.Xr lseek 2 ;
the value
.Dv SEEK_END
is not supported.
.
.Pp
If the file is opened for reading,
this function is emulated
but can be extremely slow.
If the file is opened for writing,
only forward seeks are supported;
.Fn gzseek
then compresses a sequence of zeroes
up to the new starting position.
.
.Pp
.Fn gzrewind
rewinds the given file.
This function is supported
only for reading.
.
.Pp
.Fn gzrewind file
is equivalent to
.Li (int) Ns Fn gzseek file 0L SEEK_SET .
.
.Pp
.Fn gztell
returns the starting position
for the next
.Xr gzread 3
or
.Xr gzwrite 3
on the given compressed file.
This position represents a number of bytes
in the uncompressed data stream,
and is zero when starting,
even if appending or reading
a gzip stream from the middle of a file using
.Xr gzdopen 3 .
.
.Pp
.Fn gztell file
is equivalent to
.Fn gzseek file 0L SEEK_CUR .
.
.Sh RETURN VALUES
.Fn gzseek
returns the resulting offset location
as measured in bytes
from the beginning of the uncompressed stream,
or -1 in case of error,
in particular if the file
is opened for writing
and the new starting position
would be before the current position.
.
.Sh SEE ALSO
.Xr gzerror 3 ,
.Xr gzoffset 3 ,
.Xr gzopen 3
.
.Sh HISTORY
This manual page was converted from
.In zlib.h
to mdoc format by
.An June 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
;follow=1'>Publish "Using vi"June McEnroe 2021-01-11Enable diff.colorMovedJune McEnroe 2021-01-10Set less search case-insensitiveJune McEnroe 2021-01-10Set EXINITJune McEnroe neovim is laggy as hell in my OpenBSD VM, so I switched to vi so I could type without getting frustrated. 2021-01-09Add c -t flag to print expression typeJune McEnroe Also add missing float case. 2021-01-05Update taglineJune McEnroe