mirror of
https://github.com/postgres/postgres.git
synced 2025-08-18 12:22:09 +03:00
Create a stack of pl/python "execution contexts".
This replaces the former global variable PLy_curr_procedure, and provides a place to stash per-call-level information. In particular we create a per-call-level scratch memory context. For the moment, the scratch context is just used to avoid leaking memory from datatype output function calls in PLyDict_FromTuple. There probably will be more use-cases in future. Although this is a fix for a pre-existing memory leakage bug, it seems sufficiently invasive to not want to back-patch; it feels better as part of the major rearrangement of plpython code that we've already done as part of 9.2. Jan Urbański
This commit is contained in:
@@ -14,6 +14,7 @@
|
||||
#include "plpy_cursorobject.h"
|
||||
|
||||
#include "plpy_elog.h"
|
||||
#include "plpy_main.h"
|
||||
#include "plpy_planobject.h"
|
||||
#include "plpy_procedure.h"
|
||||
#include "plpy_resultobject.h"
|
||||
@@ -119,6 +120,7 @@ PLy_cursor_query(const char *query)
|
||||
|
||||
PG_TRY();
|
||||
{
|
||||
PLyExecutionContext *exec_ctx = PLy_current_execution_context();
|
||||
SPIPlanPtr plan;
|
||||
Portal portal;
|
||||
|
||||
@@ -130,7 +132,7 @@ PLy_cursor_query(const char *query)
|
||||
SPI_result_code_string(SPI_result));
|
||||
|
||||
portal = SPI_cursor_open(NULL, plan, NULL, NULL,
|
||||
PLy_curr_procedure->fn_readonly);
|
||||
exec_ctx->curr_proc->fn_readonly);
|
||||
SPI_freeplan(plan);
|
||||
|
||||
if (portal == NULL)
|
||||
@@ -207,6 +209,7 @@ PLy_cursor_plan(PyObject *ob, PyObject *args)
|
||||
|
||||
PG_TRY();
|
||||
{
|
||||
PLyExecutionContext *exec_ctx = PLy_current_execution_context();
|
||||
Portal portal;
|
||||
char *volatile nulls;
|
||||
volatile int j;
|
||||
@@ -253,7 +256,7 @@ PLy_cursor_plan(PyObject *ob, PyObject *args)
|
||||
}
|
||||
|
||||
portal = SPI_cursor_open(NULL, plan->plan, plan->values, nulls,
|
||||
PLy_curr_procedure->fn_readonly);
|
||||
exec_ctx->curr_proc->fn_readonly);
|
||||
if (portal == NULL)
|
||||
elog(ERROR, "SPI_cursor_open() failed: %s",
|
||||
SPI_result_code_string(SPI_result));
|
||||
|
Reference in New Issue
Block a user