mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Improve reporting of run-time-detected indeterminate-collation errors.
pg_newlocale_from_collation does not have enough context to give an error message that's even a little bit useful, so move the responsibility for complaining up to its callers. Also, reword ERRCODE_INDETERMINATE_COLLATION error messages in a less jargony, more message-style-guide-compliant fashion.
This commit is contained in:
		| @@ -1503,7 +1503,20 @@ str_tolower(const char *buff, size_t nbytes, Oid collid) | ||||
| 		size_t		result_size; | ||||
|  | ||||
| 		if (collid != DEFAULT_COLLATION_OID) | ||||
| 		{ | ||||
| 			if (!OidIsValid(collid)) | ||||
| 			{ | ||||
| 				/* | ||||
| 				 * This typically means that the parser could not resolve a | ||||
| 				 * conflict of implicit collations, so report it that way. | ||||
| 				 */ | ||||
| 				ereport(ERROR, | ||||
| 						(errcode(ERRCODE_INDETERMINATE_COLLATION), | ||||
| 						 errmsg("could not determine which collation to use for lower() function"), | ||||
| 						 errhint("Use the COLLATE clause to set the collation explicitly."))); | ||||
| 			} | ||||
| 			mylocale = pg_newlocale_from_collation(collid); | ||||
| 		} | ||||
|  | ||||
| 		/* Overflow paranoia */ | ||||
| 		if ((nbytes + 1) > (INT_MAX / sizeof(wchar_t))) | ||||
| @@ -1540,7 +1553,20 @@ str_tolower(const char *buff, size_t nbytes, Oid collid) | ||||
| 		char	   *p; | ||||
|  | ||||
| 		if (collid != DEFAULT_COLLATION_OID) | ||||
| 		{ | ||||
| 			if (!OidIsValid(collid)) | ||||
| 			{ | ||||
| 				/* | ||||
| 				 * This typically means that the parser could not resolve a | ||||
| 				 * conflict of implicit collations, so report it that way. | ||||
| 				 */ | ||||
| 				ereport(ERROR, | ||||
| 						(errcode(ERRCODE_INDETERMINATE_COLLATION), | ||||
| 						 errmsg("could not determine which collation to use for lower() function"), | ||||
| 						 errhint("Use the COLLATE clause to set the collation explicitly."))); | ||||
| 			} | ||||
| 			mylocale = pg_newlocale_from_collation(collid); | ||||
| 		} | ||||
|  | ||||
| 		result = pnstrdup(buff, nbytes); | ||||
|  | ||||
| @@ -1598,7 +1624,20 @@ str_toupper(const char *buff, size_t nbytes, Oid collid) | ||||
| 		size_t		result_size; | ||||
|  | ||||
| 		if (collid != DEFAULT_COLLATION_OID) | ||||
| 		{ | ||||
| 			if (!OidIsValid(collid)) | ||||
| 			{ | ||||
| 				/* | ||||
| 				 * This typically means that the parser could not resolve a | ||||
| 				 * conflict of implicit collations, so report it that way. | ||||
| 				 */ | ||||
| 				ereport(ERROR, | ||||
| 						(errcode(ERRCODE_INDETERMINATE_COLLATION), | ||||
| 						 errmsg("could not determine which collation to use for upper() function"), | ||||
| 						 errhint("Use the COLLATE clause to set the collation explicitly."))); | ||||
| 			} | ||||
| 			mylocale = pg_newlocale_from_collation(collid); | ||||
| 		} | ||||
|  | ||||
| 		/* Overflow paranoia */ | ||||
| 		if ((nbytes + 1) > (INT_MAX / sizeof(wchar_t))) | ||||
| @@ -1635,7 +1674,20 @@ str_toupper(const char *buff, size_t nbytes, Oid collid) | ||||
| 		char	   *p; | ||||
|  | ||||
| 		if (collid != DEFAULT_COLLATION_OID) | ||||
| 		{ | ||||
| 			if (!OidIsValid(collid)) | ||||
| 			{ | ||||
| 				/* | ||||
| 				 * This typically means that the parser could not resolve a | ||||
| 				 * conflict of implicit collations, so report it that way. | ||||
| 				 */ | ||||
| 				ereport(ERROR, | ||||
| 						(errcode(ERRCODE_INDETERMINATE_COLLATION), | ||||
| 						 errmsg("could not determine which collation to use for upper() function"), | ||||
| 						 errhint("Use the COLLATE clause to set the collation explicitly."))); | ||||
| 			} | ||||
| 			mylocale = pg_newlocale_from_collation(collid); | ||||
| 		} | ||||
|  | ||||
| 		result = pnstrdup(buff, nbytes); | ||||
|  | ||||
| @@ -1705,7 +1757,20 @@ str_initcap(const char *buff, size_t nbytes, Oid collid) | ||||
| 		size_t		result_size; | ||||
|  | ||||
| 		if (collid != DEFAULT_COLLATION_OID) | ||||
| 		{ | ||||
| 			if (!OidIsValid(collid)) | ||||
| 			{ | ||||
| 				/* | ||||
| 				 * This typically means that the parser could not resolve a | ||||
| 				 * conflict of implicit collations, so report it that way. | ||||
| 				 */ | ||||
| 				ereport(ERROR, | ||||
| 						(errcode(ERRCODE_INDETERMINATE_COLLATION), | ||||
| 						 errmsg("could not determine which collation to use for initcap() function"), | ||||
| 						 errhint("Use the COLLATE clause to set the collation explicitly."))); | ||||
| 			} | ||||
| 			mylocale = pg_newlocale_from_collation(collid); | ||||
| 		} | ||||
|  | ||||
| 		/* Overflow paranoia */ | ||||
| 		if ((nbytes + 1) > (INT_MAX / sizeof(wchar_t))) | ||||
| @@ -1754,7 +1819,20 @@ str_initcap(const char *buff, size_t nbytes, Oid collid) | ||||
| 		char	   *p; | ||||
|  | ||||
| 		if (collid != DEFAULT_COLLATION_OID) | ||||
| 		{ | ||||
| 			if (!OidIsValid(collid)) | ||||
| 			{ | ||||
| 				/* | ||||
| 				 * This typically means that the parser could not resolve a | ||||
| 				 * conflict of implicit collations, so report it that way. | ||||
| 				 */ | ||||
| 				ereport(ERROR, | ||||
| 						(errcode(ERRCODE_INDETERMINATE_COLLATION), | ||||
| 						 errmsg("could not determine which collation to use for initcap() function"), | ||||
| 						 errhint("Use the COLLATE clause to set the collation explicitly."))); | ||||
| 			} | ||||
| 			mylocale = pg_newlocale_from_collation(collid); | ||||
| 		} | ||||
|  | ||||
| 		result = pnstrdup(buff, nbytes); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user