[virt-tools-list] [libosinfo v4] API to query required user avatar format

Zeeshan Ali (Khattak) zeeshanak at gnome.org
Fri Nov 23 03:26:19 UTC 2012


From: "Zeeshan Ali (Khattak)" <zeeshanak at gnome.org>

Add a new API for apps to be able to query in which format do the user
avatar file need to be in.

Based on a patch from Fabiano Fidêncio <fabiano at fidencio.org>.
---
 data/install-scripts/fedora.xml        |   3 +
 data/install-scripts/windows-cmd.xml   |   6 +
 data/schemas/libosinfo.rng             |  30 ++++
 osinfo/Makefile.am                     |  65 ++++-----
 osinfo/libosinfo.syms                  |   8 +-
 osinfo/osinfo.h                        |   1 +
 osinfo/osinfo_avatar_format.c          | 242 +++++++++++++++++++++++++++++++++
 osinfo/osinfo_avatar_format.h          |  95 +++++++++++++
 osinfo/osinfo_install_script.c         |  52 +++++++
 osinfo/osinfo_install_script.h         |   3 +
 osinfo/osinfo_install_script_private.h |  40 ++++++
 osinfo/osinfo_loader.c                 |  45 ++++++
 po/POTFILES.in                         |   1 +
 13 files changed, 559 insertions(+), 32 deletions(-)
 create mode 100644 osinfo/osinfo_avatar_format.c
 create mode 100644 osinfo/osinfo_avatar_format.h
 create mode 100644 osinfo/osinfo_install_script_private.h

diff --git a/data/install-scripts/fedora.xml b/data/install-scripts/fedora.xml
index dc767d5..fcb1143 100644
--- a/data/install-scripts/fedora.xml
+++ b/data/install-scripts/fedora.xml
@@ -122,6 +122,9 @@ reboot
         <param name="avatar-disk" policy="optional"/>
         <param name="target-disk" policy="optional"/>
     </config>
+    <avatar-format>
+      <mime-type>image/png</mime-type>
+    </avatar-format>
     <template>
       <xsl:stylesheet
         xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
diff --git a/data/install-scripts/windows-cmd.xml b/data/install-scripts/windows-cmd.xml
index 020a493..84833a9 100644
--- a/data/install-scripts/windows-cmd.xml
+++ b/data/install-scripts/windows-cmd.xml
@@ -12,6 +12,12 @@
       <param name="target-disk" policy="optional"/>
       <param name="script-disk" policy="optional"/>
     </config>
+    <avatar-format>
+      <mime-type>image/bmp</mime-type>
+      <width>48</width>
+      <height>48</height>
+      <alpha>false</alpha>
+    </avatar-format>
     <template>
       <xsl:stylesheet
         xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
diff --git a/data/schemas/libosinfo.rng b/data/schemas/libosinfo.rng
index 3c57c36..87635dd 100644
--- a/data/schemas/libosinfo.rng
+++ b/data/schemas/libosinfo.rng
@@ -478,6 +478,9 @@
           </element>
         </optional>
         <optional>
+          <ref name='avatar-format'/>
+        </optional>
+        <optional>
           <element name='config'>
             <oneOrMore>
               <element name='param'>
@@ -509,6 +512,33 @@
     </element>
   </define>
 
+  <define name='avatar-format'>
+    <element name='avatar-format'>
+      <interleave>
+        <oneOrMore>
+          <element name="mime-type">
+            <text/>
+          </element>
+        </oneOrMore>
+        <optional>
+          <element name="width">
+            <ref name='num'/>
+          </element>
+        </optional>
+        <optional>
+          <element name="height">
+            <ref name='num'/>
+          </element>
+        </optional>
+        <optional>
+          <element name="alpha">
+            <ref name='bool'/>
+          </element>
+        </optional>
+      </interleave>
+    </element>
+  </define>
+
   <define name="customElement">
     <element>
       <anyName/>
diff --git a/osinfo/Makefile.am b/osinfo/Makefile.am
index abaa78c..c8a831b 100644
--- a/osinfo/Makefile.am
+++ b/osinfo/Makefile.am
@@ -55,6 +55,7 @@ libosinfo_1_0_includedir = $(includedir)/libosinfo-1.0/osinfo
 
 libosinfo_1_0_include_HEADERS = \
   osinfo.h			\
+  osinfo_avatar_format.h 	\
   osinfo_db.h			\
   osinfo_loader.h		\
   osinfo_device.h		\
@@ -87,37 +88,39 @@ libosinfo_1_0_include_HEADERS = \
   osinfo_treelist.h		\
   $(NULL)
 
-libosinfo_1_0_la_SOURCES =	\
-  osinfo_entity.c		\
-  osinfo_enum_types.c		\
-  osinfo_filter.c		\
-  osinfo_list.c			\
-  osinfo_device.c		\
-  osinfo_devicelink.c		\
-  osinfo_devicelist.c		\
-  osinfo_devicelinklist.c	\
-  osinfo_devicelinkfilter.c	\
-  osinfo_install_config.c       \
-  osinfo_install_config_param.c \
-  osinfo_install_script.c       \
-  osinfo_install_scriptlist.c   \
-  osinfo_product.c		\
-  osinfo_productfilter.c	\
-  osinfo_productlist.c		\
-  osinfo_platform.c		\
-  osinfo_platformlist.c		\
-  osinfo_oslist.c		\
-  osinfo_os.c			\
-  osinfo_deployment.c		\
-  osinfo_deploymentlist.c	\
-  osinfo_media.c		\
-  osinfo_medialist.c		\
-  osinfo_resources.c		\
-  osinfo_resourceslist.c	\
-  osinfo_tree.c			\
-  osinfo_treelist.c		\
-  osinfo_db.c			\
-  osinfo_loader.c		\
+libosinfo_1_0_la_SOURCES =	  \
+  osinfo_avatar_format.c 	  \
+  osinfo_entity.c		  \
+  osinfo_enum_types.c		  \
+  osinfo_filter.c		  \
+  osinfo_list.c			  \
+  osinfo_device.c		  \
+  osinfo_devicelink.c		  \
+  osinfo_devicelist.c		  \
+  osinfo_devicelinklist.c	  \
+  osinfo_devicelinkfilter.c	  \
+  osinfo_install_config.c         \
+  osinfo_install_config_param.c   \
+  osinfo_install_script.c         \
+  osinfo_install_script_private.h \
+  osinfo_install_scriptlist.c     \
+  osinfo_product.c		  \
+  osinfo_productfilter.c	  \
+  osinfo_productlist.c		  \
+  osinfo_platform.c		  \
+  osinfo_platformlist.c		  \
+  osinfo_oslist.c		  \
+  osinfo_os.c			  \
+  osinfo_deployment.c		  \
+  osinfo_deploymentlist.c	  \
+  osinfo_media.c		  \
+  osinfo_medialist.c		  \
+  osinfo_resources.c		  \
+  osinfo_resourceslist.c	  \
+  osinfo_tree.c			  \
+  osinfo_treelist.c		  \
+  osinfo_db.c			  \
+  osinfo_loader.c		  \
   $(NULL)
 
 osinfo_enum_types.h: $(libosinfo_1_0_include_HEADERS) osinfo_enum_types.h.template
diff --git a/osinfo/libosinfo.syms b/osinfo/libosinfo.syms
index de33a70..f3349d9 100644
--- a/osinfo/libosinfo.syms
+++ b/osinfo/libosinfo.syms
@@ -317,6 +317,12 @@ LIBOSINFO_0.2.1 {
 
 LIBOSINFO_0.2.2 {
     global:
+	osinfo_avatar_format_get_type;
+	osinfo_avatar_format_get_mime_types;
+	osinfo_avatar_format_get_width;
+	osinfo_avatar_format_get_height;
+	osinfo_avatar_format_get_alpha;
+
 	osinfo_install_config_param_policy_get_type;
 	osinfo_media_error_get_type;
 	osinfo_product_relationship_get_type;
@@ -336,10 +342,10 @@ LIBOSINFO_0.2.2 {
 	osinfo_install_config_get_script_disk;
 	osinfo_install_config_set_script_disk;
 
+	osinfo_install_script_get_avatar_format;
 	osinfo_install_script_get_path_format;
 } LIBOSINFO_0.2.1;
 
-
 /* Symbols in next release...
 
   LIBOSINFO_0.0.2 {
diff --git a/osinfo/osinfo.h b/osinfo/osinfo.h
index 81ed1cc..559eaa8 100644
--- a/osinfo/osinfo.h
+++ b/osinfo/osinfo.h
@@ -39,6 +39,7 @@
 #include <osinfo/osinfo_install_config.h>
 #include <osinfo/osinfo_install_config_param.h>
 #include <osinfo/osinfo_install_script.h>
+#include <osinfo/osinfo_avatar_format.h>
 #include <osinfo/osinfo_install_scriptlist.h>
 #include <osinfo/osinfo_productlist.h>
 #include <osinfo/osinfo_product.h>
diff --git a/osinfo/osinfo_avatar_format.c b/osinfo/osinfo_avatar_format.c
new file mode 100644
index 0000000..fb39da9
--- /dev/null
+++ b/osinfo/osinfo_avatar_format.c
@@ -0,0 +1,242 @@
+/*
+ * libosinfo:
+ *
+ * Copyright (C) 2009-2012 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, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Authors:
+ *   Fabiano Fidêncio <fabiano at fidencio.org>
+ *   Zeeshan Ali (Khattak) <zeeshanak at gnome.org>
+ */
+
+#include <config.h>
+
+#include <osinfo/osinfo.h>
+#include <glib/gi18n-lib.h>
+
+G_DEFINE_TYPE (OsinfoAvatarFormat, osinfo_avatar_format, OSINFO_TYPE_ENTITY);
+
+#define OSINFO_AVATAR_FORMAT_GET_PRIVATE(obj)  \
+        (G_TYPE_INSTANCE_GET_PRIVATE ((obj),                \
+         OSINFO_TYPE_AVATAR_FORMAT,            \
+         OsinfoAvatarFormatPrivate))
+
+/**
+ * SECTION: osinfo_avatar_format
+ * @short_description: The required format of avatar for an install script
+ * @see_also: #OsinfoInstallScript
+ */
+
+enum {
+    PROP_0,
+
+    PROP_MIME_TYPES,
+    PROP_WIDTH,
+    PROP_HEIGHT,
+    PROP_ALPHA,
+};
+
+static void
+osinfo_avatar_format_get_property(GObject *object,
+				  guint property_id,
+                                  GValue *value,
+                                  GParamSpec *pspec)
+{
+    OsinfoAvatarFormat *avatar = OSINFO_AVATAR_FORMAT (object);
+
+    switch (property_id)
+        {
+        case PROP_MIME_TYPES:
+        {
+            GList *mime_types;
+
+            mime_types = osinfo_avatar_format_get_mime_types(avatar);
+            g_value_set_pointer(value, mime_types);
+            break;
+        }
+        case PROP_WIDTH:
+            g_value_set_int(value,
+                            osinfo_avatar_format_get_width(avatar));
+            break;
+        case PROP_HEIGHT:
+            g_value_set_int(value,
+                            osinfo_avatar_format_get_height(avatar));
+            break;
+        case PROP_ALPHA:
+            g_value_set_boolean(value,
+                                osinfo_avatar_format_get_alpha(avatar));
+            break;
+        default:
+            /* We don't have any other property... */
+            G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+            break;
+        }
+}
+
+/* Init functions */
+static void
+osinfo_avatar_format_class_init (OsinfoAvatarFormatClass *klass)
+{
+    GObjectClass *g_klass = G_OBJECT_CLASS (klass);
+    GParamSpec *pspec;
+
+    g_klass->get_property = osinfo_avatar_format_get_property;
+
+    /**
+     * OsinfoAvatarFormat:mime-types:
+     *
+     * The allowed mime-types for the avatar.
+     *
+     * Type: GLib.List(utf8)
+     * Transfer: container
+     **/
+    pspec = g_param_spec_pointer("mime-types",
+                                "MIME Types",
+                                _("The allowed mime-types for the avatar"),
+                                G_PARAM_READABLE |
+                                G_PARAM_STATIC_STRINGS);
+    g_object_class_install_property(g_klass,
+                                    PROP_MIME_TYPES,
+                                    pspec);
+
+    /**
+     * OsinfoAvatarFormat:width:
+     *
+     * The required width (in pixels) of the avatar.
+     **/
+    pspec = g_param_spec_int("width",
+                             "Width",
+                             _("The required width (in pixels) of the avatar"),
+                             -1,
+                             G_MAXINT,
+                             -1,
+                             G_PARAM_READABLE |
+                             G_PARAM_STATIC_STRINGS);
+    g_object_class_install_property(g_klass,
+                                    PROP_WIDTH,
+                                    pspec);
+
+    /**
+     * OsinfoAvatarFormat:height:
+     *
+     * The required height (in pixels) of the avatar.
+     **/
+    pspec = g_param_spec_int("height",
+                             "Height",
+                             _("The required height (in pixels) of the avatar."),
+                             -1,
+                             G_MAXINT,
+                             -1,
+                             G_PARAM_READABLE |
+                             G_PARAM_STATIC_STRINGS);
+    g_object_class_install_property(g_klass,
+                                    PROP_HEIGHT,
+                                    pspec);
+
+    /**
+     * OsinfoAvatarFormat:alpha:
+     *
+     * Whether alpha channel is supported in the avatar.
+     **/
+    pspec = g_param_spec_boolean("alpha",
+                                 "Alpha",
+                                 _("Whether alpha channel is supported in the avatar."),
+                                 TRUE,
+                                 G_PARAM_READABLE |
+                                 G_PARAM_STATIC_STRINGS);
+    g_object_class_install_property(g_klass,
+                                    PROP_ALPHA,
+                                    pspec);
+}
+
+static void
+osinfo_avatar_format_init (OsinfoAvatarFormat *avatar)
+{
+}
+
+/**
+ * osinfo_avatar_format_new:
+ *
+ * Construct a new user avatar file to a #OsinfoInstallScript.
+ *
+ * Returns: (transfer full): the necessary information to create an avatar for
+ *                           an user
+ */
+OsinfoAvatarFormat *
+osinfo_avatar_format_new(void)
+{
+    return g_object_new(OSINFO_TYPE_AVATAR_FORMAT, NULL);
+}
+
+/**
+ * osinfo_avatar_format_get_mime_types:
+ * @avatar: the avatar info
+ *
+ * Returns: (transfer container) (element-type utf8): the required mime-types of the avatar.
+ */
+GList *
+osinfo_avatar_format_get_mime_types(OsinfoAvatarFormat *avatar)
+{
+    return osinfo_entity_get_param_value_list(OSINFO_ENTITY(avatar),
+                                              OSINFO_AVATAR_FORMAT_PROP_MIME_TYPE);
+}
+
+/**
+ * osinfo_avatar_format_get_width:
+ * @avatar: the avatar info
+ *
+ * Returns: the required width (in pixels) of the avatar, or -1.
+ */
+gint
+osinfo_avatar_format_get_width(OsinfoAvatarFormat *avatar)
+{
+    return osinfo_entity_get_param_value_int64(OSINFO_ENTITY(avatar),
+                                               OSINFO_AVATAR_FORMAT_PROP_WIDTH);
+}
+
+/**
+ * osinfo_avatar_format_get_height:
+ * @avatar: the avatar info
+ *
+ * Returns: the required height (in pixels) of the avatar, or -1.
+ */
+gint
+osinfo_avatar_format_get_height(OsinfoAvatarFormat *avatar)
+{
+    return osinfo_entity_get_param_value_int64(OSINFO_ENTITY(avatar),
+                                               OSINFO_AVATAR_FORMAT_PROP_HEIGHT);
+}
+
+/**
+ * osinfo_avatar_format_get_alpha:
+ * @avatar: the avatar info
+ *
+ * Returns: Whether alpha channel is supported in the avatar.
+ */
+gboolean
+osinfo_avatar_format_get_alpha(OsinfoAvatarFormat *avatar)
+{
+    return osinfo_entity_get_param_value_boolean_with_default
+                (OSINFO_ENTITY(avatar), OSINFO_AVATAR_FORMAT_PROP_ALPHA, TRUE);
+}
+
+/*
+ * Local variables:
+ *  indent-tabs-mode: nil
+ *  c-indent-level: 4
+ *  c-basic-offset: 4
+ * End:
+ */
diff --git a/osinfo/osinfo_avatar_format.h b/osinfo/osinfo_avatar_format.h
new file mode 100644
index 0000000..fc4e03d
--- /dev/null
+++ b/osinfo/osinfo_avatar_format.h
@@ -0,0 +1,95 @@
+/*
+ * libosinfo: OS installation avatar information
+ *
+ * Copyright (C) 2009-2012 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, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Authors:
+ *   Fabiano Fidêncio <fabiano at fidencio.org>
+ *   Zeeshan Ali (Khattak) <zeeshanak at gnome.org>
+ */
+
+#include <glib-object.h>
+
+#ifndef __OSINFO_AVATAR_FORMAT_H__
+#define __OSINFO_AVATAR_FORMAT_H__
+
+/*
+ * Type macros.
+ */
+#define OSINFO_TYPE_AVATAR_FORMAT              \
+        (osinfo_avatar_format_get_type ())
+
+#define OSINFO_AVATAR_FORMAT(obj)              \
+        (G_TYPE_CHECK_INSTANCE_CAST ((obj),    \
+         OSINFO_TYPE_AVATAR_FORMAT,            \
+         OsinfoAvatarFormat))
+
+#define OSINFO_IS_AVATAR_FORMAT(obj)           \
+        (G_TYPE_CHECK_INSTANCE_TYPE ((obj),    \
+         OSINFO_TYPE_AVATAR_FORMAT))
+
+#define OSINFO_AVATAR_FORMAT_CLASS(klass)      \
+        (G_TYPE_CHECK_CLASS_CAST ((klass),     \
+         OSINFO_TYPE_AVATAR_FORMAT,            \
+         OsinfoAvatarFormatClass))
+
+#define OSINFO_IS_AVATAR_FORMAT_CLASS(klass)   \
+        (G_TYPE_CHECK_CLASS_TYPE ((klass),     \
+         OSINFO_TYPE_AVATAR_FORMAT))
+
+#define OSINFO_AVATAR_FORMAT_GET_CLASS(obj)    \
+        (G_TYPE_INSTANCE_GET_CLASS ((obj),     \
+         OSINFO_TYPE_AVATAR_FORMAT,            \
+         OsinfoAvatarFormatClass))
+
+typedef struct _OsinfoAvatarFormat OsinfoAvatarFormat;
+typedef struct _OsinfoAvatarFormatClass OsinfoAvatarFormatClass;
+
+#define OSINFO_AVATAR_FORMAT_PROP_MIME_TYPE "mime-type"
+#define OSINFO_AVATAR_FORMAT_PROP_WIDTH     "width"
+#define OSINFO_AVATAR_FORMAT_PROP_HEIGHT    "height"
+#define OSINFO_AVATAR_FORMAT_PROP_ALPHA     "alpha"
+
+/* object */
+struct _OsinfoAvatarFormat
+{
+    OsinfoEntity parent_instance;
+};
+
+/* class */
+struct _OsinfoAvatarFormatClass
+{
+    OsinfoEntityClass parent_class;
+};
+
+GType osinfo_avatar_format_get_type(void);
+
+OsinfoAvatarFormat *osinfo_avatar_format_new(void);
+
+GList *osinfo_avatar_format_get_mime_types(OsinfoAvatarFormat *avatar);
+gint osinfo_avatar_format_get_width(OsinfoAvatarFormat *avatar);
+gint osinfo_avatar_format_get_height(OsinfoAvatarFormat *avatar);
+gboolean osinfo_avatar_format_get_alpha(OsinfoAvatarFormat *avatar);
+
+#endif /* __OSINFO_AVATAR_FORMAT_H__ */
+/*
+ * Local variables:
+ *  indent-tabs-mode: nil
+ *  c-indent-level: 4
+ *  c-basic-offset: 4
+ * End:
+ */
diff --git a/osinfo/osinfo_install_script.c b/osinfo/osinfo_install_script.c
index f3cda62..5d80e23 100644
--- a/osinfo/osinfo_install_script.c
+++ b/osinfo/osinfo_install_script.c
@@ -30,6 +30,7 @@
 #include <libxslt/xsltutils.h>
 #include <libxslt/xsltInternals.h>
 #include <glib/gi18n-lib.h>
+#include "osinfo_install_script_private.h"
 
 G_DEFINE_TYPE (OsinfoInstallScript, osinfo_install_script, OSINFO_TYPE_ENTITY);
 
@@ -50,6 +51,7 @@ struct _OsinfoInstallScriptPrivate
     gchar *output_prefix;
     gchar *output_filename;
     GList *config_param_list;
+    OsinfoAvatarFormat *avatar;
 };
 
 enum {
@@ -60,6 +62,7 @@ enum {
     PROP_PROFILE,
     PROP_PRODUCT_KEY_FORMAT,
     PROP_PATH_FORMAT,
+    PROP_AVATAR_FORMAT,
 };
 
 typedef struct _OsinfoInstallScriptGenerateData OsinfoInstallScriptGenerateData;
@@ -142,6 +145,11 @@ osinfo_os_get_property(GObject    *object,
                          osinfo_install_script_get_path_format(script));
         break;
 
+    case PROP_AVATAR_FORMAT:
+        g_value_set_object(value,
+                           osinfo_install_script_get_avatar_format(script));
+        break;
+
     default:
         /* We don't have any other property... */
         G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
@@ -157,6 +165,8 @@ osinfo_install_script_finalize (GObject *object)
     g_free(script->priv->output_prefix);
     g_free(script->priv->output_filename);
     g_list_free_full(script->priv->config_param_list, g_object_unref);
+    if (script->priv->avatar != NULL)
+        g_object_unref(script->priv->avatar);
 
     /* Chain up to the parent class */
     G_OBJECT_CLASS (osinfo_install_script_parent_class)->finalize (object);
@@ -230,6 +240,16 @@ osinfo_install_script_class_init (OsinfoInstallScriptClass *klass)
                                     PROP_PATH_FORMAT,
                                     pspec);
 
+    pspec = g_param_spec_object("avatar-format",
+                                "Avatar Format",
+                                _("Expected avatar format"),
+                                OSINFO_TYPE_AVATAR_FORMAT,
+                                G_PARAM_READABLE |
+                                G_PARAM_STATIC_STRINGS);
+    g_object_class_install_property(g_klass,
+                                    PROP_AVATAR_FORMAT,
+                                    pspec);
+
     g_type_class_add_private (klass, sizeof (OsinfoInstallScriptPrivate));
 }
 
@@ -454,6 +474,38 @@ const gchar *osinfo_install_script_get_output_filename(OsinfoInstallScript *scri
     return script->priv->output_filename;
 }
 
+void
+osinfo_install_script_set_avatar_format(OsinfoInstallScript *script,
+                                        OsinfoAvatarFormat *avatar)
+{
+    g_return_if_fail(OSINFO_IS_INSTALL_SCRIPT(script));
+    g_return_if_fail(OSINFO_IS_AVATAR_FORMAT(avatar));
+
+    if (script->priv->avatar != NULL)
+        g_object_unref(script->priv->avatar);
+    script->priv->avatar = g_object_ref(avatar);
+}
+
+/**
+ * osinfo_install_script_get_avatar_format
+ *
+ * Some install scripts have restrictions on the format of the user avatar. Use
+ * this method to retrieve those restrictions in the form of an
+ * #OsinfoAvatarFormat instance.
+ *
+ * Returns: (transfer none): The avatar format, or NULL if there is no restrictions on the
+ *                           format of avatar
+ */
+OsinfoAvatarFormat *osinfo_install_script_get_avatar_format(OsinfoInstallScript *script)
+{
+    g_return_val_if_fail(OSINFO_IS_INSTALL_SCRIPT(script), NULL);
+
+    if (script->priv->avatar == NULL)
+        return NULL;
+
+    return script->priv->avatar;
+}
+
 struct _OsinfoInstallScriptGenerateData {
     GSimpleAsyncResult *res;
     OsinfoOs *os;
diff --git a/osinfo/osinfo_install_script.h b/osinfo/osinfo_install_script.h
index 036b572..a265e15 100644
--- a/osinfo/osinfo_install_script.h
+++ b/osinfo/osinfo_install_script.h
@@ -24,6 +24,7 @@
 #include <glib-object.h>
 #include <gio/gio.h>
 #include <osinfo/osinfo_install_config_param.h>
+#include <osinfo/osinfo_avatar_format.h>
 
 #ifndef __OSINFO_INSTALL_SCRIPT_H__
 #define __OSINFO_INSTALL_SCRIPT_H__
@@ -106,6 +107,8 @@ const gchar *osinfo_install_script_get_output_filename(OsinfoInstallScript *scri
 
 const gchar *osinfo_install_script_get_expected_filename(OsinfoInstallScript *script);
 
+OsinfoAvatarFormat *osinfo_install_script_get_avatar_format(OsinfoInstallScript *script);
+
 void osinfo_install_script_generate_async(OsinfoInstallScript *script,
                                           OsinfoOs *os,
                                           OsinfoInstallConfig *config,
diff --git a/osinfo/osinfo_install_script_private.h b/osinfo/osinfo_install_script_private.h
new file mode 100644
index 0000000..2ce0a41
--- /dev/null
+++ b/osinfo/osinfo_install_script_private.h
@@ -0,0 +1,40 @@
+/*
+ * libosinfo: OS installation script
+ *
+ * Copyright (C) 2012 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, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+ *
+ * Authors:
+ *   Zeeshan Ali (Khattak) <zeeshanak at gnome.org>
+ */
+
+#include <osinfo/osinfo_install_script.h>
+#include <osinfo/osinfo_avatar_format.h>
+
+#ifndef __OSINFO_INSTALL_SCRIPT_PRIVATE_H__
+#define __OSINFO_INSTALL_SCRIPT_PRIVATE_H__
+
+void osinfo_install_script_set_avatar_format(OsinfoInstallScript *script,
+                                             OsinfoAvatarFormat *avatar);
+
+#endif /* __OSINFO_INSTALL_SCRIPT_PRIVATE_H__ */
+/*
+ * Local variables:
+ *  indent-tabs-mode: nil
+ *  c-indent-level: 4
+ *  c-basic-offset: 4
+ * End:
+ */
diff --git a/osinfo/osinfo_loader.c b/osinfo/osinfo_loader.c
index 4736189..c49d303 100644
--- a/osinfo/osinfo_loader.c
+++ b/osinfo/osinfo_loader.c
@@ -34,6 +34,7 @@
 #include <libxml/tree.h>
 #include <libxml/xpath.h>
 #include <libxml/xmlreader.h>
+#include "osinfo_install_script_private.h"
 
 G_DEFINE_TYPE (OsinfoLoader, osinfo_loader, G_TYPE_OBJECT);
 
@@ -596,7 +597,31 @@ static void osinfo_loader_install_config_params(OsinfoLoader *loader,
     g_free(nodes);
 }
 
+static OsinfoAvatarFormat *osinfo_loader_avatar_format(OsinfoLoader *loader,
+                                                       xmlXPathContextPtr ctxt,
+                                                       xmlNodePtr root,
+                                                       GError **err)
+{
+    OsinfoAvatarFormat *avatar_format;
+    const gchar *const keys[] = {
+        OSINFO_AVATAR_FORMAT_PROP_MIME_TYPE,
+        OSINFO_AVATAR_FORMAT_PROP_WIDTH,
+        OSINFO_AVATAR_FORMAT_PROP_HEIGHT,
+        OSINFO_AVATAR_FORMAT_PROP_ALPHA,
+        NULL
+    };
+
+    avatar_format = osinfo_avatar_format_new();
+
+    osinfo_loader_entity(loader, OSINFO_ENTITY(avatar_format), keys, ctxt, root, err);
+    if (error_is_set(err)) {
+        g_object_unref (avatar_format);
 
+        return NULL;
+    }
+
+    return avatar_format;
+}
 
 static void osinfo_loader_install_script(OsinfoLoader *loader,
                                          xmlXPathContextPtr ctxt,
@@ -612,6 +637,8 @@ static void osinfo_loader_install_script(OsinfoLoader *loader,
         NULL
     };
     gchar *value = NULL;
+    xmlNodePtr *nodes = NULL;
+    int nnodes;
 
     if (!id) {
         OSINFO_ERROR(err, _("Missing install script id property"));
@@ -651,6 +678,24 @@ static void osinfo_loader_install_script(OsinfoLoader *loader,
                                         root,
                                         err);
 
+    nnodes = osinfo_loader_nodeset("./avatar-format", ctxt, &nodes, err);
+    if (error_is_set(err))
+        goto error;
+
+    if (nnodes > 0) {
+        OsinfoAvatarFormat *avatar_format;
+
+        xmlNodePtr saved = ctxt->node;
+        ctxt->node = nodes[0];
+        avatar_format = osinfo_loader_avatar_format(loader, ctxt, root, err);
+        ctxt->node = saved;
+        if (error_is_set(err))
+            goto error;
+
+        osinfo_install_script_set_avatar_format(installScript, avatar_format);
+    }
+    g_free(nodes);
+
     osinfo_db_add_install_script(loader->priv->db, installScript);
 
     return;
diff --git a/po/POTFILES.in b/po/POTFILES.in
index 513958c..1a209bb 100644
--- a/po/POTFILES.in
+++ b/po/POTFILES.in
@@ -23,6 +23,7 @@ data/devices/virtio-pci.xml.in
 data/devices/qemu-usb.xml.in
 data/hypervisors/rhel-xen.xml.in
 data/hypervisors/xen.xml.in
+osinfo/osinfo_avatar_format.c
 osinfo/osinfo_deployment.c
 osinfo/osinfo_devicelink.c
 osinfo/osinfo_devicelinkfilter.c
-- 
1.8.0




More information about the virt-tools-list mailing list