<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<?fileVersion 4.0.0?>
-
-<cproject storage_type_id="org.eclipse.cdt.core.XmlProjectDescriptionStorage">
+<?fileVersion 4.0.0?><cproject storage_type_id="org.eclipse.cdt.core.XmlProjectDescriptionStorage">
<storageModule moduleId="org.eclipse.cdt.core.settings">
- <cconfiguration id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2078941477">
- <storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2078941477" moduleId="org.eclipse.cdt.core.settings" name="Build (GNU)">
+ <cconfiguration id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2086840760">
+ <storageModule buildSystemId="org.eclipse.cdt.managedbuilder.core.configurationDataProvider" id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2086840760" moduleId="org.eclipse.cdt.core.settings" name="Build (GNU)">
<externalSettings/>
<extensions>
<extension id="org.eclipse.cdt.core.MachO64" point="org.eclipse.cdt.core.BinaryParser"/>
- <extension id="org.eclipse.cdt.core.ELF" point="org.eclipse.cdt.core.BinaryParser"/>
- <extension id="org.eclipse.cdt.core.PE" point="org.eclipse.cdt.core.BinaryParser"/>
<extension id="org.eclipse.cdt.core.Cygwin_PE" point="org.eclipse.cdt.core.BinaryParser"/>
+ <extension id="org.eclipse.cdt.core.PE" point="org.eclipse.cdt.core.BinaryParser"/>
+ <extension id="org.eclipse.cdt.core.ELF" point="org.eclipse.cdt.core.BinaryParser"/>
<extension id="org.eclipse.cdt.core.GNU_ELF" point="org.eclipse.cdt.core.BinaryParser"/>
<extension id="org.eclipse.cdt.core.GCCErrorParser" point="org.eclipse.cdt.core.ErrorParser"/>
</extensions>
</storageModule>
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
- <configuration buildProperties="" description="" id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2078941477" name="Build (GNU)" parent="org.eclipse.cdt.build.core.emptycfg">
- <folderInfo id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2078941477.912877605" name="/" resourcePath="">
- <toolChain id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.1792737919" name="org.eclipse.linuxtools.cdt.autotools.core.toolChain" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolChain">
- <targetPlatform id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.targetPlatform.1314607368" isAbstract="false" name="GNU Autotools Target Platform" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.targetPlatform"/>
- <builder id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.builder.508220876" keepEnvironmentInBuildfile="false" managedBuildOn="false" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.builder"/>
- <tool id="org.eclipse.linuxtools.cdt.autotools.core.gnu.toolchain.tool.configure.213892850" name="configure" superClass="org.eclipse.linuxtools.cdt.autotools.core.gnu.toolchain.tool.configure">
- <option id="org.eclipse.linuxtools.cdt.autotools.core.option.configure.name.210087798" name="Name" superClass="org.eclipse.linuxtools.cdt.autotools.core.option.configure.name" value="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2078941477" valueType="string"/>
+ <configuration artifactName="${ProjName}" buildProperties="" description="" id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2086840760" name="Build (GNU)" parent="org.eclipse.cdt.build.core.emptycfg">
+ <folderInfo id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2086840760.1254459493" name="/" resourcePath="">
+ <toolChain id="org.eclipse.linuxtools.cdt.autotools.core.toolChain.1057620081" name="GNU Autotools Toolchain" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolChain">
+ <targetPlatform id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.targetPlatform.1084930655" isAbstract="false" name="GNU Autotools Target Platform" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.targetPlatform"/>
+ <builder id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.builder.1173667006" keepEnvironmentInBuildfile="false" managedBuildOn="false" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.builder"/>
+ <tool id="org.eclipse.linuxtools.cdt.autotools.core.gnu.toolchain.tool.configure.1853089142" name="configure" superClass="org.eclipse.linuxtools.cdt.autotools.core.gnu.toolchain.tool.configure">
+ <option id="org.eclipse.linuxtools.cdt.autotools.core.option.configure.name.436034851" name="Name" superClass="org.eclipse.linuxtools.cdt.autotools.core.option.configure.name" value="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2086840760" valueType="string"/>
</tool>
- <tool id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.autogen.1802348268" name="autogen.sh" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.autogen"/>
- <tool id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gcc.2074081626" name="GCC C Compiler" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gcc">
- <option id="gnu.c.compiler.option.include.paths.2135141" name="Include paths (-I)" superClass="gnu.c.compiler.option.include.paths" valueType="includePath">
- <listOptionValue builtIn="false" value=""C:\mingw\include""/>
- <listOptionValue builtIn="false" value=""C:\mingw\include\glib-2.0""/>
- <listOptionValue builtIn="false" value=""C:\mingw\include\gtk-2.0""/>
- <listOptionValue builtIn="false" value=""C:\mingw\include\libgda-4.0""/>
- <listOptionValue builtIn="false" value=""C:\mingw\include\libgda-4.0\libgda""/>
- <listOptionValue builtIn="false" value=""C:\mingw\include\gdk-pixbuf-2.0""/>
+ <tool id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.autogen.1944671241" name="autogen.sh" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.autogen"/>
+ <tool id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gcc.806206756" name="GCC C Compiler" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gcc">
+ <option id="gnu.c.compiler.option.include.paths.868814188" name="Include paths (-I)" superClass="gnu.c.compiler.option.include.paths" valueType="includePath">
+ <listOptionValue builtIn="false" value=""C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include""/>
+ <listOptionValue builtIn="false" value=""C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\glib-2.0""/>
+ <listOptionValue builtIn="false" value=""C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\gtk-3.0""/>
+ <listOptionValue builtIn="false" value=""C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\evolution-data-server-2.32""/>
+ <listOptionValue builtIn="false" value=""C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\libgda-5.0""/>
+ <listOptionValue builtIn="false" value=""C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\libgda-5.0\libgda""/>
+ <listOptionValue builtIn="false" value=""C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\gdk-pixbuf-2.0""/>
</option>
- <inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.1589342168" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/>
+ <inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.1147008075" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/>
</tool>
- <tool id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gpp.484606055" name="GCC C++ Compiler" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gpp"/>
+ <tool id="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gpp.1763053076" name="GCC C++ Compiler" superClass="org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gpp"/>
</toolChain>
</folderInfo>
</configuration>
</cconfiguration>
</storageModule>
<storageModule moduleId="cdtBuildSystem" version="4.0.0">
- <project id="libsolipa.null.182313735" name="libsolipa"/>
+ <project id="libsolipa (gtk3).null.1736522599" name="libsolipa (gtk3)"/>
</storageModule>
<storageModule moduleId="org.eclipse.cdt.core.LanguageSettingsProviders"/>
+ <storageModule moduleId="org.eclipse.cdt.make.core.buildtargets"/>
<storageModule moduleId="scannerConfiguration">
<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId=""/>
+ <scannerConfigBuildInfo instanceId="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2086840760;org.eclipse.linuxtools.cdt.autotools.core.toolChain.2086840760.1254459493;org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gcc.806206756;cdt.managedbuild.tool.gnu.c.compiler.input.1147008075">
+ <autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId=""/>
+ </scannerConfigBuildInfo>
<scannerConfigBuildInfo instanceId="org.eclipse.linuxtools.cdt.autotools.core.toolChain.2078941477;org.eclipse.linuxtools.cdt.autotools.core.toolChain.2078941477.912877605;org.eclipse.linuxtools.cdt.autotools.core.toolchain.tool.gcc.2074081626;cdt.managedbuild.tool.gnu.c.compiler.input.1589342168">
<autodiscovery enabled="true" problemReportingEnabled="true" selectedProfileId="org.eclipse.cdt.managedbuilder.core.GCCManagedMakePerProjectProfileC"/>
</scannerConfigBuildInfo>
libsolipa_la_SOURCES = solipa.c \
allegato.c \
camelsession.c \
+ log.c \
mail.c \
mailui.c \
progresswindow.c \
solipa.h \
allegato.h \
camelsession.h \
+ log.h \
mail.h \
mailui.h \
progresswindow.h \
--- /dev/null
+/*
+ * Copyright (C) 2014 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
+
+#include <stdio.h>
+
+#include "log.h"
+
+static void solipa_log_class_init (SolipaLogClass *class);
+static void solipa_log_init (SolipaLog *solipa_log);
+
+static void solipa_log_set_property (GObject *object,
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec);
+static void solipa_log_get_property (GObject *object,
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec);
+
+static void solipa_log_handler (const gchar *log_domain,
+ GLogLevelFlags log_level,
+ const gchar *message,
+ gpointer user_data);
+
+#define SOLIPA_LOG_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_SOLIPA_LOG, SolipaLogPrivate))
+
+typedef struct _SolipaLogPrivate SolipaLogPrivate;
+struct _SolipaLogPrivate
+ {
+ Solipa *solipa;
+
+ gchar *app_name;
+ gchar *dir;
+ };
+
+G_DEFINE_TYPE (SolipaLog, solipa_log, G_TYPE_OBJECT)
+
+static void
+solipa_log_class_init (SolipaLogClass *class)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (class);
+
+ object_class->set_property = solipa_log_set_property;
+ object_class->get_property = solipa_log_get_property;
+
+ g_type_class_add_private (object_class, sizeof (SolipaLogPrivate));
+}
+
+static void
+solipa_log_init (SolipaLog *solipa_log)
+{
+ SolipaLogPrivate *priv = SOLIPA_LOG_GET_PRIVATE (solipa_log);
+}
+
+/**
+ * solipa_log_new:
+ * @solipa:
+ * @app_name:
+ *
+ * Returns: the newly created #SolipaLog object.
+ */
+SolipaLog
+*solipa_log_new (Solipa *solipa, const gchar *app_name)
+{
+ SolipaLog *solipa_log;
+ SolipaLogPrivate *priv;
+
+ gchar *_app_name;
+
+ g_return_val_if_fail (IS_SOLIPA (solipa), NULL);
+ g_return_val_if_fail (app_name != NULL, NULL);
+
+ _app_name = g_strdup (app_name);
+ g_strstrip(_app_name);
+ g_return_val_if_fail (g_strcmp0 (_app_name, "") != 0, NULL);
+
+ solipa_log = SOLIPA_LOG (g_object_new (solipa_log_get_type (), NULL));
+
+ priv = SOLIPA_LOG_GET_PRIVATE (solipa_log);
+
+ priv->solipa = solipa;
+ priv->app_name = g_strdup (_app_name);
+ g_free (_app_name);
+
+ priv->dir = g_build_filename (g_get_user_data_dir (), g_strdup_printf ("solipa_log_%s", priv->app_name), NULL);
+ if (g_mkdir_with_parents (priv->dir, S_IRWXU) < 0)
+ {
+ g_warning ("SolipaLog: unable to create log directory.");
+ g_free (priv->app_name);
+ g_free (priv->dir);
+ return NULL;
+ }
+
+ return solipa_log;
+}
+
+void
+solipa_log_add_logdomain (SolipaLog *solipalog, const gchar *log_domain)
+{
+ g_return_if_fail (IS_SOLIPA_LOG (solipalog));
+
+ g_log_set_handler (g_strcmp0 (log_domain, "") == 0 ? NULL : log_domain,
+ G_LOG_LEVEL_MASK,
+ solipa_log_handler, NULL);
+}
+
+void
+solipa_log_add_logdomains (SolipaLog *solipalog, ...)
+{
+ va_list vargs;
+
+ gchar *log_domain;
+
+ g_return_if_fail (IS_SOLIPA_LOG (solipalog));
+
+ va_start (vargs, solipalog);
+ while ((log_domain = va_arg (vargs, gchar *)) != NULL)
+ {
+ solipa_log_add_logdomain (solipalog, log_domain);
+ }
+
+ va_end (vargs);
+}
+
+/* PRIVATE */
+static void
+solipa_log_set_property (GObject *object,
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ SolipaLog *solipa_log = (SolipaLog *)object;
+ SolipaLogPrivate *priv = SOLIPA_LOG_GET_PRIVATE (solipa_log);
+
+ switch (property_id)
+ {
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ break;
+ }
+}
+
+static void
+solipa_log_get_property (GObject *object,
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ SolipaLog *solipa_log = (SolipaLog *)object;
+ SolipaLogPrivate *priv = SOLIPA_LOG_GET_PRIVATE (solipa_log);
+
+ switch (property_id)
+ {
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ break;
+ }
+}
+
+static void
+solipa_log_handler (const gchar *log_domain,
+ GLogLevelFlags log_level,
+ const gchar *message,
+ gpointer user_data)
+{
+ g_printf ("solipa_log: (%d) %s - %s\n", log_level, log_domain, message);
+}
--- /dev/null
+/*
+ * Copyright (C) 2014 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_LOG_H__
+#define __SOLIPA_LOG_H__
+
+#include <glib.h>
+#include <glib-object.h>
+
+#include "solipa.h"
+
+
+G_BEGIN_DECLS
+
+
+#define TYPE_SOLIPA_LOG (solipa_log_get_type ())
+#define SOLIPA_LOG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_SOLIPA_LOG, SolipaLog))
+#define SOLIPA_LOG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_SOLIPA_LOG, SolipaLogClass))
+#define IS_SOLIPA_LOG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_SOLIPA_LOG))
+#define IS_SOLIPA_LOG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_SOLIPA_LOG))
+#define SOLIPA_LOG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_SOLIPA_LOG, SolipaLogClass))
+
+typedef struct _SolipaLog SolipaLog;
+typedef struct _SolipaLogClass SolipaLogClass;
+
+struct _SolipaLog
+ {
+ GObject parent;
+ };
+
+struct _SolipaLogClass
+ {
+ GObjectClass parent_class;
+ };
+
+GType solipa_log_get_type (void) G_GNUC_CONST;
+
+
+SolipaLog *solipa_log_new (Solipa *solipa, const gchar *app_name);
+
+void solipa_log_add_logdomain (SolipaLog *solipalog, const gchar *log_domain);
+void solipa_log_add_logdomains (SolipaLog *solipalog, ...);
+
+
+G_END_DECLS
+
+
+#endif /* __SOLIPA_LOG_H__ */
ooo_LDADD = $(top_builddir)/src/libsolipaooo.la
noinst_PROGRAMS = allegato \
+ log \
mail \
mail_check_address \
mail_get_addresses_from_string \
--- /dev/null
+/*
+ * Copyright (C) 2014 Andrea Zagli <azagli@libero.it>
+ *
+ * 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 2 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, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#include <libgda/libgda.h>
+#include <libgda/sql-parser/gda-sql-parser.h>
+
+#include <solipa.h>
+#include <log.h>
+
+int
+main (int argc, char **argv)
+{
+ Solipa *solipa;
+ SolipaLog *solipalog;
+
+ GError *error;
+ GdaConnection *connection;
+ GdaSqlParser *parser;
+ GdaStatement *stmt;
+ GdaDataModel *dm;
+
+ gda_init ();
+
+ dm = NULL;
+
+ solipa = solipa_new ();
+
+ solipalog = solipa_log_new (solipa, "test_log");
+
+ solipa_log_add_logdomains (solipalog, "", "GLib-GObject", "Solipa", NULL);
+
+ error = NULL;
+ connection = gda_connection_open_from_string ("PostgreSQL",
+ "DB_NAME=pippo",
+ NULL,
+ GDA_CONNECTION_OPTIONS_READ_ONLY,
+ &error);
+
+ if (error != NULL)
+ {
+ g_warning ("%s", error->message != NULL ? error->message : "nessun dettaglio");
+ }
+
+ parser = gda_sql_parser_new ();
+ stmt = gda_sql_parser_parse_string (parser, "SELECT * FROM customers WHERE id=1000", NULL, NULL);
+ dm = gda_connection_statement_execute_select (connection, stmt, NULL, NULL);
+
+ gda_connection_close (connection);
+
+ g_object_unref (dm);
+ g_object_unref (stmt);
+ g_object_unref (parser);
+ g_object_unref (connection);
+
+ return 0;
+}