Commit c110eff1 authored by Tom Lane's avatar Tom Lane

Use FLEXIBLE_ARRAY_MEMBER in struct RecordIOData.

I (tgl) fixed this last night in rowtypes.c, but I missed that the
code had been copied into a couple of other places.

Michael Paquier
parent e38b1eb0
...@@ -747,7 +747,7 @@ typedef struct RecordIOData ...@@ -747,7 +747,7 @@ typedef struct RecordIOData
Oid record_type; Oid record_type;
int32 record_typmod; int32 record_typmod;
int ncolumns; int ncolumns;
ColumnIOData columns[1]; /* VARIABLE LENGTH ARRAY */ ColumnIOData columns[FLEXIBLE_ARRAY_MEMBER];
} RecordIOData; } RecordIOData;
PG_FUNCTION_INFO_V1(hstore_from_record); PG_FUNCTION_INFO_V1(hstore_from_record);
...@@ -805,8 +805,8 @@ hstore_from_record(PG_FUNCTION_ARGS) ...@@ -805,8 +805,8 @@ hstore_from_record(PG_FUNCTION_ARGS)
{ {
fcinfo->flinfo->fn_extra = fcinfo->flinfo->fn_extra =
MemoryContextAlloc(fcinfo->flinfo->fn_mcxt, MemoryContextAlloc(fcinfo->flinfo->fn_mcxt,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra; my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra;
my_extra->record_type = InvalidOid; my_extra->record_type = InvalidOid;
my_extra->record_typmod = 0; my_extra->record_typmod = 0;
...@@ -816,8 +816,8 @@ hstore_from_record(PG_FUNCTION_ARGS) ...@@ -816,8 +816,8 @@ hstore_from_record(PG_FUNCTION_ARGS)
my_extra->record_typmod != tupTypmod) my_extra->record_typmod != tupTypmod)
{ {
MemSet(my_extra, 0, MemSet(my_extra, 0,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra->record_type = tupType; my_extra->record_type = tupType;
my_extra->record_typmod = tupTypmod; my_extra->record_typmod = tupTypmod;
my_extra->ncolumns = ncolumns; my_extra->ncolumns = ncolumns;
...@@ -990,8 +990,8 @@ hstore_populate_record(PG_FUNCTION_ARGS) ...@@ -990,8 +990,8 @@ hstore_populate_record(PG_FUNCTION_ARGS)
{ {
fcinfo->flinfo->fn_extra = fcinfo->flinfo->fn_extra =
MemoryContextAlloc(fcinfo->flinfo->fn_mcxt, MemoryContextAlloc(fcinfo->flinfo->fn_mcxt,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra; my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra;
my_extra->record_type = InvalidOid; my_extra->record_type = InvalidOid;
my_extra->record_typmod = 0; my_extra->record_typmod = 0;
...@@ -1001,8 +1001,8 @@ hstore_populate_record(PG_FUNCTION_ARGS) ...@@ -1001,8 +1001,8 @@ hstore_populate_record(PG_FUNCTION_ARGS)
my_extra->record_typmod != tupTypmod) my_extra->record_typmod != tupTypmod)
{ {
MemSet(my_extra, 0, MemSet(my_extra, 0,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra->record_type = tupType; my_extra->record_type = tupType;
my_extra->record_typmod = tupTypmod; my_extra->record_typmod = tupTypmod;
my_extra->ncolumns = ncolumns; my_extra->ncolumns = ncolumns;
......
...@@ -216,7 +216,7 @@ typedef struct RecordIOData ...@@ -216,7 +216,7 @@ typedef struct RecordIOData
Oid record_type; Oid record_type;
int32 record_typmod; int32 record_typmod;
int ncolumns; int ncolumns;
ColumnIOData columns[1]; /* VARIABLE LENGTH ARRAY */ ColumnIOData columns[FLEXIBLE_ARRAY_MEMBER];
} RecordIOData; } RecordIOData;
/* state for populate_recordset */ /* state for populate_recordset */
...@@ -2148,8 +2148,8 @@ populate_record_worker(FunctionCallInfo fcinfo, const char *funcname, ...@@ -2148,8 +2148,8 @@ populate_record_worker(FunctionCallInfo fcinfo, const char *funcname,
{ {
fcinfo->flinfo->fn_extra = fcinfo->flinfo->fn_extra =
MemoryContextAlloc(fcinfo->flinfo->fn_mcxt, MemoryContextAlloc(fcinfo->flinfo->fn_mcxt,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra; my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra;
my_extra->record_type = InvalidOid; my_extra->record_type = InvalidOid;
my_extra->record_typmod = 0; my_extra->record_typmod = 0;
...@@ -2161,8 +2161,8 @@ populate_record_worker(FunctionCallInfo fcinfo, const char *funcname, ...@@ -2161,8 +2161,8 @@ populate_record_worker(FunctionCallInfo fcinfo, const char *funcname,
my_extra->record_typmod != tupTypmod)) my_extra->record_typmod != tupTypmod))
{ {
MemSet(my_extra, 0, MemSet(my_extra, 0,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra->record_type = tupType; my_extra->record_type = tupType;
my_extra->record_typmod = tupTypmod; my_extra->record_typmod = tupTypmod;
my_extra->ncolumns = ncolumns; my_extra->ncolumns = ncolumns;
...@@ -2653,8 +2653,8 @@ populate_recordset_worker(FunctionCallInfo fcinfo, const char *funcname, ...@@ -2653,8 +2653,8 @@ populate_recordset_worker(FunctionCallInfo fcinfo, const char *funcname,
{ {
fcinfo->flinfo->fn_extra = fcinfo->flinfo->fn_extra =
MemoryContextAlloc(fcinfo->flinfo->fn_mcxt, MemoryContextAlloc(fcinfo->flinfo->fn_mcxt,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra; my_extra = (RecordIOData *) fcinfo->flinfo->fn_extra;
my_extra->record_type = InvalidOid; my_extra->record_type = InvalidOid;
my_extra->record_typmod = 0; my_extra->record_typmod = 0;
...@@ -2664,8 +2664,8 @@ populate_recordset_worker(FunctionCallInfo fcinfo, const char *funcname, ...@@ -2664,8 +2664,8 @@ populate_recordset_worker(FunctionCallInfo fcinfo, const char *funcname,
my_extra->record_typmod != tupTypmod) my_extra->record_typmod != tupTypmod)
{ {
MemSet(my_extra, 0, MemSet(my_extra, 0,
sizeof(RecordIOData) - sizeof(ColumnIOData) offsetof(RecordIOData, columns) +
+ ncolumns * sizeof(ColumnIOData)); ncolumns * sizeof(ColumnIOData));
my_extra->record_type = tupType; my_extra->record_type = tupType;
my_extra->record_typmod = tupTypmod; my_extra->record_typmod = tupTypmod;
my_extra->ncolumns = ncolumns; my_extra->ncolumns = ncolumns;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment