/* * libvirt-gconfig-domain-interface-network-filterref.c: * libvirt filter reference config. * * Copyright (C) 2013 Red Hat, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that 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 library. If not, see * . * * Author: Ian Main */ #include #include "libvirt-gconfig/libvirt-gconfig.h" #include "libvirt-gconfig/libvirt-gconfig-private.h" #define GVIR_CONFIG_DOMAIN_INTERFACE_FILTERREF_GET_PRIVATE(obj) \ (G_TYPE_INSTANCE_GET_PRIVATE((obj), GVIR_CONFIG_TYPE_DOMAIN_INTERFACE_FILTERREF, GVirConfigDomainInterfaceFilterrefPrivate)) struct _GVirConfigDomainInterfaceFilterrefPrivate { gboolean unused; }; G_DEFINE_TYPE_WITH_PRIVATE(GVirConfigDomainInterfaceFilterref, gvir_config_domain_interface_filterref, GVIR_CONFIG_TYPE_OBJECT); static void gvir_config_domain_interface_filterref_class_init(GVirConfigDomainInterfaceFilterrefClass *klass G_GNUC_UNUSED) { } static void gvir_config_domain_interface_filterref_init(GVirConfigDomainInterfaceFilterref *filterref) { filterref->priv = GVIR_CONFIG_DOMAIN_INTERFACE_FILTERREF_GET_PRIVATE(filterref); } GVirConfigDomainInterfaceFilterref *gvir_config_domain_interface_filterref_new(void) { GVirConfigObject *object; object = gvir_config_object_new(GVIR_CONFIG_TYPE_DOMAIN_INTERFACE_FILTERREF, "filterref", NULL); return GVIR_CONFIG_DOMAIN_INTERFACE_FILTERREF(object); } GVirConfigDomainInterfaceFilterref *gvir_config_domain_interface_filterref_new_from_xml(const gchar *xml, GError **error) { GVirConfigObject *object; object = gvir_config_object_new_from_xml(GVIR_CONFIG_TYPE_DOMAIN_INTERFACE_FILTERREF, "filterref", NULL, xml, error); if (gvir_config_object_get_attribute(object, NULL, "filter") == NULL) { g_object_unref(G_OBJECT(object)); return NULL; } return GVIR_CONFIG_DOMAIN_INTERFACE_FILTERREF(object); } void gvir_config_domain_interface_filterref_set_name(GVirConfigDomainInterfaceFilterref *filterref, const char *filter) { g_return_if_fail(GVIR_CONFIG_IS_DOMAIN_INTERFACE_FILTERREF(filterref)); gvir_config_object_set_attribute(GVIR_CONFIG_OBJECT(filterref), "filter", filter, NULL); } const char *gvir_config_domain_interface_filterref_get_name(GVirConfigDomainInterfaceFilterref *filterref) { g_return_val_if_fail(GVIR_CONFIG_IS_DOMAIN_INTERFACE_FILTERREF(filterref), NULL); return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(filterref), NULL, "filter"); } void gvir_config_domain_interface_filterref_add_parameter(GVirConfigDomainInterfaceFilterref *filterref, GVirConfigDomainInterfaceFilterrefParameter *parameter) { g_return_if_fail(GVIR_CONFIG_IS_DOMAIN_INTERFACE_FILTERREF(filterref)); g_return_if_fail(GVIR_CONFIG_IS_DOMAIN_INTERFACE_FILTERREF_PARAMETER(parameter)); gvir_config_object_attach_add(GVIR_CONFIG_OBJECT(filterref), GVIR_CONFIG_OBJECT(parameter)); } struct GetParameterData { GVirConfigXmlDoc *doc; GList *parameters; }; static gboolean add_filterref_parameter(xmlNodePtr node, gpointer opaque) { struct GetParameterData* data = (struct GetParameterData*)opaque; GVirConfigObject *parameter; if (g_strcmp0((const gchar *)node->name, "parameter") != 0) { g_debug("unexpected node %s", node->name); return TRUE; } parameter = gvir_config_object_new_from_tree(GVIR_CONFIG_TYPE_DOMAIN_INTERFACE_FILTERREF_PARAMETER, data->doc, NULL, node); if (parameter != NULL) data->parameters = g_list_append(data->parameters, parameter); else g_debug("Failed to parse %s node", node->name); return TRUE; } /** * gvir_config_domain_interface_filterref_get_parameters: * @filterref: a #GVirConfigDomainInterfaceFilterref * * Gets the list of parameters attached to @filterref. The returned list should be * freed with g_list_free(), after its elements have been unreffed with * g_object_unref(). * * Returns: (element-type LibvirtGConfig.DomainInterfaceFilterrefParameter) (transfer full): * a newly allocated #GList of #GVirConfigDomainInterfaceFilterrefParameter. */ GList *gvir_config_domain_interface_filterref_get_parameters(GVirConfigDomainInterfaceFilterref *filterref) { struct GetParameterData data; g_return_val_if_fail(GVIR_CONFIG_IS_DOMAIN_INTERFACE_FILTERREF(filterref), NULL); g_object_get(G_OBJECT(filterref), "doc", &data.doc, NULL); data.parameters = NULL; gvir_config_object_foreach_child(GVIR_CONFIG_OBJECT(filterref), NULL, add_filterref_parameter, &data); if (data.doc != NULL) { g_object_unref(G_OBJECT(data.doc)); } return data.parameters; }