From 610dfa6d5560ebcd72ecca82c64c91503efc9bc5 Mon Sep 17 00:00:00 2001 From: Tom Lane Date: Sun, 21 Nov 1999 23:25:47 +0000 Subject: Combine index_info and find_secondary_indexes into a single routine that returns a list of RelOptInfos, eliminating the need for static state in index_info. That static state was a direct cause of coredumps; if anything decided to elog(ERROR) partway through an index_info search of pg_index, the next query would try to close a scan pointer that was pointing at no-longer-valid memory. Another example of the reasons to avoid static state variables... --- src/include/optimizer/plancat.h | 33 ++++++--------------------------- 1 file changed, 6 insertions(+), 27 deletions(-) (limited to 'src/include') diff --git a/src/include/optimizer/plancat.h b/src/include/optimizer/plancat.h index 9a12ecb1d8c..34c853d68f8 100644 --- a/src/include/optimizer/plancat.h +++ b/src/include/optimizer/plancat.h @@ -6,7 +6,7 @@ * * Copyright (c) 1994, Regents of the University of California * - * $Id: plancat.h,v 1.13 1999/07/25 23:07:23 tgl Exp $ + * $Id: plancat.h,v 1.14 1999/11/21 23:25:42 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -15,32 +15,11 @@ #include "nodes/parsenodes.h" -/* - * transient data structure to hold return value of index_info. Note that - * indexkeys, orderOprs and classlist is "null-terminated". - */ -typedef struct IdxInfoRetval -{ - Oid relid; /* OID of the index relation (not the OID - * of the relation being indexed) */ - Oid relam; /* OID of the pg_am of this index */ - int pages; /* number of pages in the index relation */ - int tuples; /* number of tuples in the index relation */ - int *indexkeys; /* keys over which we're indexing */ - Oid *orderOprs; /* operators used for ordering purposes */ - Oid *classlist; /* classes of AM operators */ - Oid indproc; - Node *indpred; -} IdxInfoRetval; - - -extern void relation_info(Query *root, - Oid relid, - bool *hashindex, int *pages, - int *tuples); - -extern bool index_info(Query *root, - bool first, int relid, IdxInfoRetval *info); + +extern void relation_info(Query *root, Index relid, + bool *hasindex, int *pages, int *tuples); + +extern List *find_secondary_indexes(Query *root, Index relid); extern Cost restriction_selectivity(Oid functionObjectId, Oid operatorObjectId, -- cgit v1.2.3