mirror of https://github.com/mirror/busybox.git
Create find_applet_by_name function. Save 32 bytes.
parent
05e782ddd3
commit
f2cc2762bb
|
@ -87,7 +87,7 @@ static void install_links(const char *busybox, int use_symbolic_links)
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
struct BB_applet search_applet, *applet;
|
struct BB_applet *applet;
|
||||||
const char *s;
|
const char *s;
|
||||||
|
|
||||||
for (s = applet_name = argv[0]; *s != '\0';) {
|
for (s = applet_name = argv[0]; *s != '\0';) {
|
||||||
|
@ -104,10 +104,7 @@ int main(int argc, char **argv)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Do a binary search to find the applet entry given the name. */
|
/* Do a binary search to find the applet entry given the name. */
|
||||||
search_applet.name = applet_name;
|
if ((applet = find_applet_by_name(applet_name)) != NULL) {
|
||||||
applet = bsearch(&search_applet, applets, NUM_APPLETS,
|
|
||||||
sizeof(struct BB_applet), applet_name_compare);
|
|
||||||
if (applet != NULL) {
|
|
||||||
if (applet->usage && argv[1] && strcmp(argv[1], "--help") == 0)
|
if (applet->usage && argv[1] && strcmp(argv[1], "--help") == 0)
|
||||||
usage(applet->usage);
|
usage(applet->usage);
|
||||||
exit((*(applet->main)) (argc, argv));
|
exit((*(applet->main)) (argc, argv));
|
||||||
|
|
|
@ -87,7 +87,7 @@ static void install_links(const char *busybox, int use_symbolic_links)
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
struct BB_applet search_applet, *applet;
|
struct BB_applet *applet;
|
||||||
const char *s;
|
const char *s;
|
||||||
|
|
||||||
for (s = applet_name = argv[0]; *s != '\0';) {
|
for (s = applet_name = argv[0]; *s != '\0';) {
|
||||||
|
@ -104,10 +104,7 @@ int main(int argc, char **argv)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Do a binary search to find the applet entry given the name. */
|
/* Do a binary search to find the applet entry given the name. */
|
||||||
search_applet.name = applet_name;
|
if ((applet = find_applet_by_name(applet_name)) != NULL) {
|
||||||
applet = bsearch(&search_applet, applets, NUM_APPLETS,
|
|
||||||
sizeof(struct BB_applet), applet_name_compare);
|
|
||||||
if (applet != NULL) {
|
|
||||||
if (applet->usage && argv[1] && strcmp(argv[1], "--help") == 0)
|
if (applet->usage && argv[1] && strcmp(argv[1], "--help") == 0)
|
||||||
usage(applet->usage);
|
usage(applet->usage);
|
||||||
exit((*(applet->main)) (argc, argv));
|
exit((*(applet->main)) (argc, argv));
|
||||||
|
|
|
@ -88,7 +88,6 @@ extern const struct BB_applet applets[];
|
||||||
#undef PROTOTYPES
|
#undef PROTOTYPES
|
||||||
|
|
||||||
extern const char *applet_name;
|
extern const char *applet_name;
|
||||||
extern int applet_name_compare(const void *x, const void *y);
|
|
||||||
|
|
||||||
extern void usage(const char *usage) __attribute__ ((noreturn));
|
extern void usage(const char *usage) __attribute__ ((noreturn));
|
||||||
extern void error_msg(const char *s, ...) __attribute__ ((format (printf, 1, 2)));
|
extern void error_msg(const char *s, ...) __attribute__ ((format (printf, 1, 2)));
|
||||||
|
@ -153,6 +152,7 @@ extern char *get_last_path_component(char *path);
|
||||||
extern FILE *wfopen(const char *path, const char *mode);
|
extern FILE *wfopen(const char *path, const char *mode);
|
||||||
extern FILE *xfopen(const char *path, const char *mode);
|
extern FILE *xfopen(const char *path, const char *mode);
|
||||||
extern void chomp(char *s);
|
extern void chomp(char *s);
|
||||||
|
extern struct BB_applet *find_applet_by_name(const char *name);
|
||||||
|
|
||||||
#ifndef DMALLOC
|
#ifndef DMALLOC
|
||||||
extern void *xmalloc (size_t size);
|
extern void *xmalloc (size_t size);
|
||||||
|
|
|
@ -88,7 +88,6 @@ extern const struct BB_applet applets[];
|
||||||
#undef PROTOTYPES
|
#undef PROTOTYPES
|
||||||
|
|
||||||
extern const char *applet_name;
|
extern const char *applet_name;
|
||||||
extern int applet_name_compare(const void *x, const void *y);
|
|
||||||
|
|
||||||
extern void usage(const char *usage) __attribute__ ((noreturn));
|
extern void usage(const char *usage) __attribute__ ((noreturn));
|
||||||
extern void error_msg(const char *s, ...) __attribute__ ((format (printf, 1, 2)));
|
extern void error_msg(const char *s, ...) __attribute__ ((format (printf, 1, 2)));
|
||||||
|
@ -153,6 +152,7 @@ extern char *get_last_path_component(char *path);
|
||||||
extern FILE *wfopen(const char *path, const char *mode);
|
extern FILE *wfopen(const char *path, const char *mode);
|
||||||
extern FILE *xfopen(const char *path, const char *mode);
|
extern FILE *xfopen(const char *path, const char *mode);
|
||||||
extern void chomp(char *s);
|
extern void chomp(char *s);
|
||||||
|
extern struct BB_applet *find_applet_by_name(const char *name);
|
||||||
|
|
||||||
#ifndef DMALLOC
|
#ifndef DMALLOC
|
||||||
extern void *xmalloc (size_t size);
|
extern void *xmalloc (size_t size);
|
||||||
|
|
12
lash.c
12
lash.c
|
@ -67,7 +67,6 @@
|
||||||
static const int MAX_LINE = 256; /* size of input buffer for cwd data */
|
static const int MAX_LINE = 256; /* size of input buffer for cwd data */
|
||||||
static const int MAX_READ = 128; /* size of input buffer for `read' builtin */
|
static const int MAX_READ = 128; /* size of input buffer for `read' builtin */
|
||||||
#define JOB_STATUS_FORMAT "[%d] %-22s %.40s\n"
|
#define JOB_STATUS_FORMAT "[%d] %-22s %.40s\n"
|
||||||
extern size_t NUM_APPLETS;
|
|
||||||
|
|
||||||
|
|
||||||
enum redir_type { REDIRECT_INPUT, REDIRECT_OVERWRITE,
|
enum redir_type { REDIRECT_INPUT, REDIRECT_OVERWRITE,
|
||||||
|
@ -1371,7 +1370,8 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
{
|
{
|
||||||
struct built_in_command *x;
|
struct built_in_command *x;
|
||||||
#ifdef BB_FEATURE_SH_STANDALONE_SHELL
|
#ifdef BB_FEATURE_SH_STANDALONE_SHELL
|
||||||
struct BB_applet search_applet, *applet;
|
struct BB_applet *applet;
|
||||||
|
const char *name;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Check if the command matches any of the non-forking builtins.
|
/* Check if the command matches any of the non-forking builtins.
|
||||||
|
@ -1404,7 +1404,7 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
* /bin/foo invocation will fork and exec /bin/foo, even if
|
* /bin/foo invocation will fork and exec /bin/foo, even if
|
||||||
* /bin/foo is a symlink to busybox.
|
* /bin/foo is a symlink to busybox.
|
||||||
*/
|
*/
|
||||||
search_applet.name = child->argv[0];
|
name = child->argv[0];
|
||||||
|
|
||||||
#ifdef BB_FEATURE_SH_APPLETS_ALWAYS_WIN
|
#ifdef BB_FEATURE_SH_APPLETS_ALWAYS_WIN
|
||||||
/* If you enable BB_FEATURE_SH_APPLETS_ALWAYS_WIN, then
|
/* If you enable BB_FEATURE_SH_APPLETS_ALWAYS_WIN, then
|
||||||
|
@ -1412,13 +1412,11 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
* /bin/cat exists on the filesystem and is _not_ busybox.
|
* /bin/cat exists on the filesystem and is _not_ busybox.
|
||||||
* Some systems want this, others do not. Choose wisely. :-)
|
* Some systems want this, others do not. Choose wisely. :-)
|
||||||
*/
|
*/
|
||||||
search_applet.name = get_last_path_component(search_applet.name);
|
name = get_last_path_component(name);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Do a binary search to find the applet entry given the name. */
|
/* Do a binary search to find the applet entry given the name. */
|
||||||
applet = bsearch(&search_applet, applets, NUM_APPLETS,
|
if ((applet = find_applet_by_name(name)) != NULL) {
|
||||||
sizeof(struct BB_applet), applet_name_compare);
|
|
||||||
if (applet != NULL) {
|
|
||||||
int argc_l;
|
int argc_l;
|
||||||
char** argv=child->argv;
|
char** argv=child->argv;
|
||||||
for(argc_l=0;*argv!=NULL; argv++, argc_l++);
|
for(argc_l=0;*argv!=NULL; argv++, argc_l++);
|
||||||
|
|
12
sh.c
12
sh.c
|
@ -67,7 +67,6 @@
|
||||||
static const int MAX_LINE = 256; /* size of input buffer for cwd data */
|
static const int MAX_LINE = 256; /* size of input buffer for cwd data */
|
||||||
static const int MAX_READ = 128; /* size of input buffer for `read' builtin */
|
static const int MAX_READ = 128; /* size of input buffer for `read' builtin */
|
||||||
#define JOB_STATUS_FORMAT "[%d] %-22s %.40s\n"
|
#define JOB_STATUS_FORMAT "[%d] %-22s %.40s\n"
|
||||||
extern size_t NUM_APPLETS;
|
|
||||||
|
|
||||||
|
|
||||||
enum redir_type { REDIRECT_INPUT, REDIRECT_OVERWRITE,
|
enum redir_type { REDIRECT_INPUT, REDIRECT_OVERWRITE,
|
||||||
|
@ -1371,7 +1370,8 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
{
|
{
|
||||||
struct built_in_command *x;
|
struct built_in_command *x;
|
||||||
#ifdef BB_FEATURE_SH_STANDALONE_SHELL
|
#ifdef BB_FEATURE_SH_STANDALONE_SHELL
|
||||||
struct BB_applet search_applet, *applet;
|
struct BB_applet *applet;
|
||||||
|
const char *name;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Check if the command matches any of the non-forking builtins.
|
/* Check if the command matches any of the non-forking builtins.
|
||||||
|
@ -1404,7 +1404,7 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
* /bin/foo invocation will fork and exec /bin/foo, even if
|
* /bin/foo invocation will fork and exec /bin/foo, even if
|
||||||
* /bin/foo is a symlink to busybox.
|
* /bin/foo is a symlink to busybox.
|
||||||
*/
|
*/
|
||||||
search_applet.name = child->argv[0];
|
name = child->argv[0];
|
||||||
|
|
||||||
#ifdef BB_FEATURE_SH_APPLETS_ALWAYS_WIN
|
#ifdef BB_FEATURE_SH_APPLETS_ALWAYS_WIN
|
||||||
/* If you enable BB_FEATURE_SH_APPLETS_ALWAYS_WIN, then
|
/* If you enable BB_FEATURE_SH_APPLETS_ALWAYS_WIN, then
|
||||||
|
@ -1412,13 +1412,11 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
* /bin/cat exists on the filesystem and is _not_ busybox.
|
* /bin/cat exists on the filesystem and is _not_ busybox.
|
||||||
* Some systems want this, others do not. Choose wisely. :-)
|
* Some systems want this, others do not. Choose wisely. :-)
|
||||||
*/
|
*/
|
||||||
search_applet.name = get_last_path_component(search_applet.name);
|
name = get_last_path_component(name);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Do a binary search to find the applet entry given the name. */
|
/* Do a binary search to find the applet entry given the name. */
|
||||||
applet = bsearch(&search_applet, applets, NUM_APPLETS,
|
if ((applet = find_applet_by_name(name)) != NULL) {
|
||||||
sizeof(struct BB_applet), applet_name_compare);
|
|
||||||
if (applet != NULL) {
|
|
||||||
int argc_l;
|
int argc_l;
|
||||||
char** argv=child->argv;
|
char** argv=child->argv;
|
||||||
for(argc_l=0;*argv!=NULL; argv++, argc_l++);
|
for(argc_l=0;*argv!=NULL; argv++, argc_l++);
|
||||||
|
|
12
shell/lash.c
12
shell/lash.c
|
@ -67,7 +67,6 @@
|
||||||
static const int MAX_LINE = 256; /* size of input buffer for cwd data */
|
static const int MAX_LINE = 256; /* size of input buffer for cwd data */
|
||||||
static const int MAX_READ = 128; /* size of input buffer for `read' builtin */
|
static const int MAX_READ = 128; /* size of input buffer for `read' builtin */
|
||||||
#define JOB_STATUS_FORMAT "[%d] %-22s %.40s\n"
|
#define JOB_STATUS_FORMAT "[%d] %-22s %.40s\n"
|
||||||
extern size_t NUM_APPLETS;
|
|
||||||
|
|
||||||
|
|
||||||
enum redir_type { REDIRECT_INPUT, REDIRECT_OVERWRITE,
|
enum redir_type { REDIRECT_INPUT, REDIRECT_OVERWRITE,
|
||||||
|
@ -1371,7 +1370,8 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
{
|
{
|
||||||
struct built_in_command *x;
|
struct built_in_command *x;
|
||||||
#ifdef BB_FEATURE_SH_STANDALONE_SHELL
|
#ifdef BB_FEATURE_SH_STANDALONE_SHELL
|
||||||
struct BB_applet search_applet, *applet;
|
struct BB_applet *applet;
|
||||||
|
const char *name;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Check if the command matches any of the non-forking builtins.
|
/* Check if the command matches any of the non-forking builtins.
|
||||||
|
@ -1404,7 +1404,7 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
* /bin/foo invocation will fork and exec /bin/foo, even if
|
* /bin/foo invocation will fork and exec /bin/foo, even if
|
||||||
* /bin/foo is a symlink to busybox.
|
* /bin/foo is a symlink to busybox.
|
||||||
*/
|
*/
|
||||||
search_applet.name = child->argv[0];
|
name = child->argv[0];
|
||||||
|
|
||||||
#ifdef BB_FEATURE_SH_APPLETS_ALWAYS_WIN
|
#ifdef BB_FEATURE_SH_APPLETS_ALWAYS_WIN
|
||||||
/* If you enable BB_FEATURE_SH_APPLETS_ALWAYS_WIN, then
|
/* If you enable BB_FEATURE_SH_APPLETS_ALWAYS_WIN, then
|
||||||
|
@ -1412,13 +1412,11 @@ static int pseudo_exec(struct child_prog *child)
|
||||||
* /bin/cat exists on the filesystem and is _not_ busybox.
|
* /bin/cat exists on the filesystem and is _not_ busybox.
|
||||||
* Some systems want this, others do not. Choose wisely. :-)
|
* Some systems want this, others do not. Choose wisely. :-)
|
||||||
*/
|
*/
|
||||||
search_applet.name = get_last_path_component(search_applet.name);
|
name = get_last_path_component(name);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Do a binary search to find the applet entry given the name. */
|
/* Do a binary search to find the applet entry given the name. */
|
||||||
applet = bsearch(&search_applet, applets, NUM_APPLETS,
|
if ((applet = find_applet_by_name(name)) != NULL) {
|
||||||
sizeof(struct BB_applet), applet_name_compare);
|
|
||||||
if (applet != NULL) {
|
|
||||||
int argc_l;
|
int argc_l;
|
||||||
char** argv=child->argv;
|
char** argv=child->argv;
|
||||||
for(argc_l=0;*argv!=NULL; argv++, argc_l++);
|
for(argc_l=0;*argv!=NULL; argv++, argc_l++);
|
||||||
|
|
16
utility.c
16
utility.c
|
@ -1691,12 +1691,20 @@ FILE *xfopen(const char *path, const char *mode)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int applet_name_compare(const void *x, const void *y)
|
static int applet_name_compare(const void *x, const void *y)
|
||||||
{
|
{
|
||||||
const struct BB_applet *applet1 = x;
|
const char *name = x;
|
||||||
const struct BB_applet *applet2 = y;
|
const struct BB_applet *applet = y;
|
||||||
|
|
||||||
return strcmp(applet1->name, applet2->name);
|
return strcmp(name, applet->name);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern size_t NUM_APPLETS;
|
||||||
|
|
||||||
|
struct BB_applet *find_applet_by_name(const char *name)
|
||||||
|
{
|
||||||
|
return bsearch(name, applets, NUM_APPLETS, sizeof(struct BB_applet),
|
||||||
|
applet_name_compare);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined BB_DD || defined BB_TAIL
|
#if defined BB_DD || defined BB_TAIL
|
||||||
|
|
Loading…
Reference in New Issue