1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-24 01:29:19 +03:00

In pg_upgrade, simplify function copy_file() by using pg_malloc() and

centralizing error/shutdown code.
This commit is contained in:
Bruce Momjian
2012-11-24 22:39:03 -05:00
parent 16e1ae77f9
commit 6b711cf37c

View File

@@ -133,6 +133,8 @@ copy_file(const char *srcfile, const char *dstfile, bool force)
int src_fd; int src_fd;
int dest_fd; int dest_fd;
char *buffer; char *buffer;
int ret = 0;
int save_errno = 0;
if ((srcfile == NULL) || (dstfile == NULL)) if ((srcfile == NULL) || (dstfile == NULL))
return -1; return -1;
@@ -150,17 +152,6 @@ copy_file(const char *srcfile, const char *dstfile, bool force)
buffer = (char *) pg_malloc(COPY_BUF_SIZE); buffer = (char *) pg_malloc(COPY_BUF_SIZE);
if (buffer == NULL)
{
if (src_fd != 0)
close(src_fd);
if (dest_fd != 0)
close(dest_fd);
return -1;
}
/* perform data copying i.e read src source, write to destination */ /* perform data copying i.e read src source, write to destination */
while (true) while (true)
{ {
@@ -168,19 +159,9 @@ copy_file(const char *srcfile, const char *dstfile, bool force)
if (nbytes < 0) if (nbytes < 0)
{ {
int save_errno = errno; save_errno = errno;
ret = -1;
if (buffer != NULL) break;
pg_free(buffer);
if (src_fd != 0)
close(src_fd);
if (dest_fd != 0)
close(dest_fd);
errno = save_errno;
return -1;
} }
if (nbytes == 0) if (nbytes == 0)
@@ -190,10 +171,12 @@ copy_file(const char *srcfile, const char *dstfile, bool force)
if (write(dest_fd, buffer, nbytes) != nbytes) if (write(dest_fd, buffer, nbytes) != nbytes)
{ {
/* if write didn't set errno, assume problem is no disk space */ save_errno = errno;
int save_errno = errno ? errno : ENOSPC; ret = -1;
break;
}
}
if (buffer != NULL)
pg_free(buffer); pg_free(buffer);
if (src_fd != 0) if (src_fd != 0)
@@ -202,21 +185,10 @@ copy_file(const char *srcfile, const char *dstfile, bool force)
if (dest_fd != 0) if (dest_fd != 0)
close(dest_fd); close(dest_fd);
if (save_errno != 0)
errno = save_errno; errno = save_errno;
return -1;
}
}
if (buffer != NULL) return ret;
pg_free(buffer);
if (src_fd != 0)
close(src_fd);
if (dest_fd != 0)
close(dest_fd);
return 1;
} }
#endif #endif