Commit 90101564 authored by Michael Paquier's avatar Michael Paquier

Fix thinko introduced by 82a5649f in slot.c

When saving a replication slot, failing to close the temporary path used
to save the slot information is considered as a failure and reported as
such.  However the code forgot to leave immediately as other failure
paths do.

Noticed while looking up at this area of the code for another patch.
parent 47ac2033
...@@ -1316,10 +1316,13 @@ SaveSlotToPath(ReplicationSlot *slot, const char *dir, int elevel) ...@@ -1316,10 +1316,13 @@ SaveSlotToPath(ReplicationSlot *slot, const char *dir, int elevel)
pgstat_report_wait_end(); pgstat_report_wait_end();
if (CloseTransientFile(fd)) if (CloseTransientFile(fd))
{
ereport(elevel, ereport(elevel,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not close file \"%s\": %m", errmsg("could not close file \"%s\": %m",
tmppath))); tmppath)));
return;
}
/* rename to permanent file, fsync file and directory */ /* rename to permanent file, fsync file and directory */
if (rename(tmppath, path) != 0) if (rename(tmppath, path) != 0)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment