Temporary varchar patch.
authorBruce Momjian
Fri, 16 Jan 1998 05:03:45 +0000 (05:03 +0000)
committerBruce Momjian
Fri, 16 Jan 1998 05:03:45 +0000 (05:03 +0000)
src/backend/executor/execAmi.c

index 4f76237b0b2c49cc1d6df398d2ff07853f9efeb6..675a58d649f7c48bf5d69ad3e08b720916b2752e 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *   $Header: /cvsroot/pgsql/src/backend/executor/execAmi.c,v 1.14 1998/01/07 21:02:36 momjian Exp $
+ *   $Header: /cvsroot/pgsql/src/backend/executor/execAmi.c,v 1.15 1998/01/16 05:03:45 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -42,6 +42,7 @@
 #include "access/genam.h"
 #include "access/heapam.h"
 #include "catalog/heap.h"
+#include "catalog/pg_type.h"
 
 static Pointer
 ExecBeginScan(Relation relation, int nkeys, ScanKey skeys,
@@ -124,6 +125,31 @@ ExecOpenR(Oid relationOid, bool isindex)
    if (relation == NULL)
        elog(DEBUG, "ExecOpenR: relation == NULL, heap_open failed.");
 
+   {
+       int i;
+       Relation trel = palloc(sizeof(RelationData));
+       TupleDesc tdesc = palloc(sizeof(struct tupleDesc));
+       AttributeTupleForm *tatt =
+               palloc(sizeof(AttributeTupleForm*)*relation->rd_att->natts);
+
+       memcpy(trel, relation, sizeof(RelationData));
+       memcpy(tdesc, relation->rd_att, sizeof(struct tupleDesc));
+       trel->rd_att = tdesc;
+       tdesc->attrs = tatt;
+       
+       for (i = 0; i < relation->rd_att->natts; i++)
+       {
+           if (relation->rd_att->attrs[i]->atttypid != VARCHAROID)
+               tdesc->attrs[i] = relation->rd_att->attrs[i];
+           else
+           {
+               tdesc->attrs[i] = palloc(sizeof(FormData_pg_attribute));
+               memcpy(tdesc->attrs[i], relation->rd_att->attrs[i],
+                                           sizeof(FormData_pg_attribute));
+               tdesc->attrs[i]->attlen = -1;
+           }
+       }
+   }
    return relation;
 }