[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1408792831-25615-1-git-send-email-Julia.Lawall@lip6.fr>
Date: Sat, 23 Aug 2014 13:20:22 +0200
From: Julia Lawall <Julia.Lawall@...6.fr>
To: dri-devel@...ts.freedesktop.org
Cc: josh@...htriplett.org, kernel-janitors@...r.kernel.org,
linux-nfc@...ts.01.org, linux-wireless@...r.kernel.org,
linux-fbdev@...r.kernel.org, linux-kernel@...r.kernel.org,
linux-media@...r.kernel.org, linux-pwm@...r.kernel.org,
devel@...verdev.osuosl.org, linux-omap@...r.kernel.org,
rtc-linux@...glegroups.com
Subject: [PATCH 0/9] use c99 initializers in structures
These patches add labels in the initializations of structure fields (c99
initializers). The complete semantic patch thta makes this change is shown
below. This rule ignores cases where the initialization is just 0 or NULL,
where some of the fields already use labels, and where there are nested
structures.
// <smpl>
@ok1@
identifier i1,i2;
position p;
@@
struct i1 i2@p = { \(0\|NULL\) };
@ok2@
identifier i1,i2,i3;
position p;
expression e;
@@
struct i1 i2@p = { ..., .i3 = e, ... };
@ok3@
identifier i1,i2;
position p;
@@
struct i1 i2@p = { ..., { ... }, ... };
@decl@
identifier i1,fld;
type T;
field list[n] fs;
@@
struct i1 {
fs
T fld;
...};
@bad@
identifier decl.i1,i2;
expression e;
position p != {ok1.p,ok2.p,ok3.p};
constant nm;
initializer list[decl.n] is;
position fix;
@@
struct i1 i2@p = { is,
(
nm(...)
|
e@fix
)
,...};
@@
identifier decl.i1,i2,decl.fld;
expression e;
position bad.p, bad.fix;
@@
struct i1 i2@p = { ...,
+ .fld = e
- e@fix
,...};
// </smpl>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists