mirror of
https://github.com/postgres/postgres.git
synced 2025-11-21 00:42:43 +03:00
Add construct_array_builtin, deconstruct_array_builtin
There were many calls to construct_array() and deconstruct_array() for built-in types, for example, when dealing with system catalog columns. These all hardcoded the type attributes necessary to pass to these functions. To simplify this a bit, add construct_array_builtin(), deconstruct_array_builtin() as wrappers that centralize this hardcoded knowledge. This simplifies many call sites and reduces the amount of hardcoded stuff that is spread around. Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://www.postgresql.org/message-id/flat/2914356f-9e5f-8c59-2995-5997fc48bcba%40enterprisedb.com
This commit is contained in:
@@ -4017,9 +4017,9 @@ xpath_internal(text *xpath_expr_text, xmltype *data, ArrayType *namespaces,
|
||||
|
||||
Assert(ARR_ELEMTYPE(namespaces) == TEXTOID);
|
||||
|
||||
deconstruct_array(namespaces, TEXTOID, -1, false, TYPALIGN_INT,
|
||||
&ns_names_uris, &ns_names_uris_nulls,
|
||||
&ns_count);
|
||||
deconstruct_array_builtin(namespaces, TEXTOID,
|
||||
&ns_names_uris, &ns_names_uris_nulls,
|
||||
&ns_count);
|
||||
|
||||
Assert((ns_count % 2) == 0); /* checked above */
|
||||
ns_count /= 2; /* count pairs only */
|
||||
|
||||
Reference in New Issue
Block a user