/// These iterators only exit normally when the loop cursor is NULL, so there /// is no point to call of_node_put on the final value. /// // Confidence: High // Copyright: (C) 2010-2012 Nicolas Palix. GPLv2. // Copyright: (C) 2010-2012 Julia Lawall, INRIA/LIP6. GPLv2. // Copyright: (C) 2010-2012 Gilles Muller, INRIA/LiP6. GPLv2. // URL: http://coccinelle.lip6.fr/ // Comments: // Options: --no-includes --include-headers virtual patch virtual context virtual org virtual report @depends on patch@ iterator name for_each_node_by_name; expression np,E; identifier l; @@ for_each_node_by_name(np,...) { ... when != break; when != goto l; } ... when != np = E - of_node_put(np); @depends on patch@ iterator name for_each_node_by_type; expression np,E; identifier l; @@ for_each_node_by_type(np,...) { ... when != break; when != goto l; } ... when != np = E - of_node_put(np); @depends on patch@ iterator name for_each_compatible_node; expression np,E; identifier l; @@ for_each_compatible_node(np,...) { ... when != break; when != goto l; } ... when != np = E - of_node_put(np); @depends on patch@ iterator name for_each_matching_node; expression np,E; identifier l; @@ for_each_matching_node(np,...) { ... when != break; when != goto l; } ... when != np = E - of_node_put(np); // ---------------------------------------------------------------------- @r depends on !patch forall@ //iterator name for_each_node_by_name; //iterator name for_each_node_by_type; //iterator name for_each_compatible_node; //iterator name for_each_matching_node; expression np,E; identifier l; position p1,p2; @@ ( *for_each_node_by_name@p1(np,...) { ... when != break; when != goto l; } | *for_each_node_by_type@p1(np,...) { ... when != break; when != goto l; } | *for_each_compatible_node@p1(np,...) { ... when != break; when != goto l; } | *for_each_matching_node@p1(np,...) { ... when != break; when != goto l; } ) ... when != np = E * of_node_put@p2(np); @script:python depends on org@ p1 << r.p1; p2 << r.p2; @@ cocci.print_main("unneeded of_node_put",p2) cocci.print_secs("iterator",p1) @script:python depends on report@ p1 << r.p1; p2 << r.p2; @@ msg = "ERROR: of_node_put not needed after iterator on line %s" % (p1[0].line) coccilib.report.print_report(p2[0], msg) lass='form'>
path: root/tools/virtio/ringtest/run-on-all.sh
his.form.submit();'>
AgeCommit message (Expand)AuthorFilesLines
authorMauro Carvalho Chehab <mchehab@s-opensource.com>2016-12-05 09:41:41 -0200
committerJonathan Corbet <corbet@lwn.net>2016-12-05 14:21:24 -0700
commitf15c323397f87b978f4057eb1462efcbf487493a (patch)
tree571deb44f3584bec33ab217767acdacde4123e14 /include/uapi
parent20b786eb2598ac10c9743535b65611ce808c8d71 (diff)
scripts: add a script to check if Documentation/00-INDEX is sane
It is easy to forget adding/removing entries at the Documentation/00-INDEX file. In a matter of fact, even before ReST conversion, people use to forget adding things here, as there are lots of missing stuff out there. Now that we're doing a hard work converting entries to ReST, and while this hole file is not outdated, it is good to have some tool that would help to verify that this file is kept updated. Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com> Signed-off-by: Jonathan Corbet <corbet@lwn.net>
Diffstat (limited to 'include/uapi')