diff options
author | Teodor Sigaev <teodor@sigaev.ru> | 2009-12-02 13:13:24 +0000 |
---|---|---|
committer | Teodor Sigaev <teodor@sigaev.ru> | 2009-12-02 13:13:24 +0000 |
commit | aebc4e67fffc89a0cf933b9617316b7019318db4 (patch) | |
tree | 81010843c02750bb9142142876598ae62cce2698 /contrib/btree_gist/btree_ts.c | |
parent | 59ed94ad0c9f74a3f057f359316c845cedc4461e (diff) | |
download | postgresql-aebc4e67fffc89a0cf933b9617316b7019318db4.tar.gz postgresql-aebc4e67fffc89a0cf933b9617316b7019318db4.zip |
Preventing intersection of ranges during page split. Changes are only
optimization, so don't backpatch.
Diffstat (limited to 'contrib/btree_gist/btree_ts.c')
-rw-r--r-- | contrib/btree_gist/btree_ts.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/contrib/btree_gist/btree_ts.c b/contrib/btree_gist/btree_ts.c index e0780ef3914..9b5dfba8cc8 100644 --- a/contrib/btree_gist/btree_ts.c +++ b/contrib/btree_gist/btree_ts.c @@ -1,5 +1,5 @@ /* - * $PostgreSQL: pgsql/contrib/btree_gist/btree_ts.c,v 1.17 2009/06/11 14:48:50 momjian Exp $ + * $PostgreSQL: pgsql/contrib/btree_gist/btree_ts.c,v 1.18 2009/12/02 13:13:24 teodor Exp $ */ #include "btree_gist.h" #include "btree_utils_num.h" @@ -99,11 +99,15 @@ gbt_tslt(const void *a, const void *b) static int gbt_tskey_cmp(const void *a, const void *b) { - if (gbt_tsgt((void *) &(((Nsrt *) a)->t[0]), (void *) &(((Nsrt *) b)->t[0]))) - return 1; - else if (gbt_tslt((void *) &(((Nsrt *) a)->t[0]), (void *) &(((Nsrt *) b)->t[0]))) - return -1; - return 0; + tsKEY *ia = (tsKEY*)(((Nsrt *) a)->t); + tsKEY *ib = (tsKEY*)(((Nsrt *) b)->t); + int res; + + res = DatumGetInt32(DirectFunctionCall2(timestamp_cmp, TimestampGetDatumFast(ia->lower), TimestampGetDatumFast(ib->lower))); + if (res == 0) + return DatumGetInt32(DirectFunctionCall2(timestamp_cmp, TimestampGetDatumFast(ia->upper), TimestampGetDatumFast(ib->upper))); + + return res; } |