[asterisk-commits] mmichelson: trunk r416444 - in /trunk: ./ res/

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Tue Jun 17 11:35:10 CDT 2014


Author: mmichelson
Date: Tue Jun 17 11:35:04 2014
New Revision: 416444

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=416444
Log:
Fix string growth algorithm for XML presence bodies.

pjpidf_print() does not return < 0 if there is not enough
room for the document to be printed. Rather, it returns
39, the length of the XML prolog.

The algorithm also had a bug in that it would return if
it attempted to grow the string larger.
........

Merged revisions 416442 from http://svn.asterisk.org/svn/asterisk/branches/12

Modified:
    trunk/   (props changed)
    trunk/res/res_pjsip_pidf_body_generator.c
    trunk/res/res_pjsip_xpidf_body_generator.c

Propchange: trunk/
------------------------------------------------------------------------------
Binary property 'branch-12-merged' - no diff available.

Modified: trunk/res/res_pjsip_pidf_body_generator.c
URL: http://svnview.digium.com/svn/asterisk/trunk/res/res_pjsip_pidf_body_generator.c?view=diff&rev=416444&r1=416443&r2=416444
==============================================================================
--- trunk/res/res_pjsip_pidf_body_generator.c (original)
+++ trunk/res/res_pjsip_pidf_body_generator.c Tue Jun 17 11:35:04 2014
@@ -80,6 +80,7 @@
 }
 
 #define MAX_STRING_GROWTHS 3
+#define XML_PROLOG 39
 
 static void pidf_to_string(void *body, struct ast_str **str)
 {
@@ -89,14 +90,13 @@
 
 	do {
 		size = pjpidf_print(pres, ast_str_buffer(*str), ast_str_size(*str) - 1);
-		if (size < 0) {
+		if (size == XML_PROLOG) {
 			ast_str_make_space(str, ast_str_size(*str) * 2);
 			++growths;
-			return;
 		}
-	} while (size < 0 && growths < MAX_STRING_GROWTHS);
+	} while (size == XML_PROLOG && growths < MAX_STRING_GROWTHS);
 
-	if (size < 0) {
+	if (size == XML_PROLOG) {
 		ast_log(LOG_WARNING, "PIDF body text too large\n");
 		return;
 	}

Modified: trunk/res/res_pjsip_xpidf_body_generator.c
URL: http://svnview.digium.com/svn/asterisk/trunk/res/res_pjsip_xpidf_body_generator.c?view=diff&rev=416444&r1=416443&r2=416444
==============================================================================
--- trunk/res/res_pjsip_xpidf_body_generator.c (original)
+++ trunk/res/res_pjsip_xpidf_body_generator.c Tue Jun 17 11:35:04 2014
@@ -97,6 +97,7 @@
 }
 
 #define MAX_STRING_GROWTHS 3
+#define XML_PROLOG 39
 
 static void xpidf_to_string(void *body, struct ast_str **str)
 {
@@ -105,16 +106,14 @@
 	int size;
 
 	do {
-
 		size = pjxpidf_print(pres, ast_str_buffer(*str), ast_str_size(*str));
-		if (size < 0) {
+		if (size == XML_PROLOG) {
 			ast_str_make_space(str, ast_str_size(*str) * 2);
 			++growths;
-			return;
 		}
-	} while (size < 0 && growths < MAX_STRING_GROWTHS);
+	} while (size == XML_PROLOG && growths < MAX_STRING_GROWTHS);
 
-	if (size < 0) {
+	if (size == XML_PROLOG) {
 		ast_log(LOG_WARNING, "XPIDF body text too large\n");
 		return;
 	}




More information about the asterisk-commits mailing list