From 446fc953bce93988d04a7c05dd96cea63f066e18 Mon Sep 17 00:00:00 2001 From: Teodor Sigaev Date: Thu, 4 Sep 2008 11:47:05 +0000 Subject: [PATCH] Fix strategy propagation to scanEntry for partial match by moving propagation to initializaion of scanEntry. --- src/backend/access/gin/ginget.c | 7 ------- src/backend/access/gin/ginscan.c | 1 + 2 files changed, 1 insertion(+), 7 deletions(-) diff --git a/src/backend/access/gin/ginget.c b/src/backend/access/gin/ginget.c index b9ae6e7210..214454262f 100644 --- a/src/backend/access/gin/ginget.c +++ b/src/backend/access/gin/ginget.c @@ -395,14 +395,7 @@ startScanKey(Relation index, GinState *ginstate, GinScanKey key) return; for (i = 0; i < key->nentries; i++) - { startScanEntry(index, ginstate, key->scanEntry + i); - /* - * Copy strategy number to each entry of key to - * use in comparePartialFn call - */ - key->scanEntry[i].strategy = key->strategy; - } memset(key->entryRes, TRUE, sizeof(bool) * key->nentries); key->isFinished = FALSE; diff --git a/src/backend/access/gin/ginscan.c b/src/backend/access/gin/ginscan.c index e5636d72ad..1ebbc2ab78 100644 --- a/src/backend/access/gin/ginscan.c +++ b/src/backend/access/gin/ginscan.c @@ -61,6 +61,7 @@ fillScanKey(GinState *ginstate, GinScanKey key, OffsetNumber attnum, Datum query key->scanEntry[i].offset = InvalidOffsetNumber; key->scanEntry[i].buffer = InvalidBuffer; key->scanEntry[i].partialMatch = NULL; + key->scanEntry[i].strategy = strategy; key->scanEntry[i].list = NULL; key->scanEntry[i].nlist = 0; key->scanEntry[i].isPartialMatch = ( ginstate->canPartialMatch[attnum - 1] && partial_matches ) -- 2.39.5