in c/src/core/message.c [813:919]
int pn_message_encode(pn_message_t *msg, char *bytes, size_t *isize)
{
size_t remaining = *isize;
size_t last_size = 0;
size_t total = 0;
/* "DL[?o?B?I?o?I]" */
last_size = pn_amqp_encode_bytes_DLEQoQBQIQoQIe(bytes, remaining, HEADER,
msg->durable, msg->durable,
msg->priority!=HEADER_PRIORITY_DEFAULT, msg->priority,
(bool)msg->ttl, msg->ttl,
msg->first_acquirer, msg->first_acquirer,
(bool)msg->delivery_count, msg->delivery_count);
if (last_size > remaining) return PN_OVERFLOW;
remaining -= last_size;
bytes += last_size;
total += last_size;
if (pn_data_size(msg->instructions)) {
pn_data_rewind(msg->instructions);
last_size = pn_amqp_encode_bytes_DLC(bytes, remaining, DELIVERY_ANNOTATIONS, msg->instructions);
if (last_size > remaining) return PN_OVERFLOW;
remaining -= last_size;
bytes += last_size;
total += last_size;
}
if (pn_data_size(msg->annotations)) {
pn_data_rewind(msg->annotations);
last_size = pn_amqp_encode_bytes_DLC(bytes, remaining, MESSAGE_ANNOTATIONS, msg->annotations);
if (last_size > remaining) return PN_OVERFLOW;
remaining -= last_size;
bytes += last_size;
total += last_size;
}
/* "DL[CzSSSCss?t?tS?IS]" */
pn_atom_t id = pn_message_get_id(msg);
pn_atom_t correlation_id = pn_message_get_correlation_id(msg);
last_size = pn_amqp_encode_bytes_DLEazSSSassQtQtSQISe(bytes, remaining, PROPERTIES,
&id,
pn_string_size(msg->user_id), pn_string_get(msg->user_id),
pn_string_bytes(msg->address),
pn_string_bytes(msg->subject),
pn_string_bytes(msg->reply_to),
&correlation_id,
pn_string_bytes(msg->content_type),
pn_string_bytes(msg->content_encoding),
(bool)msg->expiry_time, msg->expiry_time,
(bool)msg->creation_time, msg->creation_time,
pn_string_bytes(msg->group_id),
/*
* As a heuristic, null out group_sequence if there is no group_id and
* group_sequence is 0. In this case it is extremely unlikely we want
* group semantics
*/
(bool)pn_string_get(msg->group_id) || (bool)msg->group_sequence , msg->group_sequence,
pn_string_bytes(msg->reply_to_group_id));
if (last_size > remaining) return PN_OVERFLOW;
remaining -= last_size;
bytes += last_size;
total += last_size;
if (pn_data_size(msg->properties)) {
pn_data_rewind(msg->properties);
last_size = pn_amqp_encode_bytes_DLC(bytes, remaining, APPLICATION_PROPERTIES, msg->properties);
if (last_size > remaining) return PN_OVERFLOW;
remaining -= last_size;
bytes += last_size;
total += last_size;
}
if (pn_data_size(msg->body)) {
pn_data_rewind(msg->body);
pn_data_next(msg->body);
pn_type_t body_type = pn_data_type(msg->body);
pn_data_rewind(msg->body);
uint64_t descriptor = AMQP_VALUE;
if (msg->inferred) {
switch (body_type) {
case PN_BINARY:
descriptor = DATA;
break;
case PN_LIST:
descriptor = AMQP_SEQUENCE;
break;
default:
break;
}
}
last_size = pn_amqp_encode_bytes_DLC(bytes, remaining, descriptor, msg->body);
if (last_size > remaining) return PN_OVERFLOW;
remaining -= last_size;
bytes += last_size;
total += last_size;
}
*isize = total;
return 0;
}