49 return "<unknown procedure>";
82 elog(
ERROR,
"cache lookup failed for function %u", fn_oid);
146 rv =
snprintf(procName,
sizeof(procName),
147 "__plpython_procedure_%s_%u",
150 if (rv >=
sizeof(procName) || rv < 0)
151 elog(
ERROR,
"procedure name would overrun buffer");
154 for (ptr = procName; *ptr; ptr++)
156 if (!((*ptr >=
'A' && *ptr <=
'Z') ||
157 (*ptr >=
'a' && *ptr <=
'z') ||
158 (*ptr >=
'0' && *ptr <=
'9')))
164 "PL/Python function",
174 Datum protrftypes_datum;
185 proc->
fn_readonly = (procStruct->provolatile != PROVOLATILE_VOLATILE);
186 proc->
is_setof = procStruct->proretset;
187 proc->
is_procedure = (procStruct->prokind == PROKIND_PROCEDURE);
193 proc->
langid = procStruct->prolang;
195 Anum_pg_proc_protrftypes,
210 Oid rettype = procStruct->prorettype;
216 elog(
ERROR,
"cache lookup failed for type %u", rettype);
220 if (rvTypeStruct->typtype == TYPTYPE_PSEUDO)
222 if (rettype == VOIDOID ||
223 rettype == RECORDOID)
225 else if (rettype == TRIGGEROID || rettype == EVENT_TRIGGEROID)
227 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
228 errmsg(
"trigger functions can only be called as triggers")));
231 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
232 errmsg(
"PL/Python functions cannot return type %s",
259 if (procStruct->pronargs)
276 for (
i = 0;
i < total;
i++)
278 if (modes[
i] != PROARGMODE_OUT &&
279 modes[
i] != PROARGMODE_TABLE)
288 for (
i = pos = 0;
i < total;
i++)
294 (modes[
i] == PROARGMODE_OUT ||
295 modes[
i] == PROARGMODE_TABLE))
298 Assert(
types[
i] == procStruct->proargtypes.values[pos]);
307 if (argTypeStruct->typtype == TYPTYPE_PSEUDO)
309 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
310 errmsg(
"PL/Python functions cannot accept type %s",
331 Anum_pg_proc_prosrc);
356 PyObject *crv = NULL;
377 code0 = Py_CompileString(msrc,
"<string>", Py_file_input);
379 crv = PyEval_EvalCode(code0, proc->
globals, NULL);
393 if (clen < 0 || clen >=
sizeof(call))
394 elog(
ERROR,
"string would overflow buffer");
395 proc->
code = Py_CompileString(call,
"<string>", Py_eval_input);
396 if (proc->
code != NULL)
401 PLy_elog(
ERROR,
"could not compile PL/Python function \"%s\"",
404 PLy_elog(
ERROR,
"could not compile anonymous PL/Python code block");
410 Py_XDECREF(proc->
code);
445 mlen = (strlen(src) * 2) + strlen(
name) + 16;
449 Assert(plen >= 0 && plen < mlen);
456 if (*sp ==
'\r' && *(sp + 1) ==
'\n')
459 if (*sp ==
'\n' || *sp ==
'\r')
472 if (mp > (mrc + mlen))
473 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(ItemPointer pointer1, ItemPointer 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)