mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-13 19:24:21 +00:00
9b0a7cea0f
increasingly prevailing case to the point that new features like ARC don't even support the fragile ABI anymore. This required a little bit of reshuffling with exceptions because a check was assuming that ObjCNonFragileABI was only being set in ObjC mode, and that's actually a bit obnoxious to do. Most, though, it involved a perl script to translate a ton of test cases. Mostly no functionality change for driver users, although there are corner cases with disabling language-specific exceptions that we should handle more correctly now. llvm-svn: 140957
64 lines
3.6 KiB
Objective-C
64 lines
3.6 KiB
Objective-C
// RUN: %clang_cc1 -fsyntax-only -fobjc-arc -fobjc-runtime-has-weak -verify -fblocks -triple x86_64-apple-darwin10.0.0 %s
|
|
// RUN: %clang_cc1 -x objective-c++ -fsyntax-only -fobjc-arc -fobjc-runtime-has-weak -verify -fblocks -triple x86_64-apple-darwin10.0.0 %s
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
void *memset(void *, int, __SIZE_TYPE__);
|
|
void *memmove(void *s1, const void *s2, __SIZE_TYPE__ n);
|
|
void *memcpy(void *s1, const void *s2, __SIZE_TYPE__ n);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
void test(id __strong *sip, id __weak *wip, id __autoreleasing *aip,
|
|
id __unsafe_unretained *uip, void *ptr) {
|
|
// All okay.
|
|
memset(sip, 0, 17);
|
|
memset(wip, 0, 17);
|
|
memset(aip, 0, 17);
|
|
memset(uip, 0, 17);
|
|
|
|
memcpy(sip, ptr, 17); // expected-warning{{destination for this 'memcpy' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memcpy(wip, ptr, 17); // expected-warning{{destination for this 'memcpy' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memcpy(aip, ptr, 17); // expected-warning{{destination for this 'memcpy' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memcpy(uip, ptr, 17);
|
|
|
|
memcpy(ptr, sip, 17); // expected-warning{{source of this 'memcpy' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memcpy(ptr, wip, 17); // expected-warning{{source of this 'memcpy' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memcpy(ptr, aip, 17); // expected-warning{{source of this 'memcpy' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memcpy(ptr, uip, 17);
|
|
|
|
memmove(sip, ptr, 17); // expected-warning{{destination for this 'memmove' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memmove(wip, ptr, 17); // expected-warning{{destination for this 'memmove' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memmove(aip, ptr, 17); // expected-warning{{destination for this 'memmove' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memmove(uip, ptr, 17);
|
|
|
|
memmove(ptr, sip, 17); // expected-warning{{source of this 'memmove' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memmove(ptr, wip, 17); // expected-warning{{source of this 'memmove' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memmove(ptr, aip, 17); // expected-warning{{source of this 'memmove' call is a pointer to ownership-qualified type}} \
|
|
// expected-note{{explicitly cast the pointer to silence this warning}}
|
|
memmove(ptr, uip, 17);
|
|
}
|
|
|
|
void rdar9772982(int i, ...) {
|
|
__builtin_va_list ap;
|
|
|
|
__builtin_va_start(ap, i);
|
|
__builtin_va_arg(ap, __strong id); // expected-error{{second argument to 'va_arg' is of ARC ownership-qualified type '__strong id'}}
|
|
__builtin_va_end(ap);
|
|
}
|