/* * Copyright (C) 2013 Kaspar Schleiser * Copyright (C) 2013 Freie Universität Berlin * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @file * @brief shows how to set up own and use the system shell commands. * By typing help in the serial console, all the supported commands * are listed. * * @author Kaspar Schleiser * @author Zakaria Kasmi * */ #include #include #include "shell_commands.h" #include "shell.h" static int print_teststart(int argc, char **argv) { (void) argc; (void) argv; printf("[TEST_START]\n"); return 0; } static int print_testend(int argc, char **argv) { (void) argc; (void) argv; printf("[TEST_END]\n"); return 0; } static int print_echo(int argc, char **argv) { for (int i = 0; i < argc; ++i) { printf("“%s” ", argv[i]); } puts(""); return 0; } static const shell_command_t shell_commands[] = { { "start_test", "starts a test", print_teststart }, { "end_test", "ends a test", print_testend }, { "echo", "prints the input command", print_echo }, { NULL, NULL, NULL } }; int main(void) { printf("test_shell.\n"); /* define buffer to be used by the shell */ char line_buf[SHELL_DEFAULT_BUFSIZE]; /* define own shell commands */ shell_run(shell_commands, line_buf, SHELL_DEFAULT_BUFSIZE); /* or use only system shell commands */ /* shell_run(NULL, line_buf, SHELL_DEFAULT_BUFSIZE); */ return 0; }