From: Andrea Zagli Date: Thu, 4 Nov 2010 10:33:18 +0000 (+0100) Subject: Importazione dei comuni da file istat. X-Git-Tag: gtk3~28 X-Git-Url: https://saetta.ns0.it/gitweb?a=commitdiff_plain;h=3d74ddbe9565a9fc2cbbb7fa6c6b1401a2be753f;p=solipa%2Fterritorio Importazione dei comuni da file istat. --- diff --git a/.project b/.project index 6b676e5..bb569c3 100644 --- a/.project +++ b/.project @@ -68,4 +68,33 @@ org.eclipse.cdt.managedbuilder.core.managedBuildNature org.eclipse.cdt.managedbuilder.core.ScannerConfigNature + + + 1288854571030 + + 30 + + org.eclipse.ui.ide.multiFilter + 1.0-name-matches-false-false-autom4te.cache + + + + 1288854571040 + + 22 + + org.eclipse.ui.ide.multiFilter + 1.0-name-matches-false-false-*.o + + + + 1288854571050 + + 22 + + org.eclipse.ui.ide.multiFilter + 1.0-name-matches-false-false-Makefile + + + diff --git a/data/territorio/form/comune.form b/data/territorio/form/comune.form index ffd57c6..58012ce 100644 --- a/data/territorio/form/comune.form +++ b/data/territorio/form/comune.form @@ -41,4 +41,8 @@ + + + + diff --git a/data/territorio/gui/territorio.gui b/data/territorio/gui/territorio.gui index be7fe6c..7c3acd5 100644 --- a/data/territorio/gui/territorio.gui +++ b/data/territorio/gui/territorio.gui @@ -140,6 +140,14 @@ + + + True + _Comuni da Istat + True + + + @@ -1548,7 +1556,7 @@ True - 5 + 6 2 5 5 @@ -1717,6 +1725,34 @@ GTK_FILL + + + True + 0 + Capoluogo + + + 5 + 6 + GTK_FILL + GTK_FILL + + + + + True + True + False + True + + + 1 + 2 + 5 + 6 + GTK_FILL + + 0 diff --git a/docs/territorio.sql b/docs/territorio.sql index 8eacb3d..f3b019f 100644 --- a/docs/territorio.sql +++ b/docs/territorio.sql @@ -2,24 +2,9 @@ -- PostgreSQL database dump -- --- Started on 2010-08-25 10:29:20 - -SET statement_timeout = 0; -SET client_encoding = 'UTF8'; -SET standard_conforming_strings = off; -SET check_function_bodies = false; -SET client_min_messages = warning; -SET escape_string_warning = off; - --- --- TOC entry 1827 (class 1262 OID 59420) --- Name: territorio; Type: DATABASE; Schema: -; Owner: - --- - -CREATE DATABASE territorio WITH TEMPLATE = template0 ENCODING = 'UTF8' LC_COLLATE = 'Italian, Italy' LC_CTYPE = 'Italian, Italy'; - - -\connect territorio +-- Dumped from database version 8.4.4 +-- Dumped by pg_dump version 9.0.1 +-- Started on 2010-11-04 08:19:54 SET statement_timeout = 0; SET client_encoding = 'UTF8'; @@ -33,19 +18,17 @@ SET escape_string_warning = off; -- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: - -- -CREATE PROCEDURAL LANGUAGE plpgsql; +CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; SET search_path = public, pg_catalog; -SET default_tablespace = ''; - SET default_with_oids = false; -- --- TOC entry 1508 (class 1259 OID 59503) --- Dependencies: 1802 1803 3 --- Name: aggregazioni_territoriali; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- TOC entry 1507 (class 1259 OID 59503) +-- Dependencies: 1798 1799 3 +-- Name: aggregazioni_territoriali; Type: TABLE; Schema: public; Owner: - -- CREATE TABLE aggregazioni_territoriali ( @@ -57,9 +40,9 @@ CREATE TABLE aggregazioni_territoriali ( -- --- TOC entry 1506 (class 1259 OID 59481) --- Dependencies: 1796 1797 1798 1799 3 --- Name: comuni; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- TOC entry 1510 (class 1259 OID 61495) +-- Dependencies: 1807 1808 1809 1810 1811 3 +-- Name: comuni; Type: TABLE; Schema: public; Owner: - -- CREATE TABLE comuni ( @@ -67,15 +50,16 @@ CREATE TABLE comuni ( nome character varying(255) DEFAULT ''::character varying, cod_istat character varying(5) DEFAULT ''::character varying, cap character varying(5) DEFAULT ''::character varying, - status character varying(1) DEFAULT ''::character varying, - id_province integer + id_province integer, + capoluogo boolean DEFAULT false, + status character varying(1) DEFAULT ''::character varying ); -- --- TOC entry 1510 (class 1259 OID 59532) --- Dependencies: 1807 1808 1809 1810 3 --- Name: province; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- TOC entry 1509 (class 1259 OID 59532) +-- Dependencies: 1803 1804 1805 1806 3 +-- Name: province; Type: TABLE; Schema: public; Owner: - -- CREATE TABLE province ( @@ -91,7 +75,7 @@ CREATE TABLE province ( -- -- TOC entry 1505 (class 1259 OID 59459) -- Dependencies: 1793 1794 1795 3 --- Name: regioni; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- Name: regioni; Type: TABLE; Schema: public; Owner: - -- CREATE TABLE regioni ( @@ -105,7 +89,7 @@ CREATE TABLE regioni ( -- -- TOC entry 1504 (class 1259 OID 59446) -- Dependencies: 1788 1789 1790 1791 1792 3 --- Name: stati; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- Name: stati; Type: TABLE; Schema: public; Owner: - -- CREATE TABLE stati ( @@ -120,9 +104,9 @@ CREATE TABLE stati ( -- --- TOC entry 1507 (class 1259 OID 59496) --- Dependencies: 1800 1801 3 --- Name: tipi_aggregazione_territoriale; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- TOC entry 1506 (class 1259 OID 59496) +-- Dependencies: 1796 1797 3 +-- Name: tipi_aggregazione_territoriale; Type: TABLE; Schema: public; Owner: - -- CREATE TABLE tipi_aggregazione_territoriale ( @@ -133,9 +117,9 @@ CREATE TABLE tipi_aggregazione_territoriale ( -- --- TOC entry 1509 (class 1259 OID 59524) --- Dependencies: 1804 1805 1806 3 --- Name: vie; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- TOC entry 1508 (class 1259 OID 59524) +-- Dependencies: 1800 1801 1802 3 +-- Name: vie; Type: TABLE; Schema: public; Owner: - -- CREATE TABLE vie ( @@ -148,9 +132,9 @@ CREATE TABLE vie ( -- --- TOC entry 1820 (class 2606 OID 59509) --- Dependencies: 1508 1508 --- Name: aggregazioni_territoriali_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- TOC entry 1819 (class 2606 OID 59509) +-- Dependencies: 1507 1507 +-- Name: aggregazioni_territoriali_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- ALTER TABLE ONLY aggregazioni_territoriali @@ -158,9 +142,9 @@ ALTER TABLE ONLY aggregazioni_territoriali -- --- TOC entry 1816 (class 2606 OID 59489) --- Dependencies: 1506 1506 --- Name: comuni_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- TOC entry 1825 (class 2606 OID 61504) +-- Dependencies: 1510 1510 +-- Name: comuni_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- ALTER TABLE ONLY comuni @@ -168,9 +152,9 @@ ALTER TABLE ONLY comuni -- --- TOC entry 1824 (class 2606 OID 59540) --- Dependencies: 1510 1510 --- Name: province_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- TOC entry 1823 (class 2606 OID 59540) +-- Dependencies: 1509 1509 +-- Name: province_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- ALTER TABLE ONLY province @@ -178,9 +162,9 @@ ALTER TABLE ONLY province -- --- TOC entry 1814 (class 2606 OID 59466) +-- TOC entry 1815 (class 2606 OID 59466) -- Dependencies: 1505 1505 --- Name: regioni_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- Name: regioni_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- ALTER TABLE ONLY regioni @@ -188,9 +172,9 @@ ALTER TABLE ONLY regioni -- --- TOC entry 1812 (class 2606 OID 59458) +-- TOC entry 1813 (class 2606 OID 59458) -- Dependencies: 1504 1504 --- Name: stati_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- Name: stati_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- ALTER TABLE ONLY stati @@ -198,9 +182,9 @@ ALTER TABLE ONLY stati -- --- TOC entry 1818 (class 2606 OID 59502) --- Dependencies: 1507 1507 --- Name: tipi_aggregazioni_territoriali_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- TOC entry 1817 (class 2606 OID 59502) +-- Dependencies: 1506 1506 +-- Name: tipi_aggregazioni_territoriali_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- ALTER TABLE ONLY tipi_aggregazione_territoriale @@ -208,28 +192,16 @@ ALTER TABLE ONLY tipi_aggregazione_territoriale -- --- TOC entry 1822 (class 2606 OID 59531) --- Dependencies: 1509 1509 --- Name: vie_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- TOC entry 1821 (class 2606 OID 59531) +-- Dependencies: 1508 1508 +-- Name: vie_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- ALTER TABLE ONLY vie ADD CONSTRAINT vie_pkey PRIMARY KEY (id); --- --- TOC entry 1829 (class 0 OID 0) --- Dependencies: 3 --- Name: public; Type: ACL; Schema: -; Owner: - --- - -REVOKE ALL ON SCHEMA public FROM PUBLIC; -REVOKE ALL ON SCHEMA public FROM postgres; -GRANT ALL ON SCHEMA public TO postgres; -GRANT ALL ON SCHEMA public TO PUBLIC; - - --- Completed on 2010-08-25 10:29:20 +-- Completed on 2010-11-04 08:19:54 -- -- PostgreSQL database dump complete diff --git a/src/Makefile.am b/src/Makefile.am index 4531b14..a3abdf6 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -20,6 +20,8 @@ territorio_SOURCES = \ comune.h \ comuni.c \ comuni.h \ + importacomuniistat.c \ + importacomuniistat.h \ importaregioniprovinceistat.c \ importaregioniprovinceistat.h \ main.c \ diff --git a/src/importacomuniistat.c b/src/importacomuniistat.c new file mode 100644 index 0000000..32572ba --- /dev/null +++ b/src/importacomuniistat.c @@ -0,0 +1,293 @@ +/* + * Copyright (C) 2010 Andrea Zagli + * + * 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 + * + */ + +#include "importacomuniistat.h" + +static void territorio_importa_comuniistat_class_init (TerritorioImportaComuniIstatClass *klass); +static void territorio_importa_comuniistat_init (TerritorioImportaComuniIstat *territorio_importa_comuniistat); + +static void territorio_importa_comuniistat_set_property (GObject *object, + guint property_id, + const GValue *value, + GParamSpec *pspec); +static void territorio_importa_comuniistat_get_property (GObject *object, + guint property_id, + GValue *value, + GParamSpec *pspec); + +#define TERRITORIO_IMPORTA_COMUNIISTAT_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_TERRITORIO_IMPORTA_COMUNIISTAT, TerritorioImportaComuniIstatPrivate)) + +typedef struct _TerritorioImportaComuniIstatPrivate TerritorioImportaComuniIstatPrivate; +struct _TerritorioImportaComuniIstatPrivate + { + TerritorioCommons *commons; + }; + +G_DEFINE_TYPE (TerritorioImportaComuniIstat, territorio_importa_comuniistat, G_TYPE_OBJECT) + +static void +territorio_importa_comuniistat_class_init (TerritorioImportaComuniIstatClass *klass) +{ + GObjectClass *object_class = G_OBJECT_CLASS (klass); + + g_type_class_add_private (object_class, sizeof (TerritorioImportaComuniIstatPrivate)); + + object_class->set_property = territorio_importa_comuniistat_set_property; + object_class->get_property = territorio_importa_comuniistat_get_property; +} + +static void +territorio_importa_comuniistat_init (TerritorioImportaComuniIstat *territorio_importa_comuniistat) +{ + TerritorioImportaComuniIstatPrivate *priv = TERRITORIO_IMPORTA_COMUNIISTAT_GET_PRIVATE (territorio_importa_comuniistat); +} + +/** + * territorio_importa_comuniistat_new: + * @commons: + * + * Returns: the newly created #TerritorioImportaComuniIstat object. + */ +TerritorioImportaComuniIstat +*territorio_importa_comuniistat_new (TerritorioCommons *commons) +{ + GtkWidget *fchooser; + + TerritorioImportaComuniIstat *a = TERRITORIO_IMPORTA_COMUNIISTAT (g_object_new (territorio_importa_comuniistat_get_type (), NULL)); + + TerritorioImportaComuniIstatPrivate *priv = TERRITORIO_IMPORTA_COMUNIISTAT_GET_PRIVATE (a); + + priv->commons = commons; + + GtkWindow *w_main = GTK_WINDOW (gtk_builder_get_object (priv->commons->gtkbuilder, "w_main")); + + fchooser = gtk_file_chooser_dialog_new ("Scegli il file istat con i comuni", + w_main, + GTK_FILE_CHOOSER_ACTION_OPEN, + GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, + GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT, + NULL); + if (gtk_dialog_run (GTK_DIALOG (fchooser)) == GTK_RESPONSE_ACCEPT) + { + char *filename; + GdaDataModel *dm; + GError *error; + GSList *errors; + + GtkWidget *dialog; + + gint row; + gint rows; + + gchar *sql; + + GdaDataModel *dm_province; + guint id_province; + + GdaDataModel *dm_comuni; + guint id_comuni; + + filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (fchooser)); + gtk_widget_destroy (fchooser); + g_message (filename); + + GdaSet *plist = gda_set_new_inline (23, + "SEPARATOR", G_TYPE_STRING, ";", + "ESCAPE_CHAR", G_TYPE_STRING, "", + "G_TYPE_0", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_1", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_2", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_3", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_4", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_5", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_6", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_7", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_8", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_9", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_10", G_TYPE_GTYPE, G_TYPE_INT, + "G_TYPE_11", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_12", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_13", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_14", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_15", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_16", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_17", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_18", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_19", G_TYPE_GTYPE, G_TYPE_STRING, + "G_TYPE_20", G_TYPE_GTYPE, G_TYPE_STRING); + dm = gda_data_model_import_new_file (filename, TRUE, plist); + if (dm == NULL) + { + dialog = gtk_message_dialog_new (w_main, + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_WARNING, + GTK_BUTTONS_OK, + "Errore durante l'importazione del file: %s.", filename); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + return NULL; + } + + errors = gda_data_model_import_get_errors (GDA_DATA_MODEL_IMPORT (dm)); + if (errors != NULL) + { + while (errors != NULL) + { + error = (GError *)errors->data; + g_warning (error->message != NULL ? error->message : ""); + errors = g_slist_next (errors); + } + + dialog = gtk_message_dialog_new (w_main, + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_WARNING, + GTK_BUTTONS_OK, + "Errore durante l'importazione del file."); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + return NULL; + } + + rows = gda_data_model_get_n_rows (dm); + g_message ("Numero di record: %d.", rows); + if (rows < 1) + { + dialog = gtk_message_dialog_new (w_main, + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_WARNING, + GTK_BUTTONS_OK, + "Nessuna informazione da importare nel file: %s.", filename); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + return NULL; + } + + /* TODO + * segnarsi i record aggiornati, perché alla fine del ciclo quelli + * non aggiornati vanni segnati eliminati + */ + + for (row = 0; row < rows; row++) + { + sql = g_strdup_printf ("SELECT p.id" + " FROM province AS p INNER JOIN regioni AS r ON p.id_regioni = r.id" + " WHERE r.cod_istat = '%s' AND p.cod_istat = '%s'", + gdaex_data_model_get_value_stringify_at (dm, row, 0), + gdaex_data_model_get_value_stringify_at (dm, row, 1)); + dm_province = gdaex_query (priv->commons->gdaex, sql); + if (dm_province != NULL && gda_data_model_get_n_rows (dm_province) > 0) + { + id_province = gdaex_data_model_get_value_integer_at (dm_province, 0, 0); + g_object_unref (dm_province); + } + else + { + g_object_unref (dm_province); + g_warning ("Provincia (%s - %s) non trovata.", + gdaex_data_model_get_value_stringify_at (dm, row, 0), + gdaex_data_model_get_value_stringify_at (dm, row, 1)); + continue; + } + + sql = g_strdup_printf ("SELECT id FROM comuni WHERE id_province = %d AND cod_istat = '%s'", + id_province, + g_strstrip (gdaex_data_model_get_value_stringify_at (dm, row, 2))); + dm_comuni = gdaex_query (priv->commons->gdaex, sql); + if (dm_comuni == NULL || gda_data_model_get_n_rows (dm_comuni) == 0) + { + id_comuni = 0; + sql = g_strdup_printf ("SELECT COALESCE (MAX (id), 0) FROM comuni"); + dm_comuni = gdaex_query (priv->commons->gdaex, sql); + if (dm_comuni != NULL && gda_data_model_get_n_rows (dm_comuni) == 1) + { + id_comuni = gdaex_data_model_get_value_integer_at (dm_comuni, 0, 0); + } + id_comuni++; + + sql = g_strdup_printf ("INSERT INTO comuni (id, nome, cod_istat, cap, id_province, capoluogo)" + " VALUES (%d, '%s', '%s', '%s', %d, '%d')", + id_comuni, + gdaex_strescape (gdaex_data_model_get_value_stringify_at (dm, row, 8), NULL), + gdaex_data_model_get_value_stringify_at (dm, row, 2), + "", + id_province, + gdaex_data_model_get_value_integer_at (dm, 0, 10)); + } + else + { + id_comuni = gdaex_data_model_get_value_integer_at (dm_comuni, 0, 0); + sql = g_strdup_printf ("UPDATE comuni SET nome = '%s'," + " capoluogo = '%d'" + " WHERE id = %d", + gdaex_strescape (gdaex_data_model_get_value_stringify_at (dm, row, 8), NULL), + gdaex_data_model_get_value_integer_at (dm, row, 10), + id_comuni); + } + if (gdaex_execute (priv->commons->gdaex, sql) < 1) + { + g_warning ("Si è verificato un errore nell'importazione del comune: %s", + gdaex_data_model_get_value_stringify_at (dm, row, 8)); + return NULL; + } + } + + g_object_unref (dm); + g_free (filename); + } + else + { + gtk_widget_destroy (fchooser); + } + g_message ("Fine import."); + + return a; +} + +/* PRIVATE */ +static void +territorio_importa_comuniistat_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec) +{ + TerritorioImportaComuniIstat *territorio_importa_comuniistat = TERRITORIO_IMPORTA_COMUNIISTAT (object); + + TerritorioImportaComuniIstatPrivate *priv = TERRITORIO_IMPORTA_COMUNIISTAT_GET_PRIVATE (territorio_importa_comuniistat); + + switch (property_id) + { + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + break; + } +} + +static void +territorio_importa_comuniistat_get_property (GObject *object, guint property_id, GValue *value, GParamSpec *pspec) +{ + TerritorioImportaComuniIstat *territorio_importa_comuniistat = TERRITORIO_IMPORTA_COMUNIISTAT (object); + + TerritorioImportaComuniIstatPrivate *priv = TERRITORIO_IMPORTA_COMUNIISTAT_GET_PRIVATE (territorio_importa_comuniistat); + + switch (property_id) + { + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + break; + } +} + +/* CALLBACK */ diff --git a/src/importacomuniistat.h b/src/importacomuniistat.h new file mode 100644 index 0000000..c3a9da6 --- /dev/null +++ b/src/importacomuniistat.h @@ -0,0 +1,62 @@ +/* + * Copyright (C) 2010 Andrea Zagli + * + * 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 __TERRITORIO_IMPORTA_COMUNIISTAT_H__ +#define __TERRITORIO_IMPORTA_COMUNIISTAT_H__ + +#include +#include + +#include +#include + +#include "commons.h" + +G_BEGIN_DECLS + + +#define TYPE_TERRITORIO_IMPORTA_COMUNIISTAT (territorio_importa_comuniistat_get_type ()) +#define TERRITORIO_IMPORTA_COMUNIISTAT(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_TERRITORIO_IMPORTA_COMUNIISTAT, TerritorioImportaComuniIstat)) +#define TERRITORIO_IMPORTA_COMUNIISTAT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_TERRITORIO_IMPORTA_COMUNIISTAT, TerritorioImportaComuniIstatClass)) +#define IS_TERRITORIO_IMPORTA_COMUNIISTAT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_TERRITORIO_IMPORTA_COMUNIISTAT)) +#define IS_TERRITORIO_IMPORTA_COMUNIISTAT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_TERRITORIO_IMPORTA_COMUNIISTAT)) +#define TERRITORIO_IMPORTA_COMUNIISTAT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_TERRITORIO_IMPORTA_COMUNIISTAT, TerritorioImportaComuniIstatClass)) + + +typedef struct _TerritorioImportaComuniIstat TerritorioImportaComuniIstat; +typedef struct _TerritorioImportaComuniIstatClass TerritorioImportaComuniIstatClass; + +struct _TerritorioImportaComuniIstat + { + GObject parent; + }; + +struct _TerritorioImportaComuniIstatClass + { + GObjectClass parent_class; + }; + +GType territorio_importa_comuniistat_get_type (void) G_GNUC_CONST; + +TerritorioImportaComuniIstat *territorio_importa_comuniistat_new (TerritorioCommons *commons); + + +G_END_DECLS + +#endif /* __TERRITORIO_IMPORTA_COMUNIISTAT_H__ */ diff --git a/src/main.c b/src/main.c index 819f22a..449a4aa 100644 --- a/src/main.c +++ b/src/main.c @@ -31,6 +31,7 @@ #include "aggregazioniterritoriali.h" #include "commons.h" #include "comuni.h" +#include "importacomuniistat.h" #include "importaregioniprovinceistat.h" #include "province.h" #include "regioni.h" @@ -159,6 +160,15 @@ on_mnu_utilita_importa_regioniprovinceistat_activate (GtkMenuItem *menuitem, g_object_unref (m); } +G_MODULE_EXPORT void +on_mnu_utilita_importa_comuniistat_activate (GtkMenuItem *menuitem, + gpointer user_data) +{ + TerritorioImportaComuniIstat *m = territorio_importa_comuniistat_new (commons); + + g_object_unref (m); +} + G_MODULE_EXPORT void on_mnu_help_about_activate (GtkMenuItem *menuitem, gpointer user_data)