mirror of
				https://github.com/postgres/postgres.git
				synced 2025-11-04 00:02:52 -05:00 
			
		
		
		
	Adjust power() error messages to be more descriptive.
This commit is contained in:
		
							parent
							
								
									3159040627
								
							
						
					
					
						commit
						f8df836ae3
					
				@ -8,7 +8,7 @@
 | 
			
		||||
 *
 | 
			
		||||
 *
 | 
			
		||||
 * IDENTIFICATION
 | 
			
		||||
 *	  $PostgreSQL: pgsql/src/backend/utils/adt/float.c,v 1.156 2008/05/09 15:36:06 momjian Exp $
 | 
			
		||||
 *	  $PostgreSQL: pgsql/src/backend/utils/adt/float.c,v 1.157 2008/05/09 21:31:23 momjian Exp $
 | 
			
		||||
 *
 | 
			
		||||
 *-------------------------------------------------------------------------
 | 
			
		||||
 */
 | 
			
		||||
@ -1334,11 +1334,14 @@ dpow(PG_FUNCTION_ARGS)
 | 
			
		||||
	 * certain error conditions.  Specifically, we don't return a divide-by-zero
 | 
			
		||||
	 * error code for 0 ^ -1.
 | 
			
		||||
	 */
 | 
			
		||||
	if ((arg1 == 0 && arg2 < 0) ||
 | 
			
		||||
		(arg1 < 0 && floor(arg2) != arg2))
 | 
			
		||||
	if (arg1 == 0 && arg2 < 0)
 | 
			
		||||
		ereport(ERROR,
 | 
			
		||||
				(errcode(ERRCODE_INVALID_ARGUMENT_FOR_POWER_FUNCTION),
 | 
			
		||||
				 errmsg("invalid argument for power function")));
 | 
			
		||||
				 errmsg("zero raised to a negative power is undefined")));
 | 
			
		||||
	if (arg1 < 0 && floor(arg2) != arg2)
 | 
			
		||||
		ereport(ERROR,
 | 
			
		||||
				(errcode(ERRCODE_INVALID_ARGUMENT_FOR_POWER_FUNCTION),
 | 
			
		||||
				 errmsg("a negative number raised to a non-integer power yields a complex result")));
 | 
			
		||||
 | 
			
		||||
	/*
 | 
			
		||||
	 * pow() sets errno only on some platforms, depending on whether it
 | 
			
		||||
 | 
			
		||||
@ -14,7 +14,7 @@
 | 
			
		||||
 * Copyright (c) 1998-2008, PostgreSQL Global Development Group
 | 
			
		||||
 *
 | 
			
		||||
 * IDENTIFICATION
 | 
			
		||||
 *	  $PostgreSQL: pgsql/src/backend/utils/adt/numeric.c,v 1.113 2008/05/09 15:36:06 momjian Exp $
 | 
			
		||||
 *	  $PostgreSQL: pgsql/src/backend/utils/adt/numeric.c,v 1.114 2008/05/09 21:31:23 momjian Exp $
 | 
			
		||||
 *
 | 
			
		||||
 *-------------------------------------------------------------------------
 | 
			
		||||
 */
 | 
			
		||||
@ -1897,13 +1897,17 @@ numeric_power(PG_FUNCTION_ARGS)
 | 
			
		||||
	 * certain error conditions.  Specifically, we don't return a divide-by-zero
 | 
			
		||||
	 * error code for 0 ^ -1.
 | 
			
		||||
	 */
 | 
			
		||||
	if ((cmp_var(&arg1, &const_zero) == 0 &&
 | 
			
		||||
		 cmp_var(&arg2, &const_zero) < 0) ||
 | 
			
		||||
		(cmp_var(&arg1, &const_zero) < 0 &&
 | 
			
		||||
		 cmp_var(&arg2, &arg2_trunc) != 0))
 | 
			
		||||
	if (cmp_var(&arg1, &const_zero) == 0 &&
 | 
			
		||||
		cmp_var(&arg2, &const_zero) < 0)
 | 
			
		||||
		ereport(ERROR,
 | 
			
		||||
				(errcode(ERRCODE_INVALID_ARGUMENT_FOR_POWER_FUNCTION),
 | 
			
		||||
				 errmsg("invalid argument for power function")));
 | 
			
		||||
				 errmsg("zero raised to a negative power is undefined")));
 | 
			
		||||
 | 
			
		||||
	if (cmp_var(&arg1, &const_zero) < 0 &&
 | 
			
		||||
		cmp_var(&arg2, &arg2_trunc) != 0)
 | 
			
		||||
		ereport(ERROR,
 | 
			
		||||
				(errcode(ERRCODE_INVALID_ARGUMENT_FOR_POWER_FUNCTION),
 | 
			
		||||
				 errmsg("a negative number raised to a non-integer power yields a complex result")));
 | 
			
		||||
 | 
			
		||||
	/*
 | 
			
		||||
	 * Call power_var() to compute and return the result; note it handles
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user