- usage fresh bb_getopt_ulflags for ls -- very size reduce.

- small indent corrections
- remove unecessary malloc and free
This commit is contained in:
"Vladimir N. Oleynik" 2005-09-05 15:06:57 +00:00
parent 27421a1878
commit a8c23aa795

View File

@ -170,10 +170,9 @@ static int show_color = 0;
/* long option entry used only for --color, which has no short option
* equivalent. */
static int got_color_opt;
static struct option ls_color_opt[] =
{
{"color", optional_argument, &got_color_opt, 1},
{"color", optional_argument, NULL, 1},
{NULL, 0, NULL, 0}
};
@ -189,6 +188,7 @@ static struct option ls_color_opt[] =
struct dnode { /* the basic node */
char *name; /* the dir entry name */
char *fullname; /* the dir entry name */
int allocated;
struct stat dstat; /* the file stat info */
#ifdef CONFIG_SELINUX
security_context_t sid;
@ -235,8 +235,7 @@ static struct dnode *my_stat(char *fullname, char *name)
}
#endif
rc = stat(fullname, &dstat);
if(rc)
{
if(rc) {
bb_perror_msg("%s", fullname);
status = EXIT_FAILURE;
return 0;
@ -251,8 +250,7 @@ static struct dnode *my_stat(char *fullname, char *name)
}
#endif
rc = lstat(fullname, &dstat);
if(rc)
{
if(rc) {
bb_perror_msg("%s", fullname);
status = EXIT_FAILURE;
return 0;
@ -320,9 +318,8 @@ static int count_dirs(struct dnode **dn, int nfiles, int notsubdirs)
dirs = 0;
for (i = 0; i < nfiles; i++) {
if (S_ISDIR(dn[i]->dstat.st_mode)
&& (notsubdirs
|| ((dn[i]->name[0] != '.')
|| (dn[i]->name[1]
&& (notsubdirs ||
((dn[i]->name[0] != '.') || (dn[i]->name[1]
&& ((dn[i]->name[1] != '.')
|| dn[i]->name[2])))))
dirs++;
@ -352,8 +349,7 @@ static struct dnode **dnalloc(int num)
if (num < 1)
return (NULL);
p = (struct dnode **) xcalloc((size_t) num,
(size_t) (sizeof(struct dnode *)));
p = (struct dnode **) xcalloc((size_t) num, (size_t) (sizeof(struct dnode *)));
return (p);
}
@ -367,6 +363,7 @@ static void dfree(struct dnode **dnp)
cur = dnp[0];
while (cur != NULL) {
if(cur->allocated)
free(cur->fullname); /* free the filename */
next = cur->next;
free(cur); /* free the dnode */
@ -622,6 +619,7 @@ static struct dnode **list_dir(const char *path)
cur = my_stat(fullname, strrchr(fullname, '/') + 1);
if (!cur)
continue;
cur->allocated = 1;
cur->next = dn;
dn = cur;
nfiles++;
@ -951,6 +949,9 @@ static const unsigned opt_flags[] = {
#endif
#ifdef CONFIG_SELINUX
LIST_MODEBITS|LIST_NLINKS|LIST_CONTEXT|LIST_SIZE|LIST_DATE_TIME, /* K */
#endif
#ifdef CONFIG_FEATURE_AUTOWIDTH
0, 0, /* T, w - ignored */
#endif
(1U<<31)
};
@ -977,6 +978,9 @@ extern int ls_main(int argc, char **argv)
char *tabstops_str = NULL;
char *terminal_width_str = NULL;
#endif
#ifdef CONFIG_FEATURE_LS_COLOR
char *color_opt;
#endif
all_fmt = LIST_SHORT | DISP_NORMAL | STYLE_AUTO
#ifdef CONFIG_FEATURE_LS_TIMESTAMPS
@ -1000,7 +1004,11 @@ extern int ls_main(int argc, char **argv)
/* process options */
#ifdef CONFIG_FEATURE_AUTOWIDTH
opt = bb_getopt_ulflags(argc, argv, ls_options, &tabstops_str, &terminal_width_str);
opt = bb_getopt_ulflags(argc, argv, ls_options, &tabstops_str, &terminal_width_str
#ifdef CONFIG_FEATURE_LS_COLOR
, &color_opt
#endif
);
if (tabstops_str) {
tabstops = atoi(tabstops_str);
}
@ -1008,11 +1016,16 @@ extern int ls_main(int argc, char **argv)
terminal_width = atoi(terminal_width_str);
}
#else
opt = bb_getopt_ulflags(argc, argv, ls_options);
opt = bb_getopt_ulflags(argc, argv, ls_options
#ifdef CONFIG_FEATURE_LS_COLOR
, &color_opt
#endif
);
#endif
for (i = 0; opt_flags[i] != (1U<<31); i++) {
if (opt & (1 << i)) {
unsigned int flags = opt_flags[i];
if (flags & LIST_MASK_TRIGGER) {
all_fmt &= ~LIST_MASK;
}
@ -1045,51 +1058,28 @@ extern int ls_main(int argc, char **argv)
}
#ifdef CONFIG_FEATURE_LS_COLOR
if (got_color_opt) {
/* there is no way for bb_getopt_ulflags() to
* return us the argument string for long options
* which don't have a short option equivalent.
* all we can find out is that the option was
* present, and we have to rescan to find the
* argument string.
*/
got_color_opt=0;
optind = 1;
while ((i = getopt_long (argc, argv, ls_options,
ls_color_opt, NULL)) >= 0) {
if (i != 0) continue;
if (got_color_opt) {
if (!optarg || strcmp("always", optarg) == 0)
show_color = 1;
else if (strcmp("never", optarg) == 0)
show_color = 0;
else if (strcmp("auto", optarg) == 0 &&
isatty(STDOUT_FILENO))
show_color = 1;
{
/* find color bit value - last position for short getopt */
/* don't break; want to a) pick up repeated
* --color options, and b) leave optind
* set correctly when we're done.
*/
got_color_opt = 0;
}
}
#if CONFIG_FEATURE_LS_COLOR_IS_DEFAULT
} else {
/* if no option set by user, then this config option
* forces "auto", which is what busybox 1.00 and previous
* did. however, provide one more "out" for users that
* don't want color: if LS_COLOR is set, and is null or
* "none" -- then default coloring to "off".
*/
char *p;
if ((p = getenv ("LS_COLORS")) != NULL &&
(*p == '\0' || (strcmp(p, "none") == 0))) {
show_color = 0;
;
} else if (isatty(STDOUT_FILENO)) {
show_color = 1;
}
#endif
if((opt & (1 << i))) { /* next flag after short options */
if (color_opt == NULL || strcmp("always", color_opt) == 0)
show_color = 1;
else if (color_opt != NULL && strcmp("never", color_opt) == 0)
show_color = 0;
else if (color_opt != NULL && strcmp("auto", color_opt) == 0 && isatty(STDOUT_FILENO))
show_color = 1;
}
}
#endif
@ -1129,14 +1119,12 @@ extern int ls_main(int argc, char **argv)
*/
ac = argc - optind; /* how many cmd line args are left */
if (ac < 1) {
av = (char **) xcalloc((size_t) 1, (size_t) (sizeof(char *)));
av[0] = bb_xstrdup(".");
static const char * const dotdir[] = { "." };
av = (char **) dotdir;
ac = 1;
} else {
av = (char **) xcalloc((size_t) ac, (size_t) (sizeof(char *)));
for (oi = 0; oi < ac; oi++) {
av[oi] = argv[optind++]; /* copy pointer to real cmd line arg */
}
av = argv + optind;
}
/* now, everything is in the av array */
@ -1146,11 +1134,10 @@ extern int ls_main(int argc, char **argv)
/* stuff the command line file names into an dnode array */
dn = NULL;
for (oi = 0; oi < ac; oi++) {
char *fullname = bb_xstrdup(av[oi]);
cur = my_stat(fullname, fullname);
cur = my_stat(av[oi], av[oi]);
if (!cur)
continue;
cur->allocated = 0;
cur->next = dn;
dn = cur;
nfiles++;