Blob Blame History Raw
/*
 * 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 <christophe.guiraud@intel.com>
 *
 */

#include <string.h>
#include <stdlib.h>

#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;
}