diff options
author | Dan Vrátil <dvratil@redhat.com> | 2012-06-06 21:29:38 +0800 |
---|---|---|
committer | Dan Vrátil <dvratil@redhat.com> | 2012-06-06 21:29:38 +0800 |
commit | 931191474643164e96b5778c790e42cca517e729 (patch) | |
tree | aec00f3303dbcd95a8a3f18ee324ac80594ff9b5 /modules/itip-formatter/e-source-conflict-search.c | |
parent | 5b8340563c271fb684a88c6e5bb6dd3bfb629058 (diff) | |
download | gsoc2013-evolution-931191474643164e96b5778c790e42cca517e729.tar gsoc2013-evolution-931191474643164e96b5778c790e42cca517e729.tar.gz gsoc2013-evolution-931191474643164e96b5778c790e42cca517e729.tar.bz2 gsoc2013-evolution-931191474643164e96b5778c790e42cca517e729.tar.lz gsoc2013-evolution-931191474643164e96b5778c790e42cca517e729.tar.xz gsoc2013-evolution-931191474643164e96b5778c790e42cca517e729.tar.zst gsoc2013-evolution-931191474643164e96b5778c790e42cca517e729.zip |
Mail formatter rewrite - convert some plugins to modules
audio-inline, itip-formatter, prefer-plain, tnef-attachments
and vcard-inline plugins were converted to modules so that they
can fit into concept of the new formatter.
Every module still installs .eplug file, because there is no
suitable API at the moment to register plugins to the plugins dialog
and to extend the Preferences dialog.
Diffstat (limited to 'modules/itip-formatter/e-source-conflict-search.c')
-rw-r--r-- | modules/itip-formatter/e-source-conflict-search.c | 151 |
1 files changed, 151 insertions, 0 deletions
diff --git a/modules/itip-formatter/e-source-conflict-search.c b/modules/itip-formatter/e-source-conflict-search.c new file mode 100644 index 0000000000..c2f5eb6e99 --- /dev/null +++ b/modules/itip-formatter/e-source-conflict-search.c @@ -0,0 +1,151 @@ +/* + * e-source-conflict-search.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/> + * + */ + +#include "e-source-conflict-search.h" + +#define E_SOURCE_CONFLICT_SEARCH_GET_PRIVATE(obj) \ + (G_TYPE_INSTANCE_GET_PRIVATE \ + ((obj), E_TYPE_SOURCE_CONFLICT_SEARCH, ESourceConflictSearchPrivate)) + +struct _ESourceConflictSearchPrivate { + gboolean include_me; +}; + +enum { + PROP_0, + PROP_INCLUDE_ME +}; + +G_DEFINE_TYPE ( + ESourceConflictSearch, + e_source_conflict_search, + E_TYPE_SOURCE_EXTENSION) + +static void +source_conflict_search_set_property (GObject *object, + guint property_id, + const GValue *value, + GParamSpec *pspec) +{ + switch (property_id) { + case PROP_INCLUDE_ME: + e_source_conflict_search_set_include_me ( + E_SOURCE_CONFLICT_SEARCH (object), + g_value_get_boolean (value)); + return; + } + + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); +} + +static void +source_conflict_search_get_property (GObject *object, + guint property_id, + GValue *value, + GParamSpec *pspec) +{ + switch (property_id) { + case PROP_INCLUDE_ME: + g_value_set_boolean ( + value, + e_source_conflict_search_get_include_me ( + E_SOURCE_CONFLICT_SEARCH (object))); + return; + } + + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); +} + +static void +e_source_conflict_search_class_init (ESourceConflictSearchClass *class) +{ + GObjectClass *object_class; + ESourceExtensionClass *extension_class; + + g_type_class_add_private (class, sizeof (ESourceConflictSearchPrivate)); + + object_class = G_OBJECT_CLASS (class); + object_class->set_property = source_conflict_search_set_property; + object_class->get_property = source_conflict_search_get_property; + + extension_class = E_SOURCE_EXTENSION_CLASS (class); + extension_class->name = E_SOURCE_EXTENSION_CONFLICT_SEARCH; + + g_object_class_install_property ( + object_class, + PROP_INCLUDE_ME, + g_param_spec_boolean ( + "include-me", + "IncludeMe", + "Include this calendar in when " + "searching for scheduling conflicts", + TRUE, + G_PARAM_READWRITE | + G_PARAM_CONSTRUCT | + G_PARAM_STATIC_STRINGS | + E_SOURCE_PARAM_SETTING)); +} + +static void +e_source_conflict_search_init (ESourceConflictSearch *extension) +{ + extension->priv = E_SOURCE_CONFLICT_SEARCH_GET_PRIVATE (extension); +} + +/** + * e_source_conflict_search_get_include_me: + * @extension: an #ESourceConflictSearch + * + * Returns whether the calendar described by the #ESource to which + * @extension belongs should be queried for scheduling conflicts when + * negotiating a meeting invitation. + * + * Returns: whether to search for scheduling conflicts + * + * Since: 3.6 + **/ +gboolean +e_source_conflict_search_get_include_me (ESourceConflictSearch *extension) +{ + g_return_val_if_fail (E_IS_SOURCE_CONFLICT_SEARCH (extension), FALSE); + + return extension->priv->include_me; +} + +/** + * e_source_conflict_search_set_include_me: + * @extension: an #ESourceConflictSearch + * @include_me: whether to search for scheduling conflicts + * + * Sets whether the calendar described by the #ESource to which @extension + * belongs should be queried for scheduling conflicts when negotiating a + * meeting invitation. + * + * Since: 3.6 + **/ +void +e_source_conflict_search_set_include_me (ESourceConflictSearch *extension, + gboolean include_me) +{ + g_return_if_fail (E_IS_SOURCE_CONFLICT_SEARCH (extension)); + + extension->priv->include_me = include_me; + + g_object_notify (G_OBJECT (extension), "include-me"); +} + |