1 /* *INDENT-OFF* */
2 /*
3 Copyright (c) 2013, Broadcom Europe Ltd
4 Copyright (c) 2013, James Hughes
5 All rights reserved.
6
7 Redistribution and use in source and binary forms, with or without
8 modification, are permitted provided that the following conditions are met:
9 * Redistributions of source code must retain the above copyright
10 notice, this list of conditions and the following disclaimer.
11 * Redistributions in binary form must reproduce the above copyright
12 notice, this list of conditions and the following disclaimer in the
13 documentation and/or other materials provided with the distribution.
14 * Neither the name of the copyright holder nor the
15 names of its contributors may be used to endorse or promote products
16 derived from this software without specific prior written permission.
17
18 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
19 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
21 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY
22 DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
24 LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
25 ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30 /**
31 * \file RaspiCLI.c
32 * Code for handling command line parameters
33 *
34 * \date 4th March 2013
35 * \Author: James Hughes
36 *
37 * Description
38 *
39 * Some functions/structures for command line parameter parsing
40 *
41 */
42 #include <stdio.h>
43 #include <stdlib.h>
44 #include <string.h>
45 #include <memory.h>
46
47 #include "interface/vcos/vcos.h"
48
49 #include "RaspiCLI.h"
50
51
52 /**
53 * Convert a string from command line to a comand_id from the list
54 *
55 * @param commands Array of command to check
56 * @param num_command Number of commands in the array
57 * @param arg String to search for in the list
58 * @param num_parameters Returns the number of parameters used by the command
59 *
60 * @return command ID if found, -1 if not found
61 *
62 */
raspicli_get_command_id(const COMMAND_LIST * commands,const int num_commands,const char * arg,int * num_parameters)63 int raspicli_get_command_id(const COMMAND_LIST *commands, const int num_commands, const char *arg, int *num_parameters)
64 {
65 int command_id = -1;
66 int j;
67
68 vcos_assert(commands);
69 vcos_assert(num_parameters);
70 vcos_assert(arg);
71
72 if (!commands || !num_parameters || !arg)
73 return -1;
74
75 for (j = 0; j < num_commands; j++)
76 {
77 if (!strcmp(arg, commands[j].command) ||
78 !strcmp(arg, commands[j].abbrev))
79 {
80 // match
81 command_id = commands[j].id;
82 *num_parameters = commands[j].num_parameters;
83 break;
84 }
85 }
86
87 return command_id;
88 }
89
90
91 /**
92 * Display the list of commands in help format
93 *
94 * @param commands Array of command to check
95 * @param num_command Number of commands in the arry
96 *
97 *
98 */
raspicli_display_help(const COMMAND_LIST * commands,const int num_commands)99 void raspicli_display_help(const COMMAND_LIST *commands, const int num_commands)
100 {
101 int i;
102
103 vcos_assert(commands);
104
105 if (!commands)
106 return;
107
108 for (i = 0; i < num_commands; i++)
109 {
110 fprintf(stderr, "-%s, -%s\t: %s\n", commands[i].abbrev,
111 commands[i].command, commands[i].help);
112 }
113 }
114
115
116 /**
117 * Function to take a string, a mapping, and return the int equivalent
118 * @param str Incoming string to match
119 * @param map Mapping data
120 * @param num_refs The number of items in the mapping data
121 * @return The integer match for the string, or -1 if no match
122 */
raspicli_map_xref(const char * str,const XREF_T * map,int num_refs)123 int raspicli_map_xref(const char *str, const XREF_T *map, int num_refs)
124 {
125 int i;
126
127 for (i=0;i<num_refs;i++)
128 {
129 if (!strcasecmp(str, map[i].mode))
130 {
131 return map[i].mmal_mode;
132 }
133 }
134 return -1;
135 }
136
137 /**
138 * Function to take a mmal enum (as int) and return the string equivalent
139 * @param en Incoming int to match
140 * @param map Mapping data
141 * @param num_refs The number of items in the mapping data
142 * @return const pointer to string, or NULL if no match
143 */
raspicli_unmap_xref(const int en,const XREF_T * map,int num_refs)144 const char *raspicli_unmap_xref(const int en, const XREF_T *map, int num_refs)
145 {
146 int i;
147
148 for (i=0;i<num_refs;i++)
149 {
150 if (en == map[i].mmal_mode)
151 {
152 return map[i].mode;
153 }
154 }
155 return NULL;
156 }
157 /* *INDENT-ON* */
158