mirror of
https://github.com/postgres/postgres.git
synced 2025-06-27 23:21:58 +03:00
Adjust power() error messages to be more descriptive.
This commit is contained in:
@ -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
|
||||
|
Reference in New Issue
Block a user