uname,individual: fix improper printf usage
uname,awk: small code shrink function old new delta uname_main 175 166 -9 nvalloc 167 157 -10 evaluate 6381 6370 -11 ------------------------------------------------------------------------------ (add/remove: 0/0 grow/shrink: 0/3 up/down: 0/-30) Total: -30 bytes
This commit is contained in:
parent
d4f72438e4
commit
e0a7fc54eb
@ -14,13 +14,11 @@ const char *applet_name;
|
|||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
applet_name = argv[0];
|
applet_name = argv[0];
|
||||||
|
|
||||||
return APPLET_main(argc,argv);
|
return APPLET_main(argc,argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
void bb_show_usage(void)
|
void bb_show_usage(void)
|
||||||
{
|
{
|
||||||
printf(APPLET_full_usage "\n");
|
fputs(APPLET_full_usage "\n", stdout);
|
||||||
|
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
-m, --machine sun
|
-m, --machine sun
|
||||||
-a, --all SunOS rocky8 4.0 sun
|
-a, --all SunOS rocky8 4.0 sun
|
||||||
|
|
||||||
The default behavior is equivalent to `-s'.
|
The default behavior is equivalent to '-s'.
|
||||||
|
|
||||||
David MacKenzie <djm@gnu.ai.mit.edu> */
|
David MacKenzie <djm@gnu.ai.mit.edu> */
|
||||||
|
|
||||||
@ -39,47 +39,43 @@ typedef struct {
|
|||||||
} uname_info_t;
|
} uname_info_t;
|
||||||
|
|
||||||
static const char options[] ALIGN1 = "snrvmpa";
|
static const char options[] ALIGN1 = "snrvmpa";
|
||||||
static const unsigned short utsname_offset[] ALIGN2 = {
|
static const unsigned short utsname_offset[] = {
|
||||||
offsetof(uname_info_t,name.sysname),
|
offsetof(uname_info_t, name.sysname),
|
||||||
offsetof(uname_info_t,name.nodename),
|
offsetof(uname_info_t, name.nodename),
|
||||||
offsetof(uname_info_t,name.release),
|
offsetof(uname_info_t, name.release),
|
||||||
offsetof(uname_info_t,name.version),
|
offsetof(uname_info_t, name.version),
|
||||||
offsetof(uname_info_t,name.machine),
|
offsetof(uname_info_t, name.machine),
|
||||||
offsetof(uname_info_t,processor)
|
offsetof(uname_info_t, processor)
|
||||||
};
|
};
|
||||||
|
|
||||||
int uname_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
|
int uname_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
|
||||||
int uname_main(int argc, char **argv)
|
int uname_main(int argc ATTRIBUTE_UNUSED, char **argv)
|
||||||
{
|
{
|
||||||
uname_info_t uname_info;
|
uname_info_t uname_info;
|
||||||
#if defined(__sparc__) && defined(__linux__)
|
#if defined(__sparc__) && defined(__linux__)
|
||||||
char *fake_sparc = getenv("FAKE_SPARC");
|
char *fake_sparc = getenv("FAKE_SPARC");
|
||||||
#endif
|
#endif
|
||||||
const unsigned short int *delta;
|
const unsigned short *delta;
|
||||||
char toprint;
|
char toprint;
|
||||||
|
|
||||||
toprint = getopt32(argv, options);
|
toprint = getopt32(argv, options);
|
||||||
|
|
||||||
if (argc != optind) {
|
if (argv[optind]) { /* coreutils-6.9 compat */
|
||||||
bb_show_usage();
|
bb_show_usage();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (toprint & (1 << 6)) {
|
if (toprint & (1 << 6)) { /* -a => all opts on */
|
||||||
toprint = 0x3f;
|
toprint = 0x3f;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (toprint == 0) {
|
if (toprint == 0) { /* no opts => -s (sysname) */
|
||||||
toprint = 1; /* sysname */
|
toprint = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (uname(&uname_info.name) == -1) {
|
uname(&uname_info.name); /* never fails */
|
||||||
bb_error_msg_and_die("cannot get system name");
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(__sparc__) && defined(__linux__)
|
#if defined(__sparc__) && defined(__linux__)
|
||||||
if ((fake_sparc != NULL)
|
if (fake_sparc && (fake_sparc[0] | 0x20) == 'y') {
|
||||||
&& ((fake_sparc[0] == 'y')
|
|
||||||
|| (fake_sparc[0] == 'Y'))) {
|
|
||||||
strcpy(uname_info.name.machine, "sparc");
|
strcpy(uname_info.name.machine, "sparc");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -89,7 +85,8 @@ int uname_main(int argc, char **argv)
|
|||||||
delta = utsname_offset;
|
delta = utsname_offset;
|
||||||
do {
|
do {
|
||||||
if (toprint & 1) {
|
if (toprint & 1) {
|
||||||
printf("%s", ((char *)(&uname_info)) + *delta);
|
/* printf would not be safe here */
|
||||||
|
fputs((char *)(&uname_info) + *delta, stdout);
|
||||||
if (toprint > 1) {
|
if (toprint > 1) {
|
||||||
bb_putchar(' ');
|
bb_putchar(' ');
|
||||||
}
|
}
|
||||||
@ -98,5 +95,5 @@ int uname_main(int argc, char **argv)
|
|||||||
} while (toprint >>= 1);
|
} while (toprint >>= 1);
|
||||||
bb_putchar('\n');
|
bb_putchar('\n');
|
||||||
|
|
||||||
fflush_stdout_and_exit(EXIT_SUCCESS);
|
fflush_stdout_and_exit(EXIT_SUCCESS); /* coreutils-6.9 compat */
|
||||||
}
|
}
|
||||||
|
@ -852,11 +852,11 @@ static var *nvalloc(int n)
|
|||||||
|
|
||||||
if (!g_cb) {
|
if (!g_cb) {
|
||||||
size = (n <= MINNVBLOCK) ? MINNVBLOCK : n;
|
size = (n <= MINNVBLOCK) ? MINNVBLOCK : n;
|
||||||
g_cb = xmalloc(sizeof(nvblock) + size * sizeof(var));
|
g_cb = xzalloc(sizeof(nvblock) + size * sizeof(var));
|
||||||
g_cb->size = size;
|
g_cb->size = size;
|
||||||
g_cb->pos = g_cb->nv;
|
g_cb->pos = g_cb->nv;
|
||||||
g_cb->prev = pb;
|
g_cb->prev = pb;
|
||||||
g_cb->next = NULL;
|
/*g_cb->next = NULL; - xzalloc did it */
|
||||||
if (pb) pb->next = g_cb;
|
if (pb) pb->next = g_cb;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2028,9 +2028,9 @@ static var *exec_builtin(node *op, var *res)
|
|||||||
if (i < 0) i = 0;
|
if (i < 0) i = 0;
|
||||||
n = (nargs > 2) ? getvar_i(av[2]) : l-i;
|
n = (nargs > 2) ? getvar_i(av[2]) : l-i;
|
||||||
if (n < 0) n = 0;
|
if (n < 0) n = 0;
|
||||||
s = xmalloc(n+1);
|
s = xzalloc(n + 1);
|
||||||
strncpy(s, as[0]+i, n);
|
strncpy(s, as[0]+i, n);
|
||||||
s[n] = '\0';
|
/*s[n] = '\0'; - xzalloc did it */
|
||||||
setvar_p(res, s);
|
setvar_p(res, s);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user