Use bb_getopt_ulflags, save 200-300 bytes

This commit is contained in:
Glenn L McGrath 2004-01-18 05:15:16 +00:00
parent 58a2e0e262
commit 792cae5f2a

View File

@ -808,93 +808,134 @@ static int list_single(struct dnode *dn)
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
static const char ls_opts[] = "1AaCdgilnsx" /* "[-]Cadil1", POSIX mandated options, busybox always supports */
#ifdef CONFIG_FEATURE_LS_FILETYPES /* "[-]gnsx", POSIX non-mandated options, busybox always supports */
"Fp" /* "[-]Ak" GNU options, busybox always supports */
#endif /* "[-]FLRctur", POSIX mandated options, busybox optionally supports */
#ifdef CONFIG_FEATURE_LS_RECURSIVE /* "[-]p", POSIX non-mandated options, busybox optionally supports */
"R" /* "[-]SXvThw", GNU options, busybox optionally supports */
#endif /* "[-]K", SELinux mandated options, busybox optionally supports */
#ifdef CONFIG_FEATURE_LS_SORTFILES /* "[-]e", I think we made this one up */
"rSvX"
#endif
#ifdef CONFIG_FEATURE_LS_TIMESTAMPS
"ecut"
#endif
#ifdef CONFIG_FEATURE_LS_FOLLOWLINKS
"L"
#endif
#ifdef CONFIG_FEATURE_HUMAN_READABLE
"h"
#endif
"k"
#ifdef CONFIG_SELINUX
"K"
#endif
#ifdef CONFIG_FEATURE_AUTOWIDTH
"T:w:"
#endif
;
#define LIST_MASK_TRIGGER LIST_SHORT #ifdef CONFIG_FEATURE_LS_TIMESTAMPS
#define STYLE_MASK_TRIGGER STYLE_MASK # define LS_STR_TIMESTAMPS "cetu"
#define SORT_MASK_TRIGGER SORT_MASK #else
#define DISP_MASK_TRIGGER DISP_ROWS # define LS_STR_TIMESTAMPS ""
#define TIME_MASK_TRIGGER TIME_MASK #endif
#ifdef CONFIG_FEATURE_LS_SORTFILES
# define LS_STR_SORTFILES "SXrv"
#else
# define LS_STR_SORTFILES ""
#endif
#ifdef CONFIG_FEATURE_LS_FILETYPES
# define LS_STR_FILETYPES "Fp"
#else
# define LS_STR_FILETYPES ""
#endif
#ifdef CONFIG_FEATURE_LS_FOLLOWLINKS
# define LS_STR_FOLLOW_LINKS "L"
#else
# define LS_STR_FOLLOW_LINKS ""
#endif
#ifdef CONFIG_FEATURE_LS_RECURSIVE
# define LS_STR_RECURSIVE "R"
#else
# define LS_STR_RECURSIVE ""
#endif
#ifdef CONFIG_FEATURE_HUMAN_READABLE
# define LS_STR_HUMAN_READABLE "h"
#else
# define LS_STR_HUMAN_READABLE ""
#endif
#ifdef CONFIG_SELINUX
# define LS_STR_SELINUX "K"
#else
# define LS_STR_SELINUX ""
#endif
#ifdef CONFIG_FEATURE_AUTOWIDTH
# define LS_STR_AUTOWIDTH "T:w:"
#else
# define LS_STR_AUTOWIDTH ""
#endif
static const char ls_options[]="Cadil1gnsxAk" \
LS_STR_TIMESTAMPS \
LS_STR_SORTFILES \
LS_STR_FILETYPES \
LS_STR_FOLLOW_LINKS \
LS_STR_RECURSIVE \
LS_STR_HUMAN_READABLE \
LS_STR_SELINUX \
LS_STR_AUTOWIDTH;
#define LIST_MASK_TRIGGER LIST_SHORT
#define STYLE_MASK_TRIGGER STYLE_MASK
#define SORT_MASK_TRIGGER SORT_MASK
#define DISP_MASK_TRIGGER DISP_ROWS
#define TIME_MASK_TRIGGER TIME_MASK
static const unsigned opt_flags[] = { static const unsigned opt_flags[] = {
LIST_SHORT | STYLE_SINGLE, /* 1 */
DISP_HIDDEN, /* A */
DISP_HIDDEN | DISP_DOT, /* a */
LIST_SHORT | STYLE_COLUMNS, /* C */ LIST_SHORT | STYLE_COLUMNS, /* C */
DISP_NOLIST, /* d */ DISP_HIDDEN | DISP_DOT, /* a */
0, /* g - ingored */ DISP_NOLIST, /* d */
LIST_INO, /* i */ LIST_INO, /* i */
LIST_LONG | STYLE_LONG, /* l - remember LS_DISP_HR in mask! */ LIST_LONG | STYLE_LONG, /* l - remember LS_DISP_HR in mask! */
LIST_ID_NUMERIC, /* n */ LIST_SHORT | STYLE_SINGLE, /* 1 */
LIST_BLOCKS, /* s */ 0, /* g - ingored */
DISP_ROWS, /* x */ LIST_ID_NUMERIC, /* n */
#ifdef CONFIG_FEATURE_LS_FILETYPES LIST_BLOCKS, /* s */
LIST_FILETYPE | LIST_EXEC, /* F */ DISP_ROWS, /* x */
LIST_FILETYPE, /* p */ DISP_HIDDEN, /* A */
#endif #ifdef CONFIG_SELINUX
#ifdef CONFIG_FEATURE_LS_RECURSIVE LIST_CONTEXT, /* k */
DISP_RECURSIVE, /* R */ #else
#endif 0, /* k - ingored */
#ifdef CONFIG_FEATURE_LS_SORTFILES
SORT_ORDER_REVERSE, /* r */
SORT_SIZE, /* S */
SORT_VERSION, /* v */
SORT_EXT, /* v */
#endif #endif
#ifdef CONFIG_FEATURE_LS_TIMESTAMPS #ifdef CONFIG_FEATURE_LS_TIMESTAMPS
LIST_FULLTIME, /* e */ # ifdef CONFIG_FEATURE_LS_SORTFILES
#ifdef CONFIG_FEATURE_LS_SORTFILES
TIME_CHANGE | SORT_CTIME, /* c */ TIME_CHANGE | SORT_CTIME, /* c */
#else # else
TIME_CHANGE, /* c */ TIME_CHANGE, /* c */
#endif # endif
#ifdef CONFIG_FEATURE_LS_SORTFILES LIST_FULLTIME, /* e */
# ifdef CONFIG_FEATURE_LS_SORTFILES
SORT_MTIME, /* t */
# else
0, /* t - ignored -- is this correct? */
# endif
# ifdef CONFIG_FEATURE_LS_SORTFILES
TIME_ACCESS | SORT_ATIME, /* u */ TIME_ACCESS | SORT_ATIME, /* u */
#else # else
TIME_ACCESS, /* u */ TIME_ACCESS, /* u */
# endif
#endif #endif
#ifdef CONFIG_FEATURE_LS_SORTFILES #ifdef CONFIG_FEATURE_LS_SORTFILES
SORT_MTIME, /* t */ SORT_ORDER_REVERSE, /* r */
#else SORT_SIZE, /* S */
0, /* t - ignored -- is this correct? */ SORT_VERSION, /* v */
SORT_EXT, /* v */
#endif #endif
#ifdef CONFIG_FEATURE_LS_FILETYPES
LIST_FILETYPE | LIST_EXEC, /* F */
LIST_FILETYPE, /* p */
#endif #endif
#ifdef CONFIG_FEATURE_LS_FOLLOWLINKS #ifdef CONFIG_FEATURE_LS_FOLLOWLINKS
FOLLOW_LINKS, /* L */ FOLLOW_LINKS, /* L */
#endif
#ifdef CONFIG_FEATURE_LS_RECURSIVE
DISP_RECURSIVE, /* R */
#endif #endif
#ifdef CONFIG_FEATURE_HUMAN_READABLE #ifdef CONFIG_FEATURE_HUMAN_READABLE
LS_DISP_HR, /* h */ LS_DISP_HR, /* h */
#endif #endif
#ifndef CONFIG_SELINUX #ifdef CONFIG_SELINUX
0, /* k - ingored */
#else
LIST_CONTEXT, /* k */
LIST_MODEBITS|LIST_NLINKS|LIST_CONTEXT|LIST_SIZE|LIST_DATE_TIME, /* K */ LIST_MODEBITS|LIST_NLINKS|LIST_CONTEXT|LIST_SIZE|LIST_DATE_TIME, /* K */
#endif #endif
}; };
@ -904,13 +945,24 @@ LS_DISP_HR, /* h */
extern int ls_main(int argc, char **argv) extern int ls_main(int argc, char **argv)
{ {
struct dnode **dnf, **dnd; struct dnode **dnd;
int dnfiles, dndirs; struct dnode **dnf;
struct dnode *dn, *cur, **dnp; struct dnode **dnp;
int i, nfiles; struct dnode *dn;
int opt; struct dnode *cur;
int oi, ac; long opt;
int nfiles = 0;
int dnfiles;
int dndirs;
int oi;
int ac;
int i;
char **av; char **av;
#ifdef CONFIG_FEATURE_AUTOWIDTH
char *tabstops_str = NULL;
char *terminal_width_str = NULL;
#endif
#ifdef CONFIG_SELINUX #ifdef CONFIG_SELINUX
is_flask_enabled_flag = is_flask_enabled(); is_flask_enabled_flag = is_flask_enabled();
#endif #endif
@ -923,13 +975,13 @@ extern int ls_main(int argc, char **argv)
| SORT_NAME | SORT_ORDER_FORWARD | SORT_NAME | SORT_ORDER_FORWARD
#endif #endif
; ;
#ifdef CONFIG_FEATURE_AUTOWIDTH #ifdef CONFIG_FEATURE_AUTOWIDTH
/* Obtain the terminal width. */ /* Obtain the terminal width. */
get_terminal_width_height(0, &terminal_width, NULL); get_terminal_width_height(0, &terminal_width, NULL);
/* Go one less... */ /* Go one less... */
terminal_width--; terminal_width--;
#endif #endif
nfiles = 0;
#ifdef CONFIG_FEATURE_LS_COLOR #ifdef CONFIG_FEATURE_LS_COLOR
if (isatty(fileno(stdout))) if (isatty(fileno(stdout)))
@ -937,27 +989,21 @@ extern int ls_main(int argc, char **argv)
#endif #endif
/* process options */ /* process options */
while ((opt = getopt(argc, argv, ls_opts)) > 0) {
#ifdef CONFIG_FEATURE_AUTOWIDTH #ifdef CONFIG_FEATURE_AUTOWIDTH
if (opt == 'T') { opt = bb_getopt_ulflags(argc, argv, ls_options, &tabstops_str, &terminal_width_str);
tabstops = atoi(optarg); if (tabstops_str) {
continue; tabstops = atoi(tabstops_str);
} }
if (opt == 'w') { if (terminal_width_str) {
terminal_width = atoi(optarg); terminal_width = atoi(terminal_width_str);
continue; }
} #else
if (opt == ':') { opt = bb_getopt_ulflags(argc, argv, ls_options);
goto print_usage_message;
}
#endif #endif
{ /* 16 = maximum options minus tabsize and screewn width */
unsigned int flags; for (i = 0; i < 16; i++) {
const char *p = strchr(ls_opts, opt); if (opt & (1 << i)) {
if (!p) { /* shouldn't be necessary */ unsigned int flags = opt_flags[i];
goto print_usage_message;
}
flags = opt_flags[(int)(p - ls_opts)];
if (flags & LIST_MASK_TRIGGER) { if (flags & LIST_MASK_TRIGGER) {
all_fmt &= ~LIST_MASK; all_fmt &= ~LIST_MASK;
} }
@ -989,7 +1035,6 @@ extern int ls_main(int argc, char **argv)
} }
} }
/* sort out which command line options take precedence */ /* sort out which command line options take precedence */
#ifdef CONFIG_FEATURE_LS_RECURSIVE #ifdef CONFIG_FEATURE_LS_RECURSIVE
if (all_fmt & DISP_NOLIST) if (all_fmt & DISP_NOLIST)
@ -1088,7 +1133,4 @@ extern int ls_main(int argc, char **argv)
} }
} }
return (status); return (status);
print_usage_message:
bb_show_usage();
} }