mirror of
https://github.com/postgres/postgres.git
synced 2025-04-22 23:02:54 +03:00
Make get_controlfile() error logging consistent with src/common
As originally committed, get_controlfile() used a non-standard approach to error logging. Make it consistent with the majority of error logging done in src/common. Applies to master only.
This commit is contained in:
parent
b63bea5fd3
commit
7b077af500
@ -28,19 +28,6 @@
|
|||||||
#include "common/controldata_utils.h"
|
#include "common/controldata_utils.h"
|
||||||
#include "port/pg_crc32c.h"
|
#include "port/pg_crc32c.h"
|
||||||
|
|
||||||
#ifndef FRONTEND
|
|
||||||
/* NOTE: caller must provide gettext call around the format string */
|
|
||||||
#define log_error(...) \
|
|
||||||
elog(ERROR, __VA_ARGS__)
|
|
||||||
#else
|
|
||||||
#define log_error(...) \
|
|
||||||
do { \
|
|
||||||
char *buf = psprintf(__VA_ARGS__); \
|
|
||||||
fprintf(stderr, "%s: %s\n", progname, buf); \
|
|
||||||
exit(2); \
|
|
||||||
} while (0)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* get_controlfile(char *DataDir, const char *progname)
|
* get_controlfile(char *DataDir, const char *progname)
|
||||||
*
|
*
|
||||||
@ -59,12 +46,31 @@ get_controlfile(char *DataDir, const char *progname)
|
|||||||
snprintf(ControlFilePath, MAXPGPATH, "%s/global/pg_control", DataDir);
|
snprintf(ControlFilePath, MAXPGPATH, "%s/global/pg_control", DataDir);
|
||||||
|
|
||||||
if ((fd = open(ControlFilePath, O_RDONLY | PG_BINARY, 0)) == -1)
|
if ((fd = open(ControlFilePath, O_RDONLY | PG_BINARY, 0)) == -1)
|
||||||
log_error(_("could not open file \"%s\" for reading: %s"),
|
#ifndef FRONTEND
|
||||||
ControlFilePath, strerror(errno));
|
ereport(ERROR,
|
||||||
|
(errcode_for_file_access(),
|
||||||
|
errmsg("could not open file \"%s\" for reading: %m",
|
||||||
|
ControlFilePath)));
|
||||||
|
#else
|
||||||
|
{
|
||||||
|
fprintf(stderr, _("%s: could not open file \"%s\" for reading: %s\n"),
|
||||||
|
progname, ControlFilePath, strerror(errno));
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (read(fd, ControlFile, sizeof(ControlFileData)) != sizeof(ControlFileData))
|
if (read(fd, ControlFile, sizeof(ControlFileData)) != sizeof(ControlFileData))
|
||||||
log_error(_("could not read file \"%s\": %s"),
|
#ifndef FRONTEND
|
||||||
ControlFilePath, strerror(errno));
|
ereport(ERROR,
|
||||||
|
(errcode_for_file_access(),
|
||||||
|
errmsg("could not read file \"%s\": %m", ControlFilePath)));
|
||||||
|
#else
|
||||||
|
{
|
||||||
|
fprintf(stderr, _("%s: could not read file \"%s\": %s\n"),
|
||||||
|
progname, ControlFilePath, strerror(errno));
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
close(fd);
|
close(fd);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user