Commit b1fdc727 authored by Teodor Sigaev's avatar Teodor Sigaev

Fix Windows build broken in 6943a946

Also it fixes dynamic array allocation disallowed by ANSI-C.

Author: Stas Kelvich
parent 8829af47
...@@ -66,7 +66,7 @@ typedef struct ...@@ -66,7 +66,7 @@ typedef struct
#define STATHDRSIZE (offsetof(TSVectorStat, data)) #define STATHDRSIZE (offsetof(TSVectorStat, data))
static Datum tsvector_update_trigger(PG_FUNCTION_ARGS, bool config_column); static Datum tsvector_update_trigger(PG_FUNCTION_ARGS, bool config_column);
static int tsvector_bsearch(TSVector tsin, char *lexin, int lexin_len); static int tsvector_bsearch(const TSVector tsv, char *lexeme, int lexeme_len);
/* /*
* Order: haspos, len, word, for all positions (pos, weight) * Order: haspos, len, word, for all positions (pos, weight)
...@@ -684,10 +684,12 @@ tsvector_to_array(PG_FUNCTION_ARGS) ...@@ -684,10 +684,12 @@ tsvector_to_array(PG_FUNCTION_ARGS)
{ {
TSVector tsin = PG_GETARG_TSVECTOR(0); TSVector tsin = PG_GETARG_TSVECTOR(0);
WordEntry *arrin = ARRPTR(tsin); WordEntry *arrin = ARRPTR(tsin);
Datum elements[tsin->size]; Datum *elements;
int i; int i;
ArrayType *array; ArrayType *array;
elements = palloc(tsin->size * sizeof(Datum));
for (i = 0; i < tsin->size; i++) for (i = 0; i < tsin->size; i++)
{ {
elements[i] = PointerGetDatum( elements[i] = PointerGetDatum(
...@@ -696,6 +698,8 @@ tsvector_to_array(PG_FUNCTION_ARGS) ...@@ -696,6 +698,8 @@ tsvector_to_array(PG_FUNCTION_ARGS)
} }
array = construct_array(elements, tsin->size, TEXTOID, -1, false, 'i'); array = construct_array(elements, tsin->size, TEXTOID, -1, false, 'i');
pfree(elements);
PG_FREE_IF_COPY(tsin, 0); PG_FREE_IF_COPY(tsin, 0);
PG_RETURN_POINTER(array); PG_RETURN_POINTER(array);
} }
......
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