55 uint32_t natts = (uint32_t) tupdesc->natts;
56 char **keys = palloc(natts *
sizeof(*keys));
58 bool geom_found =
false;
59 for (i = 0; i < natts; i++) {
60 Oid typoid = getBaseType(TupleDescAttr(tupdesc, i)->atttypid);
61 char *tkey = TupleDescAttr(tupdesc, i)->attname.data;
62 char *key = pstrdup(tkey);
64 if (!geom_found && typoid == postgis_oid(GEOMETRYOID)) {
70 if (!geom_found && strcmp(key, ctx->
geom_name) == 0) {
79 elog(ERROR,
"encode_keys: no geometry column found");
80 ctx->
data->n_keys = k;
81 ctx->
data->keys = keys;
82 ReleaseTupleDesc(tupdesc);
static TupleDesc get_tuple_desc(struct geobuf_agg_context *ctx)