2019-06-04 16:11:38 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2014-06-02 02:12:31 +08:00
|
|
|
///
|
2015-05-10 04:09:28 +08:00
|
|
|
/// Remove unneeded variable used to store return value.
|
2014-06-02 02:12:31 +08:00
|
|
|
///
|
|
|
|
// Confidence: Moderate
|
2019-06-04 16:11:38 +08:00
|
|
|
// Copyright: (C) 2012 Peter Senna Tschudin, INRIA/LIP6.
|
2014-06-02 02:12:31 +08:00
|
|
|
// URL: http://coccinelle.lip6.fr/
|
|
|
|
// Comments: Comments on code can be deleted if near code that is removed.
|
|
|
|
// "when strict" can be removed to get more hits, but adds false
|
|
|
|
// positives
|
|
|
|
// Options: --no-includes --include-headers
|
|
|
|
|
|
|
|
virtual patch
|
|
|
|
virtual report
|
|
|
|
virtual context
|
|
|
|
virtual org
|
|
|
|
|
|
|
|
@depends on patch@
|
|
|
|
type T;
|
|
|
|
constant C;
|
|
|
|
identifier ret;
|
|
|
|
@@
|
|
|
|
- T ret = C;
|
|
|
|
... when != ret
|
|
|
|
when strict
|
|
|
|
return
|
|
|
|
- ret
|
|
|
|
+ C
|
|
|
|
;
|
|
|
|
|
|
|
|
@depends on context@
|
|
|
|
type T;
|
|
|
|
constant C;
|
|
|
|
identifier ret;
|
|
|
|
@@
|
|
|
|
* T ret = C;
|
|
|
|
... when != ret
|
|
|
|
when strict
|
|
|
|
* return ret;
|
|
|
|
|
|
|
|
@r1 depends on report || org@
|
|
|
|
type T;
|
|
|
|
constant C;
|
|
|
|
identifier ret;
|
|
|
|
position p1, p2;
|
|
|
|
@@
|
|
|
|
T ret@p1 = C;
|
|
|
|
... when != ret
|
|
|
|
when strict
|
|
|
|
return ret@p2;
|
|
|
|
|
|
|
|
@script:python depends on report@
|
|
|
|
p1 << r1.p1;
|
|
|
|
p2 << r1.p2;
|
|
|
|
C << r1.C;
|
|
|
|
ret << r1.ret;
|
|
|
|
@@
|
|
|
|
coccilib.report.print_report(p1[0], "Unneeded variable: \"" + ret + "\". Return \"" + C + "\" on line " + p2[0].line)
|
|
|
|
|
|
|
|
@script:python depends on org@
|
|
|
|
p1 << r1.p1;
|
|
|
|
p2 << r1.p2;
|
|
|
|
C << r1.C;
|
|
|
|
ret << r1.ret;
|
|
|
|
@@
|
|
|
|
cocci.print_main("unneeded \"" + ret + "\" variable", p1)
|
|
|
|
cocci.print_sec("return " + C + " here", p2)
|