summaryrefslogtreecommitdiff
path: root/scripts/coccicheck
blob: 037424b9ede5ead033621a978a6d0f069f7ba8da (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/bin/sh

SPATCH="`which ${SPATCH:=spatch}`"

if [ ! -x "$SPATCH" ]; then
    echo 'spatch is part of the Coccinelle project and is available at http://coccinelle.lip6.fr/'
    exit 1
fi

if [ "$MODE" = "" ] ; then
    echo 'You have not explicitly specify the mode to use. Fallback to "report".'
    echo 'You can specify the mode with "make coccicheck MODE=<mode>"'
    echo 'Available modes are: report, patch, context, org'
    MODE="report"
fi

echo ''
echo 'Please check for false positives in the output before submitting a patch.'
echo 'When using "patch" mode, carefully review the patch before submitting it.'
echo ''

function coccinelle {
    COCCI="$1"
    DIR="$2"

    OPT=`grep "Option" $COCCI | cut -d':' -f2`
    FILE=`echo $COCCI | sed "s|$DIR/||"`

    echo "Processing `basename $COCCI` with option(s) \"$OPT\""
    echo 'Message example to submit a patch:'

    sed -e '/\/\/\//!d' -e 's|^///||' $COCCI

    echo ' The semantic patch that makes this change is available'
    echo " in $FILE."
    echo ''
    echo ' More information about semantic patching is available at'
    echo ' http://coccinelle.lip6.fr/'
    echo ''

#   The option '-parse_cocci' can be used to syntaxically check the SmPL files.
#
#    $SPATCH -D $MODE -very_quiet -parse_cocci $COCCI $OPT > /dev/null

    $SPATCH -D $MODE -very_quiet -sp_file $COCCI $OPT -dir $DIR
}

if [ "$COCCI" = "" ] ; then
    for f in `find $srctree/scripts/coccinelle/ -name '*.cocci' -type f | sort`; do
	coccinelle $f $srctree;
    done
else
    coccinelle $COCCI $srctree
fi