]> saetta.ns0.it Git - solipa/libsolipa/commitdiff
Inizio scorporamento utilità per mail da libreria principale.
authorAndrea Zagli <azagli@libero.it>
Sat, 8 Apr 2017 08:24:48 +0000 (10:24 +0200)
committerAndrea Zagli <azagli@libero.it>
Sat, 8 Apr 2017 08:24:48 +0000 (10:24 +0200)
configure.ac
libsolipa.pc.in
libsolipamail.pc.in [new file with mode: 0644]
src/Makefile.am
src/camel.c [new file with mode: 0644]
src/camel.h [new file with mode: 0644]
src/solipa.c
src/solipa.h
tests/Makefile.am

index 4d18dad7d713f972e8faa404eaeba10b711e633e..bc294e41f8ab28c4b0f4ce8659af57c134b74172 100644 (file)
@@ -119,6 +119,7 @@ AC_SUBST(SOLIPA_WIN32_LIBS)
 # Output files
 AC_CONFIG_FILES([
        libsolipa.pc
+       libsolipamail.pc
        libsolipaooo.pc
        Makefile
        src/Makefile
index 8cd2dce2e44380990fc3e2dc1042e9f711934bfa..1bedbd9a17f54e29624398ffc1bfc0c1811dbf5d 100644 (file)
@@ -6,6 +6,6 @@ includedir=@includedir@
 Name: @PACKAGE_NAME@
 Description: Classe con funzioni varie di utilità.
 Version: @PACKAGE_VERSION@
-Requires: libgdaex >= 0.5.0 @CAMEL_PKGCONFIG@ libgtkform >= 0.5.0 gio-2.0 >= 2.36 libzakutils libzakformgtk
+Requires: libgdaex >= 0.5.0 libgtkform >= 0.5.0 gio-2.0 >= 2.36 libzakutils libzakformgtk
 Libs: -L${libdir} -lsolipa
 Cflags: -I${includedir}
diff --git a/libsolipamail.pc.in b/libsolipamail.pc.in
new file mode 100644 (file)
index 0000000..030a7a4
--- /dev/null
@@ -0,0 +1,11 @@
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+includedir=@includedir@
+
+Name: @PACKAGE_NAME@
+Description: Classe con funzioni varie di utilità - Supporto per le mail.
+Version: @PACKAGE_VERSION@
+Requires: libsolipa @CAMEL_PKGCONFIG@
+Libs: -L${libdir} -lsolipamail
+Cflags: -I${includedir}
index db5a209621dc665b1f88bec0ebeacdb1ad005d2e..b411d198222f0b02c6ccb7abc4bd0ac516b91398 100644 (file)
@@ -8,8 +8,8 @@ endif
 
 LIBS = $(SOLIPA_LIBS) \
        $(SOLIPA_WIN32_LIBS) \
-       $(CAMEL_LIBS) \
-       $(WIN32_LIBS)
+       $(WIN32_LIBS) \
+       $(CAMEL_LIBS)
 
 if HAVE_CAMEL318
   CAMEL3=-DCAMEL3=\"yes\" -DCAMEL318=\"yes\"
@@ -27,34 +27,49 @@ endif
 
 AM_CPPFLAGS = $(SOLIPA_CFLAGS) \
               $(SOLIPA_WIN32_CFLAGS) \
-              $(CAMEL_CFLAGS) \
               -DGUIDIR=\""$(guidir)"\" \
               -DG_LOG_DOMAIN=\"Solipa\" \
+              $(CAMEL_CFLAGS) \
               $(CAMEL3)
 
 lib_LTLIBRARIES = libsolipa.la \
+                  libsolipamail.la \
                   libsolipaooo.la
 
 libsolipa_la_SOURCES = solipa.c \
                        allegato.c \
-                       camelsession.c \
                        log.c \
-                       mail.c \
-                       mailui.c \
                        progresswindow.c \
-                       utils.c
+                       utils.c \
+                       camelsession.c \
+                       camel.c
 
 libsolipa_la_LDFLAGS = -no-undefined
 
 libsolipa_include_HEADERS = libsolipa.h \
                             solipa.h \
                             allegato.h \
-                            camelsession.h \
                             log.h \
-                            mail.h \
-                            mailui.h \
                             progresswindow.h \
-                            utils.h
+                            utils.h \
+                            camelsession.h \
+                            camel.h
+
+libsolipa_includedir = $(includedir)/libsolipa
+
+libsolipamail_la_LIBADD = libsolipa.la
+
+libsolipamail_la_CFLAGS =
+
+libsolipamail_la_LDFLAGS = -no-undefined
+
+libsolipamail_la_SOURCES = mail.c \
+                           mailui.c
+
+libsolipamail_include_HEADERS = mail.h \
+                                mailui.h
+
+libsolipamail_includedir = $(includedir)/libsolipa
 
 libsolipaooo_la_LIBADD = libsolipa.la \
                          $(PYTHON_LIBS)
@@ -67,6 +82,4 @@ libsolipaooo_la_SOURCES = ooo.c
 
 libsolipaooo_include_HEADERS = ooo.h
 
-libsolipa_includedir = $(includedir)/libsolipa
-
 libsolipaooo_includedir = $(includedir)/libsolipa
diff --git a/src/camel.c b/src/camel.c
new file mode 100644 (file)
index 0000000..bf01cb3
--- /dev/null
@@ -0,0 +1,186 @@
+/*
+ * Copyright (C) 2017 Andrea Zagli <azagli@libero.it>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+ */
+
+#ifdef HAVE_CONFIG_H
+       #include <config.h>
+#endif
+
+#ifdef G_OS_WIN32
+#include <windows.h>
+#endif
+
+#include <glib/gstdio.h>
+
+#include "solipa.h"
+#include "camelsession.h"
+#include "camel.h"
+
+static void solipa_camel_class_init (SolipaCamelClass *class);
+static void solipa_camel_init (SolipaCamel *solipa);
+
+static void solipa_camel_set_property (GObject *object,
+                               guint property_id,
+                               const GValue *value,
+                               GParamSpec *pspec);
+static void solipa_camel_get_property (GObject *object,
+                               guint property_id,
+                               GValue *value,
+                               GParamSpec *pspec);
+
+static void solipa_camel_dispose (GObject *gobject);
+static void solipa_camel_finalize (GObject *gobject);
+
+#define SOLIPA_CAMEL_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), SOLIPA_TYPE_CAMEL, SolipaCamelPrivate))
+
+typedef struct _SolipaCamelPrivate SolipaCamelPrivate;
+struct _SolipaCamelPrivate
+       {
+               gchar *camel_tmpdir;
+               CamelSession *camel_session;
+       };
+
+G_DEFINE_TYPE (SolipaCamel, solipa_camel, G_TYPE_OBJECT)
+
+static void
+solipa_camel_class_init (SolipaCamelClass *class)
+{
+       GObjectClass *object_class = G_OBJECT_CLASS (class);
+
+       object_class->set_property = solipa_camel_set_property;
+       object_class->get_property = solipa_camel_get_property;
+       object_class->dispose = solipa_camel_dispose;
+       object_class->finalize = solipa_camel_finalize;
+
+       g_type_class_add_private (object_class, sizeof (SolipaCamelPrivate));
+}
+
+static void
+solipa_camel_init (SolipaCamel *solipa)
+{
+       SolipaCamelPrivate *priv = SOLIPA_CAMEL_GET_PRIVATE (solipa);
+}
+
+/**
+ * solipa_camel_new:
+ *
+ * Returns: the newly created #SolipaCamel object.
+ */
+SolipaCamel
+*solipa_camel_new ()
+{
+       SolipaCamel *solipa;
+       SolipaCamelPrivate *priv;
+
+       solipa = SOLIPA_CAMEL (g_object_new (solipa_camel_get_type (), NULL));
+       priv = SOLIPA_CAMEL_GET_PRIVATE (solipa);
+
+       /* creo la directory temporanea per camel */
+       priv->camel_tmpdir = g_mkdtemp (g_build_filename (g_get_tmp_dir (), g_strdup ("solipa-camel-XXXXXX"), NULL));
+
+       /* inizializzo camel */
+       camel_init (priv->camel_tmpdir, FALSE);
+       camel_provider_init ();
+
+       priv->camel_session = solipa_camel_session_new (priv->camel_tmpdir);
+
+       return solipa;
+}
+
+CamelSession
+*solipa_camel_get_camel_session (SolipaCamel *solipa)
+{
+       SolipaCamelPrivate *priv;
+
+       g_return_val_if_fail (IS_SOLIPA (solipa), NULL);
+
+       priv = SOLIPA_CAMEL_GET_PRIVATE (solipa);
+
+       return priv->camel_session;
+}
+
+/* PRIVATE */
+static void
+solipa_camel_set_property (GObject *object,
+                   guint property_id,
+                   const GValue *value,
+                   GParamSpec *pspec)
+{
+       SolipaCamel *solipa = (SolipaCamel *)object;
+       SolipaCamelPrivate *priv = SOLIPA_CAMEL_GET_PRIVATE (solipa);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+static void
+solipa_camel_get_property (GObject *object,
+                   guint property_id,
+                   GValue *value,
+                   GParamSpec *pspec)
+{
+       SolipaCamel *solipa = (SolipaCamel *)object;
+       SolipaCamelPrivate *priv = SOLIPA_CAMEL_GET_PRIVATE (solipa);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+static void
+solipa_camel_dispose (GObject *gobject)
+{
+       SolipaCamel *solipa = (SolipaCamel *)gobject;
+       SolipaCamelPrivate *priv = SOLIPA_CAMEL_GET_PRIVATE (solipa);
+
+       if (priv->camel_tmpdir)
+               {
+                       /* rimuovo la directory temporanea */
+                       g_rmdir (priv->camel_tmpdir);
+               }
+
+       if (priv->camel_session)
+               {
+                       g_object_unref (priv->camel_session);
+                       priv->camel_session = NULL;
+               }
+
+       GObjectClass *parent_class = g_type_class_peek_parent (G_OBJECT_GET_CLASS (gobject));
+       parent_class->dispose (gobject);
+}
+
+static void
+solipa_camel_finalize (GObject *gobject)
+{
+       SolipaCamel *solipa = (SolipaCamel *)gobject;
+       SolipaCamelPrivate *priv = SOLIPA_CAMEL_GET_PRIVATE (solipa);
+
+       /* delete camel tmp dir */
+       g_rmdir (priv->camel_tmpdir);
+
+       g_free (priv->camel_tmpdir);
+
+       GObjectClass *parent_class = g_type_class_peek_parent (G_OBJECT_GET_CLASS (gobject));
+       parent_class->finalize (gobject);
+}
diff --git a/src/camel.h b/src/camel.h
new file mode 100644 (file)
index 0000000..1fd36fb
--- /dev/null
@@ -0,0 +1,62 @@
+/*
+ * Copyright (C) 2017 Andrea Zagli <azagli@libero.it>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+ */
+
+#ifndef __SOLIPA_CAMEL_H__
+#define __SOLIPA_CAMEL_H__
+
+#include <glib.h>
+#include <glib-object.h>
+
+#include <camel/camel.h>
+
+
+G_BEGIN_DECLS
+
+
+#define SOLIPA_TYPE_CAMEL                 (solipa_camel_get_type ())
+#define SOLIPA_CAMEL(obj)                 (G_TYPE_CHECK_INSTANCE_CAST ((obj), SOLIPA_TYPE_CAMEL, SolipaCamel))
+#define SOLIPA_CAMEL_CLASS(klass)         (G_TYPE_CHECK_CLASS_CAST ((klass), SOLIPA_TYPE_CAMEL, SolipaCamelClass))
+#define IS_SOLIPA_CAMEL(obj)              (G_TYPE_CHECK_INSTANCE_TYPE ((obj), SOLIPA_TYPE_CAMEL))
+#define IS_SOLIPA_CAMEL_CLASS(klass)      (G_TYPE_CHECK_CLASS_TYPE ((klass), SOLIPA_TYPE_CAMEL))
+#define SOLIPA_CAMEL_GET_CLASS(obj)       (G_TYPE_INSTANCE_GET_CLASS ((obj), SOLIPA_TYPE_CAMEL, SolipaCamelClass))
+
+typedef struct _SolipaCamel SolipaCamel;
+typedef struct _SolipaCamelClass SolipaCamelClass;
+
+struct _SolipaCamel
+       {
+               GObject parent;
+       };
+
+struct _SolipaCamelClass
+       {
+               GObjectClass parent_class;
+       };
+
+GType solipa_camel_get_type (void) G_GNUC_CONST;
+
+
+SolipaCamel *solipa_camel_new (void);
+
+CamelSession *solipa_camel_get_camel_session (SolipaCamel *solipa_camel);
+
+
+G_END_DECLS
+
+
+#endif /* __SOLIPA_CAMEL_H__ */
index b3c1f2529d4928272bfce0b6fa84fedf246223ae..293a5f5cf64500a551b6798ffa8330ad885c506f 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2010-2015 Andrea Zagli <azagli@libero.it>
+ * Copyright (C) 2010-2017 Andrea Zagli <azagli@libero.it>
  *
  * This library is free software; you can redistribute it and/or
  * modify it under the terms of the GNU Lesser General Public
@@ -30,7 +30,6 @@
 #endif
 
 #include "solipa.h"
-#include "camelsession.h"
 #include "utils.h"
 
 static void solipa_class_init (SolipaClass *class);
@@ -53,8 +52,7 @@ static void solipa_finalize (GObject *gobject);
 typedef struct _SolipaPrivate SolipaPrivate;
 struct _SolipaPrivate
        {
-               gchar *camel_tmpdir;
-               CamelSession *camel_session;
+               SolipaCamel *camel_session;
 
                gchar *guidir;
                gchar *guifile;
@@ -115,14 +113,7 @@ Solipa
        solipa = SOLIPA (g_object_new (solipa_get_type (), NULL));
        priv = SOLIPA_GET_PRIVATE (solipa);
 
-       /* creo la directory temporanea per camel */
-       priv->camel_tmpdir = g_mkdtemp (g_build_filename (g_get_tmp_dir (), g_strdup ("solipa-camel-XXXXXX"), NULL));
-
-       /* inizializzo camel */
-       camel_init (priv->camel_tmpdir, FALSE);
-       camel_provider_init ();
-
-       priv->camel_session = solipa_camel_session_new (priv->camel_tmpdir);
+       priv->camel_session = solipa_camel_new ();
 
        /* gui */
 #ifdef G_OS_WIN32
@@ -201,7 +192,8 @@ solipa_set_from_keyfile (Solipa *solipa, const gchar *filename)
        g_error_free (error);
 }
 
-CamelSession
+G_DEPRECATED
+SolipaCamel
 *solipa_get_camel_session (Solipa *solipa)
 {
        SolipaPrivate *priv;
@@ -297,12 +289,6 @@ solipa_dispose (GObject *gobject)
                        priv->gtkbuilder = NULL;
                }
 
-       if (priv->camel_tmpdir)
-               {
-                       /* rimuovo la directory temporanea */
-                       g_rmdir (priv->camel_tmpdir);
-               }
-
        if (priv->camel_session)
                {
                        g_object_unref (priv->camel_session);
@@ -319,10 +305,6 @@ solipa_finalize (GObject *gobject)
        Solipa *solipa = (Solipa *)gobject;
        SolipaPrivate *priv = SOLIPA_GET_PRIVATE (solipa);
 
-       /* delete camel tmp dir */
-       g_rmdir (priv->camel_tmpdir);
-
-       g_free (priv->camel_tmpdir);
        g_free (priv->guidir);
        g_free (priv->guifile);
 
index 13122f016849506d1e929cbe994b61b036e4037c..acb81f38ba98ea681f7e56c96d84d8cd9f3cf390 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2010-2015 Andrea Zagli <azagli@libero.it>
+ * Copyright (C) 2010-2017 Andrea Zagli <azagli@libero.it>
  *
  * This library is free software; you can redistribute it and/or
  * modify it under the terms of the GNU Lesser General Public
 
 #include <gtk/gtk.h>
 
-#include <camel/camel.h>
-
 #include <libgdaex/gdaex.h>
 
 
+#include "camel.h"
+
+
 G_BEGIN_DECLS
 
 
@@ -60,7 +61,8 @@ Solipa *solipa_new_with_keyfile (const gchar *filename);
 
 void solipa_set_from_keyfile (Solipa *solipa, const gchar *filename);
 
-CamelSession *solipa_get_camel_session (Solipa *solipa);
+G_DEPRECATED
+SolipaCamel *solipa_get_camel_session (Solipa *solipa);
 
 G_DEPRECATED
 void solipa_set_gdaex (Solipa *solipa, GdaEx *gdaex);
index 6c4bf752ed5c54ec08c4ae3da2eb8bef9a37645e..a39695fccfb6891c5e8298b820da6f390c895c19 100644 (file)
@@ -2,15 +2,26 @@ AM_CPPFLAGS = $(WARN_CFLAGS) \
               $(DISABLE_DEPRECATED_CFLAGS) \
               $(SOLIPA_CFLAGS) \
               $(CAMEL_CFLAGS) \
+              $(PYTHON_CFLAGS) \
               -I$(top_srcdir)/src \
               -DGUIDIR="\"@abs_builddir@\""
 
 LIBS = $(SOLIPA_LIBS) \
        $(CAMEL_LIBS) \
+       $(PYTHON_LIBS) \
        -export-dynamic
 
 LDADD = $(top_builddir)/src/libsolipa.la
 
+mail_LDADD = $(top_builddir)/src/libsolipa.la \
+             $(top_builddir)/src/libsolipamail.la
+mail_check_address_LDADD = $(top_builddir)/src/libsolipa.la \
+                           $(top_builddir)/src/libsolipamail.la
+mail_get_addresses_from_string_LDADD = $(top_builddir)/src/libsolipa.la \
+                                       $(top_builddir)/src/libsolipamail.la
+mailui_LDADD = $(top_builddir)/src/libsolipa.la \
+               $(top_builddir)/src/libsolipamail.la
+
 ooo_LDADD = $(top_builddir)/src/libsolipaooo.la
 ooo_pycmd_LDADD = $(top_builddir)/src/libsolipaooo.la