summaryrefslogtreecommitdiff
path: root/contrib/btree_gist
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/btree_gist')
-rw-r--r--contrib/btree_gist/btree_float4.c4
-rw-r--r--contrib/btree_gist/btree_float8.c8
-rw-r--r--contrib/btree_gist/btree_utils_num.h17
3 files changed, 8 insertions, 21 deletions
diff --git a/contrib/btree_gist/btree_float4.c b/contrib/btree_gist/btree_float4.c
index 3604c73313a..b5d9175e6d5 100644
--- a/contrib/btree_gist/btree_float4.c
+++ b/contrib/btree_gist/btree_float4.c
@@ -5,6 +5,7 @@
#include "btree_gist.h"
#include "btree_utils_num.h"
+#include "utils/float.h"
typedef struct float4key
{
@@ -98,7 +99,8 @@ float4_dist(PG_FUNCTION_ARGS)
float4 r;
r = a - b;
- CHECKFLOATVAL(r, isinf(a) || isinf(b), true);
+ if (unlikely(isinf(r)) && !isinf(a) && !isinf(b))
+ float_overflow_error();
PG_RETURN_FLOAT4(Abs(r));
}
diff --git a/contrib/btree_gist/btree_float8.c b/contrib/btree_gist/btree_float8.c
index 10a5262aaa7..8fe1fedeef8 100644
--- a/contrib/btree_gist/btree_float8.c
+++ b/contrib/btree_gist/btree_float8.c
@@ -5,6 +5,7 @@
#include "btree_gist.h"
#include "btree_utils_num.h"
+#include "utils/float.h"
typedef struct float8key
{
@@ -76,8 +77,8 @@ gbt_float8_dist(const void *a, const void *b, FmgrInfo *flinfo)
float8 r;
r = arg1 - arg2;
- CHECKFLOATVAL(r, isinf(arg1) || isinf(arg2), true);
-
+ if (unlikely(isinf(r)) && !isinf(arg1) && !isinf(arg2))
+ float_overflow_error();
return Abs(r);
}
@@ -106,7 +107,8 @@ float8_dist(PG_FUNCTION_ARGS)
float8 r;
r = a - b;
- CHECKFLOATVAL(r, isinf(a) || isinf(b), true);
+ if (unlikely(isinf(r)) && !isinf(a) && !isinf(b))
+ float_overflow_error();
PG_RETURN_FLOAT8(Abs(r));
}
diff --git a/contrib/btree_gist/btree_utils_num.h b/contrib/btree_gist/btree_utils_num.h
index cec69861726..415a7a6459a 100644
--- a/contrib/btree_gist/btree_utils_num.h
+++ b/contrib/btree_gist/btree_utils_num.h
@@ -89,23 +89,6 @@ typedef struct
#define GET_FLOAT_DISTANCE(t, arg1, arg2) Abs( ((float8) *((const t *) (arg1))) - ((float8) *((const t *) (arg2))) )
-/*
- * check to see if a float4/8 val has underflowed or overflowed
- * borrowed from src/backend/utils/adt/float.c
- */
-#define CHECKFLOATVAL(val, inf_is_valid, zero_is_valid) \
-do { \
- if (isinf(val) && !(inf_is_valid)) \
- ereport(ERROR, \
- (errcode(ERRCODE_NUMERIC_VALUE_OUT_OF_RANGE), \
- errmsg("value out of range: overflow"))); \
- \
- if ((val) == 0.0 && !(zero_is_valid)) \
- ereport(ERROR, \
- (errcode(ERRCODE_NUMERIC_VALUE_OUT_OF_RANGE), \
- errmsg("value out of range: underflow"))); \
-} while(0)
-
extern Interval *abs_interval(Interval *a);