summaryrefslogtreecommitdiff
path: root/indications.c
diff options
context:
space:
mode:
authorMartin Pycko <martinp@digium.com>2003-06-17 18:59:58 +0000
committerMartin Pycko <martinp@digium.com>2003-06-17 18:59:58 +0000
commitd562c7c22875cd216c400c7b0ef82794666274e5 (patch)
tree74be2423ef3f4064a76e54669c2eb03d0c34d6a5 /indications.c
parent268581918150931616c34f98445d711bbdb799b3 (diff)
Fix the playtones app so that we can pass the tones as an argument ( we don't need to refer to a defined tone in indications.conf )
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1102 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'indications.c')
-rwxr-xr-xindications.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/indications.c b/indications.c
index ccfd04e82..62500a790 100755
--- a/indications.c
+++ b/indications.c
@@ -143,6 +143,7 @@ int ast_playtones_start(struct ast_channel *chan, int vol, const char *playlst,
char *s, *data = ast_strdupa(playlst); /* cute */
struct playtones_def d = { vol, -1, 0, 1, NULL};
char *stringp=NULL;
+ char *separator;
if (!data)
return -1;
if (vol < 1)
@@ -151,7 +152,13 @@ int ast_playtones_start(struct ast_channel *chan, int vol, const char *playlst,
d.interruptible = interruptible;
stringp=data;
- s = strsep(&stringp,",");
+ /* the stringp/data is not null here */
+ /* check if the data is separated with '|' or with ',' by default */
+ if (strchr(stringp,'|'))
+ separator = "|";
+ else
+ separator = ",";
+ s = strsep(&stringp,separator);
while(s && *s) {
int freq1, freq2, time;
@@ -184,7 +191,7 @@ int ast_playtones_start(struct ast_channel *chan, int vol, const char *playlst,
d.items[d.nitems].duration = time;
d.nitems++;
- s = strsep(&stringp,",");
+ s = strsep(&stringp,separator);
}
if (ast_activate_generator(chan, &playtones, &d)) {