diff options
author | Dan Winship <danw@src.gnome.org> | 2000-11-02 08:11:53 +0800 |
---|---|---|
committer | Dan Winship <danw@src.gnome.org> | 2000-11-02 08:11:53 +0800 |
commit | 0fa29927fc5a0913388dc8fbc4a9b816c0a11119 (patch) | |
tree | f03f91bc99dfb77e3601f5c3506dde1eb025b059 /shell/e-storage.c | |
parent | f62d997329216c7e47bb8e78724edec4dd7e72ef (diff) | |
download | gsoc2013-evolution-0fa29927fc5a0913388dc8fbc4a9b816c0a11119.tar.gz gsoc2013-evolution-0fa29927fc5a0913388dc8fbc4a9b816c0a11119.tar.zst gsoc2013-evolution-0fa29927fc5a0913388dc8fbc4a9b816c0a11119.zip |
Add "highligted" field to Folder. Add update_folder method to
* Evolution-Storage.idl: Add "highligted" field to Folder. Add
update_folder method to StorageListener to change display_name and
highlight status.
* e-folder.c: Add "highlighted" to EFolder to match the
Evolution::Folder type.
(e_folder_get_highlighted, e_folder_set_highlighted): Added
* evolution-storage-listener.c
(impl_Evolution_StorageListener_update_folder, etc):
* e-storage.c (e_storage_updated_folder, etc):
* e-corba-storage.c (impl_StorageListener_update_folder, etc):
Implement update_folder.
* e-storage-set.c (storage_updated_folder_cb, etc): Re-emit
updated_folder signals received from EStorage.
* e-storage-set-view.c (various): Add another model column to the
ETable and set it up as a bold_column based on
e_folder_get_highligted.
(updated_folder_cb, etc): Listen to EStorageSet update_folder
signal and emit ETree node_changed signals.
* evolution-storage.c (evolution_storage_update_folder): Client
function to update a folder's display_name and highlighted status.
* Evolution-LocalStorage.idl:
* evolution-local-storage.c:
* e-local-storage.c: Change set_display_name to update_folder to
match Evolution::StorageListener
svn path=/trunk/; revision=6328
Diffstat (limited to 'shell/e-storage.c')
-rw-r--r-- | shell/e-storage.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/shell/e-storage.c b/shell/e-storage.c index 384e88af33..3ea687716c 100644 --- a/shell/e-storage.c +++ b/shell/e-storage.c @@ -49,6 +49,7 @@ struct _EStoragePrivate { enum { NEW_FOLDER, + UPDATED_FOLDER, REMOVED_FOLDER, LAST_SIGNAL }; @@ -174,6 +175,14 @@ class_init (EStorageClass *class) gtk_marshal_NONE__STRING, GTK_TYPE_NONE, 1, GTK_TYPE_STRING); + signals[UPDATED_FOLDER] = + gtk_signal_new ("updated_folder", + GTK_RUN_FIRST, + object_class->type, + GTK_SIGNAL_OFFSET (EStorageClass, updated_folder), + gtk_marshal_NONE__STRING, + GTK_TYPE_NONE, 1, + GTK_TYPE_STRING); signals[REMOVED_FOLDER] = gtk_signal_new ("removed_folder", GTK_RUN_FIRST, @@ -437,6 +446,27 @@ e_storage_new_folder (EStorage *storage, } gboolean +e_storage_updated_folder (EStorage *storage, + const char *path) +{ + EStoragePrivate *priv; + + g_return_val_if_fail (storage != NULL, FALSE); + g_return_val_if_fail (E_IS_STORAGE (storage), FALSE); + g_return_val_if_fail (path != NULL, FALSE); + g_return_val_if_fail (g_path_is_absolute (path), FALSE); + + priv = storage->priv; + + if (e_folder_tree_get_folder (priv->folder_tree, path) == NULL) + return FALSE; + + gtk_signal_emit (GTK_OBJECT (storage), signals[UPDATED_FOLDER], path); + + return TRUE; +} + +gboolean e_storage_removed_folder (EStorage *storage, const char *path) { |