|
|
|
|
@ -6,7 +6,7 @@ |
|
|
|
|
* Copyright (c) 1994, Regents of the University of California |
|
|
|
|
* |
|
|
|
|
* IDENTIFICATION |
|
|
|
|
* $Header: /cvsroot/pgsql/src/backend/utils/cache/lsyscache.c,v 1.32 1999/08/09 03:13:30 tgl Exp $ |
|
|
|
|
* $Header: /cvsroot/pgsql/src/backend/utils/cache/lsyscache.c,v 1.33 1999/08/16 02:06:25 tgl Exp $ |
|
|
|
|
* |
|
|
|
|
* NOTES |
|
|
|
|
* Eventually, the index information should go through here, too. |
|
|
|
|
@ -15,6 +15,7 @@ |
|
|
|
|
#include "postgres.h" |
|
|
|
|
|
|
|
|
|
#include "catalog/pg_operator.h" |
|
|
|
|
#include "catalog/pg_proc.h" |
|
|
|
|
#include "catalog/pg_type.h" |
|
|
|
|
#include "utils/lsyscache.h" |
|
|
|
|
#include "utils/syscache.h" |
|
|
|
|
@ -453,6 +454,31 @@ get_oprjoin(Oid opno) |
|
|
|
|
return (RegProcedure) NULL; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/* ---------- FUNCTION CACHE ---------- */ |
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* get_func_rettype |
|
|
|
|
* Given procedure id, return the function's result type. |
|
|
|
|
*/ |
|
|
|
|
Oid |
|
|
|
|
get_func_rettype(Oid funcid) |
|
|
|
|
{ |
|
|
|
|
HeapTuple func_tuple; |
|
|
|
|
Oid funcrettype; |
|
|
|
|
|
|
|
|
|
func_tuple = SearchSysCacheTuple(PROOID, |
|
|
|
|
ObjectIdGetDatum(funcid), |
|
|
|
|
0, 0, 0); |
|
|
|
|
|
|
|
|
|
if (!HeapTupleIsValid(func_tuple)) |
|
|
|
|
elog(ERROR, "Function OID %u does not exist", funcid); |
|
|
|
|
|
|
|
|
|
funcrettype = (Oid) |
|
|
|
|
((Form_pg_proc) GETSTRUCT(func_tuple))->prorettype; |
|
|
|
|
|
|
|
|
|
return funcrettype; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/* ---------- RELATION CACHE ---------- */ |
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|