[svn-commits] file: branch file/res_sorcery_realtime r383915 - /team/file/res_sorcery_realt...

SVN commits to the Digium repositories svn-commits at lists.digium.com
Tue Mar 26 13:52:06 CDT 2013


Author: file
Date: Tue Mar 26 13:52:03 2013
New Revision: 383915

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=383915
Log:
It compiles again!

Modified:
    team/file/res_sorcery_realtime/main/config.c

Modified: team/file/res_sorcery_realtime/main/config.c
URL: http://svnview.digium.com/svn/asterisk/team/file/res_sorcery_realtime/main/config.c?view=diff&rev=383915&r1=383914&r2=383915
==============================================================================
--- team/file/res_sorcery_realtime/main/config.c (original)
+++ team/file/res_sorcery_realtime/main/config.c Tue Mar 26 13:52:03 2013
@@ -2511,7 +2511,28 @@
 	return result;
 }
 
-static struct ast_variable *ast_load_realtime_helper(const char *family, va_list ap)
+static struct ast_variable *realtime_arguments_to_fields(va_list ap)
+{
+	struct ast_variable *fields = NULL;
+	const char *newparam;
+
+	while ((newparam = va_arg(ap, const char *))) {
+		const char *newval = va_arg(ap, const char *);
+		struct ast_variable *field = ast_variable_new(newparam, newval, "");
+
+		if (!field) {
+			ast_variables_destroy(fields);
+			return NULL;
+		}
+
+		field->next = fields;
+		fields = field;
+	}
+
+	return fields;
+}
+
+static struct ast_variable *ast_load_realtime_helper(const char *family, const struct ast_variable *fields)
 {
 	struct ast_config_engine *eng;
 	char db[256];
@@ -2521,7 +2542,7 @@
 
 	for (i = 1; ; i++) {
 		if ((eng = find_engine(family, i, db, sizeof(db), table, sizeof(table)))) {
-			if (eng->realtime_func && (res = eng->realtime_func(db, table, ap))) {
+			if (eng->realtime_func && (res = eng->realtime_func(db, table, fields))) {
 				return res;
 			}
 		} else {
@@ -2534,12 +2555,17 @@
 
 struct ast_variable *ast_load_realtime_all(const char *family, ...)
 {
-	struct ast_variable *res;
+	RAII_VAR(struct ast_variable *, fields, NULL, ast_variables_destroy);
+	struct ast_variable *res = NULL;
 	va_list ap;
 
 	va_start(ap, family);
-	res = ast_load_realtime_helper(family, ap);
+	fields = realtime_arguments_to_fields(ap);
 	va_end(ap);
+
+	if (fields) {
+		res = ast_load_realtime_helper(family, fields);
+	}
 
 	return res;
 }
@@ -2549,11 +2575,14 @@
 	struct ast_variable *res;
 	struct ast_variable *cur;
 	struct ast_variable **prev;
+	RAII_VAR(struct ast_variable *, fields, NULL, ast_variables_destroy);
 	va_list ap;
 
 	va_start(ap, family);
-	res = ast_load_realtime_helper(family, ap);
+	fields = realtime_arguments_to_fields(ap);
 	va_end(ap);
+
+	res = ast_load_realtime_helper(family, fields);
 
 	/* Filter the list. */
 	prev = &res;
@@ -2648,6 +2677,7 @@
 
 struct ast_config *ast_load_realtime_multientry(const char *family, ...)
 {
+	RAII_VAR(struct ast_variable *, fields, NULL, ast_variables_destroy);
 	struct ast_config_engine *eng;
 	char db[256];
 	char table[256];
@@ -2656,9 +2686,12 @@
 	int i;
 
 	va_start(ap, family);
+	fields = realtime_arguments_to_fields(ap);
+	va_end(ap);
+
 	for (i = 1; ; i++) {
 		if ((eng = find_engine(family, i, db, sizeof(db), table, sizeof(table)))) {
-			if (eng->realtime_multi_func && (res = eng->realtime_multi_func(db, table, ap))) {
+			if (eng->realtime_multi_func && (res = eng->realtime_multi_func(db, table, fields))) {
 				/* If we were returned an empty cfg, destroy it and return NULL */
 				if (!res->root) {
 					ast_config_destroy(res);
@@ -2670,13 +2703,13 @@
 			break;
 		}
 	}
-	va_end(ap);
 
 	return res;
 }
 
 int ast_update_realtime(const char *family, const char *keyfield, const char *lookup, ...)
 {
+	RAII_VAR(struct ast_variable *, fields, NULL, ast_variables_destroy);
 	struct ast_config_engine *eng;
 	int res = -1, i;
 	char db[256];
@@ -2684,23 +2717,27 @@
 	va_list ap;
 
 	va_start(ap, lookup);
+	fields = realtime_arguments_to_fields(ap);
+	va_end(ap);
+
 	for (i = 1; ; i++) {
 		if ((eng = find_engine(family, i, db, sizeof(db), table, sizeof(table)))) {
 			/* If the update succeeds, it returns 0. */
-			if (eng->update_func && !(res = eng->update_func(db, table, keyfield, lookup, ap))) {
+			if (eng->update_func && !(res = eng->update_func(db, table, keyfield, lookup, fields))) {
 				break;
 			}
 		} else {
 			break;
 		}
 	}
-	va_end(ap);
 
 	return res;
 }
 
 int ast_update2_realtime(const char *family, ...)
 {
+	RAII_VAR(struct ast_variable *, lookup_fields, NULL, ast_variables_destroy);
+	RAII_VAR(struct ast_variable *, update_fields, NULL, ast_variables_destroy);
 	struct ast_config_engine *eng;
 	int res = -1, i;
 	char db[256];
@@ -2708,22 +2745,26 @@
 	va_list ap;
 
 	va_start(ap, family);
+	lookup_fields = realtime_arguments_to_fields(ap);
+	update_fields = realtime_arguments_to_fields(ap);
+	va_end(ap);
+
 	for (i = 1; ; i++) {
 		if ((eng = find_engine(family, i, db, sizeof(db), table, sizeof(table)))) {
-			if (eng->update2_func && !(res = eng->update2_func(db, table, ap))) {
+			if (eng->update2_func && !(res = eng->update2_func(db, table, lookup_fields, update_fields))) {
 				break;
 			}
 		} else {
 			break;
 		}
 	}
-	va_end(ap);
 
 	return res;
 }
 
 int ast_store_realtime(const char *family, ...)
 {
+	RAII_VAR(struct ast_variable *, fields, NULL, ast_variables_destroy);
 	struct ast_config_engine *eng;
 	int res = -1, i;
 	char db[256];
@@ -2731,23 +2772,26 @@
 	va_list ap;
 
 	va_start(ap, family);
+	fields = realtime_arguments_to_fields(ap);
+	va_end(ap);
+
 	for (i = 1; ; i++) {
 		if ((eng = find_engine(family, i, db, sizeof(db), table, sizeof(table)))) {
 			/* If the store succeeds, it returns 0. */
-			if (eng->store_func && !(res = eng->store_func(db, table, ap))) {
+			if (eng->store_func && !(res = eng->store_func(db, table, fields))) {
 				break;
 			}
 		} else {
 			break;
 		}
 	}
-	va_end(ap);
 
 	return res;
 }
 
 int ast_destroy_realtime(const char *family, const char *keyfield, const char *lookup, ...)
 {
+	RAII_VAR(struct ast_variable *, fields, NULL, ast_variables_destroy);
 	struct ast_config_engine *eng;
 	int res = -1, i;
 	char db[256];
@@ -2755,16 +2799,18 @@
 	va_list ap;
 
 	va_start(ap, lookup);
+	fields = realtime_arguments_to_fields(ap);
+	va_end(ap);
+
 	for (i = 1; ; i++) {
 		if ((eng = find_engine(family, i, db, sizeof(db), table, sizeof(table)))) {
-			if (eng->destroy_func && !(res = eng->destroy_func(db, table, keyfield, lookup, ap))) {
+			if (eng->destroy_func && !(res = eng->destroy_func(db, table, keyfield, lookup, fields))) {
 				break;
 			}
 		} else {
 			break;
 		}
 	}
-	va_end(ap);
 
 	return res;
 }




More information about the svn-commits mailing list