Aggiunta la classe per la gestione dei log.
authorAndrea Zagli <a.zagli@comune.scandicci.fi.it>
Thu, 21 Aug 2014 09:14:43 +0000 (11:14 +0200)
committerAndrea Zagli <a.zagli@comune.scandicci.fi.it>
Thu, 21 Aug 2014 09:14:43 +0000 (11:14 +0200)
.cproject
src/Makefile.am
src/log.c [new file with mode: 0644]
src/log.h [new file with mode: 0644]
tests/Makefile.am
tests/log.c [new file with mode: 0644]

index 69cecb533bffb5b8777a33f9f395c1628742ac77..6b2f1fb5cb769b8738a2b167a6f55cca4ae1db8e 100644 (file)
--- a/.cproject
+++ b/.cproject
@@ -1,42 +1,41 @@
 <?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="&quot;C:\mingw\include&quot;"/>
-                                                                       <listOptionValue builtIn="false" value="&quot;C:\mingw\include\glib-2.0&quot;"/>
-                                                                       <listOptionValue builtIn="false" value="&quot;C:\mingw\include\gtk-2.0&quot;"/>
-                                                                       <listOptionValue builtIn="false" value="&quot;C:\mingw\include\libgda-4.0&quot;"/>
-                                                                       <listOptionValue builtIn="false" value="&quot;C:\mingw\include\libgda-4.0\libgda&quot;"/>
-                                                                       <listOptionValue builtIn="false" value="&quot;C:\mingw\include\gdk-pixbuf-2.0&quot;"/>
+                                                       <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="&quot;C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include&quot;"/>
+                                                                       <listOptionValue builtIn="false" value="&quot;C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\glib-2.0&quot;"/>
+                                                                       <listOptionValue builtIn="false" value="&quot;C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\gtk-3.0&quot;"/>
+                                                                       <listOptionValue builtIn="false" value="&quot;C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\evolution-data-server-2.32&quot;"/>
+                                                                       <listOptionValue builtIn="false" value="&quot;C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\libgda-5.0&quot;"/>
+                                                                       <listOptionValue builtIn="false" value="&quot;C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\libgda-5.0\libgda&quot;"/>
+                                                                       <listOptionValue builtIn="false" value="&quot;C:\Users\a.zagli\Documents\development_environment_gtk3\mingw\include\gdk-pixbuf-2.0&quot;"/>
                                                                </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>
index 1905935e9341741d73eb977ac8678ea34268c6c7..a178933fbe40dc8c8bde8d6b90468874f1a2af3f 100644 (file)
@@ -32,6 +32,7 @@ lib_LTLIBRARIES = libsolipa.la \
 libsolipa_la_SOURCES = solipa.c \
                        allegato.c \
                        camelsession.c \
+                       log.c \
                        mail.c \
                        mailui.c \
                        progresswindow.c \
@@ -43,6 +44,7 @@ libsolipa_include_HEADERS = libsolipa.h \
                             solipa.h \
                             allegato.h \
                             camelsession.h \
+                            log.h \
                             mail.h \
                             mailui.h \
                             progresswindow.h \
diff --git a/src/log.c b/src/log.c
new file mode 100644 (file)
index 0000000..578d3f7
--- /dev/null
+++ b/src/log.c
@@ -0,0 +1,186 @@
+/*
+ * 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);
+}
diff --git a/src/log.h b/src/log.h
new file mode 100644 (file)
index 0000000..2d793a7
--- /dev/null
+++ b/src/log.h
@@ -0,0 +1,63 @@
+/*
+ * 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__ */
index 66e5bbc3e397beb97bd71fd985fd04bb1c56fc96..7fa5182072ae98c040f0e03d58430007e0129d8b 100644 (file)
@@ -14,6 +14,7 @@ LDADD = $(top_builddir)/src/libsolipa.la
 ooo_LDADD = $(top_builddir)/src/libsolipaooo.la
 
 noinst_PROGRAMS = allegato \
+                  log \
                   mail \
                   mail_check_address \
                   mail_get_addresses_from_string \
diff --git a/tests/log.c b/tests/log.c
new file mode 100644 (file)
index 0000000..e1f86dc
--- /dev/null
@@ -0,0 +1,71 @@
+/*
+ * 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;
+}