diff options
author | landley <landley@driftwood> | 2006-09-28 17:18:51 -0400 |
---|---|---|
committer | landley <landley@driftwood> | 2006-09-28 17:18:51 -0400 |
commit | c56215062c961402515daeef8330ed75cd94af29 (patch) | |
tree | 7d29fd9f966e8392c180ec7a918d52b5ffb6a299 /toys/main.c | |
parent | 13bab2f09e9189c2b1e83ae37a1134108f9479cf (diff) | |
download | toybox-c56215062c961402515daeef8330ed75cd94af29.tar.gz |
Next snapshot. Tries to grab something out of lib in order to build, I have
an empty "blah.c" in there to make it happy but I'm not checking that in.
Diffstat (limited to 'toys/main.c')
-rw-r--r-- | toys/main.c | 95 |
1 files changed, 0 insertions, 95 deletions
diff --git a/toys/main.c b/toys/main.c deleted file mode 100644 index bd15d602..00000000 --- a/toys/main.c +++ /dev/null @@ -1,95 +0,0 @@ -/* vi: set ts=4 :*/ -/* Toybox infrastructure. - * - * Copyright 2006 Rob Landley <rob@landley.net> - * - * Licensed under GPL version 2, see file LICENSE in this tarball for details. - */ - -#include <stdio.h> -#include <strings.h> - -/* -name -main() -struct -usage (short long example info) -path (/usr/sbin) -*/ - -int toybox_main(void) -{ - printf("toybox\n"); - return 0; -} - -int toysh_main(void) -{ - printf("toysh\n"); -} - -// The monster fun applet list. - -struct toy_list { - char *name; - int (*toy_main)(void); -} toy_list[] = { - {"toybox", toybox_main}, - {"toysh", toysh_main} -}; - -// Global context for this applet. - -struct toy_context { - struct toy_list *which; - int argc; - char **argv; - char buf[4096]; -// toy_union toydata; -} toys; - -struct toy_list *find_toy_by_name(char *name) -{ - int top, bottom, middle; - - // If the name starts with "toybox", accept that as a match. Otherwise - // skip the first entry, which is out of order. - - if (!strncmp(name,"toybox",6)) return toy_list; - bottom=1; - - // Binary search to find this applet. - - top=(sizeof(toy_list)/sizeof(struct toy_list))-1; - for(;;) { - int result; - - middle=(top+bottom)/2; - if(middle<bottom || middle>top) return NULL; - result = strcmp(name,toy_list[middle].name); - if(!result) return toy_list+middle; - if(result<0) top=--middle; - else bottom=++middle; - } -} - -int main(int argc, char *argv[]) -{ - char *name; - - // Record command line arguments. - toys.argc = argc; - toys.argv = argv; - - // Figure out which applet got called. - name = rindex(argv[0],'/'); - if (!name) name = argv[0]; - else name++; - toys.which = find_toy_by_name(name); - - if (!toys.which) { - dprintf(2,"No behavior for %s\n",name); - return 1; - } - return toys.which->toy_main(); -} |