mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-03 11:25:35 +00:00
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
This commit is contained in:
@@ -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;
|
||||
}
|
||||
|
Reference in New Issue
Block a user