/* frees a tag attribute list */
static void switch_xml_free_attr(char **attr)
{
- int i = 0;
+ int i, c = 0;
char *m;
if (!attr || attr == SWITCH_XML_NIL)
return; /* nothing to free */
- while (attr[i])
- i += 2; /* find end of attribute list */
- m = attr[i + 1]; /* list of which names and values are malloced */
- for (i = 0; m[i]; i++) {
+ while (attr[c])
+ c += 2; /* find end of attribute list */
+ m = attr[c + 1]; /* list of which names and values are malloced */
+ for (i = c / 2 - 1; i >= 0 ; i--) {
if (m[i] & SWITCH_XML_NAMEM)
free(attr[i * 2]);
if (m[i] & SWITCH_XML_TXTM)
}
FST_TEARDOWN_END()
+ FST_TEST_BEGIN(test_xml_free_attr)
+ {
+ switch_xml_t parent_xml = switch_xml_new("xml");
+ switch_xml_t xml = switch_xml_add_child_d(parent_xml, "test", 1);
+ switch_xml_set_attr(xml, "a1", "v1");
+ switch_xml_set_attr_d(xml, "a2", "v2");
+ switch_xml_free(parent_xml);
+ }
+ FST_TEST_END()
+
FST_TEST_BEGIN(test_xml_set_attr)
{
switch_xml_t parent_xml = switch_xml_new("xml");