[Asterisk-Users] How do i make best use of Macro?
Mark Spencer
markster at digium.com
Fri Jun 13 09:38:26 MST 2003
data should be considered a "const void *" in all honesty (maybe i should
enforce it). Always copy to a local buffer before strseping it.
mark
On Wed, 11 Jun 2003, Steven Critchfield wrote:
> Since there was some interest in this, here is the diff against current
> cvs. Someone that is better at C should look into my use of strsep
> because there is a couple of warnings. Also there is a warning on my use
> of pbx_builtin_setvar_helper, but I can't see whats wrong here.
>
> BTW, SayNumber doesn't seem to say '0'.
>
> Usage is like this.
>
> exten => 1234,1,MeetMeCount(1234|var)
> exten => 1234,2,SayNumber(${var})
> exten => 1234,3,MeetMe(1234)
>
> ---------------------------------------------------------------------------------
>
>
> diff -U3 -r asterisk-orig/apps/app_meetme.c asterisk/apps/app_meetme.c
> --- asterisk-orig/apps/app_meetme.c 2003-06-11 23:14:38.000000000 -0500
> +++ asterisk/apps/app_meetme.c 2003-06-11 22:58:32.000000000 -0500
> @@ -54,9 +54,10 @@
> " 'q' -- quiet mode (don't play enter/leave sounds)\n";
>
> static char *descrip2 =
> -" MeetMeCount(confno): Plays back the number of users in the specified MeetMe\n"
> -"conference. Returns 0 on success or -1 on a hangup. A ZAPTEL INTERFACE\n"
> -"MUST BE INSTALLED FOR CONFERENCING FUNCTIONALITY.\n";
> +" MeetMeCount(confno[|var]): Plays back the number of users in the specifiedi\n"
> +"MeetMe conference. If var is specified, playback will be skipped and the value\n"
> +"will be returned in the variable. Returns 0 on success or -1 on a hangup.\n"
> +"A ZAPTEL INTERFACE MUST BE INSTALLED FOR CONFERENCING FUNCTIONALITY.\n";
>
> STANDARD_LOCAL_USER;
>
> @@ -465,19 +466,29 @@
> int res = 0;
> struct conf *conf;
> int cnt;
> + char* confnum;
> + char val[5] = "0"; /* I don't think we will ever get 99,999 callers into a single meetme */
> +
> if (!data || !strlen(data)) {
> ast_log(LOG_WARNING, "MeetMeCount requires an argument (conference number)\n");
> return -1;
> }
> LOCAL_USER_ADD(u);
> - conf = find_conf(data, 0);
> + confnum = strsep((char*) &data,"|");
> + conf = find_conf(confnum, 0);
> if (conf)
> cnt = conf->users;
> else
> cnt = 0;
> - if (chan->_state != AST_STATE_UP)
> - ast_answer(chan);
> - res = ast_say_number(chan, cnt, "", chan->language);
> + if(strlen(data)){
> + /* have var so load it and exit */
> + sprintf(val,"%i",cnt);
> + pbx_builtin_setvar_helper(chan,(char*) data,&val);
> + }else{
> + if (chan->_state != AST_STATE_UP)
> + ast_answer(chan);
> + res = ast_say_number(chan, cnt, "", chan->language);
> + }
> LOCAL_USER_REMOVE(u);
> return res;
> }
>
>
> --
> Steven Critchfield <critch at basesys.com>
>
> _______________________________________________
> Asterisk-Users mailing list
> Asterisk-Users at lists.digium.com
> http://lists.digium.com/mailman/listinfo/asterisk-users
>
More information about the asterisk-users
mailing list