[svn-commits] rmudgett: branch rmudgett/parking r330824 -	/team/rmudgett/parking/main/
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Wed Aug  3 19:15:12 CDT 2011
    
    
  
Author: rmudgett
Date: Wed Aug  3 19:15:08 2011
New Revision: 330824
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=330824
Log:
Add warning msgs about parking lot ramp and spaces overlap.  Update unit test to exercise this.
Modified:
    team/rmudgett/parking/main/features.c
Modified: team/rmudgett/parking/main/features.c
URL: http://svnview.digium.com/svn/asterisk/team/rmudgett/parking/main/features.c?view=diff&rev=330824&r1=330823&r2=330824
==============================================================================
--- team/rmudgett/parking/main/features.c (original)
+++ team/rmudgett/parking/main/features.c Wed Aug  3 19:15:08 2011
@@ -5415,12 +5415,11 @@
  * \brief Create a new parking lot ramp dialplan usage node.
  *
  * \param exten Parking lot access ramp extension.
- * \param lot Parking lot supplying reference data.
  *
  * \retval New usage ramp node on success.
  * \retval NULL on error.
  */
-static struct parking_dp_ramp *build_dialplan_useage_ramp(const char *exten, struct ast_parkinglot *lot)
+static struct parking_dp_ramp *build_dialplan_useage_ramp(const char *exten)
 {
 	struct parking_dp_ramp *ramp_node;
 
@@ -5439,11 +5438,12 @@
  * \param ramp_map Current parking lot context ramp usage map.
  * \param exten Parking lot access ramp extension to add.
  * \param lot Parking lot supplying reference data.
+ * \param complain TRUE if to complain of parking lot ramp conflicts.
  *
  * \retval 0 on success.  The ramp_map is updated.
  * \retval -1 on failure.
  */
-static int usage_context_add_ramp(struct parking_dp_ramp_map *ramp_map, const char *exten, struct ast_parkinglot *lot)
+static int usage_context_add_ramp(struct parking_dp_ramp_map *ramp_map, const char *exten, struct ast_parkinglot *lot, int complain)
 {
 	struct parking_dp_ramp *cur_ramp;
 	struct parking_dp_ramp *new_ramp;
@@ -5457,10 +5457,15 @@
 		}
 		if (cmp == 0) {
 			/* The ramp is already in the map. */
+			if (complain) {
+				ast_log(LOG_WARNING,
+					"Parking lot '%s' parkext %s@%s used by another parking lot.\n",
+					lot->name, exten, lot->cfg.parking_con);
+			}
 			return 0;
 		}
 		/* The new parking lot ramp goes before this node. */
-		new_ramp = build_dialplan_useage_ramp(exten, lot);
+		new_ramp = build_dialplan_useage_ramp(exten);
 		if (!new_ramp) {
 			return -1;
 		}
@@ -5470,7 +5475,7 @@
 	AST_LIST_TRAVERSE_SAFE_END;
 
 	/* New parking lot access ramp goes on the end. */
-	new_ramp = build_dialplan_useage_ramp(exten, lot);
+	new_ramp = build_dialplan_useage_ramp(exten);
 	if (!new_ramp) {
 		return -1;
 	}
@@ -5484,12 +5489,11 @@
  *
  * \param start First parking lot space to add.
  * \param stop Last parking lot space to add.
- * \param lot Parking lot supplying reference data.
  *
  * \retval New usage ramp node on success.
  * \retval NULL on error.
  */
-static struct parking_dp_spaces *build_dialplan_useage_spaces(int start, int stop, struct ast_parkinglot *lot)
+static struct parking_dp_spaces *build_dialplan_useage_spaces(int start, int stop)
 {
 	struct parking_dp_spaces *spaces_node;
 
@@ -5510,11 +5514,12 @@
  * \param start First parking lot space to add.
  * \param stop Last parking lot space to add.
  * \param lot Parking lot supplying reference data.
+ * \param complain TRUE if to complain of parking lot spaces conflicts.
  *
  * \retval 0 on success.  The space_map is updated.
  * \retval -1 on failure.
  */
-static int usage_context_add_spaces(struct parking_dp_space_map *space_map, int start, int stop, struct ast_parkinglot *lot)
+static int usage_context_add_spaces(struct parking_dp_space_map *space_map, int start, int stop, struct ast_parkinglot *lot, int complain)
 {
 	struct parking_dp_spaces *cur_node;
 	struct parking_dp_spaces *expand_node;
@@ -5530,6 +5535,17 @@
 				return 0;
 			}
 
+			if (complain
+				&& ((cur_node->start <= start && start <= cur_node->stop)
+					|| (cur_node->start <= stop && stop <= cur_node->stop)
+					|| (start < cur_node->start && cur_node->stop < stop))) {
+				/* Only complain once per range add. */
+				complain = 0;
+				ast_log(LOG_WARNING,
+					"Parking lot '%s' parkpos %d-%d@%s overlaps another parking lot.\n",
+					lot->name, start, stop, lot->cfg.parking_con);
+			}
+
 			/* Current node is eaten by the expanding node. */
 			if (expand_node->stop < cur_node->stop) {
 				expand_node->stop = cur_node->stop;
@@ -5545,12 +5561,23 @@
 		}
 		if (stop + 1 < cur_node->start) {
 			/* New range is completely before current node. */
-			new_node = build_dialplan_useage_spaces(start, stop, lot);
+			new_node = build_dialplan_useage_spaces(start, stop);
 			if (!new_node) {
 				return -1;
 			}
 			AST_LIST_INSERT_BEFORE_CURRENT(new_node, node);
 			return 0;
+		}
+
+		if (complain
+			&& ((cur_node->start <= start && start <= cur_node->stop)
+				|| (cur_node->start <= stop && stop <= cur_node->stop)
+				|| (start < cur_node->start && cur_node->stop < stop))) {
+			/* Only complain once per range add. */
+			complain = 0;
+			ast_log(LOG_WARNING,
+				"Parking lot '%s' parkpos %d-%d@%s overlaps another parking lot.\n",
+				lot->name, start, stop, lot->cfg.parking_con);
 		}
 
 		/* Current node range overlaps or is immediately adjacent to new range. */
@@ -5576,7 +5603,7 @@
 	}
 
 	/* New range goes on the end. */
-	new_node = build_dialplan_useage_spaces(start, stop, lot);
+	new_node = build_dialplan_useage_spaces(start, stop);
 	if (!new_node) {
 		return -1;
 	}
@@ -5590,22 +5617,24 @@
  *
  * \param ctx_node Usage node to add parking lot spaces.
  * \param lot Parking lot to add data to ctx_node.
+ * \param complain TRUE if to complain of parking lot ramp and spaces conflicts.
  *
  * \retval 0 on success.
  * \retval -1 on error.
  */
-static int dialplan_usage_add_parkinglot_data(struct parking_dp_context *ctx_node, struct ast_parkinglot *lot)
-{
-	if (usage_context_add_ramp(&ctx_node->access_extens, lot->cfg.parkext, lot)) {
+static int dialplan_usage_add_parkinglot_data(struct parking_dp_context *ctx_node, struct ast_parkinglot *lot, int complain)
+{
+	if (usage_context_add_ramp(&ctx_node->access_extens, lot->cfg.parkext, lot,
+		complain)) {
 		return -1;
 	}
 	if (usage_context_add_spaces(&ctx_node->spaces, lot->cfg.parking_start,
-		lot->cfg.parking_stop, lot)) {
+		lot->cfg.parking_stop, lot, complain)) {
 		return -1;
 	}
 	if (lot->cfg.parkaddhints
 		&& usage_context_add_spaces(&ctx_node->hints, lot->cfg.parking_start,
-			lot->cfg.parking_stop, lot)) {
+			lot->cfg.parking_stop, lot, 0)) {
 		return -1;
 	}
 	return 0;
@@ -5628,7 +5657,7 @@
 	if (!ctx_node) {
 		return NULL;
 	}
-	if (dialplan_usage_add_parkinglot_data(ctx_node, lot)) {
+	if (dialplan_usage_add_parkinglot_data(ctx_node, lot, 0)) {
 		destroy_dialplan_usage_context(ctx_node);
 		return NULL;
 	}
@@ -5642,11 +5671,12 @@
  *
  * \param usage_map Parking lot usage map to add the given parking lot.
  * \param lot Parking lot to add dialplan usage.
+ * \param complain TRUE if to complain of parking lot ramp and spaces conflicts.
  *
  * \retval 0 on success.
  * \retval -1 on error.
  */
-static int dialplan_usage_add_parkinglot(struct parking_dp_map *usage_map, struct ast_parkinglot *lot)
+static int dialplan_usage_add_parkinglot(struct parking_dp_map *usage_map, struct ast_parkinglot *lot, int complain)
 {
 	struct parking_dp_context *cur_ctx;
 	struct parking_dp_context *new_ctx;
@@ -5660,7 +5690,7 @@
 		}
 		if (cmp == 0) {
 			/* This is the node we will add parking lot spaces to the map. */
-			return dialplan_usage_add_parkinglot_data(cur_ctx, lot);
+			return dialplan_usage_add_parkinglot_data(cur_ctx, lot, complain);
 		}
 		/* The new parking lot context goes before this node. */
 		new_ctx = build_dialplan_useage_context(lot);
@@ -5686,11 +5716,12 @@
  * \brief Build the dialplan usage map of the current parking lot container.
  *
  * \param usage_map Parking lot usage map.  Must already be initialized.
+ * \param complain TRUE if to complain of parking lot ramp and spaces conflicts.
  *
  * \retval 0 on success.  The usage_map is filled in.
  * \retval -1 on failure.  Built usage_map is incomplete.
  */
-static int build_dialplan_useage_map(struct parking_dp_map *usage_map)
+static int build_dialplan_useage_map(struct parking_dp_map *usage_map, int complain)
 {
 	int status = 0;
 	struct ao2_iterator iter;
@@ -5700,7 +5731,7 @@
 	iter = ao2_iterator_init(parkinglots, 0);
 	for (; (curlot = ao2_iterator_next(&iter)); ao2_ref(curlot, -1)) {
 		/* Add the parking lot to the map. */
-		if (dialplan_usage_add_parkinglot(usage_map, curlot)) {
+		if (dialplan_usage_add_parkinglot(usage_map, curlot, complain)) {
 			ao2_ref(curlot, -1);
 			status = -1;
 			break;
@@ -6019,7 +6050,7 @@
 	}
 
 	/* Save current parking lot dialplan needs. */
-	if (build_dialplan_useage_map(&old_usage_map)) {
+	if (build_dialplan_useage_map(&old_usage_map, 0)) {
 		destroy_dialplan_usage_map(&old_usage_map);
 
 		/* Allow reloading later to see if conditions have improved. */
@@ -6035,7 +6066,7 @@
 		"callback to remove marked parking lots");
 
 	/* Save updated parking lot dialplan needs. */
-	if (build_dialplan_useage_map(&new_usage_map)) {
+	if (build_dialplan_useage_map(&new_usage_map, 1)) {
 		/*
 		 * Yuck, if this failure caused any parking lot dialplan items
 		 * to be lost, they will likely remain lost until Asterisk is
@@ -7094,7 +7125,7 @@
 {
 	struct parking_dp_space_map *dead_spaces = (struct parking_dp_space_map *) context;
 
-	usage_context_add_spaces(dead_spaces, space, space, NULL);
+	usage_context_add_spaces(dead_spaces, space, space, NULL, 0);
 }
 #endif	/* defined(TEST_FRAMEWORK) */
 
@@ -7148,7 +7179,7 @@
 		ast_copy_string(lot->cfg.parkext, table->ramp, sizeof(lot->cfg.parkext));
 		lot->cfg.parking_start = table->start;
 		lot->cfg.parking_stop = table->stop;
-		if (dialplan_usage_add_parkinglot_data(ctx_node, lot)) {
+		if (dialplan_usage_add_parkinglot_data(ctx_node, lot, 1)) {
 			ast_test_status_update(test, "Failed to add parking lot data for %s\n", what);
 			destroy_dialplan_usage_context(ctx_node);
 			return NULL;
@@ -7168,22 +7199,26 @@
 	{ "701", 18, 19, "10-11,14-15,18-19" },
 	{ "703", 12, 13, "10-15,18-19" },
 	{ "704", 16, 17, "10-19" },
-	{ "704", 10, 19, "10-19" },
+
+	/* Parking ramp and space conflicts are intended with these lines. */
+	{ "704", 9, 19, "9-19" },
+	{ "704", 9, 20, "9-20" },
+	{ "704", 8, 21, "8-21" },
 
 	/* Add more spaces to ctx to test removing dead parking spaces. */
-	{ "705", 21, 23, "10-19,21-23" },
-	{ "706", 26, 29, "10-19,21-23,26-29" },
-	{ "707", 31, 32, "10-19,21-23,26-29,31-32" },
-	{ "708", 36, 38, "10-19,21-23,26-29,31-32,36-38" },
-	{ "708", 40, 41, "10-19,21-23,26-29,31-32,36-38,40-41" },
+	{ "705", 23, 25, "8-21,23-25" },
+	{ "706", 28, 31, "8-21,23-25,28-31" },
+	{ "707", 33, 34, "8-21,23-25,28-31,33-34" },
+	{ "708", 38, 40, "8-21,23-25,28-31,33-34,38-40" },
+	{ "709", 42, 43, "8-21,23-25,28-31,33-34,38-40,42-43" },
 };
 
 static const struct test_map test_new_ctx[] = {
 	{ "702", 4, 5, "4-5" },
-	{ "704", 22, 24, "4-5,22-24" },
-	{ "709", 27, 28, "4-5,22-24,27-28" },
-	{ "710", 30, 33, "4-5,22-24,27-28,30-33" },
-	{ "711", 35, 37, "4-5,22-24,27-28,30-33,35-37" },
+	{ "704", 24, 26, "4-5,24-26" },
+	{ "709", 29, 30, "4-5,24-26,29-30" },
+	{ "710", 32, 35, "4-5,24-26,29-30,32-35" },
+	{ "711", 37, 39, "4-5,24-26,29-30,32-35,37-39" },
 };
 #endif	/* defined(TEST_FRAMEWORK) */
 
@@ -7214,7 +7249,9 @@
 	}
 	ast_copy_string(lot->cfg.parking_con, "test-ctx", sizeof(lot->cfg.parking_con));
 
-	ast_test_status_update(test, "Build old_ctx map\n");
+	ast_test_status_update(test,
+		"Build old_ctx map\n");
+	ast_log(LOG_NOTICE, "6 Ramp and space conflict warnings are expected.\n");
 	old_ctx = test_build_maps(test, lot, "test_old_ctx", test_old_ctx,
 		ARRAY_LEN(test_old_ctx));
 	if (!old_ctx) {
@@ -7233,7 +7270,7 @@
 	ast_test_status_update(test, "Test removing dead parking spaces\n");
 	remove_dead_spaces_usage((void *) &dead_spaces, &old_ctx->spaces,
 		&new_ctx->spaces, test_add_dead_space);
-	if (check_spaces(test, &dead_spaces, "10-19,21,26,29,38,40-41", "dead_spaces")) {
+	if (check_spaces(test, &dead_spaces, "8-21,23,28,31,40,42-43", "dead_spaces")) {
 		res = -1;
 		goto fail_dead_spaces;
 	}
    
    
More information about the svn-commits
mailing list