summaryrefslogtreecommitdiff
path: root/res/res_pjsip_xpidf_body_generator.c
diff options
context:
space:
mode:
authorMark Michelson <mmichelson@digium.com>2014-06-17 16:35:04 +0000
committerMark Michelson <mmichelson@digium.com>2014-06-17 16:35:04 +0000
commit351db2033c4565c6afbfdcd073a7d2fb0f70b983 (patch)
treef3d31968a7331cbdaf091c6cd86982e641e8b437 /res/res_pjsip_xpidf_body_generator.c
parent163c734ae7c3a208e6753e0b37f5228e438a67e3 (diff)
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 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@416444 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'res/res_pjsip_xpidf_body_generator.c')
-rw-r--r--res/res_pjsip_xpidf_body_generator.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/res/res_pjsip_xpidf_body_generator.c b/res/res_pjsip_xpidf_body_generator.c
index b68c9bba6..fba6152b3 100644
--- a/res/res_pjsip_xpidf_body_generator.c
+++ b/res/res_pjsip_xpidf_body_generator.c
@@ -97,6 +97,7 @@ static int xpidf_generate_body_content(void *body, void *data)
}
#define MAX_STRING_GROWTHS 3
+#define XML_PROLOG 39
static void xpidf_to_string(void *body, struct ast_str **str)
{
@@ -105,16 +106,14 @@ static void xpidf_to_string(void *body, struct ast_str **str)
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;
}