[asterisk-commits] eliel: branch group/data_api_gsoc2009 r205665 - in /team/group/data_api_gsoc2...

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Thu Jul 9 14:36:39 CDT 2009


Author: eliel
Date: Thu Jul  9 14:36:35 2009
New Revision: 205665

URL: http://svn.asterisk.org/svn-view/asterisk?view=rev&rev=205665
Log:
Add more documentation.
Add more tests scenarios.
Fix a crash when no filtering string is specified.


Modified:
    team/group/data_api_gsoc2009/include/asterisk/data.h
    team/group/data_api_gsoc2009/include/asterisk/xml.h
    team/group/data_api_gsoc2009/main/data.c
    team/group/data_api_gsoc2009/tests/test_data.c

Modified: team/group/data_api_gsoc2009/include/asterisk/data.h
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/data_api_gsoc2009/include/asterisk/data.h?view=diff&rev=205665&r1=205664&r2=205665
==============================================================================
--- team/group/data_api_gsoc2009/include/asterisk/data.h (original)
+++ team/group/data_api_gsoc2009/include/asterisk/data.h Thu Jul  9 14:36:35 2009
@@ -188,21 +188,27 @@
 #define ast_data_unregister(path) __ast_data_unregister(path, __FILE__)
 
 /*!
- * \internal
- * \brief
- * \param[in] root
- * \param[in] name
- * \param[in] value
+ * \brief Based on a search tree, evaluate the specified 'name' inside the tree with the
+ *        current string value.
+ *        .search = "somename=somestring"
+ *        name = "somename"
+ *        value is the current value of something and will be evaluated against "10".
+ * \param[in] root The root node pointer of the search tree.
+ * \param[in] name The name of the specific.
+ * \param[in] value The value to compare.
  * \returns The strcmp return value.
  */
 int ast_data_search_cmp_string(const struct ast_data_search *root, const char *name, const char *value);
 
 /*!
- * \internal
- * \brief
- * \param[in] root
- * \param[in] name
- * \param[in] value
+ * \brief Based on a search tree, evaluate the specified 'name' inside the tree with the
+ *        current signed integer value.
+ *        .search = "something=10"
+ *        name = "something"
+ *        value is the current value of something and will be evaluated against "10".
+ * \param[in] root The root node pointer of the search tree.
+ * \param[in] name The name of the specific.
+ * \param[in] value The value to compare.
  * \returns The strcmp return value.
  */
 int ast_data_search_cmp_sint(const struct ast_data_search *root, const char *name, int value);

Modified: team/group/data_api_gsoc2009/include/asterisk/xml.h
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/data_api_gsoc2009/include/asterisk/xml.h?view=diff&rev=205665&r1=205664&r2=205665
==============================================================================
--- team/group/data_api_gsoc2009/include/asterisk/xml.h (original)
+++ team/group/data_api_gsoc2009/include/asterisk/xml.h Thu Jul  9 14:36:35 2009
@@ -118,8 +118,7 @@
 /*!
  * \brief Get the document based on a node.
  * \param node A node that is part of the dom.
- * \retval NULL on error.
- * \retval The dom pointer where this node resides.
+ * \returns The dom pointer where this node resides.
  */
 struct ast_xml_doc *ast_xml_get_doc(struct ast_xml_node *node);
 

Modified: team/group/data_api_gsoc2009/main/data.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/data_api_gsoc2009/main/data.c?view=diff&rev=205665&r1=205664&r2=205665
==============================================================================
--- team/group/data_api_gsoc2009/main/data.c (original)
+++ team/group/data_api_gsoc2009/main/data.c Thu Jul  9 14:36:35 2009
@@ -901,6 +901,10 @@
 	char *savepath;
 	struct ast_data_search *child;
 
+	if (!node) {
+		return NULL;
+	}
+
 	if (!path) {
 		return (struct ast_data_search *) node;
 	}
@@ -942,7 +946,6 @@
 
 	child = data_search_get_node(root, name);
 	if (!child) {
-		ast_log(LOG_ERROR, "Not found!!! %s->%s\n", root->name, name);
 		return 0;
 	}
 
@@ -1186,6 +1189,11 @@
 	int found = 0;
 	struct data_filter_node *fnode, *fnode2;
 
+	if (!flist) {
+		data_result_add_child(node, generated);
+		return 1;
+	}
+
 	AST_LIST_TRAVERSE(flist, fnode, next) {
 		if (!strcasecmp(fnode->name, pathroot)) {
 			AST_LIST_TRAVERSE(&(fnode->children), fnode2, next) {
@@ -1232,7 +1240,7 @@
 		return NULL;
 	}
 
-	if (!flist) {
+	if (!flist && query->filter) {
 		flist = data_filter_generate(query->filter);
 	}
 

Modified: team/group/data_api_gsoc2009/tests/test_data.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/data_api_gsoc2009/tests/test_data.c?view=diff&rev=205665&r1=205664&r2=205665
==============================================================================
--- team/group/data_api_gsoc2009/tests/test_data.c (original)
+++ team/group/data_api_gsoc2009/tests/test_data.c Thu Jul  9 14:36:35 2009
@@ -45,7 +45,11 @@
 	struct ast_data *res, *internal;
 
 	if (!ast_data_search_cmp_sint(search, "root_test/data1", 10)) {
-		return NULL;
+		ast_debug(1, "root_test/data1 doesn't match\n");
+	}
+
+	if (!ast_data_search_cmp_sint(search, "root_test/data2", 20)) {
+		ast_debug(1, "root_test/data2 doesn't match\n");
 	}
 
 	res = ast_data_create("root_test");
@@ -56,6 +60,7 @@
 	ast_data_add_int(res, "data1", 10);
 	ast_data_add_dbl(res, "data2", 20);
 	ast_data_add_bool(res, "data3", 1);
+	ast_data_add_str(res, "name", "eliel");
 
 	internal = ast_data_add_node(res, "internal");
 	if (!internal) {
@@ -143,7 +148,7 @@
 	struct ast_data_query query = {
 		.version = AST_DATA_QUERY_VERSION,
 		.path = "test/node1/node11/node111",
-		.search = "node111/root_test/data1>=20"
+		.search = "node111/root_test/data1>=10,node111/root_test/data2<20"
 	};
 
 	switch (cmd) {




More information about the asterisk-commits mailing list