aboutsummaryrefslogtreecommitdiff
path: root/contrib/ltree/ltree_gist.c
diff options
context:
space:
mode:
authorTeodor Sigaev <teodor@sigaev.ru>2006-08-08 15:45:56 +0000
committerTeodor Sigaev <teodor@sigaev.ru>2006-08-08 15:45:56 +0000
commit09e33d1628c74149bf79c8b452e681967463e9da (patch)
tree9414a4668a460aea4d0c001655fd36d51cad4387 /contrib/ltree/ltree_gist.c
parent01c74da47e6b5e284ea40a58cae8d0c739ca9507 (diff)
downloadpostgresql-09e33d1628c74149bf79c8b452e681967463e9da.tar.gz
postgresql-09e33d1628c74149bf79c8b452e681967463e9da.zip
Fix bug introduced by last patch, thanks again to Mario Weilguni <mweilguni@sime.com>
Diffstat (limited to 'contrib/ltree/ltree_gist.c')
-rw-r--r--contrib/ltree/ltree_gist.c30
1 files changed, 25 insertions, 5 deletions
diff --git a/contrib/ltree/ltree_gist.c b/contrib/ltree/ltree_gist.c
index 42348e6e11d..31b27ae90d6 100644
--- a/contrib/ltree/ltree_gist.c
+++ b/contrib/ltree/ltree_gist.c
@@ -459,16 +459,36 @@ gist_isparent(ltree_gist * key, ltree * query)
return false;
}
+static ltree *
+copy_ltree( ltree *src ) {
+ ltree *dst = (ltree*)palloc(src->len);
+ memcpy(dst, src, src->len);
+ return dst;
+}
+
static bool
gist_ischild(ltree_gist * key, ltree * query)
{
- if (ltree_compare(query, LTG_GETLNODE(key)) < 0)
- return false;
+ ltree *left = copy_ltree(LTG_GETLNODE(key));
+ ltree *right = copy_ltree(LTG_GETRNODE(key));
+ bool res = true;
- if (ltree_compare(query, LTG_GETRNODE(key)) > 0)
- return false;
+ if (left->numlevel > query->numlevel)
+ left->numlevel = query->numlevel;
- return true;
+ if (ltree_compare(query, left) < 0)
+ res = false;
+
+ if (right->numlevel > query->numlevel)
+ right->numlevel = query->numlevel;
+
+ if (res && ltree_compare(query, right) > 0)
+ res = false;
+
+ pfree(left);
+ pfree(right);
+
+ return res;
}
static bool