packet: Introduce pa_packet_new_data() to copy data into a newly created packet

v2: (thanks Alexander Patrakov)
* turn check in pa_packet_new() into assert()

Signed-off-by: Peter Meerwald <pmeerw@pmeerw.net>
This commit is contained in:
Peter Meerwald 2014-10-23 16:51:08 +02:00 committed by Peter Meerwald
parent c1a7f0e326
commit f92300cc92
3 changed files with 16 additions and 1 deletions

View file

@ -60,6 +60,17 @@ pa_packet* pa_packet_new(size_t length) {
return p;
}
pa_packet* pa_packet_new_data(const void* data, size_t length) {
pa_packet *p = pa_packet_new(length);
pa_assert(data);
pa_assert(length > 0);
memcpy(p->data, data, length);
return p;
}
pa_packet* pa_packet_new_dynamic(void* data, size_t length) {
pa_packet *p;

View file

@ -29,6 +29,10 @@ typedef struct pa_packet pa_packet;
* on length) */
pa_packet* pa_packet_new(size_t length);
/* create packet (either of type appended or dynamic depending on length)
* and copy data */
pa_packet* pa_packet_new_data(const void* data, size_t length);
/* data must have been malloc()ed; the packet takes ownership of the memory,
* i.e. memory is free()d with the packet */
pa_packet* pa_packet_new_dynamic(void* data, size_t length);

View file

@ -36,7 +36,7 @@ static void pa_pstream_send_tagstruct_with_ancil_data(pa_pstream *p, pa_tagstruc
pa_assert(t);
pa_assert_se(data = pa_tagstruct_data(t, &length));
pa_assert_se(packet = pa_packet_new_dynamic(pa_xmemdup(data, length), length));
pa_assert_se(packet = pa_packet_new_data(data, length));
pa_tagstruct_free(t);
pa_pstream_send_packet(p, packet, ancil_data);