You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kamailio/lib/cds/doc/set_data_destroy_function.xml

72 lines
2.3 KiB

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
"http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">
<refentry id="set_data_destroy_function"> <!-- ID for references -->
<refmeta>
<refentrytitle>set_data_destroy_function</refentrytitle> <!-- title shown in references -->
<manvolnum>3</manvolnum></refmeta> <!-- man volume id (3 for libraries) -->
<refnamediv>
<refname>set_data_destroy_function</refname> <!-- function name -->
<refpurpose>set function used to deallocate message data</refpurpose> <!-- short function description -->
</refnamediv>
<refsynopsisdiv><funcsynopsis>
<funcsynopsisinfo>
#include &lt;cds/msg_queue.h&gt; <!-- included headers -->
typedef void (*destroy_function_f)(void *);
</funcsynopsisinfo>
<funcprototype> <!-- function prototype -->
<funcdef>void <function>set_data_destroy_function</function></funcdef>
<paramdef>mq_message_t *<parameter>msg</parameter></paramdef>
<paramdef>destroy_function_f <parameter>func</parameter></paramdef>
</funcprototype>
</funcsynopsis></refsynopsisdiv>
<refsect1><title>Description</title>
<para>Set destroy function for message data. This function is called from
<function>free_message</function> and is primarily used for deallocation of
complex data structures or their content. It can be used on all types of
messages (allocated using <function>create_message</function> or
<function>create_message_ex</function> or initialized using
<function>init_message_ex</function>).
<!-- detailed description -->
</para>
<example><title>Usage with create_message_ex</title>
<programlisting>
str_t *s;
mq_message_t *msg = create_message_ex(sizeof(str_t));
set_data_destroy_function((destroy_function_f)str_free_content);
s = (str_t*)get_message_data(msg);
str_dup_zt(s, "something happened");
</programlisting>
</example>
<example><title>Usage with create_message</title>
<programlisting>
str_t *s = cds_malloc(sizeof(str_t));
mq_message_t *msg = create_message(s, sizeof(str_t));
set_data_destroy_function((destroy_function_f)str_free);
str_dup_zt(s, "something happened");
</programlisting>
</example>
</refsect1>
<refsect1><title>See Also</title>
<para><xref linkend="create_message"/>, <xref linkend="create_message_ex"/>,
<xref linkend="init_message_ex"/>
<!-- references to other pages -->
</para>
</refsect1>
</refentry>