Why is this a warning? I think there are many cases when is more clear to use multi-char int constants instead of "no meaning" numbers or instead of defining const variables with same value. When parsing wave/tiff/other file types is more clear to compare the read values with some 'EVAW', 'data', etc instead of their corresponding values.
Sample code:
int waveHeader = 'EVAW';
Why does this give a warning?
This warning is useful for programmers that would mistakenly write
'test'
where they should have written"test"
.This happen much more often than programmers that do actually want multi-char int constants.
According to the standard (§6.4.4.4/10)
This is valid ISO 9899:2011 C. It compiles without warning under
gcc
with-Wall
, and a “multi-character character constant” warning with-pedantic
.From Wikipedia:
For portability sake, don't use multi-character constants with integral types.
Even if you're willing to look up what behavior your implementation defines, multi-character constants will still vary with endianness.
Better to use a (POD) struct { char[4] }; ... and then use a UDL like "WAVE"_4cc to easily construct instances of that class
If you're happy you know what you're doing and can accept the portability problems, on GCC for example you can disable the warning on the command line:
I use this for my own apps to work with AVI and MP4 file headers for similar reasons to you.