Commit 724c7064 authored by Tom Lane's avatar Tom Lane

Restructure plpgsql's parsing of datatype declarations to unify the

scalar and composite (rowtype) cases a little better.  This commit is
just a code-beautification operation and shouldn't make any real
difference in behavior, but it's an important preliminary step for
trying to improve plgsql's handling of rowtypes.
parent 2a22750c
This diff is collapsed.
This diff is collapsed.
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
* procedural language * procedural language
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/pl/plpgsql/src/plpgsql.h,v 1.45 2004/03/19 18:58:07 tgl Exp $ * $PostgreSQL: pgsql/src/pl/plpgsql/src/plpgsql.h,v 1.46 2004/06/03 22:56:43 tgl Exp $
* *
* This software is copyrighted by Jan Wieck - Hamburg. * This software is copyrighted by Jan Wieck - Hamburg.
* *
...@@ -58,8 +58,7 @@ enum ...@@ -58,8 +58,7 @@ enum
PLPGSQL_NSTYPE_LABEL, PLPGSQL_NSTYPE_LABEL,
PLPGSQL_NSTYPE_VAR, PLPGSQL_NSTYPE_VAR,
PLPGSQL_NSTYPE_ROW, PLPGSQL_NSTYPE_ROW,
PLPGSQL_NSTYPE_REC, PLPGSQL_NSTYPE_REC
PLPGSQL_NSTYPE_RECFIELD
}; };
/* ---------- /* ----------
...@@ -77,6 +76,18 @@ enum ...@@ -77,6 +76,18 @@ enum
PLPGSQL_DTYPE_TRIGARG PLPGSQL_DTYPE_TRIGARG
}; };
/* ----------
* Variants distinguished in PLpgSQL_type structs
* ----------
*/
enum
{
PLPGSQL_TTYPE_SCALAR, /* scalar types and domains */
PLPGSQL_TTYPE_ROW, /* composite types */
PLPGSQL_TTYPE_REC, /* RECORD pseudotype */
PLPGSQL_TTYPE_PSEUDO /* other pseudotypes */
};
/* ---------- /* ----------
* Execution tree node types * Execution tree node types
* ---------- * ----------
...@@ -143,8 +154,9 @@ typedef struct ...@@ -143,8 +154,9 @@ typedef struct
typedef struct typedef struct
{ /* Postgres data type */ { /* Postgres data type */
char *typname; char *typname; /* (simple) name of the type */
Oid typoid; /* OID of the data type */ Oid typoid; /* OID of the data type */
int ttype; /* PLPGSQL_TTYPE_ code */
int16 typlen; /* stuff copied from its pg_type entry */ int16 typlen; /* stuff copied from its pg_type entry */
bool typbyval; bool typbyval;
Oid typrelid; Oid typrelid;
...@@ -165,6 +177,17 @@ typedef struct ...@@ -165,6 +177,17 @@ typedef struct
int dno; int dno;
} PLpgSQL_datum; } PLpgSQL_datum;
/*
* The variants PLpgSQL_var, PLpgSQL_row, and PLpgSQL_rec share these
* fields
*/
typedef struct
{ /* Scalar or composite variable */
int dtype;
int dno;
char *refname;
int lineno;
} PLpgSQL_variable;
typedef struct PLpgSQL_expr typedef struct PLpgSQL_expr
{ /* SQL Query to plan and execute */ { /* SQL Query to plan and execute */
...@@ -186,7 +209,7 @@ typedef struct PLpgSQL_expr ...@@ -186,7 +209,7 @@ typedef struct PLpgSQL_expr
typedef struct typedef struct
{ /* Local variable */ { /* Scalar variable */
int dtype; int dtype;
int varno; int varno;
char *refname; char *refname;
...@@ -206,11 +229,12 @@ typedef struct ...@@ -206,11 +229,12 @@ typedef struct
typedef struct typedef struct
{ /* Rowtype */ { /* Row variable */
int dtype; int dtype;
int rowno; int rowno;
char *refname; char *refname;
int lineno; int lineno;
TupleDesc rowtupdesc; TupleDesc rowtupdesc;
/* /*
...@@ -227,7 +251,7 @@ typedef struct ...@@ -227,7 +251,7 @@ typedef struct
typedef struct typedef struct
{ /* Record of non-fixed structure */ { /* Record variable (non-fixed structure) */
int dtype; int dtype;
int recno; int recno;
char *refname; char *refname;
...@@ -630,9 +654,12 @@ extern int plpgsql_parse_dblwordtype(char *word); ...@@ -630,9 +654,12 @@ extern int plpgsql_parse_dblwordtype(char *word);
extern int plpgsql_parse_tripwordtype(char *word); extern int plpgsql_parse_tripwordtype(char *word);
extern int plpgsql_parse_wordrowtype(char *word); extern int plpgsql_parse_wordrowtype(char *word);
extern int plpgsql_parse_dblwordrowtype(char *word); extern int plpgsql_parse_dblwordrowtype(char *word);
extern PLpgSQL_type *plpgsql_parse_datatype(char *string); extern PLpgSQL_type *plpgsql_parse_datatype(const char *string);
extern PLpgSQL_row *plpgsql_build_rowtype(Oid classOid); extern PLpgSQL_type *plpgsql_build_datatype(Oid typeOid, int32 typmod);
extern void plpgsql_adddatum(PLpgSQL_datum * new); extern PLpgSQL_variable *plpgsql_build_variable(char *refname, int lineno,
PLpgSQL_type *dtype,
bool add2namespace);
extern void plpgsql_adddatum(PLpgSQL_datum *new);
extern int plpgsql_add_initdatums(int **varnos); extern int plpgsql_add_initdatums(int **varnos);
extern void plpgsql_HashTableInit(void); extern void plpgsql_HashTableInit(void);
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* procedural language * procedural language
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/pl/plpgsql/src/scan.l,v 1.34 2004/03/21 22:29:11 tgl Exp $ * $PostgreSQL: pgsql/src/pl/plpgsql/src/scan.l,v 1.35 2004/06/03 22:56:43 tgl Exp $
* *
* This software is copyrighted by Jan Wieck - Hamburg. * This software is copyrighted by Jan Wieck - Hamburg.
* *
...@@ -167,7 +167,6 @@ null { return K_NULL; } ...@@ -167,7 +167,6 @@ null { return K_NULL; }
open { return K_OPEN; } open { return K_OPEN; }
perform { return K_PERFORM; } perform { return K_PERFORM; }
raise { return K_RAISE; } raise { return K_RAISE; }
record { return K_RECORD; }
rename { return K_RENAME; } rename { return K_RENAME; }
result_oid { return K_RESULT_OID; } result_oid { return K_RESULT_OID; }
return { return K_RETURN; } return { return K_RETURN; }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment