diff --git a/res/res_agi.c b/res/res_agi.c index ba4ab0ec29704af9efcb0570167a20fee401974b..e96807b3fa2bf7d9504813e0f27a4f8b09fa7799 100755 --- a/res/res_agi.c +++ b/res/res_agi.c @@ -1160,6 +1160,35 @@ static int help_workhorse(int fd, char *match[]) return 0; } +static int agi_register(agi_command *agi) +{ + int x; + for (x=0;x<MAX_COMMANDS - 1;x++) { + if (commands[x].cmda[0] == agi->cmda[0]) { + ast_log(LOG_WARNING, "Command already registered!\n"); + return -1; + } + } + for (x=0;x<MAX_COMMANDS - 1;x++) { + if (!commands[x].cmda[0]) { + commands[x] = *agi; + return 0; + } + } + ast_log(LOG_WARNING, "No more room for new commands!\n"); + return -1; +} + +static void agi_unregister(agi_command *agi) +{ + int x; + for (x=0;x<MAX_COMMANDS - 1;x++) { + if (commands[x].cmda[0] == agi->cmda[0]) { + memset(&commands[x], 0, sizeof(agi_command)); + } + } +} + static agi_command *find_command(char *cmds[], int exact) { int x;