msg_217.c revision 1.17 1 1.17 rillig /* $NetBSD: msg_217.c,v 1.17 2025/04/12 15:49:50 rillig Exp $ */
2 1.1 rillig # 3 "msg_217.c"
3 1.1 rillig
4 1.11 rillig // Test for message: function '%s' falls off bottom without returning value [217]
5 1.1 rillig
6 1.12 rillig /* lint1-extra-flags: -X 351 */
7 1.12 rillig
8 1.2 rillig int
9 1.2 rillig random(int n)
10 1.2 rillig {
11 1.2 rillig if (n < 0)
12 1.2 rillig return -3;
13 1.10 rillig }
14 1.11 rillig /* expect-1: warning: function 'random' falls off bottom without returning value [217] */
15 1.3 rillig
16 1.3 rillig /*
17 1.3 rillig * The pattern 'do { } while (0)' is often used in statement macros.
18 1.3 rillig * Putting a 'return' at the end of such a macro is legitimate, the embracing
19 1.3 rillig * 'do { } while (0)' is probably there to conform to a coding standard or
20 1.3 rillig * to otherwise reduce confusion.
21 1.3 rillig *
22 1.3 rillig * Seen in external/bsd/libevent/dist/event_tagging.c, function
23 1.3 rillig * encode_int_internal.
24 1.3 rillig *
25 1.5 rillig * Before tree.c 1.243 from 2021-03-21, lint wrongly reported that the
26 1.5 rillig * 'while 0' was unreachable. This has been fixed by allowing the 'while 0'
27 1.5 rillig * in a do-while-false loop to be unreachable. The same could be useful for a
28 1.5 rillig * do-while-true.
29 1.6 rillig *
30 1.6 rillig * Before func.c 1.83 from 2021-03-21, lint wrongly reported that the function
31 1.6 rillig * would fall off the bottom.
32 1.3 rillig */
33 1.3 rillig int
34 1.3 rillig do_while_return(int i)
35 1.3 rillig {
36 1.3 rillig do {
37 1.3 rillig return i;
38 1.5 rillig } while (0);
39 1.6 rillig }
40 1.4 rillig
41 1.4 rillig /*
42 1.4 rillig * C99 5.1.2.2.3 "Program termination" p1 defines that as a special exception,
43 1.4 rillig * the function 'main' does not have to return a value, reaching the bottom
44 1.4 rillig * is equivalent to returning 0.
45 1.4 rillig *
46 1.4 rillig * Before func.c 1.72 from 2021-02-21, lint had wrongly warned about this.
47 1.4 rillig */
48 1.4 rillig int
49 1.4 rillig main(void)
50 1.4 rillig {
51 1.4 rillig }
52 1.7 rillig
53 1.7 rillig int
54 1.7 rillig reachable_continue_leads_to_endless_loop(void)
55 1.7 rillig {
56 1.7 rillig for (;;) {
57 1.7 rillig if (1)
58 1.7 rillig continue;
59 1.7 rillig break;
60 1.7 rillig }
61 1.9 rillig }
62 1.7 rillig
63 1.7 rillig int
64 1.7 rillig unreachable_continue_falls_through(void)
65 1.7 rillig {
66 1.7 rillig for (;;) {
67 1.7 rillig if (0)
68 1.15 rillig /* expect+1: warning: 'continue' statement not reached [193] */
69 1.10 rillig continue;
70 1.7 rillig break;
71 1.7 rillig }
72 1.10 rillig }
73 1.11 rillig /* expect-1: warning: function 'unreachable_continue_falls_through' falls off bottom without returning value [217] */
74 1.13 rillig
75 1.13 rillig
76 1.13 rillig _Noreturn void noreturn_c11(void);
77 1.13 rillig [[noreturn]] void noreturn_c23(void);
78 1.13 rillig __attribute__((__noreturn__)) void noreturn_gnu_prefix(void);
79 1.13 rillig void __attribute__((__noreturn__)) noreturn_gnu_infix(void);
80 1.13 rillig void noreturn_gnu_suffix(void) __attribute__((__noreturn__));
81 1.13 rillig
82 1.13 rillig int
83 1.13 rillig call_noreturn_c11(void)
84 1.13 rillig {
85 1.13 rillig noreturn_c11();
86 1.13 rillig }
87 1.13 rillig
88 1.16 rillig inline int
89 1.13 rillig call_noreturn_c23(void)
90 1.13 rillig {
91 1.13 rillig noreturn_c23();
92 1.13 rillig }
93 1.13 rillig
94 1.13 rillig int
95 1.13 rillig call_noreturn_gnu_prefix(void)
96 1.13 rillig {
97 1.13 rillig noreturn_gnu_prefix();
98 1.13 rillig }
99 1.13 rillig
100 1.13 rillig int
101 1.13 rillig call_noreturn_gnu_infix(void)
102 1.13 rillig {
103 1.13 rillig noreturn_gnu_infix();
104 1.13 rillig }
105 1.13 rillig
106 1.13 rillig int
107 1.13 rillig call_noreturn_gnu_suffix(void)
108 1.13 rillig {
109 1.13 rillig noreturn_gnu_suffix();
110 1.13 rillig }
111 1.16 rillig
112 1.16 rillig
113 1.16 rillig double *force_function_attributes_in_diagnostic[] = {
114 1.16 rillig // Force the word 'noreturn' to occur in a diagnostic.
115 1.17 rillig /* expect+1: warning: invalid combination of 'pointer to double' and 'pointer to noreturn function(void) returning void', op 'init' [124] */
116 1.16 rillig noreturn_c23,
117 1.16 rillig // The 'inline' does affect the type of the function.
118 1.17 rillig /* expect+1: warning: invalid combination of 'pointer to double' and 'pointer to function(void) returning int', op 'init' [124] */
119 1.16 rillig call_noreturn_c23,
120 1.16 rillig };
121