treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / scripts / coccinelle / tests / doubletest.cocci
blobb35519cddb133db6ae9b0b62dd9ccefae6631e87
1 // SPDX-License-Identifier: GPL-2.0-only
2 /// Find &&/|| operations that include the same argument more than once
3 //# A common source of false positives is when the expression, or
4 //# another expresssion in the same && or || operation, performs a
5 //# side effect.
6 ///
7 // Confidence: Moderate
8 // Copyright: (C) 2010 Nicolas Palix, DIKU.
9 // Copyright: (C) 2010 Julia Lawall, DIKU.
10 // Copyright: (C) 2010 Gilles Muller, INRIA/LiP6.
11 // URL: http://coccinelle.lip6.fr/
12 // Comments:
13 // Options: --no-includes --include-headers
15 virtual context
16 virtual org
17 virtual report
19 @r expression@
20 expression E;
21 position p;
25  E@p || ... || E
27  E@p && ... && E
30 @bad@
31 expression r.E,e1,e2,fn;
32 position r.p;
33 assignment operator op;
37 E@p
39  <+... \(fn(...)\|e1 op e2\|e1++\|e1--\|++e1\|--e1\) ...+>
42 @depends on context && !bad@
43 expression r.E;
44 position r.p;
47 *E@p
49 @script:python depends on org && !bad@
50 p << r.p;
53 cocci.print_main("duplicated argument to && or ||",p)
55 @script:python depends on report && !bad@
56 p << r.p;
59 coccilib.report.print_report(p[0],"duplicated argument to && or ||")