]> saetta.ns0.it Git - zakauthe/plugins/db/commitdiff
Inizio migrazione a libgdaex e senza la dipendenza di libconfi.
authorAndrea Zagli <azagli@libero.it>
Fri, 12 Feb 2010 11:56:04 +0000 (12:56 +0100)
committerAndrea Zagli <azagli@libero.it>
Fri, 12 Feb 2010 11:56:04 +0000 (12:56 +0100)
.gitignore [new file with mode: 0644]
autogen.sh
config.h.in
configure.ac
data/libautedb/glade/autedb.glade
src/Makefile.am
src/aute_db.c

diff --git a/.gitignore b/.gitignore
new file mode 100644 (file)
index 0000000..08f49ef
--- /dev/null
@@ -0,0 +1,25 @@
+COPYING
+INSTALL
+Makefile
+Makefile.in
+aclocal.m4
+autom4te.cache/
+config.guess
+config.log
+config.status
+config.sub
+configure
+depcomp
+version.xml
+gtk-doc.make
+install-sh
+libaute.pc
+libtool
+ltmain.sh
+missing
+.deps
+.libs
+*.lo
+*.o
+*.la
+*~
index c8462f773314dc3ed33974ecd4b4a2545454f505..2b9d0ee3f0b2e96f53db8db8bdcb7e037ec40846 100755 (executable)
@@ -1,98 +1,23 @@
-#!/bin/sh
+#!/bin/bash
 # Run this to generate all the initial makefiles, etc.
 
 srcdir=`dirname $0`
 test -z "$srcdir" && srcdir=.
 
-ORIGDIR=`pwd`
-cd $srcdir
-PROJECT=libautedb
-TEST_TYPE=-f
-FILE=configure.ac
+PKG_NAME="libaute-db"
 
-DIE=0
-
-have_libtool=false
-if libtoolize --version < /dev/null > /dev/null 2>&1 ; then
-       libtool_version=`libtoolize --version | sed 's/^[^0-9]*\([0-9.][0-9.]*\).*/\1/'`
-       case $libtool_version in
-           1.4*|1.5*)
-               have_libtool=true
-               ;;
-       esac
-fi
-if $have_libtool ; then : ; else
-       echo
-       echo "You must have libtool 1.4 installed to compile $PROJECT."
-       echo "Install the appropriate package for your distribution,"
-       echo "or get the source tarball at http://ftp.gnu.org/gnu/libtool/"
-       DIE=1
-fi
-
-(gtkdocize --version) < /dev/null > /dev/null 2>&1 || {
-       echo
-       echo "You must have gtk-doc installed to compile $PROJECT."
-       echo "Install the appropriate package for your distribution,"
-       echo "or get the source tarball at http://ftp.gnome.org/pub/GNOME/sources/gtk-doc/"
-       DIE=1
+(test -f $srcdir/configure.ac \
+  && test -d $srcdir/src \
+  && test -f $srcdir/src/aute_db.c) || {
+    echo -n "**Error**: Directory "\`$srcdir\'" does not look like the"
+    echo " top-level libaute directory"
+    exit 1
 }
 
-(autoconf --version) < /dev/null > /dev/null 2>&1 || {
-       echo
-       echo "You must have autoconf installed to compile $PROJECT."
-       echo "Install the appropriate package for your distribution,"
-       echo "or get the source tarball at http://ftp.gnu.org/gnu/autoconf/"
-       DIE=1
+which gnome-autogen.sh || {
+    echo "You need to install gnome-common from GNOME and make"
+    echo "sure the gnome-autogen.sh script is in your \$PATH."
+    exit 1
 }
 
-if automake --version < /dev/null > /dev/null 2>&1 ; then
-    AUTOMAKE=automake
-    ACLOCAL=aclocal
-else
-       echo
-       echo "You must have automake 1.7.x installed to compile $PROJECT."
-       echo "Install the appropriate package for your distribution,"
-       echo "or get the source tarball at http://ftp.gnu.org/gnu/automake/"
-       DIE=1
-fi
-
-if test "$DIE" -eq 1; then
-       exit 1
-fi
-
-test $TEST_TYPE $FILE || {
-       echo "You must run this script in the top-level $PROJECT directory"
-       exit 1
-}
-
-if test -z "$AUTOGEN_SUBDIR_MODE"; then
-        if test -z "$*"; then
-                echo "I am going to run ./configure with no arguments - if you wish "
-                echo "to pass any to it, please specify them on the $0 command line."
-        fi
-fi
-
-rm -rf autom4te.cache
-
-# README and INSTALL are required by automake, but may be deleted by clean
-# up rules. to get automake to work, simply touch these here, they will be
-# regenerated from their corresponding *.in files by ./configure anyway.
-touch README INSTALL
-
-$ACLOCAL || exit $?
-
-libtoolize --force || exit $?
-gtkdocize || exit $?
-
-autoheader || exit $?
-
-$AUTOMAKE --add-missing || exit $?
-autoconf || exit $?
-cd $ORIGDIR || exit $?
-
-if test -z "$AUTOGEN_SUBDIR_MODE"; then
-        $srcdir/configure --enable-maintainer-mode $AUTOGEN_CONFIGURE_ARGS "$@" || exit $?
-
-        echo 
-        echo "Now type 'make' to compile $PROJECT."
-fi
+USE_GNOME2_MACROS=1 . gnome-autogen.sh
index 0e1824b55d0da10aa5571e6d7bb5388a7acc96ba..95d491cad4c7f3c07ec3ab0b564e1d4489f6f228 100644 (file)
@@ -6,6 +6,9 @@
 /* Define to 1 if you have the <inttypes.h> header file. */
 #undef HAVE_INTTYPES_H
 
+/* libconfi is present */
+#undef HAVE_LIBCONFI
+
 /* Define to 1 if you have the <memory.h> header file. */
 #undef HAVE_MEMORY_H
 
 /* Define to 1 if you have the <unistd.h> header file. */
 #undef HAVE_UNISTD_H
 
+/* Define to the sub-directory in which libtool stores uninstalled libraries.
+   */
+#undef LT_OBJDIR
+
 /* Name of package */
 #undef PACKAGE
 
@@ -45,6 +52,9 @@
 /* Define to the one symbol short name of this package. */
 #undef PACKAGE_TARNAME
 
+/* Define to the home page for this package. */
+#undef PACKAGE_URL
+
 /* Define to the version of this package. */
 #undef PACKAGE_VERSION
 
index dddfc04621368dea520eba258baab7c884c124ed..ef11dcc1fe7663438d0e6341454cc0d6a152390a 100644 (file)
@@ -2,7 +2,7 @@
 # Process this file with autoconf to produce a configure script.
 
 AC_PREREQ(2.59)
-AC_INIT([libaute-db], [0.0.1], [azagli@libero.it])
+AC_INIT([libaute-db], [0.0.2], [azagli@libero.it])
 AC_CONFIG_SRCDIR([src/aute_db.c])
 AC_CONFIG_HEADER([config.h])
 
@@ -18,14 +18,19 @@ AC_PROG_CC
 AC_PROG_LIBTOOL
 
 # Checks for libraries.
-PKG_CHECK_MODULES(LIBAUTEDB, [gtk+-2.0 >= 2.8.0
-                              libglade-2.0 >= 2.6.0
-                              libgdaobj >= 0.0.2
-                              libaute >= 0.0.1])
+PKG_CHECK_MODULES(LIBAUTEDB, [gtk+-2.0 >= 2.16.0
+                              libgdaex >= 0.1.0
+                              libaute >= 0.0.2])
 
 AC_SUBST(LIBAUTEDB_CFLAGS)
 AC_SUBST(LIBAUTEDB_LIBS)
 
+PKG_CHECK_MODULES(LIBCONFI, [libconfi >= 0.0.2], AC_DEFINE(HAVE_LIBCONFI, [1], [libconfi is present]), have_libconfi=yes)
+
+AM_CONDITIONAL(HAVE_LIBCONFI, test x"$have_libconfi" = "xyes")
+AC_SUBST(LIBCONFI_CFLAGS)
+AC_SUBST(LIBCONFI_LIBS)
+
 AM_PATH_LIBGCRYPT(1.2.1, :, [AC_MSG_ERROR([libgcrypt >= 1.2.1 not found.])])
 
 AC_SUBST(LIBGCRYPT_CFLAGS)
index 1eb94978f993ec4639148cd92ebb3d9175444ccc..382a861e29a21fe33803fd4cd166f1dacba8675c 100644 (file)
-<?xml version="1.0" standalone="no"?> <!--*- mode: xml -*-->
-<!DOCTYPE glade-interface SYSTEM "http://glade.gnome.org/glade-2.0.dtd">
-
-<glade-interface>
-
-<widget class="GtkDialog" id="diag_main">
-  <property name="visible">True</property>
-  <property name="title" translatable="yes">Autenticazione</property>
-  <property name="type">GTK_WINDOW_TOPLEVEL</property>
-  <property name="window_position">GTK_WIN_POS_NONE</property>
-  <property name="modal">True</property>
-  <property name="resizable">True</property>
-  <property name="destroy_with_parent">False</property>
-  <property name="decorated">True</property>
-  <property name="skip_taskbar_hint">False</property>
-  <property name="skip_pager_hint">False</property>
-  <property name="type_hint">GDK_WINDOW_TYPE_HINT_DIALOG</property>
-  <property name="gravity">GDK_GRAVITY_NORTH_WEST</property>
-  <property name="focus_on_map">True</property>
-  <property name="urgency_hint">False</property>
-  <property name="has_separator">True</property>
-
-  <child internal-child="vbox">
-    <widget class="GtkVBox" id="dialog-vbox1">
-      <property name="visible">True</property>
-      <property name="homogeneous">False</property>
-      <property name="spacing">0</property>
-
-      <child internal-child="action_area">
-       <widget class="GtkHButtonBox" id="dialog-action_area1">
-         <property name="visible">True</property>
-         <property name="layout_style">GTK_BUTTONBOX_END</property>
-
-         <child>
-           <widget class="GtkButton" id="cancelbutton1">
-             <property name="visible">True</property>
-             <property name="can_default">True</property>
-             <property name="can_focus">True</property>
-             <property name="label">gtk-cancel</property>
-             <property name="use_stock">True</property>
-             <property name="relief">GTK_RELIEF_NORMAL</property>
-             <property name="focus_on_click">True</property>
-             <property name="response_id">-6</property>
-           </widget>
-         </child>
-
-         <child>
-           <widget class="GtkButton" id="okbutton1">
-             <property name="visible">True</property>
-             <property name="can_default">True</property>
-             <property name="has_default">True</property>
-             <property name="can_focus">True</property>
-             <property name="label">gtk-ok</property>
-             <property name="use_stock">True</property>
-             <property name="relief">GTK_RELIEF_NORMAL</property>
-             <property name="focus_on_click">True</property>
-             <property name="response_id">-5</property>
-           </widget>
-         </child>
-       </widget>
-       <packing>
-         <property name="padding">0</property>
-         <property name="expand">False</property>
-         <property name="fill">True</property>
-         <property name="pack_type">GTK_PACK_END</property>
-       </packing>
-      </child>
-
-      <child>
-       <widget class="GtkTable" id="table1">
-         <property name="border_width">5</property>
-         <property name="visible">True</property>
-         <property name="n_rows">3</property>
-         <property name="n_columns">2</property>
-         <property name="homogeneous">False</property>
-         <property name="row_spacing">3</property>
-         <property name="column_spacing">3</property>
-
-         <child>
-           <widget class="GtkLabel" id="label1">
-             <property name="visible">True</property>
-             <property name="label" translatable="yes">Utente</property>
-             <property name="use_underline">False</property>
-             <property name="use_markup">False</property>
-             <property name="justify">GTK_JUSTIFY_LEFT</property>
-             <property name="wrap">False</property>
-             <property name="selectable">False</property>
-             <property name="xalign">0</property>
-             <property name="yalign">0.5</property>
-             <property name="xpad">0</property>
-             <property name="ypad">0</property>
-             <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
-             <property name="width_chars">-1</property>
-             <property name="single_line_mode">False</property>
-             <property name="angle">0</property>
-           </widget>
-           <packing>
-             <property name="left_attach">0</property>
-             <property name="right_attach">1</property>
-             <property name="top_attach">0</property>
-             <property name="bottom_attach">1</property>
-             <property name="x_options">fill</property>
-             <property name="y_options"></property>
-           </packing>
-         </child>
-
-         <child>
-           <widget class="GtkLabel" id="label2">
-             <property name="visible">True</property>
-             <property name="label" translatable="yes">Password</property>
-             <property name="use_underline">False</property>
-             <property name="use_markup">False</property>
-             <property name="justify">GTK_JUSTIFY_LEFT</property>
-             <property name="wrap">False</property>
-             <property name="selectable">False</property>
-             <property name="xalign">0</property>
-             <property name="yalign">0.5</property>
-             <property name="xpad">0</property>
-             <property name="ypad">0</property>
-             <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
-             <property name="width_chars">-1</property>
-             <property name="single_line_mode">False</property>
-             <property name="angle">0</property>
-           </widget>
-           <packing>
-             <property name="left_attach">0</property>
-             <property name="right_attach">1</property>
-             <property name="top_attach">1</property>
-             <property name="bottom_attach">2</property>
-             <property name="x_options">fill</property>
-             <property name="y_options"></property>
-           </packing>
-         </child>
-
-         <child>
-           <widget class="GtkEntry" id="txt_utente">
-             <property name="visible">True</property>
-             <property name="can_focus">True</property>
-             <property name="editable">True</property>
-             <property name="visibility">True</property>
-             <property name="max_length">0</property>
-             <property name="text" translatable="yes"></property>
-             <property name="has_frame">True</property>
-             <property name="invisible_char">*</property>
-             <property name="activates_default">True</property>
-           </widget>
-           <packing>
-             <property name="left_attach">1</property>
-             <property name="right_attach">2</property>
-             <property name="top_attach">0</property>
-             <property name="bottom_attach">1</property>
-             <property name="y_options"></property>
-           </packing>
-         </child>
-
-         <child>
-           <widget class="GtkEntry" id="txt_password">
-             <property name="visible">True</property>
-             <property name="can_focus">True</property>
-             <property name="editable">True</property>
-             <property name="visibility">False</property>
-             <property name="max_length">0</property>
-             <property name="text" translatable="yes"></property>
-             <property name="has_frame">True</property>
-             <property name="invisible_char">*</property>
-             <property name="activates_default">True</property>
-           </widget>
-           <packing>
-             <property name="left_attach">1</property>
-             <property name="right_attach">2</property>
-             <property name="top_attach">1</property>
-             <property name="bottom_attach">2</property>
-             <property name="y_options"></property>
-           </packing>
-         </child>
-
-         <child>
-           <widget class="GtkExpander" id="exp_cambio">
-             <property name="visible">True</property>
-             <property name="can_focus">True</property>
-             <property name="expanded">False</property>
-             <property name="spacing">0</property>
-
-             <child>
-               <widget class="GtkTable" id="table2">
-                 <property name="border_width">5</property>
-                 <property name="visible">True</property>
-                 <property name="n_rows">2</property>
-                 <property name="n_columns">2</property>
-                 <property name="homogeneous">False</property>
-                 <property name="row_spacing">3</property>
-                 <property name="column_spacing">3</property>
-
-                 <child>
-                   <widget class="GtkLabel" id="label4">
-                     <property name="visible">True</property>
-                     <property name="label" translatable="yes">Nuova</property>
-                     <property name="use_underline">False</property>
-                     <property name="use_markup">False</property>
-                     <property name="justify">GTK_JUSTIFY_LEFT</property>
-                     <property name="wrap">False</property>
-                     <property name="selectable">False</property>
-                     <property name="xalign">0</property>
-                     <property name="yalign">0.5</property>
-                     <property name="xpad">0</property>
-                     <property name="ypad">0</property>
-                     <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
-                     <property name="width_chars">-1</property>
-                     <property name="single_line_mode">False</property>
-                     <property name="angle">0</property>
-                   </widget>
-                   <packing>
-                     <property name="left_attach">0</property>
-                     <property name="right_attach">1</property>
-                     <property name="top_attach">0</property>
-                     <property name="bottom_attach">1</property>
-                     <property name="x_options">fill</property>
-                     <property name="y_options"></property>
-                   </packing>
-                 </child>
-
-                 <child>
-                   <widget class="GtkLabel" id="label5">
-                     <property name="visible">True</property>
-                     <property name="label" translatable="yes">Conferma</property>
-                     <property name="use_underline">False</property>
-                     <property name="use_markup">False</property>
-                     <property name="justify">GTK_JUSTIFY_LEFT</property>
-                     <property name="wrap">False</property>
-                     <property name="selectable">False</property>
-                     <property name="xalign">0</property>
-                     <property name="yalign">0.5</property>
-                     <property name="xpad">0</property>
-                     <property name="ypad">0</property>
-                     <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
-                     <property name="width_chars">-1</property>
-                     <property name="single_line_mode">False</property>
-                     <property name="angle">0</property>
-                   </widget>
-                   <packing>
-                     <property name="left_attach">0</property>
-                     <property name="right_attach">1</property>
-                     <property name="top_attach">1</property>
-                     <property name="bottom_attach">2</property>
-                     <property name="x_options">fill</property>
-                     <property name="y_options"></property>
-                   </packing>
-                 </child>
-
-                 <child>
-                   <widget class="GtkEntry" id="txt_password_nuova">
-                     <property name="visible">True</property>
-                     <property name="can_focus">True</property>
-                     <property name="editable">True</property>
-                     <property name="visibility">False</property>
-                     <property name="max_length">0</property>
-                     <property name="text" translatable="yes"></property>
-                     <property name="has_frame">True</property>
-                     <property name="invisible_char">*</property>
-                     <property name="activates_default">True</property>
-                   </widget>
-                   <packing>
-                     <property name="left_attach">1</property>
-                     <property name="right_attach">2</property>
-                     <property name="top_attach">0</property>
-                     <property name="bottom_attach">1</property>
-                     <property name="y_options"></property>
-                   </packing>
-                 </child>
-
-                 <child>
-                   <widget class="GtkEntry" id="txt_password_conferma">
-                     <property name="visible">True</property>
-                     <property name="can_focus">True</property>
-                     <property name="editable">True</property>
-                     <property name="visibility">False</property>
-                     <property name="max_length">0</property>
-                     <property name="text" translatable="yes"></property>
-                     <property name="has_frame">True</property>
-                     <property name="invisible_char">*</property>
-                     <property name="activates_default">True</property>
-                   </widget>
-                   <packing>
-                     <property name="left_attach">1</property>
-                     <property name="right_attach">2</property>
-                     <property name="top_attach">1</property>
-                     <property name="bottom_attach">2</property>
-                     <property name="y_options"></property>
-                   </packing>
-                 </child>
-               </widget>
-             </child>
-
-             <child>
-               <widget class="GtkLabel" id="label3">
-                 <property name="visible">True</property>
-                 <property name="label" translatable="yes">_Cambia password</property>
-                 <property name="use_underline">True</property>
-                 <property name="use_markup">False</property>
-                 <property name="justify">GTK_JUSTIFY_LEFT</property>
-                 <property name="wrap">False</property>
-                 <property name="selectable">False</property>
-                 <property name="xalign">0.5</property>
-                 <property name="yalign">0.5</property>
-                 <property name="xpad">0</property>
-                 <property name="ypad">0</property>
-                 <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
-                 <property name="width_chars">-1</property>
-                 <property name="single_line_mode">False</property>
-                 <property name="angle">0</property>
-               </widget>
-               <packing>
-                 <property name="type">label_item</property>
-               </packing>
-             </child>
-           </widget>
-           <packing>
-             <property name="left_attach">0</property>
-             <property name="right_attach">2</property>
-             <property name="top_attach">2</property>
-             <property name="bottom_attach">3</property>
-             <property name="x_options">fill</property>
-           </packing>
-         </child>
-       </widget>
-       <packing>
-         <property name="padding">0</property>
-         <property name="expand">True</property>
-         <property name="fill">True</property>
-       </packing>
-      </child>
-    </widget>
-  </child>
-</widget>
-
-</glade-interface>
+<?xml version="1.0"?>
+<interface>
+  <!-- interface-requires gtk+ 2.6 -->
+  <!-- interface-naming-policy project-wide -->
+  <object class="GtkDialog" id="diag_main">
+    <property name="visible">True</property>
+    <property name="title" translatable="yes">Autenticazione</property>
+    <property name="modal">True</property>
+    <property name="type_hint">dialog</property>
+    <child internal-child="vbox">
+      <object class="GtkVBox" id="dialog-vbox1">
+        <property name="visible">True</property>
+        <child>
+          <object class="GtkTable" id="table1">
+            <property name="visible">True</property>
+            <property name="border_width">5</property>
+            <property name="n_rows">3</property>
+            <property name="n_columns">2</property>
+            <property name="column_spacing">3</property>
+            <property name="row_spacing">3</property>
+            <child>
+              <object class="GtkLabel" id="label1">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Utente</property>
+              </object>
+              <packing>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options"></property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkLabel" id="label2">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Password</property>
+              </object>
+              <packing>
+                <property name="top_attach">1</property>
+                <property name="bottom_attach">2</property>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options"></property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="txt_utente">
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="activates_default">True</property>
+              </object>
+              <packing>
+                <property name="left_attach">1</property>
+                <property name="right_attach">2</property>
+                <property name="y_options"></property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="txt_password">
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="visibility">False</property>
+                <property name="activates_default">True</property>
+              </object>
+              <packing>
+                <property name="left_attach">1</property>
+                <property name="right_attach">2</property>
+                <property name="top_attach">1</property>
+                <property name="bottom_attach">2</property>
+                <property name="y_options"></property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkExpander" id="exp_cambio">
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <child>
+                  <object class="GtkTable" id="table2">
+                    <property name="visible">True</property>
+                    <property name="border_width">5</property>
+                    <property name="n_rows">2</property>
+                    <property name="n_columns">2</property>
+                    <property name="column_spacing">3</property>
+                    <property name="row_spacing">3</property>
+                    <child>
+                      <object class="GtkLabel" id="label4">
+                        <property name="visible">True</property>
+                        <property name="xalign">0</property>
+                        <property name="label" translatable="yes">Nuova</property>
+                      </object>
+                      <packing>
+                        <property name="x_options">GTK_FILL</property>
+                        <property name="y_options"></property>
+                      </packing>
+                    </child>
+                    <child>
+                      <object class="GtkLabel" id="label5">
+                        <property name="visible">True</property>
+                        <property name="xalign">0</property>
+                        <property name="label" translatable="yes">Conferma</property>
+                      </object>
+                      <packing>
+                        <property name="top_attach">1</property>
+                        <property name="bottom_attach">2</property>
+                        <property name="x_options">GTK_FILL</property>
+                        <property name="y_options"></property>
+                      </packing>
+                    </child>
+                    <child>
+                      <object class="GtkEntry" id="txt_password_nuova">
+                        <property name="visible">True</property>
+                        <property name="can_focus">True</property>
+                        <property name="visibility">False</property>
+                        <property name="activates_default">True</property>
+                      </object>
+                      <packing>
+                        <property name="left_attach">1</property>
+                        <property name="right_attach">2</property>
+                        <property name="y_options"></property>
+                      </packing>
+                    </child>
+                    <child>
+                      <object class="GtkEntry" id="txt_password_conferma">
+                        <property name="visible">True</property>
+                        <property name="can_focus">True</property>
+                        <property name="visibility">False</property>
+                        <property name="activates_default">True</property>
+                      </object>
+                      <packing>
+                        <property name="left_attach">1</property>
+                        <property name="right_attach">2</property>
+                        <property name="top_attach">1</property>
+                        <property name="bottom_attach">2</property>
+                        <property name="y_options"></property>
+                      </packing>
+                    </child>
+                  </object>
+                </child>
+                <child type="label">
+                  <object class="GtkLabel" id="label3">
+                    <property name="visible">True</property>
+                    <property name="label" translatable="yes">_Cambia password</property>
+                    <property name="use_underline">True</property>
+                  </object>
+                </child>
+              </object>
+              <packing>
+                <property name="right_attach">2</property>
+                <property name="top_attach">2</property>
+                <property name="bottom_attach">3</property>
+                <property name="x_options">GTK_FILL</property>
+              </packing>
+            </child>
+          </object>
+          <packing>
+            <property name="position">2</property>
+          </packing>
+        </child>
+        <child internal-child="action_area">
+          <object class="GtkHButtonBox" id="dialog-action_area1">
+            <property name="visible">True</property>
+            <property name="layout_style">end</property>
+            <child>
+              <object class="GtkButton" id="cancelbutton1">
+                <property name="label">gtk-cancel</property>
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="can_default">True</property>
+                <property name="receives_default">False</property>
+                <property name="use_stock">True</property>
+              </object>
+              <packing>
+                <property name="expand">False</property>
+                <property name="fill">False</property>
+                <property name="position">0</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkButton" id="okbutton1">
+                <property name="label">gtk-ok</property>
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="can_default">True</property>
+                <property name="has_default">True</property>
+                <property name="receives_default">False</property>
+                <property name="use_stock">True</property>
+              </object>
+              <packing>
+                <property name="expand">False</property>
+                <property name="fill">False</property>
+                <property name="position">1</property>
+              </packing>
+            </child>
+          </object>
+          <packing>
+            <property name="expand">False</property>
+            <property name="pack_type">end</property>
+            <property name="position">0</property>
+          </packing>
+        </child>
+      </object>
+    </child>
+    <action-widgets>
+      <action-widget response="-6">cancelbutton1</action-widget>
+      <action-widget response="-5">okbutton1</action-widget>
+    </action-widgets>
+  </object>
+</interface>
index ea52079b46ed320667a11b017b14665fdb20eda4..e887b6889c285bf7da04eeec057395ae36dea341 100644 (file)
@@ -2,10 +2,12 @@ gladedir = $(datadir)/libaute-db/glade
 
 AM_CPPFLAGS = $(LIBAUTEDB_CFLAGS) \
               $(LIBGCRYPT_CFLAGS) \
+              $(LIBCONFI_CFLAGS) \
               -DGLADEDIR=\""$(gladedir)"\"
 
 LIBS = $(LIBAUTEDB_LIBS) \
-       $(LIBGCRYPT_LIBS)
+       $(LIBGCRYPT_LIBS) \
+       $(LIBCONFI_LIBS)
 
 libaute_pluginsdir = $(libdir)/libaute/plugins
 libaute_plugins_LTLIBRARIES = libaute-db.la
index 811b9f67d94ecee515370efa9e3e0a084aa08c49..31e0f68da2fc54ae61a074093a170e903f8e649e 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2005-2006 Andrea Zagli <azagli@libero.it>
+ * Copyright (C) 2005-2010 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
  */
 
 #include <gtk/gtk.h>
-#include <glade/glade.h>
 #include <gcrypt.h>
-#include <libconfi.h>
-#include <libgdaobj.h>
+#include <libgdaex.h>
 
-static GtkWidget *txt_utente,
-                 *txt_password,
-                 *exp_cambio,
-                 *txt_password_nuova,
-                 *txt_password_conferma;
+#ifdef HAVE_LIBCONFI
+       #include <libconfi.h>
+#endif
+
+static GtkWidget *txt_utente;
+static GtkWidget *txt_password;
+static GtkWidget *exp_cambio;
+static GtkWidget *txt_password_nuova;
+static GtkWidget *txt_password_conferma;
 
 /* PRIVATE */
+#ifdef HAVE_LIBCONFI
 static gboolean
-get_connection_parameters (Confi *confi, gchar **provider_id, gchar **cnc_string)
+get_connection_parameters_from_confi (Confi *confi, gchar **cnc_string)
 {
        gboolean ret = TRUE;
 
-       *provider_id = confi_path_get_value (confi, "aute/aute-db/db/provider_id");
        *cnc_string = confi_path_get_value (confi, "aute/aute-db/db/cnc_string");
 
-       if (*provider_id == NULL || *cnc_string == NULL
-           || strcmp (g_strstrip (*provider_id), "") == 0
+       if (*cnc_string == NULL
            || strcmp (g_strstrip (*cnc_string), "") == 0)
                {
                        ret = FALSE;
@@ -46,6 +47,7 @@ get_connection_parameters (Confi *confi, gchar **provider_id, gchar **cnc_string
 
        return ret;
 }
+#endif
 
 /**
  * cifra_password:
@@ -74,41 +76,72 @@ static gchar
 }
 
 static gchar
-*controllo (Confi *confi)
+*controllo (GSList *parameters)
 {
        gchar *sql;
        gchar *utente = "";
        gchar *password;
        gchar *password_nuova;
-       gchar *provider_id;
        gchar *cnc_string;
-       GdaO *gdao;
+       GdaEx *gdaex;
        GdaDataModel *dm;
 
        utente = g_strstrip (g_strdup (gtk_entry_get_text (GTK_ENTRY (txt_utente))));
        password = g_strstrip (g_strdup (gtk_entry_get_text (GTK_ENTRY (txt_password))));
 
+       cnc_string = NULL;
+
+#ifdef HAVE_LIBCONFI
+       /* the first and only parameters must be a Confi object */
        /* leggo i parametri di connessione dalla configurazione */
-       if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return NULL;
+       if (IS_CONFI (parameters->data))
+               {
+                       if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+                               {
+                                       cnc_string = NULL;
+                               }
+               }
+#endif
 
-       /* creo un oggetto GdaO */
-       gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
-       if (gdao == NULL) return NULL;
+       if (cnc_string == NULL)
+               {
+                       GSList *param;
+
+                       param = g_slist_next (parameters);
+                       if (param != NULL && param->data != NULL)
+                               {
+                                       cnc_string = g_strdup ((gchar *)param->data);
+                                       cnc_string = g_strstrip (cnc_string);
+                                       if (g_strcmp0 (cnc_string, "") == 0)
+                                               {
+                                                       cnc_string = NULL;
+                                               }
+                               }
+               }
+
+       if (cnc_string == NULL)
+               {
+                       return NULL;
+               }
+
+       /* creo un oggetto GdaEx */
+       gdaex = gdaex_new_from_string (cnc_string);
+       if (gdaex == NULL) return NULL;
 
        sql = g_strdup_printf ("SELECT codice FROM utenti "
                          "WHERE codice = '%s' AND "
                          "password = '%s' AND "
                          "status <> 'E'",
-                         gdao_strescape (utente, NULL),
-                         gdao_strescape (cifra_password (password), NULL));
-       dm = gdao_query (gdao, sql);
+                         gdaex_strescape (utente, NULL),
+                         gdaex_strescape (cifra_password (password), NULL));
+       dm = gdaex_query (gdaex, sql);
        if (dm == NULL || gda_data_model_get_n_rows (dm) <= 0)
                {
                        g_warning ("Utente o password non validi.");
                        return NULL;
                }
 
-       utente = g_strstrip (g_strdup (gdao_data_model_get_field_value_stringify_at (dm, 0, "codice")));
+       utente = g_strstrip (g_strdup (gdaex_data_model_get_field_value_stringify_at (dm, 0, "codice")));
 
        if (strcmp (utente, "") != 0
            && gtk_expander_get_expanded (GTK_EXPANDER (exp_cambio)))
@@ -130,9 +163,9 @@ static gchar
                                        sql = g_strdup_printf ("UPDATE utenti "
                                                         "SET password = '%s' "
                                                         "WHERE codice = '%s'",
-                                                        gdao_strescape (cifra_password (password_nuova), NULL),
-                                                        gdao_strescape (utente, NULL));
-                                       if (gdao_execute (gdao, sql) == -1)
+                                                        gdaex_strescape (cifra_password (password_nuova), NULL),
+                                                        gdaex_strescape (utente, NULL));
+                                       if (gdaex_execute (gdao, sql) == -1)
                                                {
                                                        /* TO DO */
                                                        g_warning ("Errore durante la modifica della password.");
@@ -146,18 +179,26 @@ static gchar
 
 /* PUBLIC */
 gchar
-*autentica (Confi *confi)
+*autentica (GSList *parameters)
 {
+       GError *error;
        gchar *ret = NULL;
 
-       GladeXML *gla_main = glade_xml_new (GLADEDIR "/autedb.glade", NULL, NULL);
-       GtkWidget *diag = glade_xml_get_widget (gla_main, "diag_main");
+       error = NULL;
+
+       GtkBuilder *gtkbuilder = gtk_builder_new ();
+       if (!gtk_builder_add_from_file (gtkbuilder, GLADEDIR "/autedb.glade", &error))
+               {
+                       return NULL;
+               }
+
+       GtkWidget *diag = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "diag_main"));
 
-       txt_utente = glade_xml_get_widget (gla_main, "txt_utente");
-       txt_password = glade_xml_get_widget (gla_main, "txt_password");
-       exp_cambio = glade_xml_get_widget (gla_main, "exp_cambio");
-       txt_password_nuova = glade_xml_get_widget (gla_main, "txt_password_nuova");
-       txt_password_conferma = glade_xml_get_widget (gla_main, "txt_password_conferma");
+       txt_utente = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_utente"));
+       txt_password = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_password"));
+       exp_cambio = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "exp_cambio"));
+       txt_password_nuova = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_password_nuova"));
+       txt_password_conferma = GTK_WIDGET (gtk_builder_get_object (gtkbuilder, "txt_password_conferma"));
 
        /* imposto di default l'utente corrente della sessione */
        gtk_entry_set_text (GTK_ENTRY (txt_utente), g_get_user_name ());
@@ -167,7 +208,7 @@ gchar
                {
                        case GTK_RESPONSE_OK:
                                /* controllo dell'utente e della password */
-                               ret = controllo (confi);
+                               ret = controllo (parameters);
                                break;
 
                        case GTK_RESPONSE_CANCEL:
@@ -179,34 +220,27 @@ gchar
                }
 
        gtk_widget_destroy (diag);
-       g_object_unref (gla_main);
+       g_object_unref (gtkbuilder);
 
        return ret;
 }
 
 /**
  * crea_utente:
- * @confi:
+ * @parameters:
  * @codice:
  * @password:
  */
 gboolean
-crea_utente (Confi *confi, const gchar *codice, const gchar *password)
+crea_utente (GSList *parameters, const gchar *codice, const gchar *password)
 {
        gchar *codice_;
        gchar *password_;
-       gchar *provider_id;
        gchar *cnc_string;
        gchar *sql;
-       GdaO *gdao;
+       GdaEx *gdaex;
        GdaDataModel *dm;
 
-       if (!IS_CONFI (confi))
-               {
-                       g_warning ("confi non è un oggetto Confi valido.");
-                       return FALSE;
-               }
-
        if (codice == FALSE || password == NULL)
                {
                        g_warning ("codice o password nulli.");
@@ -222,58 +256,83 @@ crea_utente (Confi *confi, const gchar *codice, const gchar *password)
                        return FALSE;
                }
 
+       cnc_string = NULL;
+
+#ifdef HAVE_LIBCONFI
+       /* the first and only parameters must be a Confi object */
        /* leggo i parametri di connessione dalla configurazione */
-       if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return FALSE;
+       if (IS_CONFI (parameters->data))
+               {
+                       if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+                               {
+                                       cnc_string = NULL;
+                               }
+               }
+#endif
+
+       if (cnc_string == NULL)
+               {
+                       GSList *param;
+
+                       param = g_slist_next (parameters);
+                       if (param != NULL && param->data != NULL)
+                               {
+                                       cnc_string = g_strdup ((gchar *)param->data);
+                                       cnc_string = g_strstrip (cnc_string);
+                                       if (g_strcmp0 (cnc_string, "") == 0)
+                                               {
+                                                       cnc_string = NULL;
+                                               }
+                               }
+               }
+
+       if (cnc_string == NULL)
+               {
+                       return FALSE;
+               }
 
        /* creo un oggetto GdaO */
-       gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
-       if (gdao == NULL) return FALSE;
+       gdaex = gdaex_new_from_string (cnc_string);
+       if (gdaex == NULL) return FALSE;
 
        /* controllo se esiste gia' */
-  sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
-                         gdao_strescape (codice_, NULL));
-       dm = gdao_query (gdao, sql);
+       sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
+                         gdaex_strescape (codice_, NULL));
+       dm = gdaex_query (gdaex, sql);
        if (dm != NULL && gda_data_model_get_n_rows (dm) > 0)
                {
                        /* aggiorno l'utente */
                        sql = g_strdup_printf ("UPDATE utenti SET password = '%s' WHERE codice = '%s'",
-                                              gdao_strescape (cifra_password (password_), NULL),
-                                              gdao_strescape (codice_, NULL));
+                                              gdaex_strescape (cifra_password (password_), NULL),
+                                              gdaex_strescape (codice_, NULL));
                }
        else
                {
                        /* creo l'utente */
                        sql = g_strdup_printf ("INSERT INTO utenti VALUES ('%s', '%s', '')",
-                                                                                                                gdao_strescape (codice_, NULL),
-                                                                                                                gdao_strescape (cifra_password (password_), NULL));
+                                              gdaex_strescape (codice_, NULL),
+                                              gdaex_strescape (cifra_password (password_), NULL));
                }
 
-       return (gdao_execute (gdao, sql) >= 0);
+       return (gdaex_execute (gdaex, sql) >= 0);
 }
 
 /**
  * modifice_utente:
- * @confi:
+ * @parameters:
  * @codice:
  * @password:
  */
 gboolean
-modifica_utente (Confi *confi, const gchar *codice, const gchar *password)
+modifica_utente (GSList *parameters, const gchar *codice, const gchar *password)
 {
        gchar *codice_;
        gchar *password_;
-       gchar *provider_id;
        gchar *cnc_string;
        gchar *sql;
-       GdaO *gdao;
+       GdaEx *gdaex;
        GdaDataModel *dm;
 
-       if (!IS_CONFI (confi))
-               {
-                       g_warning ("confi non è un oggetto Confi valido.");
-                       return FALSE;
-               }
-
        if (codice == FALSE || password == NULL)
                {
                        g_warning ("codice o password nulli.");
@@ -289,54 +348,77 @@ modifica_utente (Confi *confi, const gchar *codice, const gchar *password)
                        return FALSE;
                }
 
+#ifdef HAVE_LIBCONFI
+       /* the first and only parameters must be a Confi object */
        /* leggo i parametri di connessione dalla configurazione */
-       if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return FALSE;
+       if (IS_CONFI (parameters->data))
+               {
+                       if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+                               {
+                                       cnc_string = NULL;
+                               }
+               }
+#endif
 
-       /* creo un oggetto GdaO */
-       gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
-       if (gdao == NULL) return FALSE;
+       if (cnc_string == NULL)
+               {
+                       GSList *param;
+
+                       param = g_slist_next (parameters);
+                       if (param != NULL && param->data != NULL)
+                               {
+                                       cnc_string = g_strdup ((gchar *)param->data);
+                                       cnc_string = g_strstrip (cnc_string);
+                                       if (g_strcmp0 (cnc_string, "") == 0)
+                                               {
+                                                       cnc_string = NULL;
+                                               }
+                               }
+               }
+
+       if (cnc_string == NULL)
+               {
+                       return FALSE;
+               }
+
+       /* creo un oggetto GdaEx */
+       gdaex = gdaex_new_from_string (cnc_string);
+       if (gdaex == NULL) return FALSE;
 
        /* controllo se non esiste */
-  sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
-                         gdao_strescape (codice_, NULL));
-       dm = gdao_query (gdao, sql);
+       sql = g_strdup_printf ("SELECT codice FROM utenti WHERE codice = '%s'",
+                         gdaex_strescape (codice_, NULL));
+       dm = gdaex_query (gdaex, sql);
        if (dm == NULL || gda_data_model_get_n_rows (dm) <= 0)
                {
                        /* creo l'utente */
                        sql = g_strdup_printf ("INSERT INTO utenti VALUES ('%s', '%s', '')",
-                                                                                                                gdao_strescape (codice_, NULL),
-                                                                                                                gdao_strescape (cifra_password (password_), NULL));
+                                              gdaex_strescape (codice_, NULL),
+                                              gdaex_strescape (cifra_password (password_), NULL));
                }
        else
                {
                        /* aggiorno l'utente */
                        sql = g_strdup_printf ("UPDATE utenti SET password = '%s' WHERE codice = '%s'",
-                                                                                                                gdao_strescape (cifra_password (password_), NULL),
-                                                                                                                gdao_strescape (codice_, NULL));
+                                              gdaex_strescape (cifra_password (password_), NULL),
+                                              gdaex_strescape (codice_, NULL));
                }
 
-       return (gdao_execute (gdao, sql) >= 0);
+       return (gdaex_execute (gdaex, sql) >= 0);
 }
 
 /**
  * elimina_utente:
- * @confi:
+ * @parameters:
  * @codice:
  */
 gboolean
-elimina_utente (Confi *confi, const gchar *codice)
+elimina_utente (GSList *parameters, const gchar *codice)
 {
        gchar *codice_;
-       gchar *provider_id;
        gchar *cnc_string;
        gchar *sql;
-       GdaO *gdao;
-
-       if (!IS_CONFI (confi))
-               {
-                       g_warning ("confi non è un oggetto Confi valido.");
-                       return FALSE;
-               }
+       GdaEx *gdaex;
 
        if (codice == FALSE)
                {
@@ -352,16 +434,46 @@ elimina_utente (Confi *confi, const gchar *codice)
                        return FALSE;
                }
 
+#ifdef HAVE_LIBCONFI
+       /* the first and only parameters must be a Confi object */
        /* leggo i parametri di connessione dalla configurazione */
-       if (!get_connection_parameters (confi, &provider_id, &cnc_string)) return FALSE;
+       if (IS_CONFI (parameters->data))
+               {
+                       if (!get_connection_parameters_from_confi (CONFI (parameters->data), &cnc_string))
+                               {
+                                       cnc_string = NULL;
+                               }
+               }
+#endif
 
-       /* creo un oggetto GdaO */
-       gdao = gdao_new_from_string (NULL, provider_id, cnc_string);
-       if (gdao == NULL) return FALSE;
+       if (cnc_string == NULL)
+               {
+                       GSList *param;
+
+                       param = g_slist_next (parameters);
+                       if (param != NULL && param->data != NULL)
+                               {
+                                       cnc_string = g_strdup ((gchar *)param->data);
+                                       cnc_string = g_strstrip (cnc_string);
+                                       if (g_strcmp0 (cnc_string, "") == 0)
+                                               {
+                                                       cnc_string = NULL;
+                                               }
+                               }
+               }
+
+       if (cnc_string == NULL)
+               {
+                       return FALSE;
+               }
+
+       /* creo un oggetto GdaEx */
+       gdaex = gdaex_new_from_string (cnc_string);
+       if (gdaex == NULL) return FALSE;
 
        /* elimino _logicamente_ l'utente */
-  sql = g_strdup_printf ("UPDATE utenti SET status = 'E' WHERE codice = '%s'",
-                         gdao_strescape (codice_, NULL));
+       sql = g_strdup_printf ("UPDATE utenti SET status = 'E' WHERE codice = '%s'",
+                           gdaex_strescape (codice_, NULL));
 
-       return (gdao_execute (gdao, sql) >= 0);
+       return (gdaex_execute (gdaex, sql) >= 0);
 }