Home | History | Annotate | Line # | Download | only in lint1
msg_115.c revision 1.9
      1  1.9  rillig /*	$NetBSD: msg_115.c,v 1.9 2021/08/16 16:19:47 rillig Exp $	*/
      2  1.1  rillig # 3 "msg_115.c"
      3  1.1  rillig 
      4  1.1  rillig // Test for message: %soperand of '%s' must be modifiable lvalue [115]
      5  1.1  rillig 
      6  1.2  rillig void
      7  1.2  rillig example(const int *const_ptr)
      8  1.2  rillig {
      9  1.2  rillig 
     10  1.4  rillig 	*const_ptr = 3;		/* expect: 115 */
     11  1.4  rillig 	*const_ptr += 1;	/* expect: 115 */
     12  1.4  rillig 	*const_ptr -= 4;	/* expect: 115 */
     13  1.4  rillig 	*const_ptr *= 1;	/* expect: 115 */
     14  1.4  rillig 	*const_ptr /= 5;	/* expect: 115 */
     15  1.4  rillig 	*const_ptr %= 9;	/* expect: 115 */
     16  1.4  rillig 	(*const_ptr)++;		/* expect: 115 */
     17  1.9  rillig 
     18  1.9  rillig 	/* In the next example, the left operand is not an lvalue at all. */
     19  1.9  rillig 	/* expect+1: error: left operand of '=' must be lvalue [114] */
     20  1.9  rillig 	(const_ptr + 3) = const_ptr;
     21  1.2  rillig }
     22  1.5  rillig 
     23  1.6  rillig typedef struct {
     24  1.6  rillig 	int const member;
     25  1.6  rillig } const_member;
     26  1.6  rillig 
     27  1.6  rillig void take_const_member(const_member);
     28  1.6  rillig 
     29  1.9  rillig /*
     30  1.9  rillig  * Before init.c 1.208 from 2021-08-14 and decl.c 1.221 from 2021-08-10,
     31  1.9  rillig  * lint issued a wrong "warning: left operand of '%s' must be modifiable
     32  1.9  rillig  * lvalue", even in cases where the left operand was being initialized
     33  1.9  rillig  * instead of overwritten.
     34  1.9  rillig  *
     35  1.9  rillig  * See initialization_expr_using_op, typeok_assign, has_constant_member.
     36  1.9  rillig  * See C99 6.2.5p25.
     37  1.9  rillig  */
     38  1.6  rillig const_member
     39  1.5  rillig initialize_const_struct_member(void)
     40  1.5  rillig {
     41  1.8  rillig 	/* In a simple initialization, const members can be assigned. */
     42  1.6  rillig 	const_member cm1 = (const_member) { 12345 };
     43  1.8  rillig 
     44  1.6  rillig 	if (cm1.member != 0)
     45  1.7  rillig 		/* In a function call, const members can be assigned. */
     46  1.6  rillig 		take_const_member(cm1);
     47  1.6  rillig 
     48  1.6  rillig 	struct {
     49  1.6  rillig 		const_member member;
     50  1.6  rillig 	} cm2 = {
     51  1.8  rillig 	    /* In a nested initialization, const members can be assigned. */
     52  1.6  rillig 	    cm1,
     53  1.5  rillig 	};
     54  1.6  rillig 	if (cm2.member.member != 0) {
     55  1.6  rillig 	}
     56  1.5  rillig 
     57  1.7  rillig 	/* In a return statement, const members can be assigned. */
     58  1.6  rillig 	return cm1;
     59  1.5  rillig }
     60