/*------------------------------------------------------------------------- * * clauses.h * prototypes for clauses.c. * * * Copyright (c) 1994, Regents of the University of California * * $Id: clauses.h,v 1.28 1999/08/16 02:17:44 tgl Exp $ * *------------------------------------------------------------------------- */ #ifndef CLAUSES_H #define CLAUSES_H #include "nodes/relation.h" extern Expr *make_clause(int type, Node *oper, List *args); extern bool is_opclause(Node *clause); extern Expr *make_opclause(Oper *op, Var *leftop, Var *rightop); extern Var *get_leftop(Expr *clause); extern Var *get_rightop(Expr *clause); extern bool is_funcclause(Node *clause); extern Expr *make_funcclause(Func *func, List *funcargs); extern bool or_clause(Node *clause); extern Expr *make_orclause(List *orclauses); extern bool not_clause(Node *clause); extern Expr *make_notclause(Expr *notclause); extern Expr *get_notclausearg(Expr *notclause); extern bool and_clause(Node *clause); extern Expr *make_andclause(List *andclauses); extern Expr *make_ands_explicit(List *andclauses); extern List *make_ands_implicit(Expr *clause); extern List *pull_constant_clauses(List *quals, List **constantQual); extern void clause_get_relids_vars(Node *clause, Relids *relids, List **vars); extern int NumRelids(Node *clause); extern List *fix_opids(List *clauses); extern void get_relattval(Node *clause, int targetrelid, int *relid, AttrNumber *attno, Datum *constval, int *flag); extern void get_rels_atts(Node *clause, int *relid1, AttrNumber *attno1, int *relid2, AttrNumber *attno2); extern void CommuteClause(Expr *clause); extern bool expression_tree_walker(Node *node, bool (*walker) (), void *context); extern Node *expression_tree_mutator(Node *node, Node * (*mutator) (), void *context); #define is_subplan(clause) ((Node*) (clause) != NULL && \ nodeTag((Node*) (clause)) == T_Expr && \ ((Expr *) (clause))->opType == SUBPLAN_EXPR) #endif /* CLAUSES_H */