Commit 2fd26b23 authored by Noah Misch's avatar Noah Misch

Assume deconstruct_array() outputs are untoasted.

In functions that issue a deconstruct_array() call, consistently use
plain VARSIZE()/VARDATA() on the array elements.  Prior practice was
divided between those and VARSIZE_ANY_EXHDR()/VARDATA_ANY().
parent 9e092646
...@@ -611,19 +611,22 @@ hstore_from_arrays(PG_FUNCTION_ARGS) ...@@ -611,19 +611,22 @@ hstore_from_arrays(PG_FUNCTION_ARGS)
if (!value_nulls || value_nulls[i]) if (!value_nulls || value_nulls[i])
{ {
pairs[i].key = VARDATA_ANY(key_datums[i]); pairs[i].key = VARDATA(key_datums[i]);
pairs[i].val = NULL; pairs[i].val = NULL;
pairs[i].keylen = hstoreCheckKeyLen(VARSIZE_ANY_EXHDR(key_datums[i])); pairs[i].keylen =
hstoreCheckKeyLen(VARSIZE(key_datums[i]) - VARHDRSZ);
pairs[i].vallen = 4; pairs[i].vallen = 4;
pairs[i].isnull = true; pairs[i].isnull = true;
pairs[i].needfree = false; pairs[i].needfree = false;
} }
else else
{ {
pairs[i].key = VARDATA_ANY(key_datums[i]); pairs[i].key = VARDATA(key_datums[i]);
pairs[i].val = VARDATA_ANY(value_datums[i]); pairs[i].val = VARDATA(value_datums[i]);
pairs[i].keylen = hstoreCheckKeyLen(VARSIZE_ANY_EXHDR(key_datums[i])); pairs[i].keylen =
pairs[i].vallen = hstoreCheckValLen(VARSIZE_ANY_EXHDR(value_datums[i])); hstoreCheckKeyLen(VARSIZE(key_datums[i]) - VARHDRSZ);
pairs[i].vallen =
hstoreCheckValLen(VARSIZE(value_datums[i]) - VARHDRSZ);
pairs[i].isnull = false; pairs[i].isnull = false;
pairs[i].needfree = false; pairs[i].needfree = false;
} }
...@@ -704,19 +707,22 @@ hstore_from_array(PG_FUNCTION_ARGS) ...@@ -704,19 +707,22 @@ hstore_from_array(PG_FUNCTION_ARGS)
if (in_nulls[i * 2 + 1]) if (in_nulls[i * 2 + 1])
{ {
pairs[i].key = VARDATA_ANY(in_datums[i * 2]); pairs[i].key = VARDATA(in_datums[i * 2]);
pairs[i].val = NULL; pairs[i].val = NULL;
pairs[i].keylen = hstoreCheckKeyLen(VARSIZE_ANY_EXHDR(in_datums[i * 2])); pairs[i].keylen =
hstoreCheckKeyLen(VARSIZE(in_datums[i * 2]) - VARHDRSZ);
pairs[i].vallen = 4; pairs[i].vallen = 4;
pairs[i].isnull = true; pairs[i].isnull = true;
pairs[i].needfree = false; pairs[i].needfree = false;
} }
else else
{ {
pairs[i].key = VARDATA_ANY(in_datums[i * 2]); pairs[i].key = VARDATA(in_datums[i * 2]);
pairs[i].val = VARDATA_ANY(in_datums[i * 2 + 1]); pairs[i].val = VARDATA(in_datums[i * 2 + 1]);
pairs[i].keylen = hstoreCheckKeyLen(VARSIZE_ANY_EXHDR(in_datums[i * 2])); pairs[i].keylen =
pairs[i].vallen = hstoreCheckValLen(VARSIZE_ANY_EXHDR(in_datums[i * 2 + 1])); hstoreCheckKeyLen(VARSIZE(in_datums[i * 2]) - VARHDRSZ);
pairs[i].vallen =
hstoreCheckValLen(VARSIZE(in_datums[i * 2 + 1]) - VARHDRSZ);
pairs[i].isnull = false; pairs[i].isnull = false;
pairs[i].needfree = false; pairs[i].needfree = false;
} }
......
...@@ -760,9 +760,8 @@ transformRelOptions(Datum oldOptions, List *defList, char *namspace, ...@@ -760,9 +760,8 @@ transformRelOptions(Datum oldOptions, List *defList, char *namspace,
for (i = 0; i < noldoptions; i++) for (i = 0; i < noldoptions; i++)
{ {
text *oldoption = DatumGetTextP(oldoptions[i]); char *text_str = VARDATA(oldoptions[i]);
char *text_str = VARDATA(oldoption); int text_len = VARSIZE(oldoptions[i]) - VARHDRSZ;
int text_len = VARSIZE(oldoption) - VARHDRSZ;
/* Search for a match in defList */ /* Search for a match in defList */
foreach(cell, defList) foreach(cell, defList)
...@@ -1055,9 +1054,8 @@ parseRelOptions(Datum options, bool validate, relopt_kind kind, ...@@ -1055,9 +1054,8 @@ parseRelOptions(Datum options, bool validate, relopt_kind kind,
for (i = 0; i < noptions; i++) for (i = 0; i < noptions; i++)
{ {
text *optiontext = DatumGetTextP(optiondatums[i]); char *text_str = VARDATA(optiondatums[i]);
char *text_str = VARDATA(optiontext); int text_len = VARSIZE(optiondatums[i]) - VARHDRSZ;
int text_len = VARSIZE(optiontext) - VARHDRSZ;
int j; int j;
/* Search for a match in reloptions */ /* Search for a match in reloptions */
......
...@@ -172,8 +172,8 @@ gin_extract_jsonb_query(PG_FUNCTION_ARGS) ...@@ -172,8 +172,8 @@ gin_extract_jsonb_query(PG_FUNCTION_ARGS)
if (key_nulls[i]) if (key_nulls[i])
continue; continue;
entries[j++] = make_text_key(JGINFLAG_KEY, entries[j++] = make_text_key(JGINFLAG_KEY,
VARDATA_ANY(key_datums[i]), VARDATA(key_datums[i]),
VARSIZE_ANY_EXHDR(key_datums[i])); VARSIZE(key_datums[i]) - VARHDRSZ);
} }
*nentries = j; *nentries = j;
......
...@@ -1240,8 +1240,8 @@ get_jsonb_path_all(FunctionCallInfo fcinfo, bool as_text) ...@@ -1240,8 +1240,8 @@ get_jsonb_path_all(FunctionCallInfo fcinfo, bool as_text)
{ {
jbvp = findJsonbValueFromContainerLen(container, jbvp = findJsonbValueFromContainerLen(container,
JB_FOBJECT, JB_FOBJECT,
VARDATA_ANY(pathtext[i]), VARDATA(pathtext[i]),
VARSIZE_ANY_EXHDR(pathtext[i])); VARSIZE(pathtext[i]) - VARHDRSZ);
} }
else if (have_array) else if (have_array)
{ {
......
...@@ -163,8 +163,7 @@ binary_upgrade_create_empty_extension(PG_FUNCTION_ARGS) ...@@ -163,8 +163,7 @@ binary_upgrade_create_empty_extension(PG_FUNCTION_ARGS)
&textDatums, NULL, &ndatums); &textDatums, NULL, &ndatums);
for (i = 0; i < ndatums; i++) for (i = 0; i < ndatums; i++)
{ {
text *txtname = DatumGetTextPP(textDatums[i]); char *extName = TextDatumGetCString(textDatums[i]);
char *extName = text_to_cstring(txtname);
Oid extOid = get_extension_oid(extName, false); Oid extOid = get_extension_oid(extName, false);
requiredExtensions = lappend_oid(requiredExtensions, extOid); requiredExtensions = lappend_oid(requiredExtensions, extOid);
......
...@@ -323,7 +323,7 @@ tsvector_setweight_by_filter(PG_FUNCTION_ARGS) ...@@ -323,7 +323,7 @@ tsvector_setweight_by_filter(PG_FUNCTION_ARGS)
errmsg("lexeme array may not contain nulls"))); errmsg("lexeme array may not contain nulls")));
lex = VARDATA(dlexemes[i]); lex = VARDATA(dlexemes[i]);
lex_len = VARSIZE_ANY_EXHDR(dlexemes[i]); lex_len = VARSIZE(dlexemes[i]) - VARHDRSZ;
lex_pos = tsvector_bsearch(tsout, lex, lex_len); lex_pos = tsvector_bsearch(tsout, lex, lex_len);
if (lex_pos >= 0 && (j = POSDATALEN(tsout, entry + lex_pos)) != 0) if (lex_pos >= 0 && (j = POSDATALEN(tsout, entry + lex_pos)) != 0)
...@@ -609,8 +609,8 @@ tsvector_delete_arr(PG_FUNCTION_ARGS) ...@@ -609,8 +609,8 @@ tsvector_delete_arr(PG_FUNCTION_ARGS)
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED), (errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("lexeme array may not contain nulls"))); errmsg("lexeme array may not contain nulls")));
lex = VARDATA_ANY(dlexemes[i]); lex = VARDATA(dlexemes[i]);
lex_len = VARSIZE_ANY_EXHDR(dlexemes[i]); lex_len = VARSIZE(dlexemes[i]) - VARHDRSZ;
lex_pos = tsvector_bsearch(tsin, lex, lex_len); lex_pos = tsvector_bsearch(tsin, lex, lex_len);
if (lex_pos >= 0) if (lex_pos >= 0)
...@@ -793,7 +793,7 @@ array_to_tsvector(PG_FUNCTION_ARGS) ...@@ -793,7 +793,7 @@ array_to_tsvector(PG_FUNCTION_ARGS)
/* Calculate space needed for surviving lexemes. */ /* Calculate space needed for surviving lexemes. */
for (i = 0; i < nitems; i++) for (i = 0; i < nitems; i++)
datalen += VARSIZE_ANY_EXHDR(dlexemes[i]); datalen += VARSIZE(dlexemes[i]) - VARHDRSZ;
tslen = CALCDATASIZE(nitems, datalen); tslen = CALCDATASIZE(nitems, datalen);
/* Allocate and fill tsvector. */ /* Allocate and fill tsvector. */
...@@ -805,8 +805,8 @@ array_to_tsvector(PG_FUNCTION_ARGS) ...@@ -805,8 +805,8 @@ array_to_tsvector(PG_FUNCTION_ARGS)
cur = STRPTR(tsout); cur = STRPTR(tsout);
for (i = 0; i < nitems; i++) for (i = 0; i < nitems; i++)
{ {
char *lex = VARDATA_ANY(dlexemes[i]); char *lex = VARDATA(dlexemes[i]);
int lex_len = VARSIZE_ANY_EXHDR(dlexemes[i]); int lex_len = VARSIZE(dlexemes[i]) - VARHDRSZ;
memcpy(cur, lex, lex_len); memcpy(cur, lex, lex_len);
arrout[i].haspos = 0; arrout[i].haspos = 0;
......
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