llvm-project/clang/test/FixIt/fixit-errors.c
Aaron Ballman 7de7161304 Use functions with prototypes when appropriate; NFC
A significant number of our tests in C accidentally use functions
without prototypes. This patch converts the function signatures to have
a prototype for the situations where the test is not specific to K&R C
declarations. e.g.,

  void func();

becomes

  void func(void);

This is the sixth batch of tests being updated (there are a significant
number of other tests left to be updated).
2022-02-09 17:16:10 -05:00

35 lines
1.2 KiB
C

// RUN: %clang_cc1 -fsyntax-only -pedantic -verify %s
// RUN: cp %s %t
// RUN: not %clang_cc1 -pedantic -fixit -x c %t
// RUN: %clang_cc1 -pedantic -Werror -Wno-invalid-noreturn -x c %t
/* This is a test of the various code modification hints that are
provided as part of warning or extension diagnostics. All of the
warnings will be fixed by -fixit, and the resulting file should
compile cleanly with -Werror -pedantic. */
struct s; // expected-note{{previous use is here}}
union s *s1; // expected-error{{use of 's' with tag type that does not match previous declaration}}
struct Point {
float x, y, z;
};
struct Point *get_origin(void);
void test_point(void) {
(void)get_origin->x; // expected-error {{base of member reference is a function; perhaps you meant to call it with no arguments?}}
}
// These errors require C11.
#if __STDC_VERSION__ > 199901L
void noreturn_1(void) _Noreturn; // expected-error {{must precede function declarator}}
void noreturn_1(void) {
return; // expected-warning {{should not return}}
}
void noreturn_2(void) _Noreturn { // expected-error {{must precede function declarator}}
return; // expected-warning {{should not return}}
}
#endif