Re: pg_dump, gzwrite, and errno - Mailing list pgsql-hackers

From Alvaro Herrera
Subject Re: pg_dump, gzwrite, and errno
Date
Msg-id 20200618212027.GA17103@alvherre.pgsql
Whole thread Raw
In response to pg_dump, gzwrite, and errno  (Justin Pryzby <pryzby@telsasoft.com>)
Responses Re: pg_dump, gzwrite, and errno  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-hackers
On 2020-Jun-11, Justin Pryzby wrote:

> --- a/src/bin/pg_dump/pg_backup_directory.c
> +++ b/src/bin/pg_dump/pg_backup_directory.c
> @@ -347,8 +347,12 @@ _WriteData(ArchiveHandle *AH, const void *data, size_t dLen)
>         lclContext *ctx = (lclContext *) AH->formatData;
>  
>         if (dLen > 0 && cfwrite(data, dLen, ctx->dataFH) != dLen)
> +       {
> +               if (errno == 0)
> +                       errno = ENOSPC;
>                 fatal("could not write to output file: %s",
>                           get_cfp_error(ctx->dataFH));
> +       }
>  }

This seems correct to me.  (I spent a long time looking at zlib sources
to convince myself that it does work with compressed files too).  There
are more calls to cfwrite in pg_backup_directory.c though -- we should
patch them all.

-- 
Álvaro Herrera                https://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services



pgsql-hackers by date:

Previous
From: Andrew Dunstan
Date:
Subject: Re: jsonpath versus NaN
Next
From: "Bossart, Nathan"
Date:
Subject: Re: Add support for INDEX_CLEANUP and TRUNCATE to vacuumdb