From 4844adc888da4f40432f27bd8b3819be84879fb1 Mon Sep 17 00:00:00 2001
From: "Marc G. Fournier" <scrappy@hub.org>
Date: Thu, 15 Aug 1996 07:30:22 +0000
Subject: [PATCH] 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>
---
 src/backend/access/rtree/rtscan.c | 9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)

diff --git a/src/backend/access/rtree/rtscan.c b/src/backend/access/rtree/rtscan.c
index aa68f0db70..36a272c17c 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);