diff --git a/doc/src/sgml/spi.sgml b/doc/src/sgml/spi.sgml index ad8a5f084f9..c87a136bdd4 100644 --- a/doc/src/sgml/spi.sgml +++ b/doc/src/sgml/spi.sgml @@ -1,5 +1,5 @@ @@ -199,6 +199,68 @@ int SPI_finish(void) + + + SPI_push + + + + SPI_push + pushes SPI stack to allow recursive SPI calls + + + SPI_push + + + +void SPI_push(void) + + + + + Description + + + SPI_push pushes a new environment on to the + SPI call stack, allowing recursive calls to use a new environment. + + + + + + + + + + SPI_pop + + + + SPI_pop + pops SPI stack to allow recursive SPI calls + + + SPI_pop + + + +void SPI_pop(void) + + + + + Description + + + SPI_pop pops the previous environment from the + SPI call stack. For use when returning from recursive SPI calls. + + + + + + + SPI_exec diff --git a/src/backend/executor/spi.c b/src/backend/executor/spi.c index 128a063f3c6..fb44d9d56fd 100644 --- a/src/backend/executor/spi.c +++ b/src/backend/executor/spi.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/executor/spi.c,v 1.110 2004/03/05 00:47:01 momjian Exp $ + * $PostgreSQL: pgsql/src/backend/executor/spi.c,v 1.111 2004/03/17 01:05:10 momjian Exp $ * *------------------------------------------------------------------------- */ @@ -201,12 +201,14 @@ AtEOXact_SPI(bool isCommit) SPI_tuptable = NULL; } +/* Pushes SPI stack to allow recursive SPI calls */ void SPI_push(void) { _SPI_curid++; } +/* Pops SPI stack to allow recursive SPI calls */ void SPI_pop(void) { diff --git a/src/include/executor/spi.h b/src/include/executor/spi.h index 6d0ce059a20..ac2b494b532 100644 --- a/src/include/executor/spi.h +++ b/src/include/executor/spi.h @@ -2,7 +2,7 @@ * * spi.h * - * $PostgreSQL: pgsql/src/include/executor/spi.h,v 1.42 2004/03/05 00:47:01 momjian Exp $ + * $PostgreSQL: pgsql/src/include/executor/spi.h,v 1.43 2004/03/17 01:05:10 momjian Exp $ * *------------------------------------------------------------------------- */ @@ -81,8 +81,8 @@ extern int SPI_connect(void); extern int SPI_finish(void); extern void SPI_push(void); extern void SPI_pop(void); -extern int SPI_exec(const char *src, int tcount); -extern int SPI_execp(void *plan, Datum *values, const char *Nulls, +extern int SPI_exec(const char *src, int tcount); +extern int SPI_execp(void *plan, Datum *values, const char *Nulls, int tcount); extern int SPI_execp_current(void *plan, Datum *values, const char *Nulls, bool useCurrentSnapshot, int tcount);