Mail archive
alpine-devel

[alpine-devel] [PATCH] testing/csync2: new aport

From: Pablo Castorino <pcastorino_at_mendoza-conicet.gob.ar>
Date: Fri, 12 Nov 2010 14:00:52 +0000

---
 testing/csync2/01-csync2-sqlite3.patch             |  518 ++++++++++++++++++++
 .../csync2/02-csync2-1.34-gnutls_pkgconfig.patch   |   24 +
 testing/csync2/APKBUILD                            |   44 ++
 3 files changed, 586 insertions(+), 0 deletions(-)
 create mode 100644 testing/csync2/01-csync2-sqlite3.patch
 create mode 100644 testing/csync2/02-csync2-1.34-gnutls_pkgconfig.patch
 create mode 100644 testing/csync2/APKBUILD
diff --git a/testing/csync2/01-csync2-sqlite3.patch b/testing/csync2/01-csync2-sqlite3.patch
new file mode 100644
index 0000000..364dcca
--- /dev/null
+++ b/testing/csync2/01-csync2-sqlite3.patch
_at_@ -0,0 +1,518 @@
+diff -ruN csync2-1.34.vanilla/action.c csync2-1.34/action.c
+--- csync2-1.34.vanilla/action.c	2007-07-24 23:04:18.000000000 +0200
++++ csync2-1.34/action.c	2008-06-12 15:36:47.000000000 +0200
+_at_@ -69,7 +69,7 @@
+ 			"SELECT filename from action WHERE command = '%s' "
+ 			"and logfile = '%s'", command, logfile)
+ 	{
+-		textlist_add(&tl, SQL_V[0], 0);
++		textlist_add(&tl, SQL_V(0), 0);
+ 	} SQL_END;
+ 
+ 	mark = strstr(command_clr, "%%");
+_at_@ -130,7 +130,7 @@
+ 	SQL_BEGIN("Checking for sceduled commands",
+ 			"SELECT command, logfile FROM action GROUP BY command, logfile")
+ 	{
+-		textlist_add2(&tl, SQL_V[0], SQL_V[1], 0);
++		textlist_add2(&tl, SQL_V(0), SQL_V(1), 0);
+ 	} SQL_END;
+ 
+ 	for (t = tl; t != 0; t = t->next)
+diff -ruN csync2-1.34.vanilla/check.c csync2-1.34/check.c
+--- csync2-1.34.vanilla/check.c	2007-07-24 23:04:18.000000000 +0200
++++ csync2-1.34/check.c	2008-06-12 15:36:47.000000000 +0200
+_at_@ -159,7 +159,7 @@
+ 			"SELECT filename from file where "
+ 			"filename = '%s' %s ORDER BY filename", url_encode(file), where_rec)
+ 	{
+-		const char *filename = url_decode(SQL_V[0]);
++		const char *filename = url_decode(SQL_V(0));
+ 		if ( lstat_strict(prefixsubst(filename), &st) != 0 || csync_check_pure(filename) )
+ 			textlist_add(&tl, filename, 0);
+ 	} SQL_END;
+_at_@ -213,8 +213,9 @@
+ 
+ 	if ( check_type>0 && lstat_strict(prefixsubst(file), &st) != 0 ) {
+ 		if ( ignnoent ) return 0;
++		perror("blup");
+ 		csync_fatal("This should not happen: "
+-				"Can't stat %s.\n", file);
++				"Can't stat %s %s %d %d %d.\n", prefixsubst(file), file,stat(file,&st),lstat_strict(file,&st),errno);
+ 	}
+ 
+ 	switch ( check_type )
+_at_@ -231,7 +232,7 @@
+ 			"filename = '%s'", url_encode(file))
+ 		{
+ 			if ( !csync_cmpchecktxt(checktxt,
+-						url_decode(SQL_V[0])) ) {
++						url_decode(SQL_V(0))) ) {
+ 				csync_debug(2, "File has changed: %s\n", file);
+ 				this_is_dirty = 1;
+ 			}
+diff -ruN csync2-1.34.vanilla/config.h.in csync2-1.34/config.h.in
+--- csync2-1.34.vanilla/config.h.in	2007-07-24 23:04:24.000000000 +0200
++++ csync2-1.34/config.h.in	2008-06-12 15:36:47.000000000 +0200
+_at_@ -6,8 +6,8 @@
+ /* Define to 1 if you have the `rsync' library (-lrsync). */
+ #undef HAVE_LIBRSYNC
+ 
+-/* Define to 1 if you have the `sqlite' library (-lsqlite). */
+-#undef HAVE_LIBSQLITE
++/* Define to 1 if you have the `sqlite3' library (-lsqlite3). */
++#undef HAVE_LIBSQLITE3
+ 
+ /* Name of package */
+ #undef PACKAGE
+diff -ruN csync2-1.34.vanilla/configure csync2-1.34/configure
+--- csync2-1.34.vanilla/configure	2007-07-24 23:04:25.000000000 +0200
++++ csync2-1.34/configure	2008-06-12 15:36:47.000000000 +0200
+_at_@ -3671,13 +3671,13 @@
+ 
+ else
+ 
+-{ echo "$as_me:$LINENO: checking for sqlite_exec in -lsqlite" >&5
+-echo $ECHO_N "checking for sqlite_exec in -lsqlite... $ECHO_C" >&6; }
+-if test "${ac_cv_lib_sqlite_sqlite_exec+set}" = set; then
++{ echo "$as_me:$LINENO: checking for sqlite3_exec in -lsqlite3" >&5
++echo $ECHO_N "checking for sqlite3_exec in -lsqlite3... $ECHO_C" >&6; }
++if test "${ac_cv_lib_sqlite3_sqlite3_exec+set}" = set; then
+   echo $ECHO_N "(cached) $ECHO_C" >&6
+ else
+   ac_check_lib_save_LIBS=$LIBS
+-LIBS="-lsqlite  $LIBS"
++LIBS="-lsqlite3  $LIBS"
+ cat >conftest.$ac_ext <<_ACEOF
+ /* confdefs.h.  */
+ _ACEOF
+_at_@ -3691,11 +3691,11 @@
+ #ifdef __cplusplus
+ extern "C"
+ #endif
+-char sqlite_exec ();
++char sqlite3_exec ();
+ int
+ main ()
+ {
+-return sqlite_exec ();
++return sqlite3_exec ();
+   ;
+   return 0;
+ }
+_at_@ -3718,30 +3718,30 @@
+ 	 test ! -s conftest.err
+        } && test -s conftest$ac_exeext &&
+        $as_test_x conftest$ac_exeext; then
+-  ac_cv_lib_sqlite_sqlite_exec=yes
++  ac_cv_lib_sqlite3_sqlite3_exec=yes
+ else
+   echo "$as_me: failed program was:" >&5
+ sed 's/^/| /' conftest.$ac_ext >&5
+ 
+-	ac_cv_lib_sqlite_sqlite_exec=no
++	ac_cv_lib_sqlite3_sqlite3_exec=no
+ fi
+ 
+ rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+       conftest$ac_exeext conftest.$ac_ext
+ LIBS=$ac_check_lib_save_LIBS
+ fi
+-{ echo "$as_me:$LINENO: result: $ac_cv_lib_sqlite_sqlite_exec" >&5
+-echo "${ECHO_T}$ac_cv_lib_sqlite_sqlite_exec" >&6; }
+-if test $ac_cv_lib_sqlite_sqlite_exec = yes; then
++{ echo "$as_me:$LINENO: result: $ac_cv_lib_sqlite3_sqlite3_exec" >&5
++echo "${ECHO_T}$ac_cv_lib_sqlite3_sqlite3_exec" >&6; }
++if test $ac_cv_lib_sqlite3_sqlite3_exec = yes; then
+   cat >>confdefs.h <<_ACEOF
+-#define HAVE_LIBSQLITE 1
++#define HAVE_LIBSQLITE3 1
+ _ACEOF
+ 
+-  LIBS="-lsqlite $LIBS"
++  LIBS="-lsqlite3 $LIBS"
+ 
+ else
+-  { { echo "$as_me:$LINENO: error: libsqlite is required" >&5
+-echo "$as_me: error: libsqlite is required" >&2;}
++  { { echo "$as_me:$LINENO: error: libsqlite3 is required" >&5
++echo "$as_me: error: libsqlite3 is required" >&2;}
+    { (exit 1); exit 1; }; }
+ fi
+ 
+diff -ruN csync2-1.34.vanilla/configure.ac csync2-1.34/configure.ac
+--- csync2-1.34.vanilla/configure.ac	2007-07-24 23:04:19.000000000 +0200
++++ csync2-1.34/configure.ac	2008-06-12 15:36:47.000000000 +0200
+_at_@ -47,7 +47,7 @@
+ 	AS_HELP_STRING([--with-libsqlite-source=source-tar-file],
+ 		[build this libsqlite and link statically against it (hack! hack!)]),
+ 	AC_SUBST([libsqlite_source_file], $withval),
+-	AC_CHECK_LIB([sqlite], [sqlite_exec], , [AC_MSG_ERROR(libsqlite is required)])
++	AC_CHECK_LIB([sqlite3], [sqlite3_exec], , [AC_MSG_ERROR(libsqlite3 is required)])
+ )
+ AM_CONDITIONAL([PRIVATE_LIBSQLITE], [test -n "$libsqlite_source_file"])
+ 
+diff -ruN csync2-1.34.vanilla/conn.c csync2-1.34/conn.c
+--- csync2-1.34.vanilla/conn.c	2007-07-24 23:04:18.000000000 +0200
++++ csync2-1.34/conn.c	2008-06-12 15:36:47.000000000 +0200
+_at_@ -181,7 +181,7 @@
+ 			"SELECT certdata FROM x509_cert WHERE peername = '%s'",
+ 			url_encode(peername))
+ 		{
+-			if (!strcmp(SQL_V[0], certdata))
++			if (!strcmp(SQL_V(0), certdata))
+ 				cert_is_ok = 1;
+ 			else
+ 				cert_is_ok = 0;
+diff -ruN csync2-1.34.vanilla/csync2.c csync2-1.34/csync2.c
+--- csync2-1.34.vanilla/csync2.c	2007-07-24 23:04:18.000000000 +0200
++++ csync2-1.34/csync2.c	2008-06-12 15:36:47.000000000 +0200
+_at_@ -582,8 +582,8 @@
+ 				SQL_BEGIN("Check all hints",
+ 					"SELECT filename, recursive FROM hint")
+ 				{
+-					textlist_add(&tl, url_decode(SQL_V[0]),
+-							atoi(SQL_V[1]));
++					textlist_add(&tl, url_decode(SQL_V(0)),
++							atoi(SQL_V(1)));
+ 				} SQL_END;
+ 
+ 				for (t = tl; t != 0; t = t->next) {
+_at_@ -659,7 +659,7 @@
+ 						"SELECT filename FROM file WHERE filename = '%s' %s",
+ 						url_encode(realname), where_rec)
+ 					{
+-						char *filename = strdup(url_encode(SQL_V[0]));
++						char *filename = strdup(url_encode(SQL_V(0)));
+ 						csync_mark(filename, 0, 0);
+ 						free(filename);
+ 					} SQL_END;
+_at_@ -695,7 +695,7 @@
+ 			SQL_BEGIN("DB Dump - Hint",
+ 				"SELECT recursive, filename FROM hint ORDER BY filename")
+ 			{
+-				printf("%s\t%s\n", SQL_V[0], url_decode(SQL_V[1]));
++				printf("%s\t%s\n", SQL_V(0), url_decode(SQL_V(1)));
+ 				retval = -1;
+ 			} SQL_END;
+ 			break;
+_at_@ -705,8 +705,8 @@
+ 			SQL_BEGIN("DB Dump - File",
+ 				"SELECT checktxt, filename FROM file ORDER BY filename")
+ 			{
+-				if (csync_find_next(0, url_decode(SQL_V[1]))) {
+-					printf("%s\t%s\n", url_decode(SQL_V[0]), url_decode(SQL_V[1]));
++				if (csync_find_next(0, url_decode(SQL_V(1)))) {
++					printf("%s\t%s\n", url_decode(SQL_V(0)), url_decode(SQL_V(1)));
+ 					retval = -1;
+ 				}
+ 			} SQL_END;
+_at_@ -717,8 +717,8 @@
+ 			SQL_BEGIN("DB Dump - File",
+ 				"SELECT checktxt, filename FROM file ORDER BY filename")
+ 			{
+-				if ( csync_match_file_host(url_decode(SQL_V[1]), argv[optind], argv[optind+1], 0) ) {
+-					printf("%s\t%s\n", url_decode(SQL_V[0]), url_decode(SQL_V[1]));
++				if ( csync_match_file_host(url_decode(SQL_V(1)), argv[optind], argv[optind+1], 0) ) {
++					printf("%s\t%s\n", url_decode(SQL_V(0)), url_decode(SQL_V(1)));
+ 					retval = -1;
+ 				}
+ 			} SQL_END;
+_at_@ -769,9 +769,9 @@
+ 			SQL_BEGIN("DB Dump - Dirty",
+ 				"SELECT force, myname, peername, filename FROM dirty ORDER BY filename")
+ 			{
+-				if (csync_find_next(0, url_decode(SQL_V[3]))) {
+-					printf("%s\t%s\t%s\t%s\n", atoi(SQL_V[0]) ?  "force" : "chary",
+-						url_decode(SQL_V[1]), url_decode(SQL_V[2]), url_decode(SQL_V[3]));
++				if (csync_find_next(0, url_decode(SQL_V(3)))) {
++					printf("%s\t%s\t%s\t%s\n", atoi(SQL_V(0)) ?  "force" : "chary",
++						url_decode(SQL_V(1)), url_decode(SQL_V(2)), url_decode(SQL_V(3)));
+ 					retval = -1;
+ 				}
+ 			} SQL_END;
+diff -ruN csync2-1.34.vanilla/csync2.h csync2-1.34/csync2.h
+--- csync2-1.34.vanilla/csync2.h	2007-07-24 23:04:18.000000000 +0200
++++ csync2-1.34/csync2.h	2008-06-12 15:36:47.000000000 +0200
+_at_@ -22,6 +22,7 @@
+ #define CSYNC2_H 1
+ 
+ #define _GNU_SOURCE
++#define _FILE_OFFSET_BITS 64
+ 
+ #include "config.h"
+ #include <stdio.h>
+_at_@ -91,19 +92,24 @@
+ extern int csync_db_next(void *vmx, const char *err,
+ 		int *pN, const char ***pazValue, const char ***pazColName);
+ extern void csync_db_fin(void *vmx, const char *err);
++extern void * csync_db_colblob(void *stmtx,int col);
++
+ 
+ #define SQL(e, s, ...) csync_db_sql(e, s, ##__VA_ARGS__)
+ 
++#define SQL_V(col) \
++	(csync_db_colblob(SQL_VM,col))
++
+ #define SQL_BEGIN(e, s, ...) \
+ { \
+ 	char *SQL_ERR = e; \
+ 	void *SQL_VM = csync_db_begin(SQL_ERR, s, ##__VA_ARGS__); \
+ 	int SQL_COUNT = 0; \
+ 	while (1) { \
+-		const char **SQL_V, **SQL_N; \
++		const char **notSQL_V, **notSQL_N; \
+ 		int SQL_C; \
+ 		if ( !csync_db_next(SQL_VM, SQL_ERR, \
+-					&SQL_C, &SQL_V, &SQL_N) ) break; \
++					&SQL_C, &notSQL_V, &notSQL_N) ) break; \
+ 		SQL_COUNT++;
+ 
+ #define SQL_FIN }{
+diff -ruN csync2-1.34.vanilla/daemon.c csync2-1.34/daemon.c
+--- csync2-1.34.vanilla/daemon.c	2007-07-24 23:04:18.000000000 +0200
++++ csync2-1.34/daemon.c	2008-06-12 15:36:47.000000000 +0200
+_at_@ -443,8 +443,8 @@
+ 					strcmp(tag[2], "-") ? url_encode(tag[2]) : "",
+ 					strcmp(tag[2], "-") ? "'" : "")
+ 			{
+-				if ( csync_match_file_host(url_decode(SQL_V[1]), tag[1], peer, (const char **)&tag[3]) )
+-					conn_printf("%s\t%s\n", SQL_V[0], SQL_V[1]);
++				if ( csync_match_file_host(url_decode(SQL_V(1)), tag[1], peer, (const char **)&tag[3]) )
++					conn_printf("%s\t%s\n", SQL_V(0), SQL_V(1));
+ 			} SQL_END;
+ 			break;
+ 
+diff -ruN csync2-1.34.vanilla/db.c csync2-1.34/db.c
+--- csync2-1.34.vanilla/db.c	2007-07-24 23:04:18.000000000 +0200
++++ csync2-1.34/db.c	2008-06-12 15:36:47.000000000 +0200
+_at_@ -19,7 +19,7 @@
+  */
+ 
+ #include "csync2.h"
+-#include <sqlite.h>
++#include <sqlite3.h>
+ #include <stdio.h>
+ #include <stdarg.h>
+ #include <stdlib.h>
+_at_@ -33,7 +33,7 @@
+ int db_blocking_mode = 1;
+ int db_sync_mode = 1;
+ 
+-static sqlite *db = 0;
++static sqlite3 *db = 0;
+ 
+ static int get_dblock_timeout()
+ {
+_at_@ -128,44 +128,46 @@
+ 
+ void csync_db_open(const char *file)
+ {
+-	db = sqlite_open(file, 0, 0);
+-	if ( db == 0 )
+-		csync_fatal("Can't open database: %s\n", file);
++	int r;
++	//db = sqlite_open(file, 0, 0);
++	r=sqlite3_open(file, &db);
++	if ( db == 0 || r)
++		csync_fatal("Can't open database: %s, result %d\n", file,r);
+ 
+ 	/* ignore errors on table creation */
+ 	in_sql_query++;
+-	sqlite_exec(db,
++	sqlite3_exec(db,
+ 		"CREATE TABLE file ("
+ 		"	filename, checktxt,"
+ 		"	UNIQUE ( filename ) ON CONFLICT REPLACE"
+ 		")",
+ 		0, 0, 0);
+-	sqlite_exec(db,
++	sqlite3_exec(db,
+ 		"CREATE TABLE dirty ("
+ 		"	filename, force, myname, peername,"
+ 		"	UNIQUE ( filename, peername ) ON CONFLICT IGNORE"
+ 		")",
+ 		0, 0, 0);
+-	sqlite_exec(db,
++	sqlite3_exec(db,
+ 		"CREATE TABLE hint ("
+ 		"	filename, recursive,"
+ 		"	UNIQUE ( filename, recursive ) ON CONFLICT IGNORE"
+ 		")",
+ 		0, 0, 0);
+-	sqlite_exec(db,
++	sqlite3_exec(db,
+ 		"CREATE TABLE action ("
+ 		"	filename, command, logfile,"
+ 		"	UNIQUE ( filename, command ) ON CONFLICT IGNORE"
+ 		")",
+ 		0, 0, 0);
+-	sqlite_exec(db,
++	sqlite3_exec(db,
+ 		"CREATE TABLE x509_cert ("
+ 		"	peername, certdata,"
+ 		"	UNIQUE ( peername ) ON CONFLICT IGNORE"
+ 		")",
+ 		0, 0, 0);
+ 	if (!db_sync_mode)
+-		sqlite_exec(db, "PRAGMA synchronous = OFF", 0, 0, 0);
++		sqlite3_exec(db, "PRAGMA synchronous = OFF", 0, 0, 0);
+ 	in_sql_query--;
+ }
+ 
+_at_@ -178,7 +180,7 @@
+ 		SQL("COMMIT TRANSACTION", "COMMIT TRANSACTION");
+ 		tqueries_counter = -10;
+ 	}
+-	sqlite_close(db);
++	sqlite3_close(db);
+ 	begin_commit_recursion--;
+ 	db = 0;
+ }
+_at_@ -199,7 +201,7 @@
+ 	csync_debug(2, "SQL: %s\n", sql);
+ 
+ 	while (1) {
+-		rc = sqlite_exec(db, sql, 0, 0, 0);
++		rc = sqlite3_exec(db, sql, 0, 0, 0);
+ 		if ( rc != SQLITE_BUSY ) break;
+ 		if (busyc++ > get_dblock_timeout()) { db = 0; csync_fatal(DEADLOCK_MESSAGE); }
+ 		csync_debug(2, "Database is busy, sleeping a sec.\n");
+_at_@ -216,7 +218,8 @@
+ 
+ void* csync_db_begin(const char *err, const char *fmt, ...)
+ {
+-	sqlite_vm *vm;
++	//sqlite_vm *vm;
++	sqlite3_stmt *stmt;
+ 	char *sql;
+ 	va_list ap;
+ 	int rc, busyc = 0;
+_at_@ -231,7 +234,7 @@
+ 	csync_debug(2, "SQL: %s\n", sql);
+ 
+ 	while (1) {
+-		rc = sqlite_compile(db, sql, 0, &vm, 0);
++		rc = sqlite3_prepare(db, sql, 0, &stmt, 0);
+ 		if ( rc != SQLITE_BUSY ) break;
+ 		if (busyc++ > get_dblock_timeout()) { db = 0; csync_fatal(DEADLOCK_MESSAGE); }
+ 		csync_debug(2, "Database is busy, sleeping a sec.\n");
+_at_@ -242,19 +245,21 @@
+ 		csync_fatal("Database Error: %s [%d]: %s\n", err, rc, sql);
+ 	free(sql);
+ 
+-	return vm;
++	return stmt;
+ }
+ 
+-int csync_db_next(void *vmx, const char *err,
++int csync_db_next(void *stmtx, const char *err,
+ 		int *pN, const char ***pazValue, const char ***pazColName)
+ {
+-	sqlite_vm *vm = vmx;
++	//sqlite_vm *vm = vmx;
++	sqlite3_stmt *stmt = stmtx;
+ 	int rc, busyc = 0;
+ 
+ 	csync_debug(4, "Trying to fetch a row from the database.\n");
+ 
+ 	while (1) {
+-		rc = sqlite_step(vm, pN, pazValue, pazColName);
++		//rc = sqlite_step(vm, pN, pazValue, pazColName);
++		rc = sqlite3_step(stmt);
+ 		if ( rc != SQLITE_BUSY ) break;
+ 		if (busyc++ > get_dblock_timeout()) { db = 0; csync_fatal(DEADLOCK_MESSAGE); }
+ 		csync_debug(2, "Database is busy, sleeping a sec.\n");
+_at_@ -267,16 +272,21 @@
+ 
+ 	return rc == SQLITE_ROW;
+ }
++void * csync_db_colblob(void *stmtx,int col) {
++	sqlite3_stmt *stmt = stmtx;
++	return sqlite3_column_blob(stmt,col);
++}
+ 
+-void csync_db_fin(void *vmx, const char *err)
++void csync_db_fin(void *stmtx, const char *err)
+ {
+-	sqlite_vm *vm = vmx;
++	//sqlite_vm *vm = vmx;
++	sqlite3_stmt *stmt=stmtx;
+ 	int rc, busyc = 0;
+ 
+ 	csync_debug(2, "SQL Query finished.\n");
+ 
+ 	while (1) {
+-		rc = sqlite_finalize(vm, 0);
++		rc = sqlite3_finalize(stmt);
+ 		if ( rc != SQLITE_BUSY ) break;
+ 		if (busyc++ > get_dblock_timeout()) { db = 0; csync_fatal(DEADLOCK_MESSAGE); }
+ 		csync_debug(2, "Database is busy, sleeping a sec.\n");
+--- src/csync2-1.34/update.c
++++ new/update.c
+_at_@ -545,12 +545,12 @@
+ 		"SELECT filename, myname, force FROM dirty WHERE peername = '%s' "
+ 		"ORDER by filename ASC", url_encode(peername))
+ 	{
+-		const char *filename = url_decode(SQL_V[0]);
++		const char *filename = url_decode(SQL_V(0));
+ 		int i, use_this = patnum == 0;
+ 		for (i=0; i<patnum && !use_this; i++)
+ 			if ( compare_files(filename, patlist[i], recursive) ) use_this = 1;
+ 		if (use_this)
+-			textlist_add2(&tl, filename, url_decode(SQL_V[1]), atoi(SQL_V[2]));
++			textlist_add2(&tl, filename, url_decode(SQL_V(1)), atoi(SQL_V(2)));
+ 	} SQL_END;
+ 
+ 	/* just return if there are no files to update */
+_at_@ -626,7 +626,7 @@
+ 	SQL_BEGIN("Get hosts from dirty table",
+ 		"SELECT peername FROM dirty GROUP BY peername ORDER BY random()")
+ 	{
+-		textlist_add(&tl, url_decode(SQL_V[0]), 0);
++		textlist_add(&tl, url_decode(SQL_V(0)), 0);
+ 	} SQL_END;
+ 
+ 	for (t = tl; t != 0; t = t->next) {
+_at_@ -798,7 +798,7 @@
+ 			filename ? url_encode(filename) : "",
+ 			filename ? "'" : "")
+ 	{
+-		char *l_file = strdup(url_decode(SQL_V[1])), *l_checktxt = strdup(url_decode(SQL_V[0]));
++		char *l_file = strdup(url_decode(SQL_V(1))), *l_checktxt = strdup(url_decode(SQL_V(0)));
+ 		if ( csync_match_file_host(l_file, myname, peername, 0) ) {
+ 			if ( remote_eof ) {
+ got_remote_eof:
+_at_@ -936,17 +936,17 @@
+ 		const struct csync_group *g = 0;
+ 		const struct csync_group_host *h;
+ 
+-		const char *filename = url_decode(SQL_V[0]); 
++		const char *filename = url_decode(SQL_V(0)); 
+ 
+ 		while ((g=csync_find_next(g, filename)) != 0) {
+-			if (!strcmp(g->myname, SQL_V[1]))
++			if (!strcmp(g->myname, SQL_V(1)))
+ 				for (h = g->host; h; h = h->next) {
+-					if (!strcmp(h->hostname, SQL_V[2]))
++					if (!strcmp(h->hostname, SQL_V(2)))
+ 						goto this_dirty_record_is_ok;
+ 				}
+ 		}
+ 
+-		textlist_add2(&tl, SQL_V[0], SQL_V[2], 0);
++		textlist_add2(&tl, SQL_V(0), SQL_V(2), 0);
+ 
+ this_dirty_record_is_ok:
+ 		;
+_at_@ -962,8 +962,8 @@
+ 	SQL_BEGIN("Query file DB",
+ 	          "SELECT filename FROM file")
+ 	{
+-		if (!csync_find_next(0, url_decode(SQL_V[0])))
+-			textlist_add(&tl, SQL_V[0], 0);
++		if (!csync_find_next(0, url_decode(SQL_V(0))))
++			textlist_add(&tl, SQL_V(0), 0);
+ 	} SQL_END;
+ 	for (t = tl; t != 0; t = t->next) {
+ 		csync_debug(1, "Removing %s from file db.\n", t->value);
diff --git a/testing/csync2/02-csync2-1.34-gnutls_pkgconfig.patch b/testing/csync2/02-csync2-1.34-gnutls_pkgconfig.patch
new file mode 100644
index 0000000..b9e1d27
--- /dev/null
+++ b/testing/csync2/02-csync2-1.34-gnutls_pkgconfig.patch
_at_@ -0,0 +1,24 @@
+--- old/configure.ac
++++ new/configure.ac
+_at_@ -59,16 +59,11 @@
+ if test "$enable_gnutls" != no
+ then
+ 
+-	# Check for gnuTLS.
+-	AM_PATH_LIBGNUTLS(1.0.0, , [ AC_MSG_ERROR([[gnutls not found; install gnutls, gnutls-openssl and libtasn1 packages for your system or run configure with --disable-gnutls]]) ])
+-
+-	# This is a bloody hack for fedora core
+-	CFLAGS="$CFLAGS $LIBGNUTLS_CFLAGS"
+-	LIBS="$LIBS $LIBGNUTLS_LIBS -ltasn1"
+-
+-	# Check gnuTLS SSL compatibility lib.
+-	AC_CHECK_LIB([gnutls-openssl], [SSL_new], , [AC_MSG_ERROR([[gnutls-openssl not found; install gnutls, gnutls-openssl and libtasn1 packages for your system or run configure with --disable-gnutls]])])
+-
++	PKG_CHECK_MODULES(LIBGNUTLS, gnutls, [
++	CFLAGS="$CFLAGS `$PKG_CONFIG --cflags gnutls libssl`"
++	LIBS="$LIBS `$PKG_CONFIG --libs gnutls libssl` -DHAVE_LIBGNUTLS_OPENSSL"	
++	])
++	
+ fi
+ 
+ AC_CONFIG_FILES([Makefile])
diff --git a/testing/csync2/APKBUILD b/testing/csync2/APKBUILD
new file mode 100644
index 0000000..6c4096a
--- /dev/null
+++ b/testing/csync2/APKBUILD
_at_@ -0,0 +1,44 @@
+# Maintainer: Natanael Copa <ncopa_at_alpinelinux.org>
+pkgname=csync2
+pkgver=1.34
+pkgrel=0
+pkgdesc="a cluster synchronization tool"
+url="http://oss.linbit.com/csync2/"
+license="GPL-2+"
+depends=
+makedepends="librsync-dev gnutls-dev sqlite-dev autoconf automake"
+install=
+subpackages="$pkgname-doc"
+source="http://oss.linbit.com/csync2/csync2-$pkgver.tar.gz
+	01-csync2-sqlite3.patch
+	02-csync2-1.34-gnutls_pkgconfig.patch
+	"
+
+_builddir="$srcdir"/$pkgname-$pkgver
+
+prepare() {                                             
+	cd "$_builddir"
+	for i in ../*.patch; do  
+        	msg "Applying $i" 
+                patch -p1 -i $i || return 1 
+	done
+	autoreconf --install --force 
+}
+    
+build() {
+	cd "$_builddir"
+	./configure --prefix=/usr \
+		--sysconfdir=/etc \
+		--mandir=/usr/share/man \
+		--infodir=/usr/share/info
+	make || return 1
+}
+
+package() {
+	cd "$_builddir"
+	make DESTDIR="$pkgdir" install
+}
+
+md5sums="efc8a3548996b79cef2ad76af5e93cd8  csync2-1.34.tar.gz
+35ba1bb1aafd87741c7ef55bdfb2e212  01-csync2-sqlite3.patch
+31b2ed6a7bb424ccdbf1486223eca323  02-csync2-1.34-gnutls_pkgconfig.patch"
-- 
1.7.3.2
---
Unsubscribe:  alpine-devel+unsubscribe_at_lists.alpinelinux.org
Help:         alpine-devel+help_at_lists.alpinelinux.org
---
Received on Fri Nov 12 2010 - 14:00:52 GMT