From a59056a69d7cade83a2c7649442e9a78ab7ab3f3 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Mon, 5 Jun 2017 18:15:18 -0500 Subject: [PATCH] FS-10240: [freeswitch-core] Use the "Negative Lookahead" in xml dialplan cause memory leak #resolve --- src/switch_channel.c | 20 +++++++++++--------- src/switch_regex.c | 21 +++++++++++++-------- 2 files changed, 24 insertions(+), 17 deletions(-) diff --git a/src/switch_channel.c b/src/switch_channel.c index 613956b40d..39f86d838c 100644 --- a/src/switch_channel.c +++ b/src/switch_channel.c @@ -4405,15 +4405,17 @@ SWITCH_DECLARE(switch_status_t) switch_channel_set_timestamps(switch_channel_t * X = malloc(len); for (i = 0; i < proceed; i++) { - if (pcre_get_substring(dtstr, ovector, proceed, i, &replace) > 0) { - switch_size_t plen = strlen(replace); - memset(X, 'X', plen); - *(X+plen) = '\0'; - - switch_safe_free(substituted); - substituted = switch_string_replace(substituted ? substituted : dtstr, replace, X); - - pcre_free_substring(replace); + if (pcre_get_substring(dtstr, ovector, proceed, i, &replace) >= 0) { + if (replace) { + switch_size_t plen = strlen(replace); + memset(X, 'X', plen); + *(X+plen) = '\0'; + + switch_safe_free(substituted); + substituted = switch_string_replace(substituted ? substituted : dtstr, replace, X); + + pcre_free_substring(replace); + } } } diff --git a/src/switch_regex.c b/src/switch_regex.c index 6a3e067867..911796a4b7 100644 --- a/src/switch_regex.c +++ b/src/switch_regex.c @@ -174,12 +174,15 @@ SWITCH_DECLARE(void) switch_perform_substitution(switch_regex_t *re, int match_c num = -1; } - if (pcre_get_substring(field_data, ovector, match_count, num, &replace) > 0) { - switch_size_t r; - for (r = 0; r < strlen(replace) && y < (len - 1); r++) { - substituted[y++] = replace[r]; + if (pcre_get_substring(field_data, ovector, match_count, num, &replace) >= 0) { + if (replace) { + switch_size_t r; + + for (r = 0; r < strlen(replace) && y < (len - 1); r++) { + substituted[y++] = replace[r]; + } + pcre_free_substring(replace); } - pcre_free_substring(replace); } } else { substituted[y++] = data[x]; @@ -200,9 +203,11 @@ SWITCH_DECLARE(void) switch_capture_regex(switch_regex_t *re, int match_count, c int i; for (i = 0; i < match_count; i++) { - if (pcre_get_substring(field_data, ovector, match_count, i, &replace) > 0) { - callback(var, replace, user_data); - pcre_free_substring(replace); + if (pcre_get_substring(field_data, ovector, match_count, i, &replace) >= 0) { + if (replace) { + callback(var, replace, user_data); + pcre_free_substring(replace); + } } } }