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