1
1
/* intprops.h -- properties of integer types
3
Copyright (C) 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
3
Copyright (C) 2001, 2002, 2003, 2004, 2005, 2009, 2010 Free Software
5
6
This program is free software: you can redistribute it and/or modify
6
7
it under the terms of the GNU General Public License as published by
18
19
/* Written by Paul Eggert. */
22
# define GL_INTPROPS_H
22
26
/* The extra casts in the following macros work around compiler bugs,
23
27
e.g., in Cray C 5.0.3.0. */
25
29
/* True if the arithmetic type T is an integer type. bool counts as
27
#define TYPE_IS_INTEGER(t) ((t) 1.5 == 1)
31
# define TYPE_IS_INTEGER(t) ((t) 1.5 == 1)
29
33
/* True if negative values of the signed integer type T use two's
30
34
complement, ones' complement, or signed magnitude representation,
31
35
respectively. Much GNU code assumes two's complement, but some
32
36
people like to be portable to all possible C hosts. */
33
#define TYPE_TWOS_COMPLEMENT(t) ((t) ~ (t) 0 == (t) -1)
34
#define TYPE_ONES_COMPLEMENT(t) ((t) ~ (t) 0 == 0)
35
#define TYPE_SIGNED_MAGNITUDE(t) ((t) ~ (t) 0 < (t) -1)
37
# define TYPE_TWOS_COMPLEMENT(t) ((t) ~ (t) 0 == (t) -1)
38
# define TYPE_ONES_COMPLEMENT(t) ((t) ~ (t) 0 == 0)
39
# define TYPE_SIGNED_MAGNITUDE(t) ((t) ~ (t) 0 < (t) -1)
37
41
/* True if the arithmetic type T is signed. */
38
#define TYPE_SIGNED(t) (! ((t) 0 < (t) -1))
42
# define TYPE_SIGNED(t) (! ((t) 0 < (t) -1))
40
44
/* The maximum and minimum values for the integer type T. These
41
45
macros have undefined behavior if T is signed and has padding bits.
42
46
If this is a problem for you, please let us know how to fix it for
44
#define TYPE_MINIMUM(t) \
45
((t) (! TYPE_SIGNED (t) \
47
: TYPE_SIGNED_MAGNITUDE (t) \
49
: ~ (t) 0 << (sizeof (t) * CHAR_BIT - 1)))
50
#define TYPE_MAXIMUM(t) \
51
((t) (! TYPE_SIGNED (t) \
53
: ~ (~ (t) 0 << (sizeof (t) * CHAR_BIT - 1))))
48
# define TYPE_MINIMUM(t) \
49
((t) (! TYPE_SIGNED (t) \
51
: TYPE_SIGNED_MAGNITUDE (t) \
53
: ~ (t) 0 << (sizeof (t) * CHAR_BIT - 1)))
54
# define TYPE_MAXIMUM(t) \
55
((t) (! TYPE_SIGNED (t) \
57
: ~ (~ (t) 0 << (sizeof (t) * CHAR_BIT - 1))))
55
59
/* Return zero if T can be determined to be an unsigned type.
56
60
Otherwise, return 1.
58
62
tighter bound. Otherwise, it overestimates the true bound by one byte
59
63
when applied to unsigned types of size 2, 4, 16, ... bytes.
60
64
The symbol signed_type_or_expr__ is private to this header file. */
62
# define signed_type_or_expr__(t) TYPE_SIGNED (__typeof__ (t))
64
# define signed_type_or_expr__(t) 1
66
# define signed_type_or_expr__(t) TYPE_SIGNED (__typeof__ (t))
68
# define signed_type_or_expr__(t) 1
67
71
/* Bound on length of the string representing an integer type or expression T.
68
72
Subtract 1 for the sign bit if T is signed; log10 (2.0) < 146/485;
69
73
add 1 for integer division truncation; add 1 more for a minus sign
71
#define INT_STRLEN_BOUND(t) \
75
# define INT_STRLEN_BOUND(t) \
72
76
((sizeof (t) * CHAR_BIT - signed_type_or_expr__ (t)) * 146 / 485 \
73
77
+ signed_type_or_expr__ (t) + 1)
75
79
/* Bound on buffer size needed to represent an integer type or expression T,
76
80
including the terminating null. */
77
#define INT_BUFSIZE_BOUND(t) (INT_STRLEN_BOUND (t) + 1)
81
# define INT_BUFSIZE_BOUND(t) (INT_STRLEN_BOUND (t) + 1)
83
#endif /* GL_INTPROPS_H */