PostgreSQL Source Code  git master
parse_expr.h File Reference
Include dependency graph for parse_expr.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Functions

NodetransformExpr (ParseState *pstate, Node *expr, ParseExprKind exprKind)
 
const char * ParseExprKindName (ParseExprKind exprKind)
 

Variables

PGDLLIMPORT bool Transform_null_equals
 

Function Documentation

◆ ParseExprKindName()

const char* ParseExprKindName ( ParseExprKind  exprKind)

Definition at line 3113 of file parse_expr.c.

3114 {
3115  switch (exprKind)
3116  {
3117  case EXPR_KIND_NONE:
3118  return "invalid expression context";
3119  case EXPR_KIND_OTHER:
3120  return "extension expression";
3121  case EXPR_KIND_JOIN_ON:
3122  return "JOIN/ON";
3123  case EXPR_KIND_JOIN_USING:
3124  return "JOIN/USING";
3126  return "sub-SELECT in FROM";
3128  return "function in FROM";
3129  case EXPR_KIND_WHERE:
3130  return "WHERE";
3131  case EXPR_KIND_POLICY:
3132  return "POLICY";
3133  case EXPR_KIND_HAVING:
3134  return "HAVING";
3135  case EXPR_KIND_FILTER:
3136  return "FILTER";
3138  return "window PARTITION BY";
3140  return "window ORDER BY";
3142  return "window RANGE";
3144  return "window ROWS";
3146  return "window GROUPS";
3148  return "SELECT";
3150  return "INSERT";
3153  return "UPDATE";
3154  case EXPR_KIND_MERGE_WHEN:
3155  return "MERGE WHEN";
3156  case EXPR_KIND_GROUP_BY:
3157  return "GROUP BY";
3158  case EXPR_KIND_ORDER_BY:
3159  return "ORDER BY";
3160  case EXPR_KIND_DISTINCT_ON:
3161  return "DISTINCT ON";
3162  case EXPR_KIND_LIMIT:
3163  return "LIMIT";
3164  case EXPR_KIND_OFFSET:
3165  return "OFFSET";
3166  case EXPR_KIND_RETURNING:
3168  return "RETURNING";
3169  case EXPR_KIND_VALUES:
3171  return "VALUES";
3174  return "CHECK";
3177  return "DEFAULT";
3179  return "index expression";
3181  return "index predicate";
3183  return "statistics expression";
3185  return "USING";
3187  return "EXECUTE";
3189  return "WHEN";
3191  return "partition bound";
3193  return "PARTITION BY";
3195  return "CALL";
3196  case EXPR_KIND_COPY_WHERE:
3197  return "WHERE";
3199  return "GENERATED AS";
3200  case EXPR_KIND_CYCLE_MARK:
3201  return "CYCLE";
3202 
3203  /*
3204  * There is intentionally no default: case here, so that the
3205  * compiler will warn if we add a new ParseExprKind without
3206  * extending this switch. If we do see an unrecognized value at
3207  * runtime, we'll fall through to the "unrecognized" return.
3208  */
3209  }
3210  return "unrecognized expression kind";
3211 }
@ EXPR_KIND_EXECUTE_PARAMETER
Definition: parse_node.h:76
@ EXPR_KIND_DOMAIN_CHECK
Definition: parse_node.h:69
@ EXPR_KIND_COPY_WHERE
Definition: parse_node.h:82
@ EXPR_KIND_COLUMN_DEFAULT
Definition: parse_node.h:70
@ EXPR_KIND_DISTINCT_ON
Definition: parse_node.h:61
@ EXPR_KIND_MERGE_WHEN
Definition: parse_node.h:58
@ EXPR_KIND_STATS_EXPRESSION
Definition: parse_node.h:74
@ EXPR_KIND_INDEX_EXPRESSION
Definition: parse_node.h:72
@ EXPR_KIND_MERGE_RETURNING
Definition: parse_node.h:65
@ EXPR_KIND_PARTITION_BOUND
Definition: parse_node.h:79
@ EXPR_KIND_FUNCTION_DEFAULT
Definition: parse_node.h:71
@ EXPR_KIND_WINDOW_FRAME_RANGE
Definition: parse_node.h:51
@ EXPR_KIND_VALUES
Definition: parse_node.h:66
@ EXPR_KIND_FROM_SUBSELECT
Definition: parse_node.h:44
@ EXPR_KIND_POLICY
Definition: parse_node.h:78
@ EXPR_KIND_WINDOW_FRAME_GROUPS
Definition: parse_node.h:53
@ EXPR_KIND_PARTITION_EXPRESSION
Definition: parse_node.h:80
@ EXPR_KIND_JOIN_USING
Definition: parse_node.h:43
@ EXPR_KIND_INDEX_PREDICATE
Definition: parse_node.h:73
@ EXPR_KIND_ORDER_BY
Definition: parse_node.h:60
@ EXPR_KIND_OFFSET
Definition: parse_node.h:63
@ EXPR_KIND_JOIN_ON
Definition: parse_node.h:42
@ EXPR_KIND_HAVING
Definition: parse_node.h:47
@ EXPR_KIND_INSERT_TARGET
Definition: parse_node.h:55
@ EXPR_KIND_ALTER_COL_TRANSFORM
Definition: parse_node.h:75
@ EXPR_KIND_LIMIT
Definition: parse_node.h:62
@ EXPR_KIND_WHERE
Definition: parse_node.h:46
@ EXPR_KIND_UPDATE_TARGET
Definition: parse_node.h:57
@ EXPR_KIND_SELECT_TARGET
Definition: parse_node.h:54
@ EXPR_KIND_RETURNING
Definition: parse_node.h:64
@ EXPR_KIND_GENERATED_COLUMN
Definition: parse_node.h:83
@ EXPR_KIND_NONE
Definition: parse_node.h:40
@ EXPR_KIND_CALL_ARGUMENT
Definition: parse_node.h:81
@ EXPR_KIND_GROUP_BY
Definition: parse_node.h:59
@ EXPR_KIND_OTHER
Definition: parse_node.h:41
@ EXPR_KIND_FROM_FUNCTION
Definition: parse_node.h:45
@ EXPR_KIND_TRIGGER_WHEN
Definition: parse_node.h:77
@ EXPR_KIND_FILTER
Definition: parse_node.h:48
@ EXPR_KIND_UPDATE_SOURCE
Definition: parse_node.h:56
@ EXPR_KIND_CHECK_CONSTRAINT
Definition: parse_node.h:68
@ EXPR_KIND_WINDOW_PARTITION
Definition: parse_node.h:49
@ EXPR_KIND_CYCLE_MARK
Definition: parse_node.h:84
@ EXPR_KIND_WINDOW_FRAME_ROWS
Definition: parse_node.h:52
@ EXPR_KIND_WINDOW_ORDER
Definition: parse_node.h:50
@ EXPR_KIND_VALUES_SINGLE
Definition: parse_node.h:67

References EXPR_KIND_ALTER_COL_TRANSFORM, EXPR_KIND_CALL_ARGUMENT, EXPR_KIND_CHECK_CONSTRAINT, EXPR_KIND_COLUMN_DEFAULT, EXPR_KIND_COPY_WHERE, EXPR_KIND_CYCLE_MARK, EXPR_KIND_DISTINCT_ON, EXPR_KIND_DOMAIN_CHECK, EXPR_KIND_EXECUTE_PARAMETER, EXPR_KIND_FILTER, EXPR_KIND_FROM_FUNCTION, EXPR_KIND_FROM_SUBSELECT, EXPR_KIND_FUNCTION_DEFAULT, EXPR_KIND_GENERATED_COLUMN, EXPR_KIND_GROUP_BY, EXPR_KIND_HAVING, EXPR_KIND_INDEX_EXPRESSION, EXPR_KIND_INDEX_PREDICATE, EXPR_KIND_INSERT_TARGET, EXPR_KIND_JOIN_ON, EXPR_KIND_JOIN_USING, EXPR_KIND_LIMIT, EXPR_KIND_MERGE_RETURNING, EXPR_KIND_MERGE_WHEN, EXPR_KIND_NONE, EXPR_KIND_OFFSET, EXPR_KIND_ORDER_BY, EXPR_KIND_OTHER, EXPR_KIND_PARTITION_BOUND, EXPR_KIND_PARTITION_EXPRESSION, EXPR_KIND_POLICY, EXPR_KIND_RETURNING, EXPR_KIND_SELECT_TARGET, EXPR_KIND_STATS_EXPRESSION, EXPR_KIND_TRIGGER_WHEN, EXPR_KIND_UPDATE_SOURCE, EXPR_KIND_UPDATE_TARGET, EXPR_KIND_VALUES, EXPR_KIND_VALUES_SINGLE, EXPR_KIND_WHERE, EXPR_KIND_WINDOW_FRAME_GROUPS, EXPR_KIND_WINDOW_FRAME_RANGE, EXPR_KIND_WINDOW_FRAME_ROWS, EXPR_KIND_WINDOW_ORDER, and EXPR_KIND_WINDOW_PARTITION.

Referenced by check_agglevels_and_constraints(), check_srf_call_placement(), checkTargetlistEntrySQL92(), findTargetlistEntrySQL92(), and transformWindowFuncCall().

◆ transformExpr()

Node* transformExpr ( ParseState pstate,
Node expr,
ParseExprKind  exprKind 
)

Definition at line 120 of file parse_expr.c.

121 {
122  Node *result;
123  ParseExprKind sv_expr_kind;
124 
125  /* Save and restore identity of expression type we're parsing */
126  Assert(exprKind != EXPR_KIND_NONE);
127  sv_expr_kind = pstate->p_expr_kind;
128  pstate->p_expr_kind = exprKind;
129 
130  result = transformExprRecurse(pstate, expr);
131 
132  pstate->p_expr_kind = sv_expr_kind;
133 
134  return result;
135 }
#define Assert(condition)
Definition: c.h:858
static Node * transformExprRecurse(ParseState *pstate, Node *expr)
Definition: parse_expr.c:138
ParseExprKind
Definition: parse_node.h:39
Definition: nodes.h:129
ParseExprKind p_expr_kind
Definition: parse_node.h:214

References Assert, EXPR_KIND_NONE, ParseState::p_expr_kind, and transformExprRecurse().

Referenced by analyzeCTE(), array_subscript_transform(), cookConstraint(), cookDefault(), DoCopy(), domainAddCheckConstraint(), EvaluateParams(), ExpandIndirectionStar(), findTargetlistEntrySQL99(), hstore_subscript_transform(), interpret_function_parameter_list(), jsonb_subscript_transform(), resolve_unique_index_expr(), transformAlterTableStmt(), transformCallStmt(), transformExpressionList(), transformFrameOffset(), transformFuncCall(), transformGroupingFunc(), transformIndexStmt(), transformJoinUsingClause(), transformJsonTable(), transformJsonTableColumns(), transformLimitClause(), transformMergeStmt(), transformOnConflictArbiter(), transformPartitionBoundValue(), transformPartitionSpec(), transformPLAssignStmt(), transformRangeFunction(), transformRangeTableFunc(), transformRangeTableSample(), transformReturnStmt(), transformStatsStmt(), transformTargetEntry(), and transformWhereClause().

Variable Documentation

◆ Transform_null_equals

PGDLLIMPORT bool Transform_null_equals
extern

Definition at line 46 of file parse_expr.c.

Referenced by transformAExprOp().