diff options
author | Ben Pfaff <blp@nicira.com> | 2011-04-01 10:20:17 -0700 |
---|---|---|
committer | Ben Pfaff <blp@nicira.com> | 2011-04-04 10:58:54 -0700 |
commit | 67a51a1d851df25eebc676cf24bbb0f821d1c736 (patch) | |
tree | 418339101ae358aa77014b492d29c67d6a0f060d | |
parent | fe1e967e3bc6c04f773b150fbb358b2350d0ad8c (diff) |
type-props: New macro for estimating length of a decimal integer.
-rw-r--r-- | lib/type-props.h | 9 | ||||
-rw-r--r-- | tests/test-type-props.c | 13 |
2 files changed, 19 insertions, 3 deletions
diff --git a/lib/type-props.h b/lib/type-props.h index efaf4a5d..92250417 100644 --- a/lib/type-props.h +++ b/lib/type-props.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008 Nicira Networks. + * Copyright (c) 2008, 2011 Nicira Networks. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -29,4 +29,11 @@ ? ~(~(TYPE)0 << TYPE_VALUE_BITS(TYPE)) \ : (TYPE)-1) +/* Number of decimal digits required to format an integer of the given TYPE. + * Includes space for a sign, if TYPE is signed, but not for a null + * terminator. + * + * The value is an overestimate. */ +#define INT_STRLEN(TYPE) (TYPE_IS_SIGNED(TYPE) + TYPE_VALUE_BITS(TYPE) / 3 + 1) + #endif /* type-props.h */ diff --git a/tests/test-type-props.c b/tests/test-type-props.c index 0a1d3fd3..3c5ff6ae 100644 --- a/tests/test-type-props.c +++ b/tests/test-type-props.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2009 Nicira Networks. + * Copyright (c) 2008, 2009, 2011 Nicira Networks. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -16,8 +16,10 @@ #include <config.h> #include "type-props.h" +#include <inttypes.h> #include <stdio.h> #include <stdlib.h> +#include <string.h> #define MUST_SUCCEED(EXPRESSION) \ if (!(EXPRESSION)) { \ @@ -30,11 +32,18 @@ MUST_SUCCEED(TYPE_IS_INTEGER(type)); \ MUST_SUCCEED(TYPE_IS_SIGNED(type) == is_signed); \ MUST_SUCCEED(TYPE_MAXIMUM(type) == maximum); \ - MUST_SUCCEED(TYPE_MINIMUM(type) == minimum); + MUST_SUCCEED(TYPE_MINIMUM(type) == minimum); \ + sprintf(max_s, "%"PRIuMAX, (uintmax_t) (maximum)); \ + MUST_SUCCEED(strlen(max_s) <= INT_STRLEN(type)); \ + sprintf(min_s, "%"PRIdMAX, (intmax_t) (minimum)); \ + MUST_SUCCEED(strlen(min_s) <= INT_STRLEN(type)); int main (void) { + char max_s[128]; + char min_s[128]; + TEST_TYPE(char, CHAR_MIN, CHAR_MAX, (CHAR_MIN < 0)); TEST_TYPE(signed char, SCHAR_MIN, SCHAR_MAX, 1); |