mirror of
https://git.postgresql.org/git/postgresql.git
synced 2026-02-06 12:17:39 +08:00
CREATE AGGREGATE aggname (input_type) (parameter_list) along with the old syntax where the input type was named in the parameter list. This fits more naturally with the way that the aggregate is identified in DROP AGGREGATE and other utility commands; furthermore it has a natural extension to handle multiple-input aggregates, where the basetype-parameter method would get ugly. In fact, this commit fixes the grammar and all the utility commands to support multiple-input aggregates; but DefineAggregate rejects it because the executor isn't fixed yet. I didn't do anything about treating agg(*) as a zero-input aggregate instead of artificially making it a one-input aggregate, but that should be considered in combination with supporting multi-input aggregates.
83 lines
2.5 KiB
C
83 lines
2.5 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* parse_func.h
|
|
*
|
|
*
|
|
*
|
|
* Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* $PostgreSQL: pgsql/src/include/parser/parse_func.h,v 1.56 2006/04/15 17:45:41 tgl Exp $
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef PARSER_FUNC_H
|
|
#define PARSER_FUNC_H
|
|
|
|
#include "catalog/namespace.h"
|
|
#include "parser/parse_node.h"
|
|
|
|
|
|
/*
|
|
* This structure is used to explore the inheritance hierarchy above
|
|
* nodes in the type tree in order to disambiguate among polymorphic
|
|
* functions.
|
|
*/
|
|
typedef struct _InhPaths
|
|
{
|
|
int nsupers; /* number of superclasses */
|
|
Oid self; /* this class */
|
|
Oid *supervec; /* vector of superclasses */
|
|
} InhPaths;
|
|
|
|
/* Result codes for func_get_detail */
|
|
typedef enum
|
|
{
|
|
FUNCDETAIL_NOTFOUND, /* no matching function */
|
|
FUNCDETAIL_MULTIPLE, /* too many matching functions */
|
|
FUNCDETAIL_NORMAL, /* found a matching regular function */
|
|
FUNCDETAIL_AGGREGATE, /* found a matching aggregate function */
|
|
FUNCDETAIL_COERCION /* it's a type coercion request */
|
|
} FuncDetailCode;
|
|
|
|
|
|
extern Node *ParseFuncOrColumn(ParseState *pstate,
|
|
List *funcname, List *fargs,
|
|
bool agg_star, bool agg_distinct, bool is_column,
|
|
int location);
|
|
|
|
extern FuncDetailCode func_get_detail(List *funcname, List *fargs,
|
|
int nargs, Oid *argtypes,
|
|
Oid *funcid, Oid *rettype,
|
|
bool *retset, Oid **true_typeids);
|
|
|
|
extern int func_match_argtypes(int nargs,
|
|
Oid *input_typeids,
|
|
FuncCandidateList raw_candidates,
|
|
FuncCandidateList *candidates);
|
|
|
|
extern FuncCandidateList func_select_candidate(int nargs,
|
|
Oid *input_typeids,
|
|
FuncCandidateList candidates);
|
|
|
|
extern bool typeInheritsFrom(Oid subclassTypeId, Oid superclassTypeId);
|
|
|
|
extern void make_fn_arguments(ParseState *pstate,
|
|
List *fargs,
|
|
Oid *actual_arg_types,
|
|
Oid *declared_arg_types);
|
|
|
|
extern const char *funcname_signature_string(const char *funcname,
|
|
int nargs, const Oid *argtypes);
|
|
extern const char *func_signature_string(List *funcname,
|
|
int nargs, const Oid *argtypes);
|
|
|
|
extern Oid LookupFuncName(List *funcname, int nargs, const Oid *argtypes,
|
|
bool noError);
|
|
extern Oid LookupFuncNameTypeNames(List *funcname, List *argtypes,
|
|
bool noError);
|
|
extern Oid LookupAggNameTypeNames(List *aggname, List *argtypes,
|
|
bool noError);
|
|
|
|
#endif /* PARSE_FUNC_H */
|