[Bug libc/16458] endian.h macros return integers of wrong type
neleai at seznam dot cz
sourceware-bugzilla@sourceware.org
Thu Jan 16 15:09:00 GMT 2014
https://sourceware.org/bugzilla/show_bug.cgi?id=16458
Ondrej Bilka <neleai at seznam dot cz> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|REOPENED |RESOLVED
Resolution|--- |INVALID
--- Comment #3 from Ondrej Bilka <neleai at seznam dot cz> ---
> The manpage also explicitly says these are functions, not macros. And if these
> were functions, they would in fact return values of the correct type,
> regardless of the argument and parameter type, which is what the developer
> expects in C. The only constraint being that "each argument shall have a type
> such that its value may be assigned to an object with the unqualified version
> of the type of its corresponding parameter" (i.e. ISO/IEC 9899:1999 6.5.2.2
> Function calls
You are wrong here, A example that you supplied is invalid and you get same
warning with ordinary functions. Closing.
#include <stdint.h>
uint64_t foo(uint64_t bar)
{
return bar;
}
int main() {
const long int i = 42;
const uint64_t b = foo(i);
return (int) b;
}
--
You are receiving this mail because:
You are on the CC list for the bug.
More information about the Glibc-bugs
mailing list