mirror of
https://github.com/postgres/postgres.git
synced 2025-05-06 19:59:18 +03:00
Fix leakage of proc-related storage in plpython's inline handler.
Per report from Andres Freund.
This commit is contained in:
parent
05f030837c
commit
f5c23ca208
@ -1,7 +1,7 @@
|
|||||||
/**********************************************************************
|
/**********************************************************************
|
||||||
* plpython.c - python as a procedural language for PostgreSQL
|
* plpython.c - python as a procedural language for PostgreSQL
|
||||||
*
|
*
|
||||||
* $PostgreSQL: pgsql/src/pl/plpython/plpython.c,v 1.142 2010/04/30 19:15:45 tgl Exp $
|
* $PostgreSQL: pgsql/src/pl/plpython/plpython.c,v 1.143 2010/05/01 17:04:38 tgl Exp $
|
||||||
*
|
*
|
||||||
*********************************************************************
|
*********************************************************************
|
||||||
*/
|
*/
|
||||||
@ -541,12 +541,15 @@ plpython_inline_handler(PG_FUNCTION_ARGS)
|
|||||||
}
|
}
|
||||||
PG_CATCH();
|
PG_CATCH();
|
||||||
{
|
{
|
||||||
|
PLy_procedure_delete(proc);
|
||||||
PLy_curr_procedure = save_curr_proc;
|
PLy_curr_procedure = save_curr_proc;
|
||||||
PyErr_Clear();
|
PyErr_Clear();
|
||||||
PG_RE_THROW();
|
PG_RE_THROW();
|
||||||
}
|
}
|
||||||
PG_END_TRY();
|
PG_END_TRY();
|
||||||
|
|
||||||
|
PLy_procedure_delete(proc);
|
||||||
|
|
||||||
/* Pop the error context stack */
|
/* Pop the error context stack */
|
||||||
error_context_stack = plerrcontext.previous;
|
error_context_stack = plerrcontext.previous;
|
||||||
|
|
||||||
@ -1664,6 +1667,7 @@ PLy_procedure_delete(PLyProcedure *proc)
|
|||||||
}
|
}
|
||||||
if (proc->argnames)
|
if (proc->argnames)
|
||||||
PLy_free(proc->argnames);
|
PLy_free(proc->argnames);
|
||||||
|
PLy_free(proc);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user