diff options
author | Matthew Barnes <mbarnes@redhat.com> | 2013-04-19 20:15:03 +0800 |
---|---|---|
committer | Matthew Barnes <mbarnes@redhat.com> | 2013-04-24 08:06:01 +0800 |
commit | 5991b04ac5b48980f4d384951d619b3ec696e17f (patch) | |
tree | debdc2e3667ccfa13af2248cc8c0f1536d907a88 /e-util | |
parent | c64602b39797e4d1ffdc23766b2caaf5a0be000b (diff) | |
download | gsoc2013-evolution-5991b04ac5b48980f4d384951d619b3ec696e17f.tar.gz 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.am | 2 | ||||
-rw-r--r-- | e-util/e-photo-source.c | 123 | ||||
-rw-r--r-- | e-util/e-photo-source.h | 76 | ||||
-rw-r--r-- | e-util/e-util.h | 1 |
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> |