OSDN Git Service

8.4 pgindent run, with new combined Linux/FreeBSD/MinGW typedef list
[pg-rex/syncrep.git] / src / include / optimizer / plancat.h
index 307b51c..c829ac1 100644 (file)
@@ -4,9 +4,10 @@
  *       prototypes for plancat.c.
  *
  *
- * Copyright (c) 1994, Regents of the University of California
+ * Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
+ * Portions Copyright (c) 1994, Regents of the University of California
  *
- * $Id: plancat.h,v 1.15 2000/01/09 00:26:47 tgl Exp $
+ * $PostgreSQL: pgsql/src/include/optimizer/plancat.h,v 1.54 2009/06/11 14:49:11 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
 #define PLANCAT_H
 
 #include "nodes/relation.h"
+#include "utils/relcache.h"
 
+/* Hook for plugins to get control in get_relation_info() */
+typedef void (*get_relation_info_hook_type) (PlannerInfo *root,
+                                                                                                                Oid relationObjectId,
+                                                                                                                bool inhparent,
+                                                                                                                RelOptInfo *rel);
+extern PGDLLIMPORT get_relation_info_hook_type get_relation_info_hook;
 
-extern void relation_info(Query *root, Index relid,
-                                                 bool *hasindex, long *pages, double *tuples);
 
-extern List *find_secondary_indexes(Query *root, Index relid);
+extern void get_relation_info(PlannerInfo *root, Oid relationObjectId,
+                                 bool inhparent, RelOptInfo *rel);
 
-extern List *find_inheritance_children(Oid inhparent);
+extern void estimate_rel_size(Relation rel, int32 *attr_widths,
+                                 BlockNumber *pages, double *tuples);
 
-extern Selectivity restriction_selectivity(Oid functionObjectId,
-                                               Oid operatorObjectId,
-                                               Oid relationObjectId,
-                                               AttrNumber attributeNumber,
-                                               Datum constValue,
-                                               int constFlag);
+extern bool relation_excluded_by_constraints(PlannerInfo *root,
+                                                                RelOptInfo *rel, RangeTblEntry *rte);
 
-extern void index_selectivity(Query *root, RelOptInfo *rel,
-                                                         IndexOptInfo *index, List *indexquals,
-                                                         long *idxPages, Selectivity *idxSelec);
+extern List *build_physical_tlist(PlannerInfo *root, RelOptInfo *rel);
 
-extern Selectivity join_selectivity(Oid functionObjectId, Oid operatorObjectId,
-                                Oid relationObjectId1, AttrNumber attributeNumber1,
-                                Oid relationObjectId2, AttrNumber attributeNumber2);
+extern bool has_unique_index(RelOptInfo *rel, AttrNumber attno);
 
-#endif  /* PLANCAT_H */
+extern Selectivity restriction_selectivity(PlannerInfo *root,
+                                               Oid operator,
+                                               List *args,
+                                               int varRelid);
+
+extern Selectivity join_selectivity(PlannerInfo *root,
+                                Oid operator,
+                                List *args,
+                                JoinType jointype,
+                                SpecialJoinInfo *sjinfo);
+
+#endif   /* PLANCAT_H */