/* * dLeyna * * Copyright (C) 2012-2017 Intel Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU Lesser General Public License, * version 2.1, as published by the Free Software Foundation. * * This program is distributed in the hope it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License * for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA. * * Christophe Guiraud * */ #include #include #include "xml-util.h" static xmlNode *prv_get_child_node(xmlNode *node, va_list args) { const gchar *name; name = va_arg(args, const gchar *); while (name != NULL) { node = node->children; while (node != NULL) { if (node->name != NULL && !strcmp(name, (char *)node->name)) break; node = node->next; } if (node == NULL) break; name = va_arg(args, const gchar *); } return node; } static GList *prv_get_children_list(xmlNode *node, const gchar *name) { GList *child_list = NULL; node = node->children; while (node != NULL) { if (node->name != NULL && !strcmp(name, (char *)node->name)) child_list = g_list_prepend(child_list, node); node = node->next; } return child_list; } GList *xml_util_get_child_string_list_content_by_name(xmlNode *node, ...) { xmlChar *content; va_list args; GList *child_list = NULL; GList *next; GList *str_list = NULL; xmlNode *child_list_node; xmlNode *child_node; va_start(args, node); child_node = prv_get_child_node(node, args); va_end(args); if (child_node != NULL) { child_list = prv_get_children_list(child_node->parent, (const gchar *)child_node->name); next = child_list; while (next) { child_list_node = (xmlNode *)next->data; content = xmlNodeGetContent(child_list_node); if (content != NULL) { str_list = g_list_prepend(str_list, g_strdup((gchar *)content)); xmlFree(content); } next = g_list_next(next); } g_list_free(child_list); } return str_list; } gchar *xml_util_get_child_string_content_by_name(xmlNode *node, ...) { xmlChar *content; va_list args; gchar *str = NULL; xmlNode *child_node; va_start(args, node); child_node = prv_get_child_node(node, args); va_end(args); if (child_node != NULL) { content = xmlNodeGetContent(child_node); if (content != NULL) { str = g_strdup((gchar *)content); xmlFree(content); } } return str; }