diff options
-rw-r--r-- | applets/individual.c | 4 | ||||
-rw-r--r-- | coreutils/uname.c | 41 | ||||
-rw-r--r-- | editors/awk.c | 8 |
3 files changed, 24 insertions, 29 deletions
diff --git a/applets/individual.c b/applets/individual.c index 414a11b05..341f4d1c2 100644 --- a/applets/individual.c +++ b/applets/individual.c | |||
@@ -14,13 +14,11 @@ const char *applet_name; | |||
14 | int main(int argc, char **argv) | 14 | int main(int argc, char **argv) |
15 | { | 15 | { |
16 | applet_name = argv[0]; | 16 | applet_name = argv[0]; |
17 | |||
18 | return APPLET_main(argc,argv); | 17 | return APPLET_main(argc,argv); |
19 | } | 18 | } |
20 | 19 | ||
21 | void bb_show_usage(void) | 20 | void bb_show_usage(void) |
22 | { | 21 | { |
23 | printf(APPLET_full_usage "\n"); | 22 | fputs(APPLET_full_usage "\n", stdout); |
24 | |||
25 | exit(EXIT_FAILURE); | 23 | exit(EXIT_FAILURE); |
26 | } | 24 | } |
diff --git a/coreutils/uname.c b/coreutils/uname.c index 34600e7a9..76fd3ca8d 100644 --- a/coreutils/uname.c +++ b/coreutils/uname.c | |||
@@ -17,7 +17,7 @@ | |||
17 | -m, --machine sun | 17 | -m, --machine sun |
18 | -a, --all SunOS rocky8 4.0 sun | 18 | -a, --all SunOS rocky8 4.0 sun |
19 | 19 | ||
20 | The default behavior is equivalent to `-s'. | 20 | The default behavior is equivalent to '-s'. |
21 | 21 | ||
22 | David MacKenzie <djm@gnu.ai.mit.edu> */ | 22 | David MacKenzie <djm@gnu.ai.mit.edu> */ |
23 | 23 | ||
@@ -39,47 +39,43 @@ typedef struct { | |||
39 | } uname_info_t; | 39 | } uname_info_t; |
40 | 40 | ||
41 | static const char options[] ALIGN1 = "snrvmpa"; | 41 | static const char options[] ALIGN1 = "snrvmpa"; |
42 | static const unsigned short utsname_offset[] ALIGN2 = { | 42 | static const unsigned short utsname_offset[] = { |
43 | offsetof(uname_info_t,name.sysname), | 43 | offsetof(uname_info_t, name.sysname), |
44 | offsetof(uname_info_t,name.nodename), | 44 | offsetof(uname_info_t, name.nodename), |
45 | offsetof(uname_info_t,name.release), | 45 | offsetof(uname_info_t, name.release), |
46 | offsetof(uname_info_t,name.version), | 46 | offsetof(uname_info_t, name.version), |
47 | offsetof(uname_info_t,name.machine), | 47 | offsetof(uname_info_t, name.machine), |
48 | offsetof(uname_info_t,processor) | 48 | offsetof(uname_info_t, processor) |
49 | }; | 49 | }; |
50 | 50 | ||
51 | int uname_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; | 51 | int uname_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; |
52 | int uname_main(int argc, char **argv) | 52 | int uname_main(int argc ATTRIBUTE_UNUSED, char **argv) |
53 | { | 53 | { |
54 | uname_info_t uname_info; | 54 | uname_info_t uname_info; |
55 | #if defined(__sparc__) && defined(__linux__) | 55 | #if defined(__sparc__) && defined(__linux__) |
56 | char *fake_sparc = getenv("FAKE_SPARC"); | 56 | char *fake_sparc = getenv("FAKE_SPARC"); |
57 | #endif | 57 | #endif |
58 | const unsigned short int *delta; | 58 | const unsigned short *delta; |
59 | char toprint; | 59 | char toprint; |
60 | 60 | ||
61 | toprint = getopt32(argv, options); | 61 | toprint = getopt32(argv, options); |
62 | 62 | ||
63 | if (argc != optind) { | 63 | if (argv[optind]) { /* coreutils-6.9 compat */ |
64 | bb_show_usage(); | 64 | bb_show_usage(); |
65 | } | 65 | } |
66 | 66 | ||
67 | if (toprint & (1 << 6)) { | 67 | if (toprint & (1 << 6)) { /* -a => all opts on */ |
68 | toprint = 0x3f; | 68 | toprint = 0x3f; |
69 | } | 69 | } |
70 | 70 | ||
71 | if (toprint == 0) { | 71 | if (toprint == 0) { /* no opts => -s (sysname) */ |
72 | toprint = 1; /* sysname */ | 72 | toprint = 1; |
73 | } | 73 | } |
74 | 74 | ||
75 | if (uname(&uname_info.name) == -1) { | 75 | uname(&uname_info.name); /* never fails */ |
76 | bb_error_msg_and_die("cannot get system name"); | ||
77 | } | ||
78 | 76 | ||
79 | #if defined(__sparc__) && defined(__linux__) | 77 | #if defined(__sparc__) && defined(__linux__) |
80 | if ((fake_sparc != NULL) | 78 | if (fake_sparc && (fake_sparc[0] | 0x20) == 'y') { |
81 | && ((fake_sparc[0] == 'y') | ||
82 | || (fake_sparc[0] == 'Y'))) { | ||
83 | strcpy(uname_info.name.machine, "sparc"); | 79 | strcpy(uname_info.name.machine, "sparc"); |
84 | } | 80 | } |
85 | #endif | 81 | #endif |
@@ -89,7 +85,8 @@ int uname_main(int argc, char **argv) | |||
89 | delta = utsname_offset; | 85 | delta = utsname_offset; |
90 | do { | 86 | do { |
91 | if (toprint & 1) { | 87 | if (toprint & 1) { |
92 | printf("%s", ((char *)(&uname_info)) + *delta); | 88 | /* printf would not be safe here */ |
89 | fputs((char *)(&uname_info) + *delta, stdout); | ||
93 | if (toprint > 1) { | 90 | if (toprint > 1) { |
94 | bb_putchar(' '); | 91 | bb_putchar(' '); |
95 | } | 92 | } |
@@ -98,5 +95,5 @@ int uname_main(int argc, char **argv) | |||
98 | } while (toprint >>= 1); | 95 | } while (toprint >>= 1); |
99 | bb_putchar('\n'); | 96 | bb_putchar('\n'); |
100 | 97 | ||
101 | fflush_stdout_and_exit(EXIT_SUCCESS); | 98 | fflush_stdout_and_exit(EXIT_SUCCESS); /* coreutils-6.9 compat */ |
102 | } | 99 | } |
diff --git a/editors/awk.c b/editors/awk.c index cc5dc84b5..44b747b29 100644 --- a/editors/awk.c +++ b/editors/awk.c | |||
@@ -852,11 +852,11 @@ static var *nvalloc(int n) | |||
852 | 852 | ||
853 | if (!g_cb) { | 853 | if (!g_cb) { |
854 | size = (n <= MINNVBLOCK) ? MINNVBLOCK : n; | 854 | size = (n <= MINNVBLOCK) ? MINNVBLOCK : n; |
855 | g_cb = xmalloc(sizeof(nvblock) + size * sizeof(var)); | 855 | g_cb = xzalloc(sizeof(nvblock) + size * sizeof(var)); |
856 | g_cb->size = size; | 856 | g_cb->size = size; |
857 | g_cb->pos = g_cb->nv; | 857 | g_cb->pos = g_cb->nv; |
858 | g_cb->prev = pb; | 858 | g_cb->prev = pb; |
859 | g_cb->next = NULL; | 859 | /*g_cb->next = NULL; - xzalloc did it */ |
860 | if (pb) pb->next = g_cb; | 860 | if (pb) pb->next = g_cb; |
861 | } | 861 | } |
862 | 862 | ||
@@ -2028,9 +2028,9 @@ static var *exec_builtin(node *op, var *res) | |||
2028 | if (i < 0) i = 0; | 2028 | if (i < 0) i = 0; |
2029 | n = (nargs > 2) ? getvar_i(av[2]) : l-i; | 2029 | n = (nargs > 2) ? getvar_i(av[2]) : l-i; |
2030 | if (n < 0) n = 0; | 2030 | if (n < 0) n = 0; |
2031 | s = xmalloc(n+1); | 2031 | s = xzalloc(n + 1); |
2032 | strncpy(s, as[0]+i, n); | 2032 | strncpy(s, as[0]+i, n); |
2033 | s[n] = '\0'; | 2033 | /*s[n] = '\0'; - xzalloc did it */ |
2034 | setvar_p(res, s); | 2034 | setvar_p(res, s); |
2035 | break; | 2035 | break; |
2036 | 2036 | ||