Merge pull request #196 in FS/freeswitch from ~ARTURZ/freeswitch:FS-7304-dialplan-reversed-ranges to master

* commit '2d07448822b673af2de6b4b0b4bfcd68b96f3d01':
  FS-7304: Multiple and reversed ranges for XML dialplan date and time conditions
This commit is contained in:
Mike Jerris 2015-02-20 13:21:57 -06:00
commit 9a6c29f8f7
1 changed files with 12 additions and 33 deletions

View File

@ -3464,42 +3464,21 @@ SWITCH_DECLARE(switch_bool_t) switch_dow_cmp(const char *exp, int val)
SWITCH_DECLARE(int) switch_number_cmp(const char *exp, int val)
{
char *p;
if ((p = strchr(exp, '-'))) {
int min;
int max;
min = atol(exp);
p++;
max = atol(p);
if (val >= min && val <= max) {
return 1;
}
} else if ((p = strchr(exp, ','))) {
const char *cur = exp;
p++;
while (cur) {
if (atol(cur) == val) {
// Expression exp must be a comma separated list of numbers or ranges.
// To match numbers not in range 9-17, enter the reversed range 18-8.
for (;; ++exp) {
int a = strtol(exp, (char **)&exp, 10);
if (*exp != '-') {
if (a == val)
return 1;
} else {
int b = strtol(++exp, (char **)&exp, 10);
if (a <= b ? (val >= a && val <=b ) : (val >= a || val <= b))
return 1;
}
cur = p;
if (p && p + 1) {
if ((p = strchr((p + 1), ','))) {
p++;
}
}
}
} else {
if (atol(exp) == val) {
return 1;
}
if (*exp != ',')
return 0;
}
return 0;
}
SWITCH_DECLARE(int) switch_tod_cmp(const char *exp, int val)