parse_type.c
上传用户:blenddy
上传日期:2007-01-07
资源大小:6495k
文件大小:5k
- /*-------------------------------------------------------------------------
- *
- * parse_type.c
- * handle type operations for parser
- *
- * Copyright (c) 1994, Regents of the University of California
- *
- *
- * IDENTIFICATION
- * $Header: /usr/local/cvsroot/pgsql/src/backend/parser/parse_type.c,v 1.22 1999/05/29 03:17:19 tgl Exp $
- *
- *-------------------------------------------------------------------------
- */
- #include <string.h>
- #include "postgres.h"
- #include "fmgr.h"
- #include "nodes/nodes.h"
- #include "nodes/parsenodes.h"
- #include "nodes/primnodes.h"
- #include "parser/parse_node.h"
- #include "catalog/pg_type.h"
- #include "parser/parse_target.h"
- #include "parser/parse_type.h"
- #include "utils/syscache.h"
- /* check to see if a type id is valid,
- * returns true if it is. By using this call before calling
- * typeidType or typeidTypeName, more meaningful error messages
- * can be produced because the caller typically has more context of
- * what's going on - jolly
- */
- bool
- typeidIsValid(Oid id)
- {
- return (SearchSysCacheTuple(TYPOID,
- ObjectIdGetDatum(id),
- 0, 0, 0) != NULL);
- }
- /* return a type name, given a typeid */
- char *
- typeidTypeName(Oid id)
- {
- HeapTuple tup;
- Form_pg_type typetuple;
- if (!(tup = SearchSysCacheTuple(TYPOID,
- ObjectIdGetDatum(id),
- 0, 0, 0)))
- {
- elog(ERROR, "Unable to locate type oid %u in catalog", id);
- return NULL;
- }
- typetuple = (Form_pg_type) GETSTRUCT(tup);
- return (typetuple->typname).data;
- }
- /* return a Type structure, given a type id */
- Type
- typeidType(Oid id)
- {
- HeapTuple tup;
- if (!(tup = SearchSysCacheTuple(TYPOID,
- ObjectIdGetDatum(id),
- 0, 0, 0)))
- {
- elog(ERROR, "Unable to locate type oid %u in catalog", id);
- return NULL;
- }
- return (Type) tup;
- }
- /* return a Type structure, given type name */
- Type
- typenameType(char *s)
- {
- HeapTuple tup;
- if (s == NULL)
- elog(ERROR, "type(): Null type");
- if (!(tup = SearchSysCacheTuple(TYPNAME,
- PointerGetDatum(s),
- 0, 0, 0)))
- elog(ERROR, "Unable to locate type name '%s' in catalog", s);
- return (Type) tup;
- }
- /* given type, return the type OID */
- Oid
- typeTypeId(Type tp)
- {
- if (tp == NULL)
- elog(ERROR, "typeTypeId() called with NULL type struct");
- return tp->t_data->t_oid;
- }
- /* given type (as type struct), return the length of type */
- int16
- typeLen(Type t)
- {
- Form_pg_type typ;
- typ = (Form_pg_type) GETSTRUCT(t);
- return typ->typlen;
- }
- /* given type (as type struct), return the value of its 'byval' attribute.*/
- bool
- typeByVal(Type t)
- {
- Form_pg_type typ;
- typ = (Form_pg_type) GETSTRUCT(t);
- return typ->typbyval;
- }
- /* given type (as type struct), return the name of type */
- char *
- typeTypeName(Type t)
- {
- Form_pg_type typ;
- typ = (Form_pg_type) GETSTRUCT(t);
- return (typ->typname).data;
- }
- /* given a type, return its typetype ('c' for 'c'atalog types) */
- char
- typeTypeFlag(Type t)
- {
- Form_pg_type typ;
- typ = (Form_pg_type) GETSTRUCT(t);
- return typ->typtype;
- }
- /* Given a type structure and a string, returns the internal form of
- that string */
- char *
- stringTypeString(Type tp, char *string, int32 atttypmod)
- {
- Oid op;
- Oid typelem;
- op = ((Form_pg_type) GETSTRUCT(tp))->typinput;
- typelem = ((Form_pg_type) GETSTRUCT(tp))->typelem; /* XXX - used for
- * array_in */
- return (char *) fmgr(op, string, typelem, atttypmod);
- }
- /* Given a type id, returns the out-conversion function of the type */
- #ifdef NOT_USED
- Oid
- typeidOutfunc(Oid type_id)
- {
- HeapTuple typeTuple;
- Form_pg_type type;
- Oid outfunc;
- typeTuple = SearchSysCacheTuple(TYPOID,
- ObjectIdGetDatum(type_id),
- 0, 0, 0);
- if (!HeapTupleIsValid(typeTuple))
- elog(ERROR, "typeidOutfunc: Invalid type - oid = %u", type_id);
- type = (Form_pg_type) GETSTRUCT(typeTuple);
- outfunc = type->typoutput;
- return outfunc;
- }
- #endif
- Oid
- typeidTypeRelid(Oid type_id)
- {
- HeapTuple typeTuple;
- Form_pg_type type;
- typeTuple = SearchSysCacheTuple(TYPOID,
- ObjectIdGetDatum(type_id),
- 0, 0, 0);
- if (!HeapTupleIsValid(typeTuple))
- elog(ERROR, "typeidTypeRelid: Invalid type - oid = %u", type_id);
- type = (Form_pg_type) GETSTRUCT(typeTuple);
- return type->typrelid;
- }
- Oid
- typeTypeRelid(Type typ)
- {
- Form_pg_type typtup;
- typtup = (Form_pg_type) GETSTRUCT(typ);
- return typtup->typrelid;
- }
- Oid
- typeTypElem(Type typ)
- {
- Form_pg_type typtup;
- typtup = (Form_pg_type) GETSTRUCT(typ);
- return typtup->typelem;
- }
- /* Given the attribute type of an array return the attribute type of
- an element of the array */
- Oid
- GetArrayElementType(Oid typearray)
- {
- HeapTuple type_tuple;
- Form_pg_type type_struct_array;
- type_tuple = SearchSysCacheTuple(TYPOID,
- ObjectIdGetDatum(typearray),
- 0, 0, 0);
- if (!HeapTupleIsValid(type_tuple))
- elog(ERROR, "GetArrayElementType: Cache lookup failed for type %u",
- typearray);
- /* get the array type struct from the type tuple */
- type_struct_array = (Form_pg_type) GETSTRUCT(type_tuple);
- if (type_struct_array->typelem == InvalidOid)
- {
- elog(ERROR, "GetArrayElementType: type %s is not an array",
- type_struct_array->typname);
- }
- return type_struct_array->typelem;
- }
- /* Given a type structure, return the in-conversion function of the type */
- Oid
- typeInfunc(Type typ)
- {
- Form_pg_type typtup;
- typtup = (Form_pg_type) GETSTRUCT(typ);
- return typtup->typinput;
- }