diff options
author | Marc G. Fournier <scrappy@hub.org> | 1996-08-15 07:30:22 +0000 |
---|---|---|
committer | Marc G. Fournier <scrappy@hub.org> | 1996-08-15 07:30:22 +0000 |
commit | 4844adc888da4f40432f27bd8b3819be84879fb1 (patch) | |
tree | 7277dfa4719876b9931b43d8903c8f0f2503e588 | |
parent | bde34552a279a13a7980049455d6a79951cc5c5d (diff) | |
download | postgresql-4844adc888da4f40432f27bd8b3819be84879fb1.tar.gz postgresql-4844adc888da4f40432f27bd8b3819be84879fb1.zip |
Fixes;
Postgres is not able to cluster a relation on which an rtree index is
defined. Postmaster gives the following error message:
Too Large Allocation Request("!(0 < (size) && (size) <= (0xfffffff)):size=0
[0x0]", File:"/export/home/postgres/src/backend/utils/mmgr/mcxt.c", Line: 220)
!(0 <(size) && (size) <= (0xfffffff)) (0) [No such file or directory]
Submitted by: Dirk Koeser <koeser@informatik.uni-rostock.de>
-rw-r--r-- | src/backend/access/rtree/rtscan.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/src/backend/access/rtree/rtscan.c b/src/backend/access/rtree/rtscan.c index aa68f0db70b..36a272c17cb 100644 --- a/src/backend/access/rtree/rtscan.c +++ b/src/backend/access/rtree/rtscan.c @@ -7,7 +7,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/access/rtree/Attic/rtscan.c,v 1.1.1.1 1996/07/09 06:21:13 scrappy Exp $ + * $Header: /cvsroot/pgsql/src/backend/access/rtree/Attic/rtscan.c,v 1.2 1996/08/15 07:30:22 scrappy Exp $ * *------------------------------------------------------------------------- */ @@ -122,15 +122,13 @@ rtrescan(IndexScanDesc s, bool fromEnd, ScanKey key) } else { /* initialize opaque data */ p = (RTreeScanOpaque) palloc(sizeof(RTreeScanOpaqueData)); - p->s_internalKey = - (ScanKey) palloc(sizeof(ScanKeyData) * s->numberOfKeys); p->s_stack = p->s_markstk = (RTSTACK *) NULL; p->s_internalNKey = s->numberOfKeys; p->s_flags = 0x0; - for (i = 0; i < s->numberOfKeys; i++) - p->s_internalKey[i].sk_argument = s->keyData[i].sk_argument; s->opaque = p; if (s->numberOfKeys > 0) { + p->s_internalKey = + (ScanKey) palloc(sizeof(ScanKeyData) * s->numberOfKeys); /* * Scans on internal pages use different operators than they @@ -140,6 +138,7 @@ rtrescan(IndexScanDesc s, bool fromEnd, ScanKey key) */ for (i = 0; i < s->numberOfKeys; i++) { + p->s_internalKey[i].sk_argument = s->keyData[i].sk_argument; internal_proc = RTMapOperator(s->relation, s->keyData[i].sk_attno, s->keyData[i].sk_procedure); |