/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/* This file is part of gnome-spell bonobo component
Copyright (C) 2000 Helix Code, Inc.
Authors: Radek Doulik <rodo@helixcode.com>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#include <config.h>
#include <bonobo.h>
#include "listener.h"
static BonoboObjectClass *listener_parent_class;
static POA_GNOME_HTMLEditor_Listener__vepv listener_vepv;
inline static HTMLEditorListener *
htmleditor_listener_from_servant (PortableServer_Servant servant)
{
return HTMLEDITOR_LISTENER (bonobo_object_from_servant (servant));
}
static CORBA_any *
get_any_null ()
{
CORBA_any *rv;
rv = CORBA_any__alloc ();
rv->_type = TC_null;
return rv;
}
static gchar *
resolve_image_url (HTMLEditorListener *l, gchar *url)
{
gchar *cid = NULL;
printf ("resolve_image_url %s\n", url);
if (!strncmp (url, "file:", 5)) {
gchar *id;
id = (gchar *) g_hash_table_lookup (l->composer->inline_images, url + 5);
if (!id) {
id = header_msgid_generate ();
g_hash_table_insert (l->composer->inline_images, g_strdup (url + 5), id);
}
cid = g_strconcat ("cid:", id, NULL);
printf ("resolved to %s\n", cid);
}
return cid;
}
static void
reply_indent (HTMLEditorListener *l, CORBA_Environment * ev)
{
if (!GNOME_HTMLEditor_Engine_isParagraphEmpty (l->composer->editor_engine, ev)) {
if (GNOME_HTMLEditor_Engine_isPreviousParagraphEmpty (l->composer->editor_engine, ev))
GNOME_HTMLEditor_Engine_runCommand (l->composer->editor_engine, "cursor-backward", ev);
else {
GNOME_HTMLEditor_Engine_runCommand (l->composer->editor_engine, "insert-paragraph", ev);
return;
}
}
GNOME_HTMLEditor_Engine_runCommand (l->composer->editor_engine, "style-normal", ev);
GNOME_HTMLEditor_Engine_runCommand (l->composer->editor_engine, "indent-zero", ev);
GNOME_HTMLEditor_Engine_runCommand (l->composer->editor_engine, "italic-off", ev);
}
static CORBA_any *
impl_event (PortableServer_Servant _servant,
const CORBA_char * name, const CORBA_any * arg,
CORBA_Environment * ev)
{
HTMLEditorListener *l = htmleditor_listener_from_servant (_servant);
BonoboArg *data;
CORBA_any *rv = NULL;
/* printf ("impl_event\n"); */
if (!strcmp (name, "command")) {
/* FIXME check for insert-paragraph command */
data = GNOME_HTMLEditor_Engine_getParagraphData (l->composer->editor_engine, "orig", ev);
if (ev->_major == CORBA_NO_EXCEPTION && data) {
if (CORBA_TypeCode_equal (data->_type, TC_boolean, ev) && BONOBO_ARG_GET_BOOLEAN (data))
reply_indent (l, ev);
BONOBO_ARG_SET_BOOLEAN (data, CORBA_FALSE);
GNOME_HTMLEditor_Engine_setParagraphData (l->composer->editor_engine, "orig", data, ev);
}
} else if (!strcmp (name, "image_url")) {
gchar *url;
if ((url = resolve_image_url (l, BONOBO_ARG_GET_STRING (arg)))) {
rv = bonobo_arg_new (TC_string);
BONOBO_ARG_SET_STRING (rv, url);
printf ("new url: %s\n", url);
g_free (url);
}
}
return rv ? rv : get_any_null ();
}
POA_GNOME_HTMLEditor_Listener__epv *
htmleditor_listener_get_epv (void)
{
POA_GNOME_HTMLEditor_Listener__epv *epv;
epv = g_new0 (POA_GNOME_HTMLEditor_Listener__epv, 1);
epv->event = impl_event;
return epv;
}
static void
init_listener_corba_class (void)
{
listener_vepv.Bonobo_Unknown_epv = bonobo_object_get_epv ();
listener_vepv.GNOME_HTMLEditor_Listener_epv = htmleditor_listener_get_epv ();
}
static void
listener_class_init (HTMLEditorListenerClass *klass)
{
listener_parent_class = gtk_type_class (bonobo_object_get_type ());
init_listener_corba_class ();
}
GtkType
htmleditor_listener_get_type (void)
{
static GtkType type = 0;
if (!type){
GtkTypeInfo info = {
"HTMLEditorListener",
sizeof (HTMLEditorListener),
sizeof (HTMLEditorListenerClass),
(GtkClassInitFunc) listener_class_init,
(GtkObjectInitFunc) NULL,
NULL, /* reserved 1 */
NULL, /* reserved 2 */
(GtkClassInitFunc) NULL
};
type = gtk_type_unique (bonobo_object_get_type (), &info);
}
return type;
}
HTMLEditorListener *
htmleditor_listener_construct (HTMLEditorListener *listener, GNOME_HTMLEditor_Listener corba_listener)
{
g_return_val_if_fail (listener != NULL, NULL);
g_return_val_if_fail (IS_HTMLEDITOR_LISTENER (listener), NULL);
g_return_val_if_fail (corba_listener != CORBA_OBJECT_NIL, NULL);
if (!bonobo_object_construct (BONOBO_OBJECT (listener), (CORBA_Object) corba_listener))
return NULL;
return listener;
}
static GNOME_HTMLEditor_Listener
create_listener (BonoboObject *listener)
{
POA_GNOME_HTMLEditor_Listener *servant;
CORBA_Environment ev;
servant = (POA_GNOME_HTMLEditor_Listener *) g_new0 (BonoboObjectServant, 1);
servant->vepv = &listener_vepv;
CORBA_exception_init (&ev);
POA_GNOME_HTMLEditor_Listener__init ((PortableServer_Servant) servant, &ev);
ORBIT_OBJECT_KEY(servant->_private)->object = NULL;
if (ev._major != CORBA_NO_EXCEPTION){
g_free (servant);
CORBA_exception_free (&ev);
return CORBA_OBJECT_NIL;
}
CORBA_exception_free (&ev);
return (GNOME_HTMLEditor_Listener) bonobo_object_activate_servant (listener, servant);
}
HTMLEditorListener *
htmleditor_listener_new (EMsgComposer *composer)
{
HTMLEditorListener *listener;
GNOME_HTMLEditor_Listener corba_listener;
listener = gtk_type_new (HTMLEDITOR_LISTENER_TYPE);
listener->composer = composer;
corba_listener = create_listener (BONOBO_OBJECT (listener));
if (corba_listener == CORBA_OBJECT_NIL) {
bonobo_object_unref (BONOBO_OBJECT (listener));
return NULL;
}
return htmleditor_listener_construct (listener, corba_listener);
}