mirror of
https://github.com/mirror/tinycc.git
synced 2025-01-15 05:20:06 +08:00
String literals are always const
Don't make the standard mandated types of string literals depends on warning options. Instead make them always const, but limit the emission of the warning by that option.
This commit is contained in:
parent
b68df809eb
commit
d4fe9aba3f
4
tccgen.c
4
tccgen.c
@ -2829,7 +2829,8 @@ static void gen_assign_cast(CType *dt)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* check const and volatile */
|
/* check const and volatile */
|
||||||
if ((!(type1->t & VT_CONSTANT) && (type2->t & VT_CONSTANT)) ||
|
if ((!(type1->t & VT_CONSTANT) && (type2->t & VT_CONSTANT) &&
|
||||||
|
((type2->t & VT_BTYPE) != VT_BYTE || tcc_state->warn_write_strings)) ||
|
||||||
(!(type1->t & VT_VOLATILE) && (type2->t & VT_VOLATILE)))
|
(!(type1->t & VT_VOLATILE) && (type2->t & VT_VOLATILE)))
|
||||||
tcc_warning("assignment discards qualifiers from pointer target type");
|
tcc_warning("assignment discards qualifiers from pointer target type");
|
||||||
break;
|
break;
|
||||||
@ -4381,7 +4382,6 @@ ST_FUNC void unary(void)
|
|||||||
/* string parsing */
|
/* string parsing */
|
||||||
t = VT_BYTE;
|
t = VT_BYTE;
|
||||||
str_init:
|
str_init:
|
||||||
if (tcc_state->warn_write_strings)
|
|
||||||
t |= VT_CONSTANT;
|
t |= VT_CONSTANT;
|
||||||
type.t = t;
|
type.t = t;
|
||||||
mk_pointer(&type);
|
mk_pointer(&type);
|
||||||
|
Loading…
Reference in New Issue
Block a user