/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */ /* e-folder.c * * Copyright (C) 2000 Ximian, Inc. * * This program is free software; you can redistribute it and/or * modify it under the terms of version 2 of the GNU General Public * published by the Free Software Foundation; either version 2 of the * License as published by the Free Software Foundation. * * 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 * General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. * * Author: Ettore Perazzoli */ #ifdef HAVE_CONFIG_H #include <config.h> #endif #include "e-folder.h" #include <glib.h> #include <gtk/gtksignal.h> #include <gal/util/e-util.h> #define PARENT_TYPE GTK_TYPE_OBJECT static GtkObjectClass *parent_class = NULL; struct _EFolderPrivate { char *name; char *type; char *description; char *physical_uri; int child_highlight; int unread_count; int self_highlight : 1; int is_stock : 1; }; #define EF_CLASS(obj) \ E_FOLDER_CLASS (GTK_OBJECT (obj)->klass) enum { CHANGED, LAST_SIGNAL }; static guint signals[LAST_SIGNAL] = { 0 }; /* EFolder methods. */ static gboolean save_info (EFolder *folder) { g_warning ("`%s' does not implement `EFolder::save_info()'", gtk_type_name (GTK_OBJECT_TYPE (folder))); return FALSE; } static gboolean load_info (EFolder *folder) { g_warning ("`%s' does not implement `EFolder::load_info()'", gtk_type_name (GTK_OBJECT_TYPE (folder))); return FALSE; } static gboolean remove (EFolder *folder) { g_warning ("`%s' does not implement `EFolder::remove()'", gtk_type_name (GTK_OBJECT_TYPE (folder))); return FALSE; } static const char * get_physical_uri (EFolder *folder) { return folder->priv->physical_uri; } /* GtkObject methods. */ static void destroy (GtkObject *object) { EFolder *folder; EFolderPrivate *priv; folder = E_FOLDER (object); priv = folder->priv; g_free (priv->name); g_free (priv->type); g_free (priv->description); g_free (priv->physical_uri); g_free (priv); (* GTK_OBJECT_CLASS (parent_class)->destroy) (object); } static void class_init (EFolderClass *klass) { GtkObjectClass *object_class; parent_class = gtk_type_class (gtk_object_get_type ()); object_class = GTK_OBJECT_CLASS (klass); object_class->destroy = destroy; signals[CHANGED] = gtk_signal_new ("changed", GTK_RUN_FIRST, object_class->type, GTK_SIGNAL_OFFSET (EFolderClass, changed), gtk_marshal_NONE__NONE, GTK_TYPE_NONE, 0); gtk_object_class_add_signals (object_class, signals, LAST_SIGNAL); klass->save_info = save_info; klass->load_info = load_info; klass->remove = remove; klass->get_physical_uri = get_physical_uri; } static void init (EFolder *folder) { EFolderPrivate *priv; priv = g_new (EFolderPrivate, 1); priv->type = NULL; priv->name = NULL; priv->description = NULL; priv->physical_uri = NULL; priv->child_highlight = 0; priv->unread_count = 0; priv->self_highlight = FALSE; priv->is_stock = FALSE; folder->priv = priv; } void e_folder_construct (EFolder *folder, const char *name, const char *type, const char *description) { EFolderPrivate *priv; g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); g_return_if_fail (name != NULL); g_return_if_fail (type != NULL); GTK_OBJECT_UNSET_FLAGS (GTK_OBJECT (folder), GTK_FLOATING); priv = folder->priv; priv->name = g_strdup (name); priv->type = g_strdup (type); priv->description = g_strdup (description); } EFolder * e_folder_new (const char *name, const char *type, const char *description) { EFolder *folder; g_return_val_if_fail (name != NULL, NULL); g_return_val_if_fail (type != NULL, NULL); g_return_val_if_fail (description != NULL, NULL); folder = gtk_type_new (E_TYPE_FOLDER); e_folder_construct (folder, name, type, description); return folder; } const char * e_folder_get_name (EFolder *folder) { g_return_val_if_fail (folder != NULL, NULL); g_return_val_if_fail (E_IS_FOLDER (folder), NULL); return folder->priv->name; } const char * e_folder_get_type_string (EFolder *folder) { g_return_val_if_fail (folder != NULL, NULL); g_return_val_if_fail (E_IS_FOLDER (folder), NULL); return folder->priv->type; } const char * e_folder_get_description (EFolder *folder) { g_return_val_if_fail (folder != NULL, NULL); g_return_val_if_fail (E_IS_FOLDER (folder), NULL); return folder->priv->description; } const char * e_folder_get_physical_uri (EFolder *folder) { g_return_val_if_fail (folder != NULL, NULL); g_return_val_if_fail (E_IS_FOLDER (folder), NULL); return folder->priv->physical_uri; } int e_folder_get_unread_count (EFolder *folder) { g_return_val_if_fail (folder != NULL, FALSE); g_return_val_if_fail (E_IS_FOLDER (folder), FALSE); return folder->priv->unread_count; } gboolean e_folder_get_highlighted (EFolder *folder) { g_return_val_if_fail (folder != NULL, FALSE); g_return_val_if_fail (E_IS_FOLDER (folder), FALSE); return folder->priv->child_highlight || folder->priv->unread_count; } gboolean e_folder_get_is_stock (EFolder *folder) { g_return_val_if_fail (folder != NULL, FALSE); g_return_val_if_fail (E_IS_FOLDER (folder), FALSE); return folder->priv->is_stock; } void e_folder_set_name (EFolder *folder, const char *name) { g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); g_return_if_fail (name != NULL); g_free (folder->priv->name); folder->priv->name = g_strdup (name); gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]); } void e_folder_set_type_string (EFolder *folder, const char *type) { g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); g_return_if_fail (type != NULL); g_free (folder->priv->type); folder->priv->type = g_strdup (type); gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]); } void e_folder_set_description (EFolder *folder, const char *description) { g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); g_return_if_fail (description != NULL); g_free (folder->priv->description); folder->priv->description = g_strdup (description); gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]); } void e_folder_set_physical_uri (EFolder *folder, const char *physical_uri) { g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); g_return_if_fail (physical_uri != NULL); g_free (folder->priv->physical_uri); folder->priv->physical_uri = g_strdup (physical_uri); gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]); } void e_folder_set_unread_count (EFolder *folder, gint unread_count) { g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); folder->priv->unread_count = unread_count; gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]); } void e_folder_set_child_highlight (EFolder *folder, gboolean highlighted) { g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); if (highlighted) folder->priv->child_highlight++; else folder->priv->child_highlight--; gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]); } void e_folder_set_is_stock (EFolder *folder, gboolean is_stock) { g_return_if_fail (folder != NULL); g_return_if_fail (E_IS_FOLDER (folder)); folder->priv->is_stock = !! is_stock; gtk_signal_emit (GTK_OBJECT (folder), signals[CHANGED]); } E_MAKE_TYPE (e_folder, "EFolder", EFolder, class_init, init, PARENT_TYPE) sg=1'>Expand</a>)</th><th class='left'>Author</th><th class='left'>Age</th><th class='left'>Files</th><th class='left'>Lines</th></tr> <tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/freebsd-ports-gnome/commit/converters/php56-mbstring?h=dependabot/npm_and_yarn/devel/electron6/files/ini-1.3.8&id=33c7fe1367adc1ce318818f1e56d4571bcbf72ea'>lang/php56: Update from 5.6.25 to 5.6.26</a></td><td>tz</td><td><span title='2016-09-23 16:26:44 +0800'>2016-09-23</span></td><td>1</td><td><span class='deletions'>-1</span>/<span class='insertions'>+0</span></td></tr> <tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/freebsd-ports-gnome/commit/converters/php56-mbstring?h=dependabot/npm_and_yarn/devel/electron6/files/ini-1.3.8&id=991e376f105fa6347769b4350fec6b62222fdb0b'>lang/php56: Update from 5.6.24 to 5.6.25</a></td><td>tz</td><td><span title='2016-08-30 20:55:20 +0800'>2016-08-30</span></td><td>1</td><td><span class='deletions'>-1</span>/<span class='insertions'>+1</span></td></tr> <tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/freebsd-ports-gnome/commit/converters/php56-mbstring?h=dependabot/npm_and_yarn/devel/electron6/files/ini-1.3.8&id=431402e6f41b0ead2340cd5b739afd97a7750d92'>Don't use extension.ini any more, and have each extension install in its</a></td><td>mat</td><td><span title='2016-08-03 20:47:05 +0800'>2016-08-03</span></td><td>1</td><td><span class='deletions'>-0</span>/<span class='insertions'>+1</span></td></tr> <tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/freebsd-ports-gnome/commit/converters/php56-mbstring?h=dependabot/npm_and_yarn/devel/electron6/files/ini-1.3.8&id=3656942337901fd7e640ce3a52f6ef8775c857dc'>lang/php56: update 5.6.19 -> 5.6.20</a></td><td>junovitch</td><td><span title='2016-04-03 22:20:06 +0800'>2016-04-03</span></td><td>1</td><td><span class='deletions'>-1</span>/<span class='insertions'>+0</span></td></tr> <tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/freebsd-ports-gnome/commit/converters/php56-mbstring?h=dependabot/npm_and_yarn/devel/electron6/files/ini-1.3.8&id=3455c3fd70ebe0fc6a328b7ab57d5cadfa52921b'>Bump PORTREVISION, not PORTVERSION.</a></td><td>ale</td><td><span title='2015-12-16 01:13:56 +0800'>2015-12-16</span></td><td>1</td><td><span class='deletions'>-1</span>/<span class='insertions'>+1</span></td></tr> <tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/freebsd-ports-gnome/commit/converters/php56-mbstring?h=dependabot/npm_and_yarn/devel/electron6/files/ini-1.3.8&id=10f629bfc9024f8da8be843ea66d80dbffb6a900'>Switch to onigurum5 port and bump PORTREVISION.</a></td><td>ale</td><td><span title='2015-12-15 22:53:35 +0800'>2015-12-15</span></td><td>1</td><td><span class='deletions'>-0</span>/<span class='insertions'>+1</span></td></tr>