/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
/* e-folder.c
*
* Copyright (C) 2000, 2001, 2002 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
* 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 "e-util/e-corba-utils.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]);
}
/* Gotta love CORBA. */
void
e_folder_to_corba (EFolder *folder,
const char *evolution_uri,
GNOME_Evolution_Folder *folder_return)
{
g_return_if_fail (E_IS_FOLDER (folder));
g_return_if_fail (folder_return != NULL);
folder_return->type = e_safe_corba_string_dup (e_folder_get_type_string (folder));
folder_return->description = e_safe_corba_string_dup (e_folder_get_description (folder));
folder_return->displayName = e_safe_corba_string_dup (e_folder_get_name (folder));
folder_return->physicalUri = e_safe_corba_string_dup (e_folder_get_physical_uri (folder));
folder_return->evolutionUri = e_safe_corba_string_dup (evolution_uri);
folder_return->unreadCount = e_folder_get_unread_count (folder);
}
E_MAKE_TYPE (e_folder, "EFolder", EFolder, class_init, init, PARENT_TYPE)