carl9170: Fix wrong completion usage
[linux-stable.git] / scripts / coccinelle / null / badzero.cocci
blob5551da2b4fe32baaea72e0ec84c1a5b024756535
1 /// Compare pointer-typed values to NULL rather than 0
2 ///
3 //# This makes an effort to choose between !x and x == NULL.  !x is used
4 //# if it has previously been used with the function used to initialize x.
5 //# This relies on type information.  More type information can be obtained
6 //# using the option -all_includes and the option -I to specify an
7 //# include path.
8 //
9 // Confidence: High
10 // Copyright: (C) 2012 Julia Lawall, INRIA/LIP6.  GPLv2.
11 // Copyright: (C) 2012 Gilles Muller, INRIA/LiP6.  GPLv2.
12 // URL: http://coccinelle.lip6.fr/
13 // Comments: Requires Coccinelle version 1.0.0-rc20 or later
14 // Options:
16 virtual patch
17 virtual context
18 virtual org
19 virtual report
21 @initialize:ocaml@
23 let negtable = Hashtbl.create 101
25 @depends on patch@
26 expression *E;
27 identifier f;
31   (E = f(...)) ==
32 - 0
33 + NULL
35   (E = f(...)) !=
36 - 0
37 + NULL
39 - 0
40 + NULL
41   == (E = f(...))
43 - 0
44 + NULL
45   != (E = f(...))
49 @t1 depends on !patch@
50 expression *E;
51 identifier f;
52 position p;
56   (E = f(...)) ==
57 * 0@p
59   (E = f(...)) !=
60 * 0@p
62 * 0@p
63   == (E = f(...))
65 * 0@p
66   != (E = f(...))
69 @script:python depends on org@
70 p << t1.p;
73 coccilib.org.print_todo(p[0], "WARNING comparing pointer to 0")
75 @script:python depends on report@
76 p << t1.p;
79 coccilib.report.print_report(p[0], "WARNING comparing pointer to 0")
81 // Tests of returned values
83 @s@
84 identifier f;
85 expression E,E1;
88  E = f(...)
89  ... when != E = E1
90  !E
92 @script:ocaml depends on s@
93 f << s.f;
96 try let _ = Hashtbl.find negtable f in ()
97 with Not_found -> Hashtbl.add negtable f ()
99 @ r disable is_zero,isnt_zero exists @
100 expression *E;
101 identifier f;
104 E = f(...)
106 (E == 0
107 |E != 0
108 |0 == E
109 |0 != E
112 @script:ocaml@
113 f << r.f;
116 try let _ = Hashtbl.find negtable f in ()
117 with Not_found -> include_match false
119 // This rule may lead to inconsistent path problems, if E is defined in two
120 // places
121 @ depends on patch disable is_zero,isnt_zero @
122 expression *E;
123 expression E1;
124 identifier r.f;
127 E = f(...)
128 <...
130 - E == 0
131 + !E
133 - E != 0
134 + E
136 - 0 == E
137 + !E
139 - 0 != E
140 + E
142 ...>
143 ?E = E1
145 @t2 depends on !patch disable is_zero,isnt_zero @
146 expression *E;
147 expression E1;
148 identifier r.f;
149 position p1;
150 position p2;
153 E = f(...)
154 <...
156 * E == 0@p1
158 * E != 0@p2
160 * 0@p1 == E
162 * 0@p1 != E
164 ...>
165 ?E = E1
167 @script:python depends on org@
168 p << t2.p1;
171 coccilib.org.print_todo(p[0], "WARNING comparing pointer to 0, suggest !E")
173 @script:python depends on org@
174 p << t2.p2;
177 coccilib.org.print_todo(p[0], "WARNING comparing pointer to 0")
179 @script:python depends on report@
180 p << t2.p1;
183 coccilib.report.print_report(p[0], "WARNING comparing pointer to 0, suggest !E")
185 @script:python depends on report@
186 p << t2.p2;
189 coccilib.report.print_report(p[0], "WARNING comparing pointer to 0")
191 @ depends on patch disable is_zero,isnt_zero @
192 expression *E;
196   E ==
197 - 0
198 + NULL
200   E !=
201 - 0
202 + NULL
204 - 0
205 + NULL
206   == E
208 - 0
209 + NULL
210   != E
213 @ t3 depends on !patch disable is_zero,isnt_zero @
214 expression *E;
215 position p;
219 * E == 0@p
221 * E != 0@p
223 * 0@p == E
225 * 0@p != E
228 @script:python depends on org@
229 p << t3.p;
232 coccilib.org.print_todo(p[0], "WARNING comparing pointer to 0")
234 @script:python depends on report@
235 p << t3.p;
238 coccilib.report.print_report(p[0], "WARNING comparing pointer to 0")