From: Andrea Zagli Date: Fri, 14 Dec 2012 08:41:12 +0000 (+0100) Subject: Fix deleting wrong fields and tables on autofill. X-Git-Url: https://saetta.ns0.it/gitweb?a=commitdiff_plain;h=5a3d6ab49b5102a8303e4799724c1832eef6567e;p=zakaudit%2Fgui Fix deleting wrong fields and tables on autofill. --- diff --git a/.project b/.project index 81a24a1..8a94168 100644 --- a/.project +++ b/.project @@ -25,7 +25,7 @@ - 1355472247482 + 1355472683699 30 @@ -34,7 +34,7 @@ - 1355472247485 + 1355472683704 22 @@ -43,7 +43,7 @@ - 1355472247488 + 1355472683707 22 @@ -52,7 +52,7 @@ - 1355472247496 + 1355472683713 22 @@ -61,7 +61,7 @@ - 1355472247499 + 1355472683716 22 @@ -70,7 +70,7 @@ - 1355472247502 + 1355472683720 22 @@ -79,7 +79,7 @@ - 1355472247508 + 1355472683724 22 @@ -88,7 +88,7 @@ - 1355472247511 + 1355472683727 22 @@ -97,7 +97,7 @@ - 1355472247515 + 1355472683733 22 @@ -106,7 +106,7 @@ - 1355472247518 + 1355472683737 22 @@ -115,7 +115,7 @@ - 1355472247522 + 1355472683740 22 @@ -124,7 +124,7 @@ - 1355472247525 + 1355472683744 22 @@ -133,7 +133,7 @@ - 1355472247528 + 1355472683749 22 @@ -142,7 +142,7 @@ - 1355472247532 + 1355472683752 22 @@ -151,7 +151,7 @@ - 1355472247537 + 1355472683756 22 @@ -160,7 +160,7 @@ - 1355472247540 + 1355472683760 22 @@ -169,7 +169,7 @@ - 1355472247544 + 1355472683770 22 @@ -178,7 +178,7 @@ - 1355472247550 + 1355472683773 22 @@ -186,5 +186,14 @@ 1.0-name-matches-false-false-*.o + + 1355472683776 + + 22 + + org.eclipse.ui.ide.multiFilter + 1.0-name-matches-false-false-*.exe + + diff --git a/data/audit-gui/gui/audit-gui.gui b/data/audit-gui/gui/audit-gui.gui index f582081..ba5637e 100644 --- a/data/audit-gui/gui/audit-gui.gui +++ b/data/audit-gui/gui/audit-gui.gui @@ -1,58 +1,425 @@ - + + + False + 5 + normal + Audit GUI + 0.0.1 + Copyright © Andrea Zagli 2010-2012 + Andrea Zagli <azagli@libero.it> + + + True + False + 2 + + + True + False + end + + + False + True + end + 0 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + False + Datasource - Audit GUI + True + center-on-parent + True + + + True + False + 5 + 5 + + + True + False + 3 + 2 + 5 + 5 + + + True + False + 0 + ID + + + GTK_FILL + GTK_FILL + + + + + True + False + 0 + lbl_id + + + 1 + 2 + GTK_FILL + + + + + True + False + Name + + + 1 + 2 + GTK_FILL + GTK_FILL + + + + + True + True + 30 + ● + False + False + True + True + + + 1 + 2 + 1 + 2 + GTK_FILL + + + + + True + False + 0 + + + + + + True + False + <b>Connection string</b> + True + + + + + 2 + 2 + 3 + + + + + True + True + 0 + + + + + True + False + 5 + end + + + gtk-cancel + True + True + True + True + + + False + False + 0 + + + + + gtk-save + True + True + True + True + + + False + False + 1 + + + + + False + True + 1 + + + + + + + False + Datasources - Audit GUI + True + center-on-parent + True + + + True + False + 5 + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + tstore_ds_tables_fields + False + 0 + + + Objects + + + + 0 + 1 + + + + + + 0 + 2 + + + + + + 3 + 4 + + + + + + 5 + 6 + + + + + + + + + True + True + 0 + + + + + True + False + 5 + end + + + New _Datasource + True + True + True + True + + + False + False + 0 + + + + + New _Table + True + True + True + True + + + False + False + 1 + + + + + gtk-edit + True + True + True + True + + + False + False + 2 + + + + + gtk-delete + True + True + True + True + + + False + False + 3 + + + + + False + True + 1 + + + + + + False Audit GUI center 600 400 - + True - vertical + False True + False True + False _File True True + False gtk-open True + False True True - + gtk-close True + False True True - + True + False gtk-quit True + False True True - + @@ -62,17 +429,20 @@ True + False _Utilities True True + False True + False Add _all tables and fields True - + @@ -82,18 +452,21 @@ True + False A_iuto True True + False gtk-about True + False True True - + @@ -103,64 +476,41 @@ False + True 0 True - vertical + False + True + True 1 True + False 2 False + True 2 - - 5 - normal - Audit GUI - 0.0.1 - Andrea Zagli 2010-2011 - Andrea Zagli <azagli@libero.it> - - - True - vertical - 2 - - - - - - True - end - - - False - end - 0 - - - - - + False Open Audit Datasource - Audit GUI True center-on-parent @@ -168,21 +518,24 @@ True + False 5 - vertical 5 True + False 5 True + False 0 Table name prefix False + True 0 @@ -190,164 +543,36 @@ True True - - - - 1 - - - - - False - 0 - - - - - - - - True - 5 - end - - - gtk-cancel - True - True - True - True + ● + False + False + True + True - False - False - 0 - - - - - gtk-open - True - True - True - True - - - False - False + True + True 1 - False - 2 - - - - - - - Datasource - Audit GUI - True - center-on-parent - True - - - True - 5 - vertical - 5 - - - True - 3 - 2 - 5 - 5 - - - True - 0 - ID - - - GTK_FILL - GTK_FILL - - - - - True - 0 - lbl_id - - - 1 - 2 - GTK_FILL - - - - - True - Name - - - 1 - 2 - GTK_FILL - GTK_FILL - - - - - True - True - 30 - - - - 1 - 2 - 1 - 2 - GTK_FILL - - - - - True - 0 - - - - - - True - <b>Connection string</b> - True - - - - - 2 - 2 - 3 - - - - + False + True 0 - + + + + True + False 5 end - + gtk-cancel True True @@ -361,8 +586,8 @@ - - gtk-save + + gtk-open True True True @@ -377,49 +602,55 @@ False - 1 + True + 2 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + False + Audit GUI + True + center-on-parent + 550 + True + False + + + True + False + 5 + 5 + + + True + False + label + + + False + True + 0 + + + + + True + False + + + False + True + 1 + + + + + False Table - Audit GUI True center-on-parent @@ -429,19 +660,24 @@ True + False 5 - vertical 5 True + False 3 2 5 5 + + + True + False 0 Table @@ -455,6 +691,7 @@ True + False 0 ID @@ -466,6 +703,7 @@ True + False 0 lbl_id @@ -477,6 +715,7 @@ + False lbl_id_datasources @@ -489,6 +728,7 @@ True + False lstore_tables @@ -505,18 +745,17 @@ GTK_FILL - - - False + True 0 True + False 5 @@ -558,13 +797,15 @@ + True + True 0 True - vertical + False 5 spread @@ -598,17 +839,21 @@ False + True 1 + True + True 1 True + False 5 end @@ -642,180 +887,11 @@ False + True 2 - - Datasources - Audit GUI - True - center-on-parent - True - - - True - 5 - vertical - 5 - - - True - True - automatic - automatic - etched-in - - - True - True - tstore_ds_tables_fields - False - 0 - - - Objects - - - - 0 - 1 - - - - - - 0 - 2 - - - - - - 3 - 4 - - - - - - 5 - 6 - - - - - - - - - 0 - - - - - True - 5 - end - - - New _Datasource - True - True - True - True - - - False - False - 0 - - - - - New _Table - True - True - True - True - - - False - False - 1 - - - - - gtk-edit - True - True - True - True - - - False - False - 2 - - - - - gtk-delete - True - True - True - True - - - False - False - 3 - - - - - False - 1 - - - - - - - Audit GUI - True - center-on-parent - 550 - True - False - - - True - 5 - vertical - 5 - - - True - label - - - False - 0 - - - - - True - - - False - 1 - - - - - diff --git a/src/datasources.c b/src/datasources.c index 831e5c3..3477784 100644 --- a/src/datasources.c +++ b/src/datasources.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2010-2011 Andrea Zagli + * Copyright (C) 2010-2012 Andrea Zagli * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public @@ -656,26 +656,34 @@ datasources_add_all_tables (Datasources *datasources) return; } - /* removing tables that aren't still in db */ - if (g_strcmp0 (ids_tables_saved, "") != 0) + /* removing fields that aren't still in db */ + if (g_strcmp0 (ids_fields_saved, "") != 0) { - ids_tables_saved[strlen (ids_tables_saved) - 1] = '\0'; - sql = g_strdup_printf ("DELETE FROM %stables WHERE id NOT IN (%s)", + ids_fields_saved[strlen (ids_fields_saved) - 1] = '\0'; + sql = g_strdup_printf ("DELETE FROM %sfields AS f" + " WHERE f.id NOT IN (%s)" + " AND EXISTS (SELECT id FROM %stables AS t" + " WHERE f.id_tables = t.id" + " AND t.id_datasources = %d)", + priv->commons->prefix, + ids_fields_saved, priv->commons->prefix, - ids_tables_saved); + id_ds); stmt = gda_sql_parser_parse_string (priv->commons->gdaparser, sql, NULL, NULL); g_free (sql); gda_connection_statement_execute_non_select (priv->commons->gdacon, stmt, NULL, NULL, &error); g_object_unref (stmt); } - /* removing fields that aren't still in db */ - if (g_strcmp0 (ids_fields_saved, "") != 0) + /* removing tables that aren't still in db */ + if (g_strcmp0 (ids_tables_saved, "") != 0) { - ids_fields_saved[strlen (ids_fields_saved) - 1] = '\0'; - sql = g_strdup_printf ("DELETE FROM %sfields WHERE id NOT IN (%s)", + ids_tables_saved[strlen (ids_tables_saved) - 1] = '\0'; + sql = g_strdup_printf ("DELETE FROM %stables WHERE id NOT IN (%s)" + " AND id_datasources = %d", priv->commons->prefix, - ids_fields_saved); + ids_tables_saved, + id_ds); stmt = gda_sql_parser_parse_string (priv->commons->gdaparser, sql, NULL, NULL); g_free (sql); gda_connection_statement_execute_non_select (priv->commons->gdacon, stmt, NULL, NULL, &error);