[libvirt] [libvirt-glib 1/4] Add GVirConfigDomainDiskDriver
Zeeshan Ali (Khattak)
zeeshanak at gnome.org
Thu Jan 16 19:44:56 UTC 2014
On Fri, Dec 6, 2013 at 11:13 AM, Christophe Fergeau <cfergeau at redhat.com> wrote:
> This class wraps creation of configuration data for the driver part of a
> domain disk device. The methods needed for this are currently part of
> GVirConfigDomainDisk, but since the disk driver is getting more and more
> attributes, it's better to move such configuration to a dedicated class to
> avoid a too big API in GVirConfigDomainDisk
> ---
> libvirt-gconfig/Makefile.am | 2 +
> .../libvirt-gconfig-domain-disk-driver.c | 244 +++++++++++++++++++++
> .../libvirt-gconfig-domain-disk-driver.h | 116 ++++++++++
> libvirt-gconfig/libvirt-gconfig-domain-disk.c | 3 +
> libvirt-gconfig/libvirt-gconfig.h | 1 +
> libvirt-gconfig/libvirt-gconfig.sym | 21 ++
> 6 files changed, 387 insertions(+)
> create mode 100644 libvirt-gconfig/libvirt-gconfig-domain-disk-driver.c
> create mode 100644 libvirt-gconfig/libvirt-gconfig-domain-disk-driver.h
>
> diff --git a/libvirt-gconfig/Makefile.am b/libvirt-gconfig/Makefile.am
> index 0793da1..7550afe 100644
> --- a/libvirt-gconfig/Makefile.am
> +++ b/libvirt-gconfig/Makefile.am
> @@ -37,6 +37,7 @@ GCONFIG_HEADER_FILES = \
> libvirt-gconfig-domain-cpu-feature.h \
> libvirt-gconfig-domain-device.h \
> libvirt-gconfig-domain-disk.h \
> + libvirt-gconfig-domain-disk-driver.h \
> libvirt-gconfig-domain-filesys.h \
> libvirt-gconfig-domain-graphics.h \
> libvirt-gconfig-domain-graphics-desktop.h \
> @@ -121,6 +122,7 @@ GCONFIG_SOURCE_FILES = \
> libvirt-gconfig-domain-cpu-feature.c \
> libvirt-gconfig-domain-device.c \
> libvirt-gconfig-domain-disk.c \
> + libvirt-gconfig-domain-disk-driver.c \
> libvirt-gconfig-domain-filesys.c \
> libvirt-gconfig-domain-graphics.c \
> libvirt-gconfig-domain-graphics-desktop.c \
> diff --git a/libvirt-gconfig/libvirt-gconfig-domain-disk-driver.c b/libvirt-gconfig/libvirt-gconfig-domain-disk-driver.c
> new file mode 100644
> index 0000000..ddf7ce2
> --- /dev/null
> +++ b/libvirt-gconfig/libvirt-gconfig-domain-disk-driver.c
> @@ -0,0 +1,244 @@
> +/*
> + * libvirt-gconfig-domain-disk-driver.c: libvirt domain disk driver configuration
> + *
> + * Copyright (C) 2011, 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
> + * <http://www.gnu.org/licenses/>.
> + *
> + * Author: Christophe Fergeau <cfergeau at redhat.com>
> + */
> +
> +#include <config.h>
> +
> +#include "libvirt-gconfig/libvirt-gconfig.h"
> +#include "libvirt-gconfig/libvirt-gconfig-private.h"
> +
> +#define GVIR_CONFIG_DOMAIN_DISK_DRIVER_GET_PRIVATE(obj) \
> + (G_TYPE_INSTANCE_GET_PRIVATE((obj), GVIR_CONFIG_TYPE_DOMAIN_DISK_DRIVER, GVirConfigDomainDiskDriverPrivate))
> +
> +struct _GVirConfigDomainDiskDriverPrivate
> +{
> + gboolean unused;
> +};
> +
> +G_DEFINE_TYPE(GVirConfigDomainDiskDriver, gvir_config_domain_disk_driver, GVIR_CONFIG_TYPE_OBJECT);
> +
> +
> +static void gvir_config_domain_disk_driver_class_init(GVirConfigDomainDiskDriverClass *klass)
> +{
> + g_type_class_add_private(klass, sizeof(GVirConfigDomainDiskDriverPrivate));
> +}
> +
> +
> +static void gvir_config_domain_disk_driver_init(GVirConfigDomainDiskDriver *driver)
> +{
> + g_debug("Init GVirConfigDomainDiskDriver=%p", driver);
> +
> + driver->priv = GVIR_CONFIG_DOMAIN_DISK_DRIVER_GET_PRIVATE(driver);
> +}
> +
> +
> +GVirConfigDomainDiskDriver *gvir_config_domain_disk_driver_new(void)
> +{
> + GVirConfigObject *object;
> +
> + object = gvir_config_object_new(GVIR_CONFIG_TYPE_DOMAIN_DISK_DRIVER,
> + "driver", NULL);
> + return GVIR_CONFIG_DOMAIN_DISK_DRIVER(object);
> +}
> +
> +GVirConfigDomainDiskDriver *gvir_config_domain_disk_driver_new_from_xml(const gchar *xml,
> + GError **error)
> +{
> + GVirConfigObject *object;
> +
> + object = gvir_config_object_new_from_xml(GVIR_CONFIG_TYPE_DOMAIN_DISK_DRIVER,
> + "driver", NULL, xml, error);
> + return GVIR_CONFIG_DOMAIN_DISK_DRIVER(object);
> +}
> +
> +
> +void gvir_config_domain_disk_driver_set_cache(GVirConfigDomainDiskDriver *driver,
> + GVirConfigDomainDiskCacheType cache_type)
> +{
> + g_return_if_fail(GVIR_CONFIG_IS_DOMAIN_DISK_DRIVER(driver));
> +
> + gvir_config_object_set_attribute_with_type(GVIR_CONFIG_OBJECT(driver),
> + "cache",
> + GVIR_CONFIG_TYPE_DOMAIN_DISK_CACHE_TYPE,
> + cache_type,
> + NULL);
> +}
> +
> +
> +GVirConfigDomainDiskCacheType gvir_config_domain_disk_driver_get_cache(GVirConfigDomainDiskDriver *driver)
> +{
> + g_return_val_if_fail(GVIR_CONFIG_IS_DOMAIN_DISK_DRIVER(driver),
> + GVIR_CONFIG_DOMAIN_DISK_CACHE_DEFAULT);
> +
> + return gvir_config_object_get_attribute_genum(GVIR_CONFIG_OBJECT(driver),
> + NULL, "cache",
> + GVIR_CONFIG_TYPE_DOMAIN_DISK_CACHE_TYPE,
> + GVIR_CONFIG_DOMAIN_DISK_CACHE_DEFAULT);
> +}
> +
> +
> +void gvir_config_domain_disk_driver_set_name(GVirConfigDomainDiskDriver *driver,
> + const char *name)
Since libvirt support only specific drivers and they are identified by
name, I'd suggest this be an enum.
Rest of the patch looks good.
More information about the libvir-list
mailing list