From 83b652dc7ed56f23279e3975cdcc12e6bc77ed8f Mon Sep 17 00:00:00 2001 From: Peter Eisentraut Date: Fri, 13 Mar 2015 00:11:45 -0400 Subject: [PATCH] Fix compilation on older PostgreSQL versions --- test/expected/test.out | 1 + test/sql/test.sql | 2 ++ uri.c | 24 ++++++++++++------------ 3 files changed, 15 insertions(+), 12 deletions(-) diff --git a/test/expected/test.out b/test/expected/test.out index 0e82ac7..e7ab605 100644 --- a/test/expected/test.out +++ b/test/expected/test.out @@ -1,4 +1,5 @@ \pset null _null_ +SET client_min_messages = warning; CREATE TABLE test (a serial, b uri); INSERT INTO test (b) VALUES ('http://www.postgresql.org/'), diff --git a/test/sql/test.sql b/test/sql/test.sql index c113fd3..8fa75b1 100644 --- a/test/sql/test.sql +++ b/test/sql/test.sql @@ -1,5 +1,7 @@ \pset null _null_ +SET client_min_messages = warning; + CREATE TABLE test (a serial, b uri); INSERT INTO test (b) diff --git a/uri.c b/uri.c index 8d4d3cb..56d4344 100644 --- a/uri.c +++ b/uri.c @@ -143,18 +143,20 @@ uri_host_inet(PG_FUNCTION_ARGS) if (uri.hostData.ip4) { unsigned char *data = uri.hostData.ip4; - char *tmp = psprintf("%u.%u.%u.%u", data[0], data[1], data[2], data[3]); + char *tmp = palloc(16); + snprintf(tmp, 16, "%u.%u.%u.%u", data[0], data[1], data[2], data[3]); uriFreeUriMembersA(&uri); PG_RETURN_INET_P(DirectFunctionCall1(inet_in, CStringGetDatum(tmp))); } else if (uri.hostData.ip6) { unsigned char *data = uri.hostData.ip6; - char *tmp = psprintf("%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x", - data[0], data[1], data[2], data[3], - data[4], data[5], data[6], data[7], - data[8], data[9], data[10], data[11], - data[12], data[13], data[14], data[15]); + char *tmp = palloc(40); + snprintf(tmp, 40, "%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x", + data[0], data[1], data[2], data[3], + data[4], data[5], data[6], data[7], + data[8], data[9], data[10], data[11], + data[12], data[13], data[14], data[15]); uriFreeUriMembersA(&uri); PG_RETURN_INET_P(DirectFunctionCall1(inet_in, CStringGetDatum(tmp))); } @@ -226,7 +228,7 @@ uri_path(PG_FUNCTION_ARGS) Datum arg = PG_GETARG_DATUM(0); char *s = TextDatumGetCString(arg); UriUriA uri; - ArrayBuildState *astate = initArrayResult(TEXTOID, CurrentMemoryContext); + ArrayBuildState *astate = NULL; UriPathSegmentA *pa; parse_uri(s, &uri); @@ -241,11 +243,9 @@ uri_path(PG_FUNCTION_ARGS) } uriFreeUriMembersA(&uri); - if (astate) - PG_RETURN_ARRAYTYPE_P(makeArrayResult(astate, - CurrentMemoryContext)); - else - PG_RETURN_NULL(); + PG_RETURN_ARRAYTYPE_P(astate + ? makeArrayResult(astate, CurrentMemoryContext) + : construct_empty_array(TEXTOID)); } static int