diff options
author | Denis Vlasenko | 2007-04-10 21:38:30 +0000 |
---|---|---|
committer | Denis Vlasenko | 2007-04-10 21:38:30 +0000 |
commit | 335b63d8d1876ce4e172ebcc9d64544785682244 (patch) | |
tree | 14183fd728ce51ae10baee70f7d8f72c39d30649 /include/busybox.h | |
parent | 07c394e69b0cfa7cd30e97ffc6edb0d857905f45 (diff) | |
download | busybox-335b63d8d1876ce4e172ebcc9d64544785682244.zip busybox-335b63d8d1876ce4e172ebcc9d64544785682244.tar.gz |
make a few struct bb_applet members conditional
rename sllep_and_die -> xfunc_die
make fflush_stdout_and_exit NOFORK-safe
fix some buglets found by randomconfig
Diffstat (limited to 'include/busybox.h')
-rw-r--r-- | include/busybox.h | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/include/busybox.h b/include/busybox.h index 6f48087..380de9a 100644 --- a/include/busybox.h +++ b/include/busybox.h @@ -9,26 +9,35 @@ #include "libbb.h" +#if ENABLE_FEATURE_INSTALLER /* order matters: used as index into "install_dir[]" in busybox.c */ -enum Location { +typedef enum bb_install_loc_t { _BB_DIR_ROOT = 0, _BB_DIR_BIN, _BB_DIR_SBIN, _BB_DIR_USR_BIN, _BB_DIR_USR_SBIN -}; +} bb_install_loc_t; +#endif -enum SUIDRoot { +#if ENABLE_FEATURE_SUID +typedef enum bb_suid_t { _BB_SUID_NEVER = 0, _BB_SUID_MAYBE, _BB_SUID_ALWAYS -}; +} bb_suid_t; +#endif -struct BB_applet { +struct bb_applet { const char *name; int (*main) (int argc, char **argv); - __extension__ enum Location location:8; - __extension__ enum SUIDRoot need_suid:8; +#if ENABLE_FEATURE_INSTALLER + __extension__ enum bb_install_loc_t install_loc:8; +#endif +#if ENABLE_FEATURE_SUID + __extension__ enum bb_suid_t need_suid:8; +#endif +#if ENABLE_FEATURE_EXEC_PREFER_APPLETS /* true if instead if fork(); exec("applet"); waitpid(); * one can do fork(); exit(applet_main(argc,argv)); waitpid(); */ unsigned char noexec; @@ -36,10 +45,11 @@ struct BB_applet { /* true if instead if fork(); exec("applet"); waitpid(); * one can simply call applet_main(argc,argv); */ unsigned char nofork; +#endif }; /* Defined in applet.c */ -extern const struct BB_applet applets[]; +extern const struct bb_applet applets[]; extern const unsigned short NUM_APPLETS; #endif /* _BB_INTERNAL_H_ */ |