* [devel] zlib/gzio.c: inconsistent gzeof()
@ 2008-03-06 12:25 Alexey Tourbin
2008-03-06 12:54 ` Alexey Tourbin
0 siblings, 1 reply; 2+ messages in thread
From: Alexey Tourbin @ 2008-03-06 12:25 UTC (permalink / raw)
To: devel
[-- Attachment #1: Type: text/plain, Size: 897 bytes --]
Я обнаружил, что gzeof() ведёт себя по-разному, в зависимости от того,
находимся ли мы режиме "transparent" (cat) или же в режиме настоящего
разжатия.
А именно, в режиме настоящего разжатия, если прочитано батйтов меньше,
чем запрошено, то (автоматически) выставляется флаг EOF. В transparent
режиме, если прочитано меньше, чем требуется, то флаг EOF выставляется
только после следующего gzread(), который возвращает 0.
$ cat test.c
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <zlib.h>
int main(int argc, char *argv[])
{
gzFile gz = gzopen(argv[1], "rb");
assert(gz);
char buf[BUFSIZ];
int n = gzread(gz, buf, sizeof(buf));
printf("n=%d eof=%d\n", n, gzeof(gz));
return 0;
}
$ echo a >a
$ echo a |gzip >a.gz
$ gcc -Wall test.c -lz
$ ./a.out a.gz
n=2 eof=1
$ ./a.out a
n=2 eof=0
$
Хотел спросить, надо это фиксить или нет.
[-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --]
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [devel] zlib/gzio.c: inconsistent gzeof()
2008-03-06 12:25 [devel] zlib/gzio.c: inconsistent gzeof() Alexey Tourbin
@ 2008-03-06 12:54 ` Alexey Tourbin
0 siblings, 0 replies; 2+ messages in thread
From: Alexey Tourbin @ 2008-03-06 12:54 UTC (permalink / raw)
To: devel
[-- Attachment #1: Type: text/plain, Size: 1341 bytes --]
On Thu, Mar 06, 2008 at 03:25:11PM +0300, Alexey Tourbin wrote:
> Я обнаружил, что gzeof() ведёт себя по-разному, в зависимости от того,
> находимся ли мы режиме "transparent" (cat) или же в режиме настоящего
> разжатия.
>
> А именно, в режиме настоящего разжатия, если прочитано батйтов меньше,
> чем запрошено, то (автоматически) выставляется флаг EOF. В transparent
> режиме, если прочитано меньше, чем требуется, то флаг EOF выставляется
> только после следующего gzread(), который возвращает 0.
>
> $ cat test.c
> #include <stdio.h>
> #include <stdlib.h>
> #include <assert.h>
> #include <zlib.h>
> int main(int argc, char *argv[])
> {
> gzFile gz = gzopen(argv[1], "rb");
> assert(gz);
>
> char buf[BUFSIZ];
> int n = gzread(gz, buf, sizeof(buf));
> printf("n=%d eof=%d\n", n, gzeof(gz));
>
> return 0;
> }
> $ echo a >a
> $ echo a |gzip >a.gz
> $ gcc -Wall test.c -lz
> $ ./a.out a.gz
> n=2 eof=1
> $ ./a.out a
> n=2 eof=0
> $
>
> Хотел спросить, надо это фиксить или нет.
Ещё одно любопытное обстоятельство: если прочитано ровно столько байтов,
сколько запрошено, то в режиме разжатия gzeof() возвращает 1 (флаг z_eof
на самом деле не установлен, но в gzeof() есть дополнительная проверка
z_err == Z_STREAM_END).
А стандартный feof(3) в этом случае вроде бы возвращает 0.
[-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --]
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2008-03-06 12:54 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-03-06 12:25 [devel] zlib/gzio.c: inconsistent gzeof() Alexey Tourbin
2008-03-06 12:54 ` Alexey Tourbin
ALT Linux Team development discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
public-inbox-index devel
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.devel
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git