summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2001-01-02 15:48:21 +0000
committerJim Meyering <jim@meyering.net>2001-01-02 15:48:21 +0000
commit22fc5f7ac91831c6e7f1c9edbe1cee3e8757036f (patch)
treef74b7e807e266a9b11c92ee67d92acc7ed8b4e94
parent4dcf0e2c7b2fa0dba69554fa05b6d9d1c67d88ed (diff)
downloadcoreutils-22fc5f7ac91831c6e7f1c9edbe1cee3e8757036f.tar.xz
(ulonglong_t): Define place-holder type to avoid some #if directives.
(LONGEST_INTEGRAL_TYPE): Remove definition. (MAX_INTEGRAL_TYPE_SIZE): Use ulonglong_t instead of LONGEST_INTEGRAL_TYPE. (print_long_long): Compile this function even on systems without long long support. (decode_one_format): Remove #if directive.
-rw-r--r--src/od.c20
1 files changed, 9 insertions, 11 deletions
diff --git a/src/od.c b/src/od.c
index 84c10597e..3f16e3110 100644
--- a/src/od.c
+++ b/src/od.c
@@ -226,12 +226,14 @@ static FILE *in_stream;
static int have_read_stdin;
#if HAVE_UNSIGNED_LONG_LONG
-# define LONGEST_INTEGRAL_TYPE unsigned long long
+typedef unsigned long long ulonglong_t;
#else
-# define LONGEST_INTEGRAL_TYPE long int
+/* This is just a place-holder to avoid a few `#if' directives.
+ In this case, the type isn't actually used. */
+typedef unsigned long int ulonglong_t;
#endif
-#define MAX_INTEGRAL_TYPE_SIZE sizeof(LONGEST_INTEGRAL_TYPE)
+#define MAX_INTEGRAL_TYPE_SIZE sizeof (ulonglong_t)
static enum size_spec integral_type_size[MAX_INTEGRAL_TYPE_SIZE + 1];
#define MAX_FP_TYPE_SIZE sizeof(LONG_DOUBLE)
@@ -435,19 +437,17 @@ print_long (off_t n_bytes, const char *block, const char *fmt_string)
}
}
-#if HAVE_UNSIGNED_LONG_LONG
static void
print_long_long (off_t n_bytes, const char *block, const char *fmt_string)
{
off_t i;
- for (i = n_bytes / sizeof (unsigned long long); i > 0; i--)
+ for (i = n_bytes / sizeof (ulonglong_t); i > 0; i--)
{
- unsigned long long tmp = *(const unsigned long long *) block;
+ ulonglong_t tmp = *(const ulonglong_t *) block;
printf (fmt_string, tmp);
- block += sizeof (unsigned long long);
+ block += sizeof (ulonglong_t);
}
}
-#endif
static void
print_float (off_t n_bytes, const char *block, const char *fmt_string)
@@ -764,9 +764,7 @@ this system doesn't provide a %lu-byte integral type"), s_orig, size);
break;
case LONG_LONG:
-#if HAVE_UNSIGNED_LONG_LONG
print_function = print_long_long;
-#endif
break;
default:
@@ -1636,7 +1634,7 @@ main (int argc, char **argv)
integral_type_size[sizeof (int)] = INT;
integral_type_size[sizeof (long int)] = LONG;
#if HAVE_UNSIGNED_LONG_LONG
- integral_type_size[sizeof (long long)] = LONG_LONG;
+ integral_type_size[sizeof (ulonglong_t)] = LONG_LONG;
#endif
for (i = 0; i <= MAX_FP_TYPE_SIZE; i++)