Use bb_getopt_ulflags, save 200-300 bytes
This commit is contained in:
parent
58a2e0e262
commit
792cae5f2a
244
coreutils/ls.c
244
coreutils/ls.c
@ -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();
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user