49 return "<unknown procedure>";
87 elog(
ERROR,
"cache lookup failed for function %u", fn_oid);
157 rv =
snprintf(procName,
sizeof(procName),
158 "__plpython_procedure_%s_%u",
161 if (rv >=
sizeof(procName) || rv < 0)
162 elog(
ERROR,
"procedure name would overrun buffer");
165 for (ptr = procName; *ptr; ptr++)
167 if (!((*ptr >=
'A' && *ptr <=
'Z') ||
168 (*ptr >=
'a' && *ptr <=
'z') ||
169 (*ptr >=
'0' && *ptr <=
'9')))
175 "PL/Python function",
185 Datum protrftypes_datum;
196 proc->
fn_readonly = (procStruct->provolatile != PROVOLATILE_VOLATILE);
197 proc->
is_setof = procStruct->proretset;
198 proc->
is_procedure = (procStruct->prokind == PROKIND_PROCEDURE);
204 proc->
langid = procStruct->prolang;
206 Anum_pg_proc_protrftypes,
221 Oid rettype = procStruct->prorettype;
227 elog(
ERROR,
"cache lookup failed for type %u", rettype);
231 if (rvTypeStruct->typtype == TYPTYPE_PSEUDO)
233 if (rettype == VOIDOID ||
234 rettype == RECORDOID)
236 else if (rettype == TRIGGEROID || rettype == EVENT_TRIGGEROID)
238 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
239 errmsg(
"trigger functions can only be called as triggers")));
242 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
243 errmsg(
"PL/Python functions cannot return type %s",
270 if (procStruct->pronargs)
287 for (
i = 0;
i < total;
i++)
289 if (modes[
i] != PROARGMODE_OUT &&
290 modes[
i] != PROARGMODE_TABLE)
299 for (
i = pos = 0;
i < total;
i++)
305 (modes[
i] == PROARGMODE_OUT ||
306 modes[
i] == PROARGMODE_TABLE))
309 Assert(
types[
i] == procStruct->proargtypes.values[pos]);
318 if (argTypeStruct->typtype == TYPTYPE_PSEUDO)
320 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
321 errmsg(
"PL/Python functions cannot accept type %s",
342 Anum_pg_proc_prosrc);
367 PyObject *crv = NULL;
388 code0 = Py_CompileString(msrc,
"<string>", Py_file_input);
390 crv = PyEval_EvalCode(code0, proc->
globals, NULL);
404 if (clen < 0 || clen >=
sizeof(call))
405 elog(
ERROR,
"string would overflow buffer");
406 proc->
code = Py_CompileString(call,
"<string>", Py_eval_input);
407 if (proc->
code != NULL)
412 PLy_elog(
ERROR,
"could not compile PL/Python function \"%s\"",
415 PLy_elog(
ERROR,
"could not compile anonymous PL/Python code block");
421 Py_XDECREF(proc->
code);
456 mlen = (strlen(src) * 2) + strlen(
name) + 16;
460 Assert(plen >= 0 && plen < mlen);
467 if (*sp ==
'\r' && *(sp + 1) ==
'\n')
470 if (*sp ==
'\n' || *sp ==
'\r')
483 if (mp > (mrc + mlen))
484 elog(
FATAL,
"buffer overrun in PLy_procedure_munge_source");
#define TextDatumGetCString(d)
void * hash_search(HTAB *hashp, const void *keyPtr, HASHACTION action, bool *foundPtr)
HTAB * hash_create(const char *tabname, int64 nelem, const HASHCTL *info, int flags)
int errcode(int sqlerrcode)
int errmsg(const char *fmt,...)
#define ereport(elevel,...)
int get_func_arg_info(HeapTuple procTup, Oid **p_argtypes, char ***p_argnames, char **p_argmodes)
Assert(PointerIsAligned(start, uint64))
#define HeapTupleIsValid(tuple)
static TransactionId HeapTupleHeaderGetRawXmin(const HeapTupleHeaderData *tup)
static void * GETSTRUCT(const HeapTupleData *tuple)
bool ItemPointerEquals(const ItemPointerData *pointer1, const ItemPointerData *pointer2)
char * MemoryContextStrdup(MemoryContext context, const char *string)
char * pstrdup(const char *in)
void pfree(void *pointer)
void * palloc0(Size size)
MemoryContext TopMemoryContext
void MemoryContextDelete(MemoryContext context)
void MemoryContextSetIdentifier(MemoryContext context, const char *id)
#define AllocSetContextCreate
#define ALLOCSET_DEFAULT_SIZES
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
List * oid_array_to_list(Datum datum)
FormData_pg_proc * Form_pg_proc
FormData_pg_type * Form_pg_type
PyObject * PLy_interp_globals
char * PLy_procedure_name(PLyProcedure *proc)
void init_procedure_caches(void)
static char * PLy_procedure_munge_source(const char *name, const char *src)
static PLyProcedure * PLy_procedure_create(HeapTuple procTup, Oid fn_oid, PLyTrigType is_trigger)
PLyProcedure * PLy_procedure_get(Oid fn_oid, Oid fn_rel, PLyTrigType is_trigger)
static bool PLy_procedure_valid(PLyProcedure *proc, HeapTuple procTup)
static HTAB * PLy_procedure_cache
void PLy_procedure_compile(PLyProcedure *proc, const char *src)
void PLy_procedure_delete(PLyProcedure *proc)
struct PLyProcedureKey PLyProcedureKey
struct PLyProcedureEntry PLyProcedureEntry
void PLy_output_setup_func(PLyObToDatum *arg, MemoryContext arg_mcxt, Oid typeOid, int32 typmod, PLyProcedure *proc)
void PLy_input_setup_func(PLyDatumToOb *arg, MemoryContext arg_mcxt, Oid typeOid, int32 typmod, PLyProcedure *proc)
static Datum ObjectIdGetDatum(Oid X)
void ReleaseSysCache(HeapTuple tuple)
HeapTuple SearchSysCache1(int cacheId, Datum key1)
Datum SysCacheGetAttr(int cacheId, HeapTuple tup, AttrNumber attributeNumber, bool *isNull)
Datum SysCacheGetAttrNotNull(int cacheId, HeapTuple tup, AttrNumber attributeNumber)