Fix app bug, update skel example, add skel to makefile as option (bug #3869)
authorMark Spencer <markster@digium.com>
Sun, 27 Mar 2005 22:29:57 +0000 (22:29 +0000)
committerMark Spencer <markster@digium.com>
Sun, 27 Mar 2005 22:29:57 +0000 (22:29 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@5277 65c4cc65-6c06-0410-ace0-fbb531ad65f3

app.c
apps/Makefile
apps/app_skel.c

diff --git a/app.c b/app.c
index 0ea51f8..9d70e53 100755 (executable)
--- a/app.c
+++ b/app.c
@@ -1489,7 +1489,8 @@ int ast_parseoptions(const struct ast_option *options, struct ast_flags *flags,
                                ast_log(LOG_WARNING, "Missing closing parenthesis for argument '%c'\n", curarg);
                                res = -1;
                        }
-               }
+               } else if (argloc)
+                       args[argloc - 1] = NULL;
        }
        return res;
 }
index 62d9a47..8a4d5bf 100755 (executable)
@@ -50,6 +50,7 @@ endif
 # Experimental things
 #
 #APPS+=app_ivrdemo.so
+#APPS+=app_skel.so
 
 APPS+=$(shell if [ -f /usr/include/linux/zaptel.h ]; then echo "app_zapras.so app_meetme.so app_flash.so app_zapbarge.so app_zapscan.so" ; fi)
 APPS+=$(shell if [ -f /usr/local/include/zaptel.h ]; then echo "app_zapras.so app_meetme.so app_flash.so app_zapbarge.so app_zapscan.so" ; fi)
index 47ab89f..fdfd649 100755 (executable)
@@ -3,9 +3,9 @@
  *
  * Skeleton application
  * 
- * Copyright (C) 1999, Mark Spencer
+ * Copyright (C) <Year>, <Your Name Here>
  *
- * Mark Spencer <markster@linux-support.net>
+ * <Your Name Here> <<You Email Here>>
  *
  * This program is free software, distributed under the terms of
  * the GNU General Public License
@@ -17,6 +17,7 @@
 #include <asterisk/pbx.h>
 #include <asterisk/module.h>
 #include <asterisk/lock.h>
+#include <asterisk/app.h>
 #include <stdlib.h>
 #include <unistd.h>
 #include <string.h>
@@ -27,19 +28,63 @@ static char *synopsis =
 "  This is a skeleton application that shows you the basic structure to create your\n"
 "own asterisk applications.\n";
 
+#define OPTION_A       (1 << 0)        /* Option A */
+#define OPTION_B       (1 << 1)        /* Option B(n) */
+#define OPTION_C       (1 << 2)        /* Option C(str) */
+#define OPTION_NULL    (1 << 3)        /* Dummy Termination */
+
+AST_DECLARE_OPTIONS(app_opts,{
+       ['a'] = { OPTION_A },
+       ['b'] = { OPTION_B, 1 },
+       ['c'] = { OPTION_C, 2 }
+});
+
 STANDARD_LOCAL_USER;
 
 LOCAL_USER_DECL;
 
-static int skel_exec(struct ast_channel *chan, void *data)
+static int app_exec(struct ast_channel *chan, void *data)
 {
-       int res=0;
+       int res = 0;
+       struct ast_flags flags;
        struct localuser *u;
+       char *options=NULL;
+       char *dummy = NULL;
+       char *args;
+       int argc = 0;
+       char *opts[2];
+       char *argv[2];
+
+       if (!(args = ast_strdupa((char *)data))) {
+               ast_log(LOG_ERROR, "Out of memory!\n");
+               return -1;
+       }
+
        if (!data) {
-               ast_log(LOG_WARNING, "skel requires an argument (filename)\n");
+               ast_log(LOG_WARNING, "%s requires an argument (dummy|[options])\n",app);
                return -1;
        }
+
        LOCAL_USER_ADD(u);
+       if ((argc = ast_separate_app_args(args, '|', argv, sizeof(argv) / sizeof(char *)))) {
+               dummy = argv[0];
+               options = argv[1];
+               ast_parseoptions(app_opts, &flags, opts, options);
+       }
+
+
+       if (dummy && !ast_strlen_zero(dummy)) 
+               ast_log(LOG_NOTICE, "Dummy value is : %s\n", dummy);
+
+       if (ast_test_flag(&flags, OPTION_A))
+               ast_log(LOG_NOTICE, "Option A is set\n");
+
+       if (ast_test_flag(&flags, OPTION_B))
+               ast_log(LOG_NOTICE,"Option B is set with : %s\n", opts[0] ? opts[0] : "<unspecified>");
+
+       if (ast_test_flag(&flags, OPTION_C))
+               ast_log(LOG_NOTICE,"Option C is set with : %s\n", opts[1] ? opts[1] : "<unspecified>");
+
        /* Do our thing here */
        LOCAL_USER_REMOVE(u);
        return res;
@@ -53,7 +98,7 @@ int unload_module(void)
 
 int load_module(void)
 {
-       return ast_register_application(app, skel_exec, tdesc, synopsis);
+       return ast_register_application(app, app_exec, tdesc, synopsis);
 }
 
 char *description(void)