coccicheck 1.5 KB
Newer Older
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