
https://cplusplus.github.io/CWG/issues/722.html nullptr passed to a variadic function now converted to void* in C++. This does not affect C23 nullptr. Also fixes -Wformat-pedantic so that it no longer warns for nullptr passed to %p (because it is converted to void* in C++ and it is allowed for va_arg(ap, void*) in C23)
22 lines
889 B
C
22 lines
889 B
C
// RUN: %clang_cc1 -fsyntax-only -verify -Wno-format -Wformat-pedantic %s
|
|
// RUN: %clang_cc1 -xobjective-c -fblocks -fsyntax-only -verify -Wno-format -Wformat-pedantic %s
|
|
// RUN: %clang_cc1 -xc++ -fsyntax-only -verify -Wno-format -Wformat-pedantic %s
|
|
// RUN: %clang_cc1 -std=c23 -fsyntax-only -verify -Wno-format -Wformat-pedantic %s
|
|
|
|
__attribute__((format(printf, 1, 2)))
|
|
int printf(const char *restrict, ...);
|
|
|
|
int main(void) {
|
|
printf("%p", (int *)0); // expected-warning {{format specifies type 'void *' but the argument has type 'int *'}}
|
|
printf("%p", (void *)0);
|
|
|
|
#ifdef __OBJC__
|
|
printf("%p", ^{}); // expected-warning {{format specifies type 'void *' but the argument has type 'void (^)(void)'}}
|
|
printf("%p", (id)0); // expected-warning {{format specifies type 'void *' but the argument has type 'id'}}
|
|
#endif
|
|
|
|
#if !__is_identifier(nullptr)
|
|
printf("%p", nullptr);
|
|
#endif
|
|
}
|