changed typing of constants, to be more compatible with PCC
and future standard
This commit is contained in:
parent
3f2a4d9c7c
commit
a8703841b2
1 changed files with 13 additions and 3 deletions
|
@ -274,7 +274,9 @@ fill_int_expr(ex, ivalue, fund)
|
||||||
ex->ex_type = int_type;
|
ex->ex_type = int_type;
|
||||||
break;
|
break;
|
||||||
case LONG:
|
case LONG:
|
||||||
ex->ex_type = long_type;
|
ex->ex_type =
|
||||||
|
(ivalue & (1L << (8*long_size - 1))) ? ulong_type
|
||||||
|
: long_type;
|
||||||
break;
|
break;
|
||||||
case UNSIGNED:
|
case UNSIGNED:
|
||||||
/* We cannot make a test like
|
/* We cannot make a test like
|
||||||
|
@ -286,10 +288,18 @@ fill_int_expr(ex, ivalue, fund)
|
||||||
answer. We assume that the type "unsigned long"
|
answer. We assume that the type "unsigned long"
|
||||||
is not part of portable C !
|
is not part of portable C !
|
||||||
*/
|
*/
|
||||||
ex->ex_type = (ivalue & ~max_unsigned) ? long_type : uint_type;
|
ex->ex_type =
|
||||||
|
(ivalue & ~max_int) ?
|
||||||
|
( (ivalue & ~max_unsigned) ?
|
||||||
|
( ivalue & (1L<<(8*long_size-1)) ?
|
||||||
|
ulong_type : long_type
|
||||||
|
) : uint_type
|
||||||
|
) : int_type;
|
||||||
break;
|
break;
|
||||||
case INTEGER:
|
case INTEGER:
|
||||||
ex->ex_type = (ivalue <= max_int) ? int_type : long_type;
|
ex->ex_type = (ivalue <= max_int) ? int_type
|
||||||
|
: (ivalue & (1L << (8*long_size - 1))) ? ulong_type
|
||||||
|
: long_type;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
crash("(intexpr) bad fund %s\n", symbol2str(fund));
|
crash("(intexpr) bad fund %s\n", symbol2str(fund));
|
||||||
|
|
Loading…
Reference in a new issue