Skip to content

Commit

Permalink
Merge pull request #887 from Ansuel/fix-freetdm
Browse files Browse the repository at this point in the history
freetdm: add patch for PCRE2 support
  • Loading branch information
jslachta authored Nov 9, 2024
2 parents f3d37d5 + 0a9ac6c commit 0256d07
Show file tree
Hide file tree
Showing 2 changed files with 97 additions and 1 deletion.
2 changes: 1 addition & 1 deletion libs/freetdm/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
include $(TOPDIR)/rules.mk

PKG_NAME:=freetdm
PKG_RELEASE:=2
PKG_RELEASE:=3
PKG_MAINTAINER:=

PKG_SOURCE_PROTO:=git
Expand Down
96 changes: 96 additions & 0 deletions libs/freetdm/patches/900-mod_freetdm-Adapt-to-new-PCRE2-API.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
From f2a6ac861701217a42fbcb11d5295eadb34b6beb Mon Sep 17 00:00:00 2001
From: Christian Marangi <[email protected]>
Date: Fri, 8 Nov 2024 02:33:00 +0100
Subject: [PATCH] mod_freetdm: Adapt to new PCRE2 API

Adapt to new PCRE2 API.

Signed-off-by: Christian Marangi <[email protected]>
---
mod_freetdm/mod_freetdm.c | 28 +++++++++++++++-------------
1 file changed, 15 insertions(+), 13 deletions(-)

--- a/mod_freetdm/mod_freetdm.c
+++ b/mod_freetdm/mod_freetdm.c
@@ -2325,21 +2325,21 @@ static FIO_SIGNAL_CB_FUNCTION(on_fxo_sig
switch_set_string(caller_data->collected, dtmf);

if ((regex || fail_regex) && !zstr(dtmf)) {
+ switch_regex_match_data_t *match_data = NULL;
switch_regex_t *re = NULL;
- int ovector[30];
int match = 0;

if (fail_regex) {
- match = switch_regex_perform(dtmf, fail_regex, &re, ovector, sizeof(ovector) / sizeof(ovector[0]));
+ match = switch_regex_perform(dtmf, fail_regex, &re, &match_data);
status = match ? FTDM_SUCCESS : FTDM_BREAK;
- switch_regex_safe_free(re);
+ switch_regex_and_match_data_safe_free(re, match_data);
ftdm_log(FTDM_LOG_DEBUG, "DTMF [%s] vs fail regex %s %s\n", dtmf, fail_regex, match ? "matched" : "did not match");
}

if (status == FTDM_SUCCESS && regex) {
- match = switch_regex_perform(dtmf, regex, &re, ovector, sizeof(ovector) / sizeof(ovector[0]));
+ match = switch_regex_perform(dtmf, regex, &re, &match_data);
status = match ? FTDM_BREAK : FTDM_SUCCESS;
- switch_regex_safe_free(re);
+ switch_regex_and_match_data_safe_free(re, match_data);
ftdm_log(FTDM_LOG_DEBUG, "DTMF [%s] vs dial regex %s %s\n", dtmf, regex, match ? "matched" : "did not match");
}
ftdm_log(FTDM_LOG_DEBUG, "returning %s to COLLECT event with DTMF %s\n", status == FTDM_SUCCESS ? "success" : "break", dtmf);
@@ -2545,21 +2545,22 @@ static FIO_SIGNAL_CB_FUNCTION(on_fxs_sig
switch_set_string(caller_data->collected, dtmf);

if ((regex || fail_regex) && !zstr(dtmf)) {
+ switch_regex_match_data_t *match_data = NULL;
switch_regex_t *re = NULL;
int ovector[30];
int match = 0;

if (fail_regex) {
- match = switch_regex_perform(dtmf, fail_regex, &re, ovector, sizeof(ovector) / sizeof(ovector[0]));
+ match = switch_regex_perform(dtmf, fail_regex, &re, &match_data);
status = match ? FTDM_SUCCESS : FTDM_BREAK;
- switch_regex_safe_free(re);
+ switch_regex_and_match_data_safe_free(re, match_data);
ftdm_log(FTDM_LOG_DEBUG, "DTMF [%s] vs fail regex %s %s\n", dtmf, fail_regex, match ? "matched" : "did not match");
}

if (status == FTDM_SUCCESS && regex) {
- match = switch_regex_perform(dtmf, regex, &re, ovector, sizeof(ovector) / sizeof(ovector[0]));
+ match = switch_regex_perform(dtmf, regex, &re, &match_data);
status = match ? FTDM_BREAK : FTDM_SUCCESS;
- switch_regex_safe_free(re);
+ switch_regex_and_match_data_safe_free(re, match_data);
ftdm_log(FTDM_LOG_DEBUG, "DTMF [%s] vs dial regex %s %s\n", dtmf, regex, match ? "matched" : "did not match");
}
ftdm_log(FTDM_LOG_DEBUG, "returning %s to COLLECT event with DTMF %s\n", status == FTDM_SUCCESS ? "success" : "break", dtmf);
@@ -2631,22 +2632,23 @@ static FIO_SIGNAL_CB_FUNCTION(on_r2_sign
ftdm_log(FTDM_LOG_DEBUG, "R2 DNIS so far [%s]\n", caller_data->dnis.digits);

if ((regex || fail_regex) && !zstr(caller_data->dnis.digits)) {
+ switch_regex_match_data_t *match_data = NULL;
switch_regex_t *re = NULL;
int ovector[30];
int match = 0;

if (fail_regex) {
- match = switch_regex_perform(caller_data->dnis.digits, fail_regex, &re, ovector, sizeof(ovector) / sizeof(ovector[0]));
+ match = switch_regex_perform(caller_data->dnis.digits, fail_regex, &re, &match_data);
status = match ? FTDM_SUCCESS : FTDM_BREAK;
- switch_regex_safe_free(re);
+ switch_regex_and_match_data_safe_free(re, match_data);
}

if (status == FTDM_SUCCESS && regex) {
- match = switch_regex_perform(caller_data->dnis.digits, regex, &re, ovector, sizeof(ovector) / sizeof(ovector[0]));
+ match = switch_regex_perform(caller_data->dnis.digits, regex, &re, &match_data);
status = match ? FTDM_BREAK : FTDM_SUCCESS;
}

- switch_regex_safe_free(re);
+ switch_regex_and_match_data_safe_free(re, match_data);
}
}
break;

0 comments on commit 0256d07

Please sign in to comment.