]> granicus.if.org Git - postgresql/commitdiff
Atttypmod cleanup.
authorBruce Momjian <bruce@momjian.us>
Fri, 13 Feb 1998 19:46:22 +0000 (19:46 +0000)
committerBruce Momjian <bruce@momjian.us>
Fri, 13 Feb 1998 19:46:22 +0000 (19:46 +0000)
src/backend/commands/copy.c
src/backend/parser/parse_node.c
src/backend/parser/parse_target.c
src/backend/parser/parse_type.c
src/backend/utils/adt/arrayfuncs.c
src/include/catalog/pg_attribute.h
src/include/parser/parse_type.h
src/include/utils/array.h

index f5b06d12de2ed91b7cb846b45011e63646e86266..2dee47fa1faf6d41e52f6c845085abe133ba66ea 100644 (file)
@@ -6,7 +6,7 @@
  *
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/commands/copy.c,v 1.41 1998/02/10 16:02:51 momjian Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/commands/copy.c,v 1.42 1998/02/13 19:45:38 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -48,8 +48,7 @@ static Oid    GetOutputFunction(Oid type);
 static Oid     GetTypeElement(Oid type);
 static Oid     GetInputFunction(Oid type);
 static Oid     IsTypeByVal(Oid type);
-static void
-GetIndexRelations(Oid main_relation_oid,
+static void GetIndexRelations(Oid main_relation_oid,
                                  int *n_indices,
                                  Relation **index_rels);
 
index b4ffeeb21a34efbea151db1b2f65554c6b690246..708bb54103cd1d0cea143cc1ad68ffac26a9e6c4 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/parser/parse_node.c,v 1.12 1998/02/10 16:03:39 momjian Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/parser/parse_node.c,v 1.13 1998/02/13 19:45:43 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -79,7 +79,7 @@ make_operand(char *opname,
                        Assert(nodeTag(result) == T_Const);
                        val = (Datum) textout((struct varlena *)
                                                                  con->constvalue);
-                       infunc = typeidRetinfunc(true_typeId);
+                       infunc = typeidInfunc(true_typeId);
                        con = makeNode(Const);
                        con->consttype = true_typeId;
                        con->constlen = typeLen(true_type);
@@ -185,10 +185,10 @@ make_op(char *opname, Node *ltree, Node *rtree)
                        CONVERTABLE_TYPE(rtypeId) && nodeTag(rtree) == T_Const &&
                        !((Const *) rtree)->constiscast)
                {
-                       outfunc = typeidRetoutfunc(rtypeId);
-                       infunc = typeidRetinfunc(ltypeId);
+                       outfunc = typeidOutfunc(rtypeId);
+                       infunc = typeidInfunc(ltypeId);
                        outstr = (char *) fmgr(outfunc, ((Const *) rtree)->constvalue);
-                       ((Const *) rtree)->constvalue = (Datum) fmgr(infunc, outstr);
+                       ((Const *) rtree)->constvalue = (Datum) fmgr(infunc, outstr, -1);
                        pfree(outstr);
                        ((Const *) rtree)->consttype = rtypeId = ltypeId;
                        newtype = typeidType(rtypeId);
@@ -200,10 +200,10 @@ make_op(char *opname, Node *ltree, Node *rtree)
                        CONVERTABLE_TYPE(ltypeId) && nodeTag(ltree) == T_Const &&
                        !((Const *) ltree)->constiscast)
                {
-                       outfunc = typeidRetoutfunc(ltypeId);
-                       infunc = typeidRetinfunc(rtypeId);
+                       outfunc = typeidOutfunc(ltypeId);
+                       infunc = typeidInfunc(rtypeId);
                        outstr = (char *) fmgr(outfunc, ((Const *) ltree)->constvalue);
-                       ((Const *) ltree)->constvalue = (Datum) fmgr(infunc, outstr);
+                       ((Const *) ltree)->constvalue = (Datum) fmgr(infunc, outstr, -1);
                        pfree(outstr);
                        ((Const *) ltree)->consttype = ltypeId = rtypeId;
                        newtype = typeidType(ltypeId);
index 559360cb9d706d4f2191a288417c60bcac94b3f8..7dbeb91ce63a6fc2fa36f1324eba7b4510b0dc98 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/parser/parse_target.c,v 1.9 1998/02/10 16:03:41 momjian Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/parser/parse_target.c,v 1.10 1998/02/13 19:45:44 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -394,7 +394,7 @@ make_targetlist_expr(ParseState *pstate,
                                lnext(expr) =
                                        makeConst(attrtype,
                                                          attrlen,
-                                                         (Datum) fmgr(typeidRetinfunc(attrtype),
+                                                         (Datum) fmgr(typeidInfunc(attrtype),
                                                                                 val, typeidTypElem(attrtype), -1),
                                                          false,
                                                          true /* Maybe correct-- 80% chance */ ,
index 0f69f62bf9c73332fe04d632c57b399d09d9b2a7..6ca081b4e592d8c966747e53c0497ec36e3a0106 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/parser/parse_type.c,v 1.5 1998/02/10 16:03:42 momjian Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/parser/parse_type.c,v 1.6 1998/02/13 19:45:45 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -148,7 +148,7 @@ stringTypeString(Type tp, char *string, int16 atttypmod)
 
 /* Given a type id, returns the out-conversion function of the type */
 Oid
-typeidRetoutfunc(Oid type_id)
+typeidOutfunc(Oid type_id)
 {
        HeapTuple       typeTuple;
        TypeTupleForm type;
@@ -158,7 +158,7 @@ typeidRetoutfunc(Oid type_id)
                                                                        ObjectIdGetDatum(type_id),
                                                                        0, 0, 0);
        if (!HeapTupleIsValid(typeTuple))
-               elog(ERROR, "typeidRetoutfunc: Invalid type - oid = %u", type_id);
+               elog(ERROR, "typeidOutfunc: Invalid type - oid = %u", type_id);
 
        type = (TypeTupleForm) GETSTRUCT(typeTuple);
        outfunc = type->typoutput;
@@ -241,7 +241,7 @@ GetArrayElementType(Oid typearray)
 
 /* Given a type id, returns the in-conversion function of the type */
 Oid
-typeidRetinfunc(Oid type_id)
+typeidInfunc(Oid type_id)
 {
        HeapTuple       typeTuple;
        TypeTupleForm type;
@@ -251,7 +251,7 @@ typeidRetinfunc(Oid type_id)
                                                                        ObjectIdGetDatum(type_id),
                                                                        0, 0, 0);
        if (!HeapTupleIsValid(typeTuple))
-               elog(ERROR, "typeidRetinfunc: Invalid type - oid = %u", type_id);
+               elog(ERROR, "typeidInfunc: Invalid type - oid = %u", type_id);
 
        type = (TypeTupleForm) GETSTRUCT(typeTuple);
        infunc = type->typinput;
index 6d5db4e78327198ed76a239e585a75fa2de2ee37..bb91516bb5e1aec691d09d9efb26fd7bf96bc07f 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/utils/adt/arrayfuncs.c,v 1.24 1998/01/15 19:45:01 pgsql Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/utils/adt/arrayfuncs.c,v 1.25 1998/02/13 19:45:53 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
 
 /*-=-=--=-=-=-=-=-=-=-=--=-=-=-=-=-=-=-=--=-=-=-=-=-=-=-=--=-=-=-=-=-=-=-*/
 static int     _ArrayCount(char *str, int dim[], int typdelim);
-static char *
-_ReadArrayStr(char *arrayStr, int nitems, int ndim, int dim[],
+static char *_ReadArrayStr(char *arrayStr, int nitems, int ndim, int dim[],
                          FmgrInfo *inputproc, Oid typelem, char typdelim,
                          int typlen, bool typbyval, char typalign,
-                         int *nbytes);
+                         int *nbytes, int16 typmod);
 
 #ifdef LOARRAY
 static char *
@@ -93,7 +92,8 @@ static char *array_seek(char *ptr, int eltsize, int nitems);
  */
 char      *
 array_in(char *string,                 /* input array in external form */
-                Oid element_type)              /* type OID of an array element */
+                Oid element_type,              /* type OID of an array element */
+                int16 typmod)
 {
        int                     typlen;
        bool            typbyval,
@@ -208,7 +208,7 @@ array_in(char *string,                      /* input array in external form */
                /* array not a large object */
                dataPtr =
                        (char *) _ReadArrayStr(p, nitems, ndim, dim, &inputproc, typelem,
-                                                                  typdelim, typlen, typbyval, typalign,
+                                                                  typmod, typdelim, typlen, typbyval, typalign,
                                                                   &nbytes);
                nbytes += ARR_OVERHEAD(ndim);
                retval = (ArrayType *) palloc(nbytes);
@@ -369,6 +369,7 @@ _ReadArrayStr(char *arrayStr,
                          FmgrInfo *inputproc,          /* function used for the
                                                                                 * conversion */
                          Oid typelem,
+                         int16 typmod,
                          char typdelim,
                          int typlen,
                          bool typbyval,
@@ -460,7 +461,7 @@ _ReadArrayStr(char *arrayStr,
                *q = '\0';
                if (i >= nitems)
                        elog(ERROR, "array_in: illformed array constant");
-               values[i] = (*fmgr_faddr(inputproc)) (p, typelem);
+               values[i] = (*fmgr_faddr(inputproc)) (p, typelem, typmod);
                p = ++q;
                if (!eoArray)
 
index 6a075dad57df700a27b18695cd1bacd724619683..5dd861f9aad68576c3067a879b13c7a20ebc82fb 100644 (file)
@@ -7,7 +7,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- * $Id: pg_attribute.h,v 1.27 1998/02/10 16:04:03 momjian Exp $
+ * $Id: pg_attribute.h,v 1.28 1998/02/13 19:46:09 momjian Exp $
  *
  * NOTES
  *       the genbki.sh script reads this file and generates .bki
@@ -88,7 +88,8 @@ CATALOG(pg_attribute) BOOTSTRAP
        int2            atttypmod;
        /*
         * atttypmod records type-specific modifications supplied at table
-     * creation time.
+     * creation time, and passes it to input and output functions as the
+     * third argument.
         */
 
        bool            attbyval;
index cca43855c510367599f51a41ad5f447b1e2ae2de..da92efe984c06455bf361abafd8c71f874baf917 100644 (file)
@@ -6,7 +6,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- * $Id: parse_type.h,v 1.4 1998/02/10 16:04:32 momjian Exp $
+ * $Id: parse_type.h,v 1.5 1998/02/13 19:46:18 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -27,11 +27,11 @@ extern bool typeByVal(Type t);
 extern char *typeTypeName(Type t);
 extern char typeTypeFlag(Type t);
 extern char *stringTypeString(Type tp, char *string, int16 atttypmod);
-extern Oid typeidRetoutfunc(Oid type_id);
+extern Oid typeidOutfunc(Oid type_id);
 extern Oid typeidTypeRelid(Oid type_id);
 extern Oid typeTypeRelid(Type typ);
 extern Oid typeidTypElem(Oid type_id);
 extern Oid GetArrayElementType(Oid typearray);
-extern Oid typeidRetinfunc(Oid type_id);
+extern Oid typeidInfunc(Oid type_id);
 
 #endif                                                 /* PARSE_TYPE_H */
index 60c4592fd20e98326d5a029b21244a805b709788..d5c1b8e515158911652cef66f453a57b5c84c516 100644 (file)
@@ -10,7 +10,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- * $Id: array.h,v 1.9 1998/01/24 22:50:31 momjian Exp $
+ * $Id: array.h,v 1.10 1998/02/13 19:46:22 momjian Exp $
  *
  * NOTES
  *       XXX the data array should be LONGALIGN'd -- notice that the array
@@ -114,7 +114,7 @@ typedef struct
 /*
  * prototypes for functions defined in arrayfuncs.c
  */
-extern char *array_in(char *string, Oid element_type);
+extern char *array_in(char *string, Oid element_type, int16 typmod);
 extern char *array_out(ArrayType *v, Oid element_type);
 extern char *array_dims(ArrayType *v, bool *isNull);
 extern Datum array_ref(ArrayType *array, int n, int indx[], int reftype,