2 * Copyright (c) 1995, 1996, 1997, 1998 Kungliga Tekniska Högskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 * must display the following acknowledgement:
19 * This product includes software developed by the Kungliga Tekniska
20 * Högskolan and its contributors.
22 * 4. Neither the name of the Institute nor the names of its contributors
23 * may be used to endorse or promote products derived from this software
24 * without specific prior written permission.
26 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
27 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
29 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
30 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
31 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
32 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
33 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
35 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47 sl_match (SL_cmd
*cmds
, char *cmd
, int exactp
)
49 SL_cmd
*c
, *current
= NULL
, *partial_cmd
= NULL
;
50 int partial_match
= 0;
52 for (c
= cmds
; c
->name
; ++c
) {
55 if (strcmp (cmd
, c
->name
) == 0)
57 else if (strncmp (cmd
, c
->name
, strlen(cmd
)) == 0 &&
58 partial_cmd
!= current
) {
60 partial_cmd
= current
;
63 if (partial_match
== 1 && !exactp
)
70 sl_help (SL_cmd
*cmds
, int argc
, char **argv
)
76 for (c
= cmds
; c
->name
; ++c
) {
79 printf ("\n\t%s%s", prev_c
->usage
? prev_c
->usage
: "",
80 prev_c
->usage
? "\n" : "");
82 printf ("%s", c
->name
);
84 printf (", %s", c
->name
);
87 printf ("\n\t%s%s", prev_c
->usage
? prev_c
->usage
: "",
88 prev_c
->usage
? "\n" : "");
90 c
= sl_match (cmds
, argv
[1], 0);
92 printf ("No such command: %s. "
93 "Try \"help\" for a list of all commands\n",
96 printf ("%s\t%s\n", c
->name
, c
->usage
);
97 if(c
->help
&& *c
->help
)
98 printf ("%s\n", c
->help
);
99 if((++c
)->name
&& c
->func
== NULL
) {
100 printf ("Synonyms:");
101 while (c
->name
&& c
->func
== NULL
)
102 printf ("\t%s", (c
++)->name
);
111 char *readline(char *prompt
);
112 void add_history(char *p
);
117 readline(char *prompt
)
120 printf ("%s", prompt
);
122 if(fgets(buf
, sizeof(buf
), stdin
) == NULL
)
124 if (buf
[strlen(buf
) - 1] == '\n')
125 buf
[strlen(buf
) - 1] = '\0';
137 sl_command(SL_cmd
*cmds
, int argc
, char **argv
)
140 c
= sl_match (cmds
, argv
[0], 0);
143 return (*c
->func
)(argc
, argv
);
152 sl_make_argv(char *line
, int *ret_argc
, char ***ret_argv
)
160 argv
= malloc(nargv
* sizeof(*argv
));
165 for(p
= strtok_r (line
, " \t", &foo
);
167 p
= strtok_r (NULL
, " \t", &foo
)) {
168 if(argc
== nargv
- 1) {
171 tmp
= realloc (argv
, nargv
* sizeof(*argv
));
186 /* return values: 0 on success, -1 on fatal error, or return value of command */
188 sl_command_loop(SL_cmd
*cmds
, char *prompt
, void **data
)
196 buf
= readline(prompt
);
202 ret
= sl_make_argv(buf
, &argc
, &argv
);
204 fprintf(stderr
, "sl_loop: out of memory\n");
209 ret
= sl_command(cmds
, argc
, argv
);
211 printf ("Unrecognized command: %s\n", argv
[0]);
221 sl_loop(SL_cmd
*cmds
, char *prompt
)
225 while((ret
= sl_command_loop(cmds
, prompt
, &data
)) == 0)