diff options
author | Denis Vlasenko | 2008-04-14 19:50:06 +0000 |
---|---|---|
committer | Denis Vlasenko | 2008-04-14 19:50:06 +0000 |
commit | 7089c31d578d683804598b405e2cdf375cd7ce33 (patch) | |
tree | d341e2416feb70de55b9684a8d03852f5f5f404c /coreutils | |
parent | c7131c3e58c2cef17263d03ac542f7fbea1ce2db (diff) | |
download | busybox-7089c31d578d683804598b405e2cdf375cd7ce33.zip busybox-7089c31d578d683804598b405e2cdf375cd7ce33.tar.gz |
od: fix "od -b"
Diffstat (limited to 'coreutils')
-rw-r--r-- | coreutils/od_bloaty.c | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/coreutils/od_bloaty.c b/coreutils/od_bloaty.c index 942cf03..5e22875 100644 --- a/coreutils/od_bloaty.c +++ b/coreutils/od_bloaty.c @@ -508,10 +508,10 @@ check_and_close(void) } /* If S points to a single valid modern od format string, put - a description of that format in *TSPEC, make *NEXT point at the - character following the just-decoded format (if *NEXT is non-NULL), - and return zero. For example, if S were "d4afL" - *NEXT would be set to "afL" and *TSPEC would be + a description of that format in *TSPEC, return pointer to + character following the just-decoded format. + For example, if S were "d4afL", we will return a rtp to "afL" + and *TSPEC would be { fmt = SIGNED_DECIMAL; size = INT or LONG; (whichever integral_type_size[4] resolves to) @@ -521,9 +521,8 @@ check_and_close(void) S_ORIG is solely for reporting errors. It should be the full format string argument. */ -static void -decode_one_format(const char *s_orig, const char *s, const char **next, - struct tspec *tspec) +static const char * +decode_one_format(const char *s_orig, const char *s, struct tspec *tspec) { enum size_spec size_spec; unsigned size; @@ -536,7 +535,6 @@ decode_one_format(const char *s_orig, const char *s, const char **next, unsigned field_width = 0; int pos; - assert(tspec != NULL); switch (*s) { case 'd': @@ -562,13 +560,14 @@ decode_one_format(const char *s_orig, const char *s, const char **next, s = end; } } else { - static const uint8_t CSIL_sizeof[] = { + static const uint8_t CSIL_sizeof[4] = { sizeof(char), sizeof(short), sizeof(int), sizeof(long), }; size = CSIL_sizeof[p - CSIL]; + s++; /* skip C/S/I/L */ } #define ISPEC_TO_FORMAT(Spec, Min_format, Long_format, Max_format) \ @@ -716,8 +715,7 @@ decode_one_format(const char *s_orig, const char *s, const char **next, if (tspec->hexl_mode_trailer) s++; - if (next != NULL) - *next = s; + return s; } /* Decode the modern od format string S. Append the decoded @@ -733,7 +731,7 @@ decode_format_string(const char *s) struct tspec tspec; const char *next; - decode_one_format(s_orig, s, &next, &tspec); + next = decode_one_format(s_orig, s, &tspec); assert(s != next); s = next; |