mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 22:46:06 +00:00

diagnostic message are compared. If either is a substring of the other, then no error is given. This gives rise to an unexpected case: // expect-error{{candidate function has different number of parameters}} will match the following error messages from Clang: candidate function has different number of parameters (expected 1 but has 2) candidate function has different number of parameters It will also match these other error messages: candidate function function has different number of parameters number of parameters This patch will change so that the verification string must be a substring of the diagnostic message before accepting. Also, all the failing tests from this change have been corrected. Some stats from this cleanup: 87 - removed extra spaces around verification strings 70 - wording updates to diagnostics 40 - extra leading or trailing characters (typos, unmatched parens or quotes) 35 - diagnostic level was included (error:, warning:, or note:) 18 - flag name put in the warning (-Wprotocol) llvm-svn: 146619
51 lines
1.8 KiB
C
51 lines
1.8 KiB
C
// RUN: %clang_cc1 -fsyntax-only -verify %s
|
|
char *foo(float) __attribute__((__overloadable__));
|
|
|
|
void test_foo_1(float fv, double dv, float _Complex fc, double _Complex dc) {
|
|
char *cp1 = foo(fv);
|
|
char *cp2 = foo(dv);
|
|
// Note: GCC and EDG reject these two, but they are valid C99 conversions
|
|
char *cp3 = foo(fc);
|
|
char *cp4 = foo(dc);
|
|
}
|
|
|
|
int *foo(float _Complex) __attribute__((__overloadable__));
|
|
|
|
void test_foo_2(float fv, double dv, float _Complex fc, double _Complex dc) {
|
|
char *cp1 = foo(fv);
|
|
char *cp2 = foo(dv);
|
|
int *ip = foo(fc);
|
|
int *lp = foo(dc);
|
|
}
|
|
|
|
long *foo(double _Complex) __attribute__((__overloadable__));
|
|
|
|
void test_foo_3(float fv, double dv, float _Complex fc, double _Complex dc) {
|
|
char *cp1 = foo(fv);
|
|
char *cp2 = foo(dv);
|
|
int *ip = foo(fc);
|
|
long *lp = foo(dc);
|
|
}
|
|
|
|
char *promote_or_convert(double _Complex) __attribute__((__overloadable__)); // expected-note 2 {{candidate function}}
|
|
int *promote_or_convert(long double _Complex) __attribute__((__overloadable__)); // expected-note 2 {{candidate function}}
|
|
|
|
void test_promote_or_convert(float f, float _Complex fc) {
|
|
char *cp = promote_or_convert(fc); // expected-error{{call to 'promote_or_convert' is ambiguous}}
|
|
int *ip2 = promote_or_convert(f); // expected-error{{call to 'promote_or_convert' is ambiguous}}
|
|
}
|
|
|
|
char *promote_or_convert2(float) __attribute__((__overloadable__));
|
|
int *promote_or_convert2(double _Complex) __attribute__((__overloadable__));
|
|
|
|
void test_promote_or_convert2(float _Complex fc) {
|
|
int *cp = promote_or_convert2(fc);
|
|
}
|
|
|
|
char *promote_or_convert3(int _Complex) __attribute__((__overloadable__));
|
|
int *promote_or_convert3(long _Complex) __attribute__((__overloadable__));
|
|
|
|
void test_promote_or_convert3(short _Complex sc) {
|
|
char *cp = promote_or_convert3(sc);
|
|
}
|