mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Fix case issues with quotes.
This commit is contained in:
		| @@ -10,7 +10,7 @@ | |||||||
|  * |  * | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $Header: /cvsroot/pgsql/src/backend/postmaster/postmaster.c,v 1.60 1997/11/07 20:51:47 momjian Exp $ |  *	  $Header: /cvsroot/pgsql/src/backend/postmaster/postmaster.c,v 1.61 1997/11/10 05:10:21 momjian Exp $ | ||||||
|  * |  * | ||||||
|  * NOTES |  * NOTES | ||||||
|  * |  * | ||||||
| @@ -131,8 +131,8 @@ static char *progname = (char *) NULL; | |||||||
|  */ |  */ | ||||||
| static char Execfile[MAXPATHLEN] = ""; | static char Execfile[MAXPATHLEN] = ""; | ||||||
|  |  | ||||||
| static int ServerSock_INET = INVALID_SOCK;	/* stream socket server */ | static int	ServerSock_INET = INVALID_SOCK;		/* stream socket server */ | ||||||
| static int ServerSock_UNIX = INVALID_SOCK;	/* stream socket server */ | static int	ServerSock_UNIX = INVALID_SOCK;		/* stream socket server */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Set by the -o option |  * Set by the -o option | ||||||
| @@ -149,8 +149,8 @@ static char ExtraOptions[ARGV_SIZE] = ""; | |||||||
| static int	Reinit = 1; | static int	Reinit = 1; | ||||||
| static int	SendStop = 0; | static int	SendStop = 0; | ||||||
|  |  | ||||||
| static int      NetServer = 0; /* if not zero, postmaster listen for | static int	NetServer = 0;		/* if not zero, postmaster listen for | ||||||
| 				  non-local connections */ | 								 * non-local connections */ | ||||||
| static int	MultiplexedBackends = 0; | static int	MultiplexedBackends = 0; | ||||||
| static int	MultiplexedBackendPort; | static int	MultiplexedBackendPort; | ||||||
|  |  | ||||||
| @@ -318,8 +318,8 @@ PostmasterMain(int argc, char *argv[]) | |||||||
| 				else | 				else | ||||||
| 					DebugLvl = 1; | 					DebugLvl = 1; | ||||||
| 				break; | 				break; | ||||||
| 		        case 'i': | 			case 'i': | ||||||
| 			        NetServer = 1; | 				NetServer = 1; | ||||||
| 				break; | 				break; | ||||||
| 			case 'm': | 			case 'm': | ||||||
| 				MultiplexedBackends = 1; | 				MultiplexedBackends = 1; | ||||||
| @@ -394,15 +394,15 @@ PostmasterMain(int argc, char *argv[]) | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if (NetServer) | 	if (NetServer) | ||||||
| 	  { | 	{ | ||||||
| 	    status = StreamServerPort(hostName, PostPortName, &ServerSock_INET); | 		status = StreamServerPort(hostName, PostPortName, &ServerSock_INET); | ||||||
| 	    if (status != STATUS_OK) | 		if (status != STATUS_OK) | ||||||
| 	      { | 		{ | ||||||
| 		fprintf(stderr, "%s: cannot create INET stream port\n", | 			fprintf(stderr, "%s: cannot create INET stream port\n", | ||||||
| 			progname); | 					progname); | ||||||
| 		exit(1); | 			exit(1); | ||||||
| 	      } | 		} | ||||||
| 	  } | 	} | ||||||
| 	status = StreamServerPort(NULL, PostPortName, &ServerSock_UNIX); | 	status = StreamServerPort(NULL, PostPortName, &ServerSock_UNIX); | ||||||
| 	if (status != STATUS_OK) | 	if (status != STATUS_OK) | ||||||
| 	{ | 	{ | ||||||
| @@ -487,11 +487,13 @@ usage(const char *progname) | |||||||
| static int | static int | ||||||
| ServerLoop(void) | ServerLoop(void) | ||||||
| { | { | ||||||
| 	fd_set		rmask, basemask; | 	fd_set		rmask, | ||||||
|  | 				basemask; | ||||||
| 	int			nSockets, | 	int			nSockets, | ||||||
| 				nSelected, | 				nSelected, | ||||||
| 				status, | 				status, | ||||||
| 				oldFd, newFd; | 				oldFd, | ||||||
|  | 				newFd; | ||||||
| 	Dlelem	   *next, | 	Dlelem	   *next, | ||||||
| 			   *curr; | 			   *curr; | ||||||
|  |  | ||||||
| @@ -511,11 +513,11 @@ ServerLoop(void) | |||||||
| 	FD_SET(ServerSock_UNIX, &basemask); | 	FD_SET(ServerSock_UNIX, &basemask); | ||||||
| 	nSockets = ServerSock_UNIX; | 	nSockets = ServerSock_UNIX; | ||||||
| 	if (ServerSock_INET != INVALID_SOCK) | 	if (ServerSock_INET != INVALID_SOCK) | ||||||
| 	  { | 	{ | ||||||
| 	    FD_SET(ServerSock_INET, &basemask); | 		FD_SET(ServerSock_INET, &basemask); | ||||||
| 	    if (ServerSock_INET > ServerSock_UNIX)  | 		if (ServerSock_INET > ServerSock_UNIX) | ||||||
| 	      nSockets = ServerSock_INET; | 			nSockets = ServerSock_INET; | ||||||
| 	  } | 	} | ||||||
| 	nSockets++; | 	nSockets++; | ||||||
|  |  | ||||||
| #ifdef HAVE_SIGPROCMASK | #ifdef HAVE_SIGPROCMASK | ||||||
| @@ -564,10 +566,10 @@ ServerLoop(void) | |||||||
| 		/* new connection pending on our well-known port's socket */ | 		/* new connection pending on our well-known port's socket */ | ||||||
| 		oldFd = -1; | 		oldFd = -1; | ||||||
| 		if (FD_ISSET(ServerSock_UNIX, &rmask)) | 		if (FD_ISSET(ServerSock_UNIX, &rmask)) | ||||||
| 		  oldFd = ServerSock_UNIX; | 			oldFd = ServerSock_UNIX; | ||||||
| 		else if (ServerSock_INET != INVALID_SOCK && | 		else if (ServerSock_INET != INVALID_SOCK && | ||||||
| 			 FD_ISSET(ServerSock_INET, &rmask)) | 				 FD_ISSET(ServerSock_INET, &rmask)) | ||||||
| 		  oldFd = ServerSock_INET; | 			oldFd = ServerSock_INET; | ||||||
| 		if (oldFd >= 0) | 		if (oldFd >= 0) | ||||||
| 		{ | 		{ | ||||||
|  |  | ||||||
| @@ -587,9 +589,9 @@ ServerLoop(void) | |||||||
| 							progname, newFd); | 							progname, newFd); | ||||||
| 			} | 			} | ||||||
| 			else if (DebugLvl) | 			else if (DebugLvl) | ||||||
| 			  fprintf(stderr,  | 				fprintf(stderr, | ||||||
| 				  "%s: ServerLoop: connect failed: (%d) %s\n", | 						"%s: ServerLoop: connect failed: (%d) %s\n", | ||||||
| 				  progname, errno, strerror(errno)); | 						progname, errno, strerror(errno)); | ||||||
| 			--nSelected; | 			--nSelected; | ||||||
| 			FD_CLR(oldFd, &rmask); | 			FD_CLR(oldFd, &rmask); | ||||||
| 		} | 		} | ||||||
| @@ -823,7 +825,7 @@ ConnStartup(Port *port, int *status, | |||||||
| static void | static void | ||||||
| send_error_reply(Port *port, const char *errormsg) | send_error_reply(Port *port, const char *errormsg) | ||||||
| { | { | ||||||
| 	int			rc;	/* return code from write */ | 	int			rc;				/* return code from write */ | ||||||
| 	char	   *reply; | 	char	   *reply; | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| @@ -1299,8 +1301,10 @@ ExitPostmaster(int status) | |||||||
| 	 * Not sure of the semantics here.	When the Postmaster dies, should | 	 * Not sure of the semantics here.	When the Postmaster dies, should | ||||||
| 	 * the backends all be killed? probably not. | 	 * the backends all be killed? probably not. | ||||||
| 	 */ | 	 */ | ||||||
| 	if (ServerSock_INET != INVALID_SOCK) close(ServerSock_INET); | 	if (ServerSock_INET != INVALID_SOCK) | ||||||
| 	if (ServerSock_UNIX != INVALID_SOCK) close(ServerSock_UNIX); | 		close(ServerSock_INET); | ||||||
|  | 	if (ServerSock_UNIX != INVALID_SOCK) | ||||||
|  | 		close(ServerSock_UNIX); | ||||||
| 	exitpg(status); | 	exitpg(status); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1315,10 +1319,9 @@ dumpstatus(SIGNAL_ARGS) | |||||||
|  |  | ||||||
| 		fprintf(stderr, "%s: dumpstatus:\n", progname); | 		fprintf(stderr, "%s: dumpstatus:\n", progname); | ||||||
| 		fprintf(stderr, "\tsock %d: nBytes=%d, laddr=0x%lx, raddr=0x%lx\n", | 		fprintf(stderr, "\tsock %d: nBytes=%d, laddr=0x%lx, raddr=0x%lx\n", | ||||||
| 			port->sock, port->nBytes, | 				port->sock, port->nBytes, | ||||||
| 			(long int) port->laddr.in.sin_addr.s_addr, | 				(long int) port->laddr.in.sin_addr.s_addr, | ||||||
| 			(long int) port->raddr.in.sin_addr.s_addr); | 				(long int) port->raddr.in.sin_addr.s_addr); | ||||||
| 		curr = DLGetSucc(curr); | 		curr = DLGetSucc(curr); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  * |  * | ||||||
|  * Copyright (c) 1994, Regents of the University of California |  * Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * $Id: c.h,v 1.26 1997/10/30 23:36:56 momjian Exp $ |  * $Id: c.h,v 1.27 1997/11/10 05:10:34 momjian Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -697,8 +697,8 @@ typedef struct Exception | |||||||
| #define INT_ALIGN_MASK (sizeof(int32) - 1) | #define INT_ALIGN_MASK (sizeof(int32) - 1) | ||||||
|  |  | ||||||
| /* This function gets call too often, so we inline it if we can */ | /* This function gets call too often, so we inline it if we can */ | ||||||
| #define MemSet(start, val, len)	do \ | #define MemSet(start, val, len) do \ | ||||||
| 								{   /* are we aligned for int32? */ \ | 								{	/* are we aligned for int32? */ \ | ||||||
| 									/* We have to cast the pointer to int \ | 									/* We have to cast the pointer to int \ | ||||||
| 									   so we can do the AND */ \ | 									   so we can do the AND */ \ | ||||||
| 									if (((int)(start) & INT_ALIGN_MASK) == 0 && \ | 									if (((int)(start) & INT_ALIGN_MASK) == 0 && \ | ||||||
| @@ -707,7 +707,7 @@ typedef struct Exception | |||||||
| 									/* \ | 									/* \ | ||||||
| 									 * We got this number by testing this \ | 									 * We got this number by testing this \ | ||||||
| 									 * against the stock memset() on \ | 									 * against the stock memset() on \ | ||||||
| 									 * bsd/os 3.0.  Larger values were \ | 									 * bsd/os 3.0.	Larger values were \ | ||||||
| 									 * slower. \ | 									 * slower. \ | ||||||
| 									 */ \ | 									 */ \ | ||||||
| 										(len) <= 64) \ | 										(len) <= 64) \ | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  * |  * | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.43 1997/11/07 20:52:15 momjian Exp $ |  *	  $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.44 1997/11/10 05:10:45 momjian Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -340,8 +340,9 @@ PQsetdb(const char *pghost, const char *pgport, const char *pgoptions, const cha | |||||||
|  |  | ||||||
| 		if (!pghost || pghost[0] == '\0') | 		if (!pghost || pghost[0] == '\0') | ||||||
| 		{ | 		{ | ||||||
| 		  conn->pghost = NULL; | 			conn->pghost = NULL; | ||||||
| 		  if (tmp = getenv("PGHOST")) conn->pghost = strdup(tmp); | 			if (tmp = getenv("PGHOST")) | ||||||
|  | 				conn->pghost = strdup(tmp); | ||||||
| 		} | 		} | ||||||
| 		else | 		else | ||||||
| 			conn->pghost = strdup(pghost); | 			conn->pghost = strdup(pghost); | ||||||
| @@ -413,14 +414,23 @@ PQsetdb(const char *pghost, const char *pgport, const char *pgoptions, const cha | |||||||
| 		{ | 		{ | ||||||
| 			if (((tmp = (char *) dbName) && (dbName[0] != '\0')) || | 			if (((tmp = (char *) dbName) && (dbName[0] != '\0')) || | ||||||
| 				((tmp = getenv("PGDATABASE")))) | 				((tmp = getenv("PGDATABASE")))) | ||||||
| 			{ |  | ||||||
| 				conn->dbName = strdup(tmp); | 				conn->dbName = strdup(tmp); | ||||||
| 			} |  | ||||||
| 			else | 			else | ||||||
| 				conn->dbName = strdup(conn->pguser); | 				conn->dbName = strdup(conn->pguser); | ||||||
| 			for (i = 0; conn->dbName[i]; i++) |  | ||||||
| 				if (isupper(conn->dbName[i])) | 			/* | ||||||
| 					conn->dbName[i] = tolower(conn->dbName[i]); | 			 * if the table name is surrounded by double-quotes, then | ||||||
|  | 			 * don't convert case | ||||||
|  | 			 */ | ||||||
|  | 			if (*conn->dbName == '"') | ||||||
|  | 			{ | ||||||
|  | 				strcpy(conn->dbName, conn->dbName + 1); | ||||||
|  | 				*(conn->dbName + strlen(conn->dbName) - 1) = '\0'; | ||||||
|  | 			} | ||||||
|  | 			else | ||||||
|  | 				for (i = 0; conn->dbName[i]; i++) | ||||||
|  | 					if (isupper(conn->dbName[i])) | ||||||
|  | 						conn->dbName[i] = tolower(conn->dbName[i]); | ||||||
| 		} | 		} | ||||||
| 		else | 		else | ||||||
| 			conn->dbName = NULL; | 			conn->dbName = NULL; | ||||||
| @@ -470,7 +480,9 @@ connectDB(PGconn *conn) | |||||||
| 	MsgType		msgtype; | 	MsgType		msgtype; | ||||||
| 	int			laddrlen = sizeof(struct sockaddr); | 	int			laddrlen = sizeof(struct sockaddr); | ||||||
| 	Port	   *port = conn->port; | 	Port	   *port = conn->port; | ||||||
| 	int			portno, family, len; | 	int			portno, | ||||||
|  | 				family, | ||||||
|  | 				len; | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * Initialize the startup packet. | 	 * Initialize the startup packet. | ||||||
| @@ -499,7 +511,7 @@ connectDB(PGconn *conn) | |||||||
| 	MemSet((char *) port, 0, sizeof(Port)); | 	MemSet((char *) port, 0, sizeof(Port)); | ||||||
|  |  | ||||||
| 	if (conn->pghost && | 	if (conn->pghost && | ||||||
| 	    (!(hp = gethostbyname(conn->pghost)) || hp->h_addrtype != AF_INET)) | 	  (!(hp = gethostbyname(conn->pghost)) || hp->h_addrtype != AF_INET)) | ||||||
| 	{ | 	{ | ||||||
| 		(void) sprintf(conn->errorMessage, | 		(void) sprintf(conn->errorMessage, | ||||||
| 					   "connectDB() --  unknown hostname: %s\n", | 					   "connectDB() --  unknown hostname: %s\n", | ||||||
| @@ -510,17 +522,17 @@ connectDB(PGconn *conn) | |||||||
| 	portno = atoi(conn->pgport); | 	portno = atoi(conn->pgport); | ||||||
| 	port->raddr.in.sin_family = family = conn->pghost ? AF_INET : AF_UNIX; | 	port->raddr.in.sin_family = family = conn->pghost ? AF_INET : AF_UNIX; | ||||||
| 	if (family == AF_INET) | 	if (family == AF_INET) | ||||||
| 	  { | 	{ | ||||||
| 	    memmove((char *) &(port->raddr.in.sin_addr), | 		memmove((char *) &(port->raddr.in.sin_addr), | ||||||
| 		    (char *) hp->h_addr, | 				(char *) hp->h_addr, | ||||||
| 		    hp->h_length); | 				hp->h_length); | ||||||
| 	    port->raddr.in.sin_port = htons((unsigned short) (portno)); | 		port->raddr.in.sin_port = htons((unsigned short) (portno)); | ||||||
| 	    len = sizeof(struct sockaddr_in); | 		len = sizeof(struct sockaddr_in); | ||||||
| 	  } | 	} | ||||||
| 	else | 	else | ||||||
| 	  { | 	{ | ||||||
| 	    len = UNIXSOCK_PATH(port->raddr.un,portno); | 		len = UNIXSOCK_PATH(port->raddr.un, portno); | ||||||
| 	  } | 	} | ||||||
| 	/* connect to the server  */ | 	/* connect to the server  */ | ||||||
| 	if ((port->sock = socket(family, SOCK_STREAM, 0)) < 0) | 	if ((port->sock = socket(family, SOCK_STREAM, 0)) < 0) | ||||||
| 	{ | 	{ | ||||||
| @@ -529,12 +541,12 @@ connectDB(PGconn *conn) | |||||||
| 					   errno, strerror(errno)); | 					   errno, strerror(errno)); | ||||||
| 		goto connect_errReturn; | 		goto connect_errReturn; | ||||||
| 	} | 	} | ||||||
| 	if (connect(port->sock, (struct sockaddr *) &port->raddr, len) < 0) | 	if (connect(port->sock, (struct sockaddr *) & port->raddr, len) < 0) | ||||||
| 	{ | 	{ | ||||||
| 		(void) sprintf(conn->errorMessage, | 		(void) sprintf(conn->errorMessage, | ||||||
| 			       "connectDB() failed: Is the postmaster running at '%s' on port '%s'?\n", | 					   "connectDB() failed: Is the postmaster running at '%s' on port '%s'?\n", | ||||||
| 			       conn->pghost ? conn->pghost : "UNIX Socket",  | 					   conn->pghost ? conn->pghost : "UNIX Socket", | ||||||
| 			       conn->pgport); | 					   conn->pgport); | ||||||
| 		goto connect_errReturn; | 		goto connect_errReturn; | ||||||
| 	} | 	} | ||||||
| 	if (family == AF_INET) | 	if (family == AF_INET) | ||||||
| @@ -779,7 +791,8 @@ packetSend(Port *port, | |||||||
| 		   PacketLen len, | 		   PacketLen len, | ||||||
| 		   bool nonBlocking) | 		   bool nonBlocking) | ||||||
| { | { | ||||||
| 	PacketLen doneLen = write(port->sock,  buf, len); | 	PacketLen	doneLen = write(port->sock, buf, len); | ||||||
|  |  | ||||||
| 	if (doneLen < len) | 	if (doneLen < len) | ||||||
| 	{ | 	{ | ||||||
| 		return (STATUS_ERROR); | 		return (STATUS_ERROR); | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  * |  * | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-exec.c,v 1.39 1997/11/03 04:21:49 momjian Exp $ |  *	  $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-exec.c,v 1.40 1997/11/10 05:10:50 momjian Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -17,6 +17,7 @@ | |||||||
| #include <signal.h> | #include <signal.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| #include <errno.h> | #include <errno.h> | ||||||
|  | #include <ctype.h> | ||||||
| #include "postgres.h" | #include "postgres.h" | ||||||
| #include "libpq/pqcomm.h" | #include "libpq/pqcomm.h" | ||||||
| #include "libpq/pqsignal.h" | #include "libpq/pqsignal.h" | ||||||
| @@ -31,12 +32,14 @@ | |||||||
|  |  | ||||||
| #ifdef TIOCGWINSZ | #ifdef TIOCGWINSZ | ||||||
| struct winsize screen_size; | struct winsize screen_size; | ||||||
|  |  | ||||||
| #else | #else | ||||||
| struct winsize | struct winsize | ||||||
| { | { | ||||||
| 	int			ws_row; | 	int			ws_row; | ||||||
| 	int			ws_col; | 	int			ws_col; | ||||||
| }			screen_size; | }			screen_size; | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* the rows array in a PGresGroup  has to grow to accommodate the rows */ | /* the rows array in a PGresGroup  has to grow to accommodate the rows */ | ||||||
| @@ -1674,6 +1677,7 @@ int | |||||||
| PQfnumber(PGresult *res, const char *field_name) | PQfnumber(PGresult *res, const char *field_name) | ||||||
| { | { | ||||||
| 	int			i; | 	int			i; | ||||||
|  | 	char	   *field_case; | ||||||
|  |  | ||||||
| 	if (!res) | 	if (!res) | ||||||
| 	{ | 	{ | ||||||
| @@ -1686,13 +1690,27 @@ PQfnumber(PGresult *res, const char *field_name) | |||||||
| 		res->attDescs == NULL) | 		res->attDescs == NULL) | ||||||
| 		return -1; | 		return -1; | ||||||
|  |  | ||||||
|  | 	field_case = strdup(field_name); | ||||||
|  | 	if (*field_case == '"') | ||||||
|  | 	{ | ||||||
|  | 		strcpy(field_case, field_case + 1); | ||||||
|  | 		*(field_case + strlen(field_case) - 1) = '\0'; | ||||||
|  | 	} | ||||||
|  | 	else | ||||||
|  | 		for (i = 0; field_case; i++) | ||||||
|  | 			if (isupper(field_case[i])) | ||||||
|  | 				field_case[i] = tolower(field_case[i]); | ||||||
|  |  | ||||||
| 	for (i = 0; i < res->numAttributes; i++) | 	for (i = 0; i < res->numAttributes; i++) | ||||||
| 	{ | 	{ | ||||||
| 		if (strcasecmp(field_name, res->attDescs[i].name) == 0) | 		if (strcmp(field_name, res->attDescs[i].name) == 0) | ||||||
|  | 		{ | ||||||
|  | 			free(field_case); | ||||||
| 			return i; | 			return i; | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
|  | 	free(field_case); | ||||||
| 	return -1; | 	return -1; | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| Oid | Oid | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user