mirror of
https://github.com/postgres/postgres.git
synced 2025-07-05 07:21:24 +03:00
Remove unneeded stat calls.
This commit is contained in:
@ -7,7 +7,7 @@
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $Header: /cvsroot/pgsql/src/backend/libpq/hba.c,v 1.18 1997/08/18 02:14:37 momjian Exp $
|
* $Header: /cvsroot/pgsql/src/backend/libpq/hba.c,v 1.19 1997/08/27 03:48:31 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -15,9 +15,9 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/types.h>
|
||||||
|
#include <fcntl.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/types.h> /* needed by in.h on Ultrix */
|
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -299,8 +299,7 @@ find_hba_entry(const char DataDir[], const struct in_addr ip_addr,
|
|||||||
system.
|
system.
|
||||||
|
|
||||||
---------------------------------------------------------------------------*/
|
---------------------------------------------------------------------------*/
|
||||||
int rc;
|
int fd;
|
||||||
struct stat statbuf;
|
|
||||||
|
|
||||||
FILE *file; /* The config file we have to read */
|
FILE *file; /* The config file we have to read */
|
||||||
|
|
||||||
@ -315,9 +314,9 @@ find_hba_entry(const char DataDir[], const struct in_addr ip_addr,
|
|||||||
strlen(OLD_CONF_FILE)+2)*sizeof(char));
|
strlen(OLD_CONF_FILE)+2)*sizeof(char));
|
||||||
sprintf(old_conf_file, "%s/%s", DataDir, OLD_CONF_FILE);
|
sprintf(old_conf_file, "%s/%s", DataDir, OLD_CONF_FILE);
|
||||||
|
|
||||||
rc = stat(old_conf_file, &statbuf);
|
if ((fd = open(old_conf_file,O_RDONLY,0)) != -1) {
|
||||||
if (rc == 0) {
|
|
||||||
/* Old config file exists. Tell this guy he needs to upgrade. */
|
/* Old config file exists. Tell this guy he needs to upgrade. */
|
||||||
|
close(fd);
|
||||||
sprintf(PQerrormsg,
|
sprintf(PQerrormsg,
|
||||||
"A file exists by the name used for host-based authentication "
|
"A file exists by the name used for host-based authentication "
|
||||||
"in prior releases of Postgres (%s). The name and format of "
|
"in prior releases of Postgres (%s). The name and format of "
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $Header: /cvsroot/pgsql/src/backend/utils/init/Attic/findbe.c,v 1.4 1997/08/12 20:16:12 momjian Exp $
|
* $Header: /cvsroot/pgsql/src/backend/utils/init/Attic/findbe.c,v 1.5 1997/08/27 03:48:38 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -14,8 +14,8 @@
|
|||||||
#include <grp.h>
|
#include <grp.h>
|
||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "postgres.h"
|
#include "postgres.h"
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $Header: /cvsroot/pgsql/src/backend/utils/init/postinit.c,v 1.11 1997/08/19 21:35:50 momjian Exp $
|
* $Header: /cvsroot/pgsql/src/backend/utils/init/postinit.c,v 1.12 1997/08/27 03:48:39 momjian Exp $
|
||||||
*
|
*
|
||||||
* NOTES
|
* NOTES
|
||||||
* InitPostgres() is the function called from PostgresMain
|
* InitPostgres() is the function called from PostgresMain
|
||||||
@ -30,7 +30,6 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/file.h>
|
#include <sys/file.h>
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -79,15 +78,6 @@ static void InitUserid(void);
|
|||||||
|
|
||||||
static IPCKey PostgresIpcKey;
|
static IPCKey PostgresIpcKey;
|
||||||
|
|
||||||
|
|
||||||
#ifndef private
|
|
||||||
#ifndef EBUG
|
|
||||||
#define private static
|
|
||||||
#else /* !defined(EBUG) */
|
|
||||||
#define private
|
|
||||||
#endif /* !defined(EBUG) */
|
|
||||||
#endif /* !defined(private) */
|
|
||||||
|
|
||||||
/* ----------------------------------------------------------------
|
/* ----------------------------------------------------------------
|
||||||
* InitPostgres support
|
* InitPostgres support
|
||||||
* ----------------------------------------------------------------
|
* ----------------------------------------------------------------
|
||||||
@ -141,7 +131,7 @@ InitMyDatabaseId()
|
|||||||
sprintf(dbfname, "%s%cpg_database", DataDir, SEP_CHAR);
|
sprintf(dbfname, "%s%cpg_database", DataDir, SEP_CHAR);
|
||||||
fileflags = O_RDONLY;
|
fileflags = O_RDONLY;
|
||||||
|
|
||||||
if ((dbfd = open(dbfname, O_RDONLY, 0666)) < 0)
|
if ((dbfd = open(dbfname, O_RDONLY, 0)) < 0)
|
||||||
elog(FATAL, "Cannot open %s", dbfname);
|
elog(FATAL, "Cannot open %s", dbfname);
|
||||||
|
|
||||||
pfree(dbfname);
|
pfree(dbfname);
|
||||||
@ -261,10 +251,10 @@ static void
|
|||||||
DoChdirAndInitDatabaseNameAndPath(char *name) {
|
DoChdirAndInitDatabaseNameAndPath(char *name) {
|
||||||
char *reason;
|
char *reason;
|
||||||
/* Failure reason returned by some function. NULL if no failure */
|
/* Failure reason returned by some function. NULL if no failure */
|
||||||
struct stat statbuf;
|
int fd;
|
||||||
char errormsg[1000];
|
char errormsg[1000];
|
||||||
|
|
||||||
if (stat(DataDir, &statbuf) < 0)
|
if ((fd = open(DataDir, O_RDONLY,0)) == -1)
|
||||||
sprintf(errormsg, "Database system does not exist. "
|
sprintf(errormsg, "Database system does not exist. "
|
||||||
"PGDATA directory '%s' not found. Normally, you "
|
"PGDATA directory '%s' not found. Normally, you "
|
||||||
"create a database system by running initdb.",
|
"create a database system by running initdb.",
|
||||||
@ -272,13 +262,14 @@ DoChdirAndInitDatabaseNameAndPath(char *name) {
|
|||||||
else {
|
else {
|
||||||
char myPath[MAXPGPATH]; /* DatabasePath points here! */
|
char myPath[MAXPGPATH]; /* DatabasePath points here! */
|
||||||
|
|
||||||
|
close(fd);
|
||||||
if (strlen(DataDir) + strlen(name) + 10 > sizeof(myPath))
|
if (strlen(DataDir) + strlen(name) + 10 > sizeof(myPath))
|
||||||
sprintf(errormsg, "Internal error in postinit.c: database "
|
sprintf(errormsg, "Internal error in postinit.c: database "
|
||||||
"pathname exceeds maximum allowable length.");
|
"pathname exceeds maximum allowable length.");
|
||||||
else {
|
else {
|
||||||
sprintf(myPath, "%s/base/%s", DataDir, name);
|
sprintf(myPath, "%s/base/%s", DataDir, name);
|
||||||
|
|
||||||
if (stat(myPath, &statbuf) < 0)
|
if ((fd = open(myPath, O_RDONLY,0)) == -1)
|
||||||
sprintf(errormsg,
|
sprintf(errormsg,
|
||||||
"Database '%s' does not exist. "
|
"Database '%s' does not exist. "
|
||||||
"(We know this because the directory '%s' "
|
"(We know this because the directory '%s' "
|
||||||
@ -288,6 +279,7 @@ DoChdirAndInitDatabaseNameAndPath(char *name) {
|
|||||||
"of '%s/base/'.",
|
"of '%s/base/'.",
|
||||||
name, myPath, DataDir);
|
name, myPath, DataDir);
|
||||||
else {
|
else {
|
||||||
|
close(fd);
|
||||||
ValidatePgVersion(DataDir, &reason);
|
ValidatePgVersion(DataDir, &reason);
|
||||||
if (reason != NULL)
|
if (reason != NULL)
|
||||||
sprintf(errormsg,
|
sprintf(errormsg,
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $Header: /cvsroot/pgsql/src/utils/Attic/version.c,v 1.5 1997/07/28 00:57:08 momjian Exp $
|
* $Header: /cvsroot/pgsql/src/utils/Attic/version.c,v 1.6 1997/08/27 03:48:50 momjian Exp $
|
||||||
*
|
*
|
||||||
* NOTES
|
* NOTES
|
||||||
* XXX eventually, should be able to handle version identifiers
|
* XXX eventually, should be able to handle version identifiers
|
||||||
@ -63,42 +63,34 @@ ValidatePgVersion(const char *path, char **reason_p) {
|
|||||||
int fd;
|
int fd;
|
||||||
char version[4];
|
char version[4];
|
||||||
char full_path[MAXPGPATH+1];
|
char full_path[MAXPGPATH+1];
|
||||||
struct stat statbuf;
|
|
||||||
|
|
||||||
PathSetVersionFilePath(path, full_path);
|
PathSetVersionFilePath(path, full_path);
|
||||||
|
|
||||||
if (stat(full_path, &statbuf) < 0) {
|
if ((fd = open(full_path, O_RDONLY,0)) == -1) {
|
||||||
*reason_p = malloc(200);
|
*reason_p = malloc(200);
|
||||||
sprintf(*reason_p, "File '%s' does not exist.", full_path);
|
sprintf(*reason_p, "File '%s' does not exist or no read permission.", full_path);
|
||||||
} else {
|
} else {
|
||||||
fd = open(full_path, O_RDONLY, 0);
|
if (read(fd, version, 4) < 4 ||
|
||||||
if (fd < 0) {
|
!isascii(version[0]) || !isdigit(version[0]) ||
|
||||||
*reason_p = malloc(200);
|
version[1] != '.' ||
|
||||||
sprintf(*reason_p, "Unable to open file '%s'. Errno = %s (%d).",
|
!isascii(version[2]) || !isdigit(version[2]) ||
|
||||||
full_path, strerror(errno), errno);
|
version[3] != '\n') {
|
||||||
} else {
|
|
||||||
if (read(fd, version, 4) < 4 ||
|
|
||||||
!isascii(version[0]) || !isdigit(version[0]) ||
|
|
||||||
version[1] != '.' ||
|
|
||||||
!isascii(version[2]) || !isdigit(version[2]) ||
|
|
||||||
version[3] != '\n') {
|
|
||||||
|
|
||||||
|
*reason_p = malloc(200);
|
||||||
|
sprintf(*reason_p, "File '%s' does not have a valid format "
|
||||||
|
"for a PG_VERSION file.", full_path);
|
||||||
|
} else {
|
||||||
|
if (version[2] != '0' + PG_VERSION ||
|
||||||
|
version[0] != '0' + PG_RELEASE) {
|
||||||
*reason_p = malloc(200);
|
*reason_p = malloc(200);
|
||||||
sprintf(*reason_p, "File '%s' does not have a valid format "
|
sprintf(*reason_p,
|
||||||
"for a PG_VERSION file.", full_path);
|
"Version number in file '%s' should be %d.%d, "
|
||||||
} else {
|
"not %c.%c.",
|
||||||
if (version[2] != '0' + PG_VERSION ||
|
full_path,
|
||||||
version[0] != '0' + PG_RELEASE) {
|
PG_RELEASE, PG_VERSION, version[0], version[2]);
|
||||||
*reason_p = malloc(200);
|
} else *reason_p = NULL;
|
||||||
sprintf(*reason_p,
|
|
||||||
"Version number in file '%s' should be %d.%d, "
|
|
||||||
"not %c.%c.",
|
|
||||||
full_path,
|
|
||||||
PG_RELEASE, PG_VERSION, version[0], version[2]);
|
|
||||||
} else *reason_p = NULL;
|
|
||||||
}
|
|
||||||
close(fd);
|
|
||||||
}
|
}
|
||||||
|
close(fd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user