aboutsummaryrefslogtreecommitdiffstats
path: root/e-util
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2013-04-19 20:15:03 +0800
committerMatthew Barnes <mbarnes@redhat.com>2013-04-24 08:06:01 +0800
commit5991b04ac5b48980f4d384951d619b3ec696e17f (patch)
treedebdc2e3667ccfa13af2248cc8c0f1536d907a88 /e-util
parentc64602b39797e4d1ffdc23766b2caaf5a0be000b (diff)
downloadgsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.tar
gsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.tar.gz
gsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.tar.bz2
gsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.tar.lz
gsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.tar.xz
gsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.tar.zst
gsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.zip
Add EPhotoSource interface.
EPhotoSource is an interface used to extend the functionality of EPhotoCache. You can add an object implementing EPhotoSource to an EPhotoCache with e_photo_cache_add_photo_source() and remove it with e_photo_cache_remove_photo_source(). When EPhotoCache needs a photo for an email address, it will invoke e_photo_source_get_photo() on all available EPhotoSource objects simultaneously and select one photo.
Diffstat (limited to 'e-util')
-rw-r--r--e-util/Makefile.am2
-rw-r--r--e-util/e-photo-source.c123
-rw-r--r--e-util/e-photo-source.h76
-rw-r--r--e-util/e-util.h1
4 files changed, 202 insertions, 0 deletions
diff --git a/e-util/Makefile.am b/e-util/Makefile.am
index e7a8f794cc..933bdd85fc 100644
--- a/e-util/Makefile.am
+++ b/e-util/Makefile.am
@@ -216,6 +216,7 @@ eutilinclude_HEADERS = \
e-paned.h \
e-passwords.h \
e-photo-cache.h \
+ e-photo-source.h \
e-picture-gallery.h \
e-plugin-ui.h \
e-plugin.h \
@@ -464,6 +465,7 @@ libeutil_la_SOURCES = \
e-paned.c \
e-passwords.c \
e-photo-cache.c \
+ e-photo-source.c \
e-picture-gallery.c \
e-plugin-ui.c \
e-plugin.c \
diff --git a/e-util/e-photo-source.c b/e-util/e-photo-source.c
new file mode 100644
index 0000000000..d3c65c987f
--- /dev/null
+++ b/e-util/e-photo-source.c
@@ -0,0 +1,123 @@
+/*
+ * e-photo-source.c
+ *
+ * This program 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 of the License, or (at your option) version 3.
+ *
+ * This program 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 the program; if not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+/**
+ * SECTION: e-photo-source
+ * @include: e-util/e-util.h
+ * @short_description: A source of email address photos
+ *
+ * #EPhotoSource is an interface used to extend the functionality of
+ * #EPhotoCache. You can add an object implementing #EPhotoSource to an
+ * #EPhotoCache with e_photo_cache_add_photo_source() and remove it with
+ * e_photo_cache_remove_photo_source(). When #EPhotoCache needs a photo
+ * for an email addres, it will invoke e_photo_source_get_photo() on all
+ * available #EPhotoSource objects simultaneously and select one photo.
+ **/
+
+#include "e-photo-source.h"
+
+G_DEFINE_INTERFACE (
+ EPhotoSource,
+ e_photo_source,
+ G_TYPE_OBJECT)
+
+static void
+e_photo_source_default_init (EPhotoSourceInterface *interface)
+{
+}
+
+/**
+ * e_photo_source_get_photo:
+ * @photo_source: an #EPhotoSource
+ * @email_address: an email address
+ * @cancellable: optional #GCancellable object, or %NULL
+ * @callback: a #GAsyncReadyCallback to call when the request is satisfied
+ * @user_data: data to pass to the callback function
+ *
+ * Asynchronously searches for a photo or logo for @email_address.
+ *
+ * When the operation is finished, @callback will be called. You can then
+ * call e_photo_source_get_photo_finish() to get the result of the operation.
+ **/
+void
+e_photo_source_get_photo (EPhotoSource *photo_source,
+ const gchar *email_address,
+ GCancellable *cancellable,
+ GAsyncReadyCallback callback,
+ gpointer user_data)
+{
+ EPhotoSourceInterface *interface;
+
+ g_return_if_fail (E_IS_PHOTO_SOURCE (photo_source));
+ g_return_if_fail (email_address != NULL);
+
+ interface = E_PHOTO_SOURCE_GET_INTERFACE (photo_source);
+ g_return_if_fail (interface->get_photo != NULL);
+
+ interface->get_photo (
+ photo_source, email_address,
+ cancellable, callback, user_data);
+}
+
+/**
+ * e_photo_source_get_photo_finish:
+ * @photo_source: an #EPhotoSource
+ * @result: a #GAsyncResult
+ * @out_stream: return location for a #GInputStream
+ * @out_priority: return location for a priority value, or %NULL
+ * @error: return location for a #GError, or %NULL
+ *
+ * Finishes the operation started with e_photo_source_get_photo().
+ *
+ * If a match was found, a #GInputStream from which to read image data is
+ * returned through the @out_stream return location, and a suggested priority
+ * value for the match is returned through the @out_priority return location.
+ *
+ * You can use the @out_priority value to rank this result among other
+ * #EPhotoSource results. The value is usually @G_PRIORITY_DEFAULT, but
+ * may be @G_PRIORITY_LOW if the result is a fallback image.
+ *
+ * If no match was found, the @out_stream return location is set to %NULL
+ * (the @out_priority return location will remain unset).
+ *
+ * The return value indicates whether the search completed successfully,
+ * not whether a match was found. If an error occurred, the function will
+ * set @error and return %FALSE.
+ *
+ * Returns: whether the search completed successfully
+ **/
+gboolean
+e_photo_source_get_photo_finish (EPhotoSource *photo_source,
+ GAsyncResult *result,
+ GInputStream **out_stream,
+ gint *out_priority,
+ GError **error)
+{
+ EPhotoSourceInterface *interface;
+
+ g_return_val_if_fail (E_IS_PHOTO_SOURCE (photo_source), FALSE);
+ g_return_val_if_fail (G_IS_ASYNC_RESULT (result), FALSE);
+ g_return_val_if_fail (out_stream != NULL, FALSE);
+
+ interface = E_PHOTO_SOURCE_GET_INTERFACE (photo_source);
+ g_return_val_if_fail (interface->get_photo_finish != NULL, FALSE);
+
+ return interface->get_photo_finish (
+ photo_source, result, out_stream, out_priority, error);
+}
+
diff --git a/e-util/e-photo-source.h b/e-util/e-photo-source.h
new file mode 100644
index 0000000000..dfbaf2618d
--- /dev/null
+++ b/e-util/e-photo-source.h
@@ -0,0 +1,76 @@
+/*
+ * e-photo-source.h
+ *
+ * This program 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 of the License, or (at your option) version 3.
+ *
+ * This program 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 the program; if not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+#if !defined (__E_UTIL_H_INSIDE__) && !defined (LIBEUTIL_COMPILATION)
+#error "Only <e-util/e-util.h> should be included directly."
+#endif
+
+#ifndef E_PHOTO_SOURCE_H
+#define E_PHOTO_SOURCE_H
+
+#include <gio/gio.h>
+
+/* Standard GObject macros */
+#define E_TYPE_PHOTO_SOURCE \
+ (e_photo_source_get_type ())
+#define E_PHOTO_SOURCE(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST \
+ ((obj), E_TYPE_PHOTO_SOURCE, EPhotoSource))
+#define E_IS_PHOTO_SOURCE(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE \
+ ((obj), E_TYPE_PHOTO_SOURCE))
+#define E_PHOTO_SOURCE_GET_INTERFACE(obj) \
+ (G_TYPE_INSTANCE_GET_INTERFACE \
+ ((obj), E_TYPE_PHOTO_SOURCE, EPhotoSourceInterface))
+
+G_BEGIN_DECLS
+
+typedef struct _EPhotoSource EPhotoSource;
+typedef struct _EPhotoSourceInterface EPhotoSourceInterface;
+
+struct _EPhotoSourceInterface {
+ GTypeInterface parent_interface;
+
+ void (*get_photo) (EPhotoSource *photo_source,
+ const gchar *email_address,
+ GCancellable *cancellable,
+ GAsyncReadyCallback callback,
+ gpointer user_data);
+ gboolean (*get_photo_finish) (EPhotoSource *photo_source,
+ GAsyncResult *result,
+ GInputStream **out_stream,
+ gint *out_priority,
+ GError **error);
+};
+
+GType e_photo_source_get_type (void) G_GNUC_CONST;
+void e_photo_source_get_photo (EPhotoSource *photo_source,
+ const gchar *email_address,
+ GCancellable *cancellable,
+ GAsyncReadyCallback callback,
+ gpointer user_data);
+gboolean e_photo_source_get_photo_finish (EPhotoSource *photo_source,
+ GAsyncResult *result,
+ GInputStream **out_stream,
+ gint *out_priority,
+ GError **error);
+
+G_END_DECLS
+
+#endif /* E_PHOTO_SOURCE_H */
+
diff --git a/e-util/e-util.h b/e-util/e-util.h
index 3870c45c69..34d4586318 100644
--- a/e-util/e-util.h
+++ b/e-util/e-util.h
@@ -132,6 +132,7 @@
#include <e-util/e-paned.h>
#include <e-util/e-passwords.h>
#include <e-util/e-photo-cache.h>
+#include <e-util/e-photo-source.h>
#include <e-util/e-picture-gallery.h>
#include <e-util/e-plugin-ui.h>
#include <e-util/e-plugin.h>