]> granicus.if.org Git - postgresql/commitdiff
Make DatumGetInetP() unpack inet datums with a 1-byte header, and add
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>
Tue, 8 Nov 2011 20:39:43 +0000 (22:39 +0200)
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>
Tue, 8 Nov 2011 20:45:28 +0000 (22:45 +0200)
a new macro, DatumGetInetPP(), that does not. This brings these macros
in line with other DatumGet*P() macros.

Backpatch to 8.3, where 1-byte header varlenas were introduced.

src/backend/utils/adt/network.c
src/include/utils/inet.h

index 0ea13fc47bd33652b73524e9f3743baddede760f..cd979464e6630354eb98a37d2f1c9686f2d0e84a 100644 (file)
@@ -907,7 +907,7 @@ convert_network_to_scalar(Datum value, Oid typid)
                case INETOID:
                case CIDROID:
                        {
-                               inet       *ip = DatumGetInetP(value);
+                               inet       *ip = DatumGetInetPP(value);
                                int                     len;
                                double          res;
                                int                     i;
index 948f0cde9d97acf076592f872317e42d32cba431..2a526a3c80772c6a90bf85b9ec172ab67e14203d 100644 (file)
@@ -70,9 +70,11 @@ typedef struct macaddr
 /*
  * fmgr interface macros
  */
-#define DatumGetInetP(X)       ((inet *) PG_DETOAST_DATUM_PACKED(X))
+#define DatumGetInetP(X)       ((inet *) PG_DETOAST_DATUM(X))
+#define DatumGetInetPP(X)      ((inet *) PG_DETOAST_DATUM_PACKED(X))
 #define InetPGetDatum(X)       PointerGetDatum(X)
 #define PG_GETARG_INET_P(n) DatumGetInetP(PG_GETARG_DATUM(n))
+#define PG_GETARG_INET_PP(n) DatumGetInetP(PG_GETARG_DATUM_PACKED(n))
 #define PG_RETURN_INET_P(x) return InetPGetDatum(x)
 /* macaddr is a fixed-length pass-by-reference datatype */
 #define DatumGetMacaddrP(X)    ((macaddr *) DatumGetPointer(X))