Home | History | Annotate | Line # | Download | only in lint1
msg_323.c revision 1.5
      1  1.5  rillig /*	$NetBSD: msg_323.c,v 1.5 2023/03/28 14:44:35 rillig Exp $	*/
      2  1.1  rillig # 3 "msg_323.c"
      3  1.1  rillig 
      4  1.1  rillig // Test for message: continue in 'do ... while (0)' loop [323]
      5  1.4  rillig 
      6  1.5  rillig /* lint1-extra-flags: -X 351 */
      7  1.5  rillig 
      8  1.3  rillig void println(const char *);
      9  1.1  rillig 
     10  1.4  rillig /*
     11  1.4  rillig  * In simple cases of a do-while-0 loop, the statements 'break' and
     12  1.4  rillig  * 'continue' have the same effect, and 'break' is much more common.
     13  1.4  rillig  *
     14  1.4  rillig  * This is also covered by Clang-Tidy.
     15  1.4  rillig  */
     16  1.4  rillig void
     17  1.4  rillig simple_case(const char *p)
     18  1.4  rillig {
     19  1.4  rillig 	do {
     20  1.4  rillig 		if (p[0] == '+')
     21  1.4  rillig 			break;
     22  1.4  rillig 		if (p[1] == '-')
     23  1.4  rillig 			continue;
     24  1.4  rillig 		println("no sign");
     25  1.4  rillig 	/* expect+1: error: continue in 'do ... while (0)' loop [323] */
     26  1.4  rillig 	} while (0);
     27  1.4  rillig }
     28  1.4  rillig 
     29  1.4  rillig /*
     30  1.4  rillig  * If there is a 'switch' statement inside the do-while-0 loop, the 'break'
     31  1.4  rillig  * statement is tied to the 'switch' statement instead of the loop.
     32  1.4  rillig  */
     33  1.3  rillig void
     34  1.4  rillig nested_switch(const char *p)
     35  1.3  rillig {
     36  1.3  rillig 	do {
     37  1.3  rillig 		switch (*p) {
     38  1.3  rillig 		case 'a':
     39  1.3  rillig 			continue;	/* leaves the 'do while 0' */
     40  1.3  rillig 		case 'b':
     41  1.3  rillig 			break;		/* leaves the 'switch' */
     42  1.3  rillig 		}
     43  1.3  rillig 		println("b");
     44  1.3  rillig 	/* XXX: Is that really worth an error? */
     45  1.3  rillig 	/* expect+1: error: continue in 'do ... while (0)' loop [323] */
     46  1.3  rillig 	} while (0);
     47  1.3  rillig }
     48  1.4  rillig 
     49  1.4  rillig /*
     50  1.4  rillig  * In a nested loop, the 'continue' statement is bound to the inner loop,
     51  1.4  rillig  * thus no warning.
     52  1.4  rillig  */
     53  1.4  rillig void
     54  1.4  rillig nested_for(void)
     55  1.4  rillig {
     56  1.4  rillig 	do {
     57  1.4  rillig 		for (int i = 0; i < 6; i++) {
     58  1.4  rillig 			if (i < 3)
     59  1.4  rillig 				continue;
     60  1.4  rillig 		}
     61  1.4  rillig 	} while (0);
     62  1.4  rillig }
     63