summary refs log tree commit diff
path: root/doc/zlib/gzseek.3
blob: cd85fd4caad596700df02e3dc4a4cb96fbfbcb3a (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 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
f authors matchJune McEnroe There are probably better things to sort by but title definitely always exists. 2021-09-13Swap-remove tags as they're foundJune McEnroe This makes it even faster. From ~1s on a sqlite3.c amalgamation to ~0.85s. 2021-09-12Replace htagml regex with strncmpJune McEnroe Since ctags only ever produces regular expressions of the form /^re$/ or /^re/ with no other special characters, instead unescape the pattern and simply use strncmp. Running on a sqlite3.c amalgamation, the regex version takes ~37s while the strncmp version takes ~1s, producing identical output. Big win! 2021-09-11Also defer printing comment for lone close-parensJune McEnroe 2021-09-10Publish "git-comment"June McEnroe 2021-09-10Add git comment --pretty optionJune McEnroe 2021-09-08Defer printing comment if line is blank or closing braceJune McEnroe This fixes badly indented comments. 2021-09-08Up default min-repeat to 30 linesJune McEnroe 2021-09-08Handle dirty lines in git-commentJune McEnroe 2021-09-08Document and install git-commentJune McEnroe 2021-09-08Add repeat and all options to git-commentJune McEnroe 2021-09-08Add group threshold to git-commentJune McEnroe