summaryrefslogtreecommitdiff
path: root/nonprism
diff options
context:
space:
mode:
authorAndré Fabian Silva Delgado <emulatorman@parabola.nu>2017-02-08 23:17:29 -0300
committerAndré Fabian Silva Delgado <emulatorman@parabola.nu>2017-02-08 23:18:38 -0300
commit68829dbe3acccbb9ae405789958fcce0c06f0c3b (patch)
tree3ff3d8ca301c005c340d162607aa4a92beac57aa /nonprism
parent7385f16a555acf249ab3c1c9909f11ca0b4199f8 (diff)
claws-mail-3.14.1-3.nonprism1: add upstream patch for reintroduction of dillo html plugin
Diffstat (limited to 'nonprism')
-rw-r--r--nonprism/claws-mail/PKGBUILD22
-rw-r--r--nonprism/claws-mail/dillo-plugin.diff855
2 files changed, 871 insertions, 6 deletions
diff --git a/nonprism/claws-mail/PKGBUILD b/nonprism/claws-mail/PKGBUILD
index 4cacd4c0c..4e8a19a35 100644
--- a/nonprism/claws-mail/PKGBUILD
+++ b/nonprism/claws-mail/PKGBUILD
@@ -1,10 +1,10 @@
-# $Id: PKGBUILD 286991 2017-01-19 19:17:42Z andyrtr $
+# $Id: PKGBUILD 288058 2017-02-05 09:28:56Z andyrtr $
# Maintainer (Arch): Andreas Radke <andyrtr@archlinux.org>
# Maintainer: Márcio Silva <coadde@parabola.nu>
pkgname=claws-mail
pkgver=3.14.1
-pkgrel=2.nonprism1
+pkgrel=3.nonprism1
pkgdesc="A GTK+ based e-mail client, without libgdata support"
arch=('i686' 'x86_64' 'armv7h')
license=('GPL3')
@@ -13,7 +13,7 @@ depends=('gtk2' 'gnutls' 'startup-notification' 'enchant' 'gpgme' 'libetpan' 'co
'libsm' 'dbus-glib' 'hicolor-icon-theme' 'desktop-file-utils')
makedepends=('spamassassin' 'bogofilter' 'valgrind'
# dependencies for plugins
- 'libnotify' 'libcanberra' 'poppler-glib' 'pygtk'
+ 'libnotify' 'libcanberra' 'poppler-glib' 'pygtk' 'dillo'
# deps to build the docs
'docbook-utils')
#'libchamplain' needed for geolocation plugin, disabled for now - most time it's not compatible with current gnome releases
@@ -29,15 +29,25 @@ optdepends=('python2: needed for some tools and python plugin'
'libarchive: for archive plugin and various other plugins'
'libytnef: for tnef_parse plugin'
'poppler-glib: for pdf viewer plugin'
- 'ghostscript: for pdf viewer plugin')
+ 'ghostscript: for pdf viewer plugin'
+ 'dillo: for html viewer plugin')
replaces=('sylpheed-claws' 'claws-mail-extra-plugins' 'claws-mail-libre' 'claws-mail-libre-nonprism' 'claws-mail-nonprism')
conflicts=('claws-mail-extra-plugins' 'claws-mail-libre' 'claws-mail-libre-nonprism' 'claws-mail-nonprism')
provides=('claws')
-source=(http://www.claws-mail.org/download.php?file=releases/claws-mail-$pkgver.tar.xz{,.asc})
+source=(http://www.claws-mail.org/download.php?file=releases/claws-mail-$pkgver.tar.xz{,.asc}
+ dillo-plugin.diff)
sha256sums=('b79a1dc04f0b3d1f693e84d7fa7282f140fb5280179281445a8b954ce423c335'
- 'SKIP')
+ 'SKIP'
+ 'e58fde187b53ce12d4cb711a11ad2c6f5c3d152253e07999710decfd414b14ce')
validpgpkeys=('8B3B297A03468356692F8D592CD716D654D6BBD4') # Paul <paul@claws-mail.org>
+prepare() {
+ cd ${pkgname}-${pkgver}
+ # upstream reintroduction of dillo plugin - after fancy plugin dropped
+ patch -Np1 -i ../dillo-plugin.diff
+ autoreconf -vfi
+}
+
build() {
cd ${pkgname}-${pkgver}
diff --git a/nonprism/claws-mail/dillo-plugin.diff b/nonprism/claws-mail/dillo-plugin.diff
new file mode 100644
index 000000000..86cafae4d
--- /dev/null
+++ b/nonprism/claws-mail/dillo-plugin.diff
@@ -0,0 +1,855 @@
+From 1e068dbfc2837809030dcbf0173d2841a411d95a Mon Sep 17 00:00:00 2001
+From: wwp <wwp@free.fr>
+Date: Thu, 2 Feb 2017 18:06:27 +0100
+Subject: [PATCH] Re-introducing the Dillo plugin. Tested against Dillo
+ 3.0.4.1/3.0.5.
+
+---
+ configure.ac | 15 ++
+ src/plugins/Makefile.am | 1 +
+ src/plugins/dillo/Makefile.am | 33 ++++
+ src/plugins/dillo/README | 48 ++++++
+ src/plugins/dillo/dillo_prefs.c | 305 +++++++++++++++++++++++++++++++++++++
+ src/plugins/dillo/dillo_prefs.h | 46 ++++++
+ src/plugins/dillo/dillo_viewer.c | 310 ++++++++++++++++++++++++++++++++++++++
+ 7 files changed, 758 insertions(+)
+ create mode 100644 src/plugins/dillo/Makefile.am
+ create mode 100644 src/plugins/dillo/README
+ create mode 100644 src/plugins/dillo/dillo_prefs.c
+ create mode 100644 src/plugins/dillo/dillo_prefs.h
+ create mode 100644 src/plugins/dillo/dillo_viewer.c
+
+diff --git a/configure.ac b/configure.ac
+index b0683cf..e8e4ae4 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -988,6 +988,10 @@ AC_ARG_ENABLE(clamd-plugin,
+ [ --disable-clamd-plugin Do not build clamd plugin],
+ [enable_clamd_plugin=$enableval], [enable_clamd_plugin=auto])
+
++AC_ARG_ENABLE(dillo-plugin,
++ [ --disable-dillo-plugin Do not build dillo plugin],
++ [enable_dillo_plugin=$enableval], [enable_dillo_plugin=auto])
++
+ AC_ARG_ENABLE(fancy-plugin,
+ [ --disable-fancy-plugin Do not build fancy plugin],
+ [enable_fancy_plugin=$enableval], [enable_fancy_plugin=auto])
+@@ -1416,6 +1420,15 @@ else
+ AC_MSG_RESULT(no)
+ fi
+
++AC_MSG_CHECKING([whether to build Dillo plugin])
++if test x"$enable_dillo_plugin" != xno; then
++ PLUGINS="$PLUGINS dillo"
++ AC_MSG_RESULT(yes)
++else
++ DISABLED_PLUGINS="$DISABLED_PLUGINS dillo"
++ AC_MSG_RESULT(no)
++fi
++
+ AC_MSG_CHECKING([whether to build fancy plugin])
+ if test x"$enable_fancy_plugin" != xno; then
+ dependencies_missing=""
+@@ -1872,6 +1885,7 @@ AM_CONDITIONAL(BUILD_BOGOFILTER_PLUGIN, test x"$enable_bogofilter_plugin" != xn
+ AM_CONDITIONAL(BUILD_BSFILTER_PLUGIN, test x"$enable_bsfilter_plugin" != xno)
+ AM_CONDITIONAL(BUILD_CLAMD_PLUGIN, test x"$enable_clamd_plugin" != xno)
+ AM_CONDITIONAL(BUILD_DEMO_PLUGIN, test x"$enable_demo_plugin" != xno)
++AM_CONDITIONAL(BUILD_DILLO_PLUGIN, test x"$enable_dillo_plugin" != xno)
+ AM_CONDITIONAL(BUILD_FANCY_PLUGIN, test x"$enable_fancy_plugin" != xno)
+ AM_CONDITIONAL(BUILD_FETCHINFO_PLUGIN, test x"$enable_fetchinfo_plugin" != xno)
+ AM_CONDITIONAL(BUILD_GDATA_PLUGIN, test x"$enable_gdata_plugin" != xno)
+@@ -1920,6 +1934,7 @@ src/plugins/bsfilter/Makefile
+ src/plugins/clamd/Makefile
+ src/plugins/clamd/libclamd/Makefile
+ src/plugins/demo/Makefile
++src/plugins/dillo/Makefile
+ src/plugins/fancy/Makefile
+ src/plugins/fetchinfo/Makefile
+ src/plugins/gdata/Makefile
+diff --git a/src/plugins/Makefile.am b/src/plugins/Makefile.am
+index 6acc1fb..28abfdb 100644
+--- a/src/plugins/Makefile.am
++++ b/src/plugins/Makefile.am
+@@ -13,6 +13,7 @@ SUBDIRS = \
+ bsfilter \
+ clamd \
+ demo \
++ dillo \
+ fancy \
+ fetchinfo \
+ gdata \
+diff --git a/src/plugins/dillo/Makefile.am b/src/plugins/dillo/Makefile.am
+new file mode 100644
+index 0000000..2dd9349
+--- /dev/null
++++ b/src/plugins/dillo/Makefile.am
+@@ -0,0 +1,33 @@
++# Copyright 1999-2014 the Claws Mail team.
++# This file is part of Claws Mail package, and distributed under the
++# terms of the General Public License version 3 (or later).
++# See COPYING file for license details.
++
++plugindir = $(pkglibdir)/plugins
++
++plugin_LTLIBRARIES = dillo.la
++
++dillo_la_SOURCES = \
++ dillo_viewer.c \
++ dillo_prefs.c \
++ dillo_prefs.h
++
++dillo_la_LDFLAGS = \
++ -avoid-version -module
++
++if CYGWIN
++cygwin_export_lib = -L$(top_builddir)/src -lclaws-mail
++else
++cygwin_export_lib =
++endif
++
++dillo_la_LIBADD = $(cygwin_export_lib) \
++ $(GTK_LIBS)
++
++dillo_la_CPPFLAGS = \
++ -I$(top_srcdir)/src \
++ -I$(top_builddir)/src/common \
++ -I$(top_srcdir)/src/common \
++ -I$(top_srcdir)/src/gtk \
++ $(GLIB_CFLAGS) \
++ $(GTK_CFLAGS)
+diff --git a/src/plugins/dillo/README b/src/plugins/dillo/README
+new file mode 100644
+index 0000000..a61f4e0
+--- /dev/null
++++ b/src/plugins/dillo/README
+@@ -0,0 +1,48 @@
++Dillo Viewer: HTML mail viewing in Claws Mail
++-------------------------------------------------
++
++This plugin uses the Dillo (http://www.dillo.org) browser to
++view text/html MIME parts inside Claws Mail.
++
++When the plugin is loaded, if the MIME part to be viewed is of
++text/html type, then the MIME part is saved in a temporary file and
++Dillo is started with special options to embed it inside
++Claws Mail' message view and to "safely" view the part. Dillo is
++also run in the fullwindow mode, where the toolbar, menubar and the
++statusbar are hidden so the message is viewed in a larger area. The
++fullwindow mode is toggled on and off by double clicking on an empty
++part of the page or by clicking on the icon in the lower right corner.
++
++The "safe" viewing of text/html message parts is achieved by using the
++-l (or --local) option of Dillo. This option prevents Dillo from
++retrieving remote web resources, like images. Thus, no connection
++to the Internet is done. If the user wants to view the message
++without this restriction, s/he just reloads the page by clicking on
++the "Reload" button in Dillo's toolbar.
++
++WARNING: This plugin is provided as is. The author does not guarantee
++safe viewing of text/html messages although he tried hard to achieve
++this goal.
++
++What Dillo version should be used?
++----------------------------------
++
++Dillo 0.7.0 was the first version that included the features needed by
++Claws, but it had a small bug where remote resources could be
++accessed even with the --local option (when a BASE element is present
++in the message).
++
++Since 2002-03-16, the CVS tree of Dillo fixed that bug.
++
++Dillo 0.7.2 and newer (up to 3.0.5) do not have that bug, and are the
++recommended versions to be used.
++
++Acknowledgment:
++---------------
++
++The author of this plugin thanks the author of Dillo, Jorge Arellano
++Cid, who accepted to integrate and improve the different patches
++needed for this functionality.
++
++--
++Melvin Hadasht
+diff --git a/src/plugins/dillo/dillo_prefs.c b/src/plugins/dillo/dillo_prefs.c
+new file mode 100644
+index 0000000..8d9529b
+--- /dev/null
++++ b/src/plugins/dillo/dillo_prefs.c
+@@ -0,0 +1,305 @@
++/*
++ * Claws Mail -- a GTK+ based, lightweight, and fast e-mail client
++ * Copyright (C) 1999-2012 the Claws Mail Team
++ *
++ * This program is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 3 of the License, or
++ * (at your option) any later version.
++ *
++ * 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, see <http://www.gnu.org/licenses/>.
++ *
++ */
++
++/*
++ * The structure of this file has been borrowed from the structure of
++ * the image_viewer plugin file. I also used it as an example of how to
++ * build the preferences for the dillo plugin.
++ */
++
++#ifdef HAVE_CONFIG_H
++# include "config.h"
++#include "claws-features.h"
++#endif
++
++#include "defs.h"
++
++#include <glib.h>
++#include <glib/gi18n.h>
++#include <gtk/gtk.h>
++
++#include "gtkutils.h"
++#include "utils.h"
++#include "prefs.h"
++#include "prefs_gtk.h"
++#include "prefswindow.h"
++#include "combobox.h"
++#include "addressbook.h"
++
++#include "dillo_prefs.h"
++
++#define PREFS_BLOCK_NAME "Dillo"
++
++DilloBrowserPrefs dillo_prefs;
++
++typedef struct _DilloBrowserPage DilloBrowserPage;
++
++struct _DilloBrowserPage {
++ PrefsPage page;
++ GtkWidget *local;
++ GtkWidget *whitelist_ab;
++ GtkWidget *whitelist_ab_folder_combo;
++ GtkWidget *whitelist_ab_select_btn;
++ GtkWidget *full;
++};
++
++static PrefParam param[] = {
++ {"local_browse", "TRUE", &dillo_prefs.local, P_BOOL, NULL, NULL, NULL},
++ {"full_window", "TRUE", &dillo_prefs.full, P_BOOL, NULL, NULL, NULL},
++ {"whitelist_ab", "FALSE", &dillo_prefs.whitelist_ab, P_BOOL,
++ NULL, NULL, NULL},
++ {"whitelist_ab_folder", N_("Any"), &dillo_prefs.whitelist_ab_folder, P_STRING,
++ NULL, NULL, NULL},
++
++ {0,0,0,0,0,0,0}
++};
++
++static DilloBrowserPage prefs_page;
++
++static void create_dillo_prefs_page (PrefsPage *page,
++ GtkWindow *window,
++ gpointer data);
++static void destroy_dillo_prefs_page (PrefsPage *page);
++static void save_dillo_prefs (PrefsPage *page);
++
++#ifndef USE_NEW_ADDRBOOK
++static void dillo_whitelist_ab_select_cb(GtkWidget *widget, gpointer data)
++{
++ DilloBrowserPage *page = (DilloBrowserPage *) data;
++ const gchar *folderpath = NULL;
++ gchar *new_path = NULL;
++
++ folderpath = gtk_entry_get_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN((page->whitelist_ab_folder_combo)))));
++ new_path = addressbook_folder_selection(folderpath);
++ if (new_path) {
++ gtk_entry_set_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN((page->whitelist_ab_folder_combo)))), new_path);
++ g_free(new_path);
++ }
++}
++#endif
++
++static void local_checkbox_toggled(GtkToggleButton *button,
++ gpointer user_data)
++{
++ gboolean active = gtk_toggle_button_get_active(button);
++ DilloBrowserPage *prefs_page = (DilloBrowserPage *) user_data;
++
++ gtk_widget_set_sensitive(prefs_page->whitelist_ab, active);
++ gtk_widget_set_sensitive(prefs_page->whitelist_ab_folder_combo, active &&
++ gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->whitelist_ab)));
++#ifndef USE_NEW_ADDRBOOK
++ gtk_widget_set_sensitive(prefs_page->whitelist_ab_select_btn, active &&
++ gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->whitelist_ab)));
++#endif
++}
++
++static void whitelist_checkbox_toggled(GtkToggleButton *button,
++ gpointer user_data)
++{
++ gboolean active = gtk_toggle_button_get_active(button);
++ DilloBrowserPage *prefs_page = (DilloBrowserPage *) user_data;
++
++ active &= gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->local));
++
++ gtk_widget_set_sensitive(prefs_page->whitelist_ab_folder_combo, active);
++ gtk_widget_set_sensitive(prefs_page->whitelist_ab_select_btn, active);
++}
++
++void dillo_prefs_init(void)
++{
++ static gchar *path[3];
++ gchar *rcpath;
++
++ path[0] = _("Plugins");
++ path[1] = _("Dillo Browser");
++ path[2] = NULL;
++
++ prefs_set_default(param);
++ rcpath = g_strconcat(get_rc_dir(), G_DIR_SEPARATOR_S, COMMON_RC, NULL);
++ prefs_read_config(param, PREFS_BLOCK_NAME, rcpath, NULL);
++ g_free(rcpath);
++
++ prefs_page.page.path = path;
++ prefs_page.page.create_widget = create_dillo_prefs_page;
++ prefs_page.page.destroy_widget = destroy_dillo_prefs_page;
++ prefs_page.page.save_page = save_dillo_prefs;
++ prefs_page.page.weight = 35.0;
++ prefs_gtk_register_page((PrefsPage *) &prefs_page);
++}
++
++void dillo_prefs_done(void)
++{
++ prefs_gtk_unregister_page((PrefsPage *) &prefs_page);
++}
++
++static void create_dillo_prefs_page(PrefsPage *page,
++ GtkWindow *window,
++ gpointer data)
++{
++ DilloBrowserPage *prefs_page = (DilloBrowserPage *) page;
++
++ GtkWidget *vbox;
++ GtkWidget *local_checkbox;
++ GtkWidget *full_checkbox;
++ GtkWidget *label;
++ GtkWidget *whitelist_ab_checkbtn;
++ GtkWidget *whitelist_ab_folder_combo;
++ GtkWidget *whitelist_ab_select_btn;
++ GtkWidget *hbox_whitelist, *spacer;
++
++ vbox = gtk_vbox_new(FALSE, 3);
++ gtk_container_set_border_width(GTK_CONTAINER(vbox), VBOX_BORDER);
++ gtk_widget_show(vbox);
++
++ local_checkbox = gtk_check_button_new_with_label
++ (_("Load remote links in mails"));
++ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(local_checkbox),
++ !dillo_prefs.local);
++ gtk_box_pack_start(GTK_BOX(vbox), local_checkbox, FALSE, FALSE, 0);
++ gtk_widget_show(local_checkbox);
++ CLAWS_SET_TIP(local_checkbox,
++ _("Equivalent to Dillo's '--local' option"));
++
++ label = gtk_label_new(_("You can still load remote links "
++ "by reloading the page"));
++ gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
++ gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5);
++ gtkut_widget_set_small_font_size (label);
++ gtk_widget_show(label);
++
++
++ hbox_whitelist = gtk_hbox_new(FALSE, 8);
++ gtk_widget_show(hbox_whitelist);
++ gtk_box_pack_start (GTK_BOX (vbox), hbox_whitelist, FALSE, FALSE, 0);
++
++ spacer = gtk_hbox_new(FALSE, 0);
++ gtk_widget_set_size_request(spacer, 12, -1);
++ gtk_widget_show(spacer);
++ gtk_box_pack_start(GTK_BOX(hbox_whitelist), spacer, FALSE, FALSE, 0);
++
++ whitelist_ab_checkbtn = gtk_check_button_new_with_label(_("Only for senders found in address book/folder"));
++ gtk_widget_show(whitelist_ab_checkbtn);
++ gtk_box_pack_start(GTK_BOX(hbox_whitelist), whitelist_ab_checkbtn, FALSE, FALSE, 0);
++
++ whitelist_ab_folder_combo = combobox_text_new(TRUE, _("Any"), NULL);
++ gtk_widget_set_size_request(whitelist_ab_folder_combo, 100, -1);
++ gtk_box_pack_start (GTK_BOX (hbox_whitelist), whitelist_ab_folder_combo, TRUE, TRUE, 0);
++
++ whitelist_ab_select_btn = gtk_button_new_with_label(_("Select ..."));
++ gtk_widget_show (whitelist_ab_select_btn);
++ gtk_box_pack_start (GTK_BOX (hbox_whitelist), whitelist_ab_select_btn, FALSE, FALSE, 0);
++
++ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(whitelist_ab_checkbtn), dillo_prefs.whitelist_ab);
++ if (dillo_prefs.whitelist_ab_folder != NULL) {
++ /* translate "Any" (stored UNtranslated) */
++ if (strcasecmp(dillo_prefs.whitelist_ab_folder, "Any") == 0)
++ gtk_entry_set_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN((whitelist_ab_folder_combo)))),
++ _("Any"));
++ else
++ /* backward compatibility (when translated "Any" was stored) */
++ if (g_utf8_collate(dillo_prefs.whitelist_ab_folder, _("Any")) == 0)
++ gtk_entry_set_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN((whitelist_ab_folder_combo)))),
++ dillo_prefs.whitelist_ab_folder);
++ else
++ gtk_entry_set_text(GTK_ENTRY(gtk_bin_get_child(GTK_BIN((whitelist_ab_folder_combo)))),
++ dillo_prefs.whitelist_ab_folder);
++ }
++
++ full_checkbox = gtk_check_button_new_with_label
++ (_("Full window mode (hide controls)"));
++ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(full_checkbox),
++ dillo_prefs.full);
++ gtk_box_pack_start(GTK_BOX(vbox), full_checkbox, FALSE, FALSE, 0);
++ gtk_widget_show(full_checkbox);
++ CLAWS_SET_TIP(full_checkbox,
++ _("Equivalent to Dillo's '--fullwindow' option"));
++
++ g_signal_connect(G_OBJECT(local_checkbox), "toggled",
++ G_CALLBACK(local_checkbox_toggled),
++ prefs_page);
++
++ g_signal_connect(G_OBJECT(whitelist_ab_checkbtn), "toggled",
++ G_CALLBACK(whitelist_checkbox_toggled),
++ prefs_page);
++
++#ifndef USE_NEW_ADDRBOOK
++ g_signal_connect(G_OBJECT (whitelist_ab_select_btn), "clicked",
++ G_CALLBACK(dillo_whitelist_ab_select_cb), prefs_page);
++#else
++ gtk_widget_set_sensitive(GTK_WIDGET(whitelist_ab_select_btn), FALSE);
++#endif
++ gtk_widget_set_sensitive(whitelist_ab_checkbtn, !dillo_prefs.local);
++ gtk_widget_set_sensitive(whitelist_ab_folder_combo, !dillo_prefs.local && dillo_prefs.whitelist_ab);
++ gtk_widget_set_sensitive(whitelist_ab_select_btn, !dillo_prefs.local && dillo_prefs.whitelist_ab);
++
++
++ prefs_page->local = local_checkbox;
++ prefs_page->full = full_checkbox;
++ prefs_page->whitelist_ab = whitelist_ab_checkbtn;
++ prefs_page->whitelist_ab_folder_combo = whitelist_ab_folder_combo;
++ prefs_page->whitelist_ab_select_btn = whitelist_ab_select_btn;
++ prefs_page->page.widget = vbox;
++}
++
++static void destroy_dillo_prefs_page(PrefsPage *page)
++{
++ /* Do nothing! */
++}
++
++static void save_dillo_prefs(PrefsPage *page)
++{
++ DilloBrowserPage *prefs_page = (DilloBrowserPage *) page;
++ PrefFile *pref_file;
++ gchar *rc_file_path = g_strconcat(get_rc_dir(), G_DIR_SEPARATOR_S,
++ COMMON_RC, NULL);
++
++ dillo_prefs.local = !gtk_toggle_button_get_active
++ (GTK_TOGGLE_BUTTON(prefs_page->local));
++ dillo_prefs.full = gtk_toggle_button_get_active
++ (GTK_TOGGLE_BUTTON(prefs_page->full));
++
++ dillo_prefs.whitelist_ab = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->whitelist_ab));
++ g_free(dillo_prefs.whitelist_ab_folder);
++ dillo_prefs.whitelist_ab_folder = gtk_editable_get_chars(
++ GTK_EDITABLE(gtk_bin_get_child(GTK_BIN((prefs_page->whitelist_ab_folder_combo)))), 0, -1);
++ /* store UNtranslated "Any" */
++ if (g_utf8_collate(dillo_prefs.whitelist_ab_folder, _("Any")) == 0) {
++ g_free(dillo_prefs.whitelist_ab_folder);
++ dillo_prefs.whitelist_ab_folder = g_strdup("Any");
++ }
++
++ pref_file = prefs_write_open(rc_file_path);
++ g_free(rc_file_path);
++
++ if (!(pref_file) ||
++ (prefs_set_block_label(pref_file, PREFS_BLOCK_NAME) < 0))
++ return;
++
++ if (prefs_write_param(param, pref_file->fp) < 0) {
++ g_warning("failed to write Dillo Plugin configuration\n");
++ prefs_file_close_revert(pref_file);
++ return;
++ }
++
++ if (fprintf(pref_file->fp, "\n") < 0) {
++ FILE_OP_ERROR(rc_file_path, "fprintf");
++ prefs_file_close_revert(pref_file);
++ } else
++ prefs_file_close(pref_file);
++}
+diff --git a/src/plugins/dillo/dillo_prefs.h b/src/plugins/dillo/dillo_prefs.h
+new file mode 100644
+index 0000000..d4b5b4d
+--- /dev/null
++++ b/src/plugins/dillo/dillo_prefs.h
+@@ -0,0 +1,46 @@
++/*
++ * Claws Mail -- a GTK+ based, lightweight, and fast e-mail client
++ * Copyright (C) 1999-2012 the Claws Mail Team
++ *
++ * This program is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 3 of the License, or
++ * (at your option) any later version.
++ *
++ * 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, see <http://www.gnu.org/licenses/>.
++ *
++ */
++
++/*
++ * The structure of this file has been borrowed from the structure of
++ * the image_viewer plugin file. I also used it as an example of how to
++ * build the preferences for the dillo plugin.
++ */
++
++#ifndef DILLOPREFS_H
++#define DILLOPREFS_H
++
++#include <glib.h>
++
++typedef struct _DilloBrowserPrefs DilloBrowserPrefs;
++
++struct _DilloBrowserPrefs
++{
++ gboolean local; /**< local browsing */
++ gboolean whitelist_ab;
++ gchar *whitelist_ab_folder;
++ gboolean full; /**< use full window */
++};
++
++extern DilloBrowserPrefs dillo_prefs;
++
++void dillo_prefs_init(void);
++void dillo_prefs_done(void);
++
++#endif
+diff --git a/src/plugins/dillo/dillo_viewer.c b/src/plugins/dillo/dillo_viewer.c
+new file mode 100644
+index 0000000..1c63fa3
+--- /dev/null
++++ b/src/plugins/dillo/dillo_viewer.c
+@@ -0,0 +1,310 @@
++/*
++ * Claws Mail -- a GTK+ based, lightweight, and fast e-mail client
++ * Copyright (C) 1999-2012 the Claws Mail Team
++ *
++ * This program is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 3 of the License, or
++ * (at your option) any later version.
++ *
++ * 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, see <http://www.gnu.org/licenses/>.
++ *
++ */
++
++#ifdef HAVE_CONFIG_H
++# include "config.h"
++#include "claws-features.h"
++#endif
++
++#include <unistd.h>
++
++#include <glib.h>
++#include <glib/gi18n.h>
++#include <gtk/gtk.h>
++#if GTK_CHECK_VERSION(3, 0, 0)
++#include <gtk/gtkx.h>
++#endif
++#include <gdk/gdkx.h>
++
++#include "common/claws.h"
++#include "common/version.h"
++#include "plugin.h"
++#include "utils.h"
++#include "mimeview.h"
++#include "addr_compl.h"
++
++#include "dillo_prefs.h"
++
++#define PLUGIN_NAME (_("Dillo HTML Viewer"))
++
++typedef struct _DilloViewer DilloViewer;
++
++struct _DilloViewer
++{
++ MimeViewer mimeviewer;
++ GtkWidget *widget;
++ GtkWidget *socket;
++ gchar *filename;
++};
++
++static MimeViewerFactory dillo_viewer_factory;
++
++static GtkWidget *dillo_get_widget(MimeViewer *_viewer)
++{
++ DilloViewer *viewer = (DilloViewer *) _viewer;
++
++ debug_print("dillo_get_widget\n");
++
++ return GTK_WIDGET(viewer->widget);
++}
++
++#if !GTK_CHECK_VERSION(3, 0, 0)
++static gboolean socket_destroy_cb(GtkObject *object, gpointer data)
++#else
++static gboolean socket_destroy_cb(GtkObject *object, gpointer data)
++#endif
++{
++ DilloViewer *viewer = (DilloViewer *) data;
++ debug_print("Destroyed dillo socket %p\n", viewer->socket);
++ viewer->socket = NULL;
++ return FALSE;
++}
++
++static gboolean found_in_addressbook(const gchar *address)
++{
++ gchar *addr = NULL;
++ gboolean found = FALSE;
++ gint num_addr = 0;
++
++ if (!address)
++ return FALSE;
++
++ addr = g_strdup(address);
++ extract_address(addr);
++ num_addr = complete_address(addr);
++ if (num_addr > 1) {
++ /* skip first item (this is the search string itself) */
++ int i = 1;
++ for (; i < num_addr && !found; i++) {
++ gchar *caddr = get_complete_address(i);
++ extract_address(caddr);
++ if (strcasecmp(caddr, addr) == 0)
++ found = TRUE;
++ g_free(caddr);
++ }
++ }
++ g_free(addr);
++ return found;
++}
++
++static gboolean load_images(DilloViewer *viewer)
++{
++ MessageView *messageview = ((MimeViewer *)viewer)->mimeview
++ ? ((MimeViewer *)viewer)->mimeview->messageview
++ : NULL;
++ MsgInfo *msginfo = NULL;
++ gchar *ab_folderpath = NULL;
++
++ if (messageview == NULL)
++ return FALSE;
++
++ msginfo = messageview->msginfo;
++
++ if (msginfo == NULL)
++ return FALSE;
++
++ /* don't load remote images, period. */
++ if (dillo_prefs.local)
++ return FALSE;
++
++ /* don't do whitelisting -> load images */
++ if (!dillo_prefs.whitelist_ab)
++ return TRUE;
++
++ if (*dillo_prefs.whitelist_ab_folder != '\0' &&
++ strcasecmp(dillo_prefs.whitelist_ab_folder, _("Any")) != 0)
++ ab_folderpath = dillo_prefs.whitelist_ab_folder;
++
++ start_address_completion(ab_folderpath);
++
++ /* do whitelisting -> check sender */
++ if (found_in_addressbook(msginfo->from)) {
++ end_address_completion();
++ return TRUE;
++ }
++
++ end_address_completion();
++ return FALSE;
++}
++
++static void dillo_show_mimepart(MimeViewer *_viewer,
++ const gchar *infile,
++ MimeInfo *partinfo)
++{
++ DilloViewer *viewer = (DilloViewer *) _viewer;
++
++ debug_print("dillo_show_mimepart\n");
++
++ if (viewer->filename != NULL) {
++ claws_unlink(viewer->filename);
++ g_free(viewer->filename);
++ }
++
++ viewer->filename = procmime_get_tmp_file_name(partinfo);
++
++ if (!(procmime_get_part(viewer->filename, partinfo) < 0)) {
++ gchar *cmd;
++
++ if (viewer->socket)
++ gtk_widget_destroy(viewer->socket);
++ viewer->socket = gtk_socket_new();
++ debug_print("Adding dillo socket %p", viewer->socket);
++ gtk_container_add(GTK_CONTAINER(viewer->widget),
++ viewer->socket);
++ gtk_widget_realize(viewer->socket);
++ gtk_widget_show(viewer->socket);
++ g_signal_connect(G_OBJECT(viewer->socket), "destroy",
++ G_CALLBACK(socket_destroy_cb), viewer);
++
++ cmd = g_strdup_printf("dillo %s%s-x %d \"%s\"",
++ (!load_images(viewer) ? "-l " : ""),
++ (dillo_prefs.full ? "-f " : ""),
++ (gint) GDK_WINDOW_XWINDOW(viewer->socket->window),
++ viewer->filename);
++
++ execute_command_line(cmd, TRUE, NULL);
++ g_free(cmd);
++ }
++}
++
++static void dillo_clear_viewer(MimeViewer *_viewer)
++{
++ DilloViewer *viewer = (DilloViewer *) _viewer;
++
++ debug_print("dillo_clear_viewer\n");
++ debug_print("Removing dillo socket %p\n", viewer->socket);
++
++ if (viewer->socket) {
++ gtk_widget_destroy(viewer->socket);
++ }
++}
++
++static void dillo_destroy_viewer(MimeViewer *_viewer)
++{
++ DilloViewer *viewer = (DilloViewer *) _viewer;
++
++ debug_print("dillo_destroy_viewer\n");
++
++ if (viewer->socket) {
++ gtk_widget_destroy(viewer->socket);
++ }
++
++ g_object_unref(GTK_WIDGET(viewer->widget));
++ claws_unlink(viewer->filename);
++ g_free(viewer->filename);
++ g_free(viewer);
++}
++
++static MimeViewer *dillo_viewer_create(void)
++{
++ DilloViewer *viewer;
++
++ debug_print("dillo_viewer_create\n");
++
++ viewer = g_new0(DilloViewer, 1);
++ viewer->mimeviewer.factory = &dillo_viewer_factory;
++ viewer->mimeviewer.get_widget = dillo_get_widget;
++ viewer->mimeviewer.show_mimepart = dillo_show_mimepart;
++ viewer->mimeviewer.clear_viewer = dillo_clear_viewer;
++ viewer->mimeviewer.destroy_viewer = dillo_destroy_viewer;
++ viewer->mimeviewer.get_selection = NULL;
++ viewer->widget = gtk_event_box_new();
++
++ gtk_widget_show(viewer->widget);
++ g_object_ref(viewer->widget);
++
++ viewer->filename = NULL;
++
++ return (MimeViewer *) viewer;
++}
++
++static gchar *content_types[] =
++ {"text/html", NULL};
++
++static MimeViewerFactory dillo_viewer_factory =
++{
++ content_types,
++ 0,
++
++ dillo_viewer_create,
++};
++
++gint plugin_init(gchar **error)
++{
++ gchar *dillo_path = NULL;
++ if (!check_plugin_version(MAKE_NUMERIC_VERSION(2,9,2,72),
++ VERSION_NUMERIC, PLUGIN_NAME, error))
++ return -1;
++
++ if ((dillo_path = g_find_program_in_path("dillo")) == NULL) {
++ *error = g_strdup(_("Can't find the dillo executable in PATH. Is it installed?"));
++ return -1;
++ }
++ g_free(dillo_path);
++
++ dillo_prefs_init();
++
++ mimeview_register_viewer_factory(&dillo_viewer_factory);
++
++ return 0;
++}
++
++gboolean plugin_done(void)
++{
++ mimeview_unregister_viewer_factory(&dillo_viewer_factory);
++
++ dillo_prefs_done();
++ return TRUE;
++}
++
++const gchar *plugin_name(void)
++{
++ return PLUGIN_NAME;
++}
++
++const gchar *plugin_desc(void)
++{
++ return _("This plugin renders HTML mail using the Dillo "
++ "web browser.\n"
++ "\n"
++ "Options can be found in /Configuration/Preferences/Plugins/Dillo Browser");
++}
++
++const gchar *plugin_type(void)
++{
++ return "GTK2";
++}
++
++const gchar *plugin_licence(void)
++{
++ return "GPL3+";
++}
++
++const gchar *plugin_version(void)
++{
++ return VERSION;
++}
++
++struct PluginFeature *plugin_provides(void)
++{
++ static struct PluginFeature features[] =
++ { {PLUGIN_MIMEVIEWER, "text/html"},
++ {PLUGIN_NOTHING, NULL}};
++ return features;
++}
+--
+1.7.10.4
+