mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-08-01 06:35:09 +00:00
beastie
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@11352 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
38eabef83b
commit
80900446a9
@ -305,6 +305,31 @@ static inline switch_bool_t switch_string_var_check(char *s, switch_bool_t disab
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline switch_bool_t switch_string_var_check_const(const char *s)
|
||||||
|
{
|
||||||
|
const char *p;
|
||||||
|
int dol = 0;
|
||||||
|
|
||||||
|
for (p = s; p && *p; p++) {
|
||||||
|
if (*p == '$') {
|
||||||
|
dol = 1;
|
||||||
|
} else if (dol) {
|
||||||
|
if (*p == '{') {
|
||||||
|
return SWITCH_TRUE;
|
||||||
|
} else if (*p != '\\') {
|
||||||
|
dol = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SWITCH_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline char *switch_var_clean_string(char *s)
|
||||||
|
{
|
||||||
|
switch_string_var_check(s, SWITCH_TRUE);
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
static inline char *switch_clean_string(char *s)
|
static inline char *switch_clean_string(char *s)
|
||||||
{
|
{
|
||||||
char *p;
|
char *p;
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
#include <switch_caller.h>
|
#include <switch_caller.h>
|
||||||
|
|
||||||
#define profile_dup(a,b,p) if (!switch_strlen_zero(a)) { b = switch_core_strdup(p, a); } else { b = SWITCH_BLANK_STRING; }
|
#define profile_dup(a,b,p) if (!switch_strlen_zero(a)) { b = switch_core_strdup(p, a); } else { b = SWITCH_BLANK_STRING; }
|
||||||
#define profile_dup_clean(a,b,p) if (!switch_strlen_zero(a)) { b = switch_clean_string(switch_core_strdup(p, a)); switch_string_var_check( (char *) b , SWITCH_TRUE);} else { b = SWITCH_BLANK_STRING; }
|
#define profile_dup_clean(a,b,p) if (!switch_strlen_zero(a)) { b = switch_var_clean_string(switch_clean_string(switch_core_strdup(p, a)));} else { b = SWITCH_BLANK_STRING; }
|
||||||
|
|
||||||
SWITCH_DECLARE(switch_caller_profile_t *) switch_caller_profile_new(switch_memory_pool_t *pool,
|
SWITCH_DECLARE(switch_caller_profile_t *) switch_caller_profile_new(switch_memory_pool_t *pool,
|
||||||
const char *username,
|
const char *username,
|
||||||
|
@ -586,7 +586,7 @@ SWITCH_DECLARE(switch_status_t) switch_channel_set_variable_var_check(switch_cha
|
|||||||
int ok = 1;
|
int ok = 1;
|
||||||
|
|
||||||
if (var_check) {
|
if (var_check) {
|
||||||
ok = !switch_string_var_check((char *)value, SWITCH_FALSE);
|
ok = !switch_string_var_check_const(value);
|
||||||
}
|
}
|
||||||
if (ok) {
|
if (ok) {
|
||||||
switch_event_add_header_string(channel->variables, SWITCH_STACK_BOTTOM, varname, value);
|
switch_event_add_header_string(channel->variables, SWITCH_STACK_BOTTOM, varname, value);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user